From d51ffbc5620d71630d01a7f69bd55ec0544f66bc Mon Sep 17 00:00:00 2001
From: Alexandre Vanini <vanini.alexandre@gmail.com>
Date: Wed, 1 May 2019 15:46:20 +0200
Subject: [PATCH] [TESTS] - ASSERT PY
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit

J'ai ajouté le support des assert dans le test de la compilation serveur, cela nous permet de séparer les tests du code. Il faudra implémenter ce support pour chaque type de langages et ça risque de devenir très différent à chaque fois.
---
 .../assert_test01/.idea/assert_test01.iml     |   13 +
 tests/python/assert_test01/.idea/misc.xml     |    7 +
 tests/python/assert_test01/.idea/modules.xml  |    8 +
 tests/python/assert_test01/.idea/vcs.xml      |    6 +
 .../python/assert_test01/.idea/workspace.xml  |  213 +
 tests/python/assert_test01/main.py            |    3 +
 tests/python/assert_test01/main.pyc           |  Bin 0 -> 354 bytes
 tests/python/assert_test01/test.py            |    6 +
 tests/python/assert_test01/test.pyc           |  Bin 0 -> 628 bytes
 tests/python/assert_test01/venv/.Python       |    1 +
 tests/python/assert_test01/venv/bin/activate  |   78 +
 .../assert_test01/venv/bin/activate.csh       |   42 +
 .../assert_test01/venv/bin/activate.fish      |  101 +
 .../assert_test01/venv/bin/activate.ps1       |   60 +
 .../assert_test01/venv/bin/activate_this.py   |   46 +
 .../assert_test01/venv/bin/easy_install       |   10 +
 .../assert_test01/venv/bin/easy_install-2.7   |   10 +
 tests/python/assert_test01/venv/bin/pip       |   10 +
 tests/python/assert_test01/venv/bin/pip2      |   10 +
 tests/python/assert_test01/venv/bin/pip2.7    |   10 +
 tests/python/assert_test01/venv/bin/python    |  Bin 0 -> 51744 bytes
 .../assert_test01/venv/bin/python-config      |   78 +
 tests/python/assert_test01/venv/bin/python2   |    1 +
 tests/python/assert_test01/venv/bin/python2.7 |    1 +
 tests/python/assert_test01/venv/bin/wheel     |   10 +
 .../assert_test01/venv/include/python2.7      |    1 +
 .../venv/lib/python2.7/LICENSE.txt            |    1 +
 .../venv/lib/python2.7/UserDict.py            |    1 +
 .../venv/lib/python2.7/UserDict.pyc           |  Bin 0 -> 11385 bytes
 .../venv/lib/python2.7/_abcoll.py             |    1 +
 .../venv/lib/python2.7/_abcoll.pyc            |  Bin 0 -> 31478 bytes
 .../venv/lib/python2.7/_weakrefset.py         |    1 +
 .../venv/lib/python2.7/_weakrefset.pyc        |  Bin 0 -> 12414 bytes
 .../assert_test01/venv/lib/python2.7/abc.py   |    1 +
 .../assert_test01/venv/lib/python2.7/abc.pyc  |  Bin 0 -> 6770 bytes
 .../venv/lib/python2.7/codecs.py              |    1 +
 .../venv/lib/python2.7/codecs.pyc             |  Bin 0 -> 42067 bytes
 .../assert_test01/venv/lib/python2.7/config   |    1 +
 .../venv/lib/python2.7/copy_reg.py            |    1 +
 .../venv/lib/python2.7/copy_reg.pyc           |  Bin 0 -> 5740 bytes
 .../venv/lib/python2.7/distutils/__init__.py  |  134 +
 .../venv/lib/python2.7/distutils/__init__.pyc |  Bin 0 -> 4443 bytes
 .../lib/python2.7/distutils/distutils.cfg     |    6 +
 .../venv/lib/python2.7/encodings              |    1 +
 .../venv/lib/python2.7/fnmatch.py             |    1 +
 .../venv/lib/python2.7/fnmatch.pyc            |  Bin 0 -> 3956 bytes
 .../venv/lib/python2.7/genericpath.py         |    1 +
 .../venv/lib/python2.7/genericpath.pyc        |  Bin 0 -> 4144 bytes
 .../venv/lib/python2.7/lib-dynload            |    1 +
 .../venv/lib/python2.7/linecache.py           |    1 +
 .../venv/lib/python2.7/linecache.pyc          |  Bin 0 -> 3614 bytes
 .../venv/lib/python2.7/locale.py              |    1 +
 .../venv/lib/python2.7/locale.pyc             |  Bin 0 -> 56908 bytes
 .../lib/python2.7/no-global-site-packages.txt |    0
 .../venv/lib/python2.7/ntpath.py              |    1 +
 .../venv/lib/python2.7/ntpath.pyc             |  Bin 0 -> 14384 bytes
 .../venv/lib/python2.7/orig-prefix.txt        |    1 +
 .../assert_test01/venv/lib/python2.7/os.py    |    1 +
 .../assert_test01/venv/lib/python2.7/os.pyc   |  Bin 0 -> 28720 bytes
 .../venv/lib/python2.7/posixpath.py           |    1 +
 .../venv/lib/python2.7/posixpath.pyc          |  Bin 0 -> 12731 bytes
 .../assert_test01/venv/lib/python2.7/re.py    |    1 +
 .../assert_test01/venv/lib/python2.7/re.pyc   |  Bin 0 -> 14610 bytes
 .../assertpy-0.14.dist-info/INSTALLER         |    1 +
 .../assertpy-0.14.dist-info/LICENSE           |   27 +
 .../assertpy-0.14.dist-info/METADATA          |   48 +
 .../assertpy-0.14.dist-info/RECORD            |   10 +
 .../assertpy-0.14.dist-info/WHEEL             |    5 +
 .../assertpy-0.14.dist-info/top_level.txt     |    1 +
 .../site-packages/assertpy/__init__.py        |    2 +
 .../site-packages/assertpy/__init__.pyc       |  Bin 0 -> 476 bytes
 .../site-packages/assertpy/assertpy.py        | 1373 +++
 .../site-packages/assertpy/assertpy.pyc       |  Bin 0 -> 63355 bytes
 .../python2.7/site-packages/easy_install.py   |    5 +
 .../python2.7/site-packages/easy_install.pyc  |  Bin 0 -> 369 bytes
 .../pip-19.1.dist-info/INSTALLER              |    1 +
 .../pip-19.1.dist-info/LICENSE.txt            |   20 +
 .../site-packages/pip-19.1.dist-info/METADATA |   75 +
 .../site-packages/pip-19.1.dist-info/RECORD   |  618 ++
 .../site-packages/pip-19.1.dist-info/WHEEL    |    6 +
 .../pip-19.1.dist-info/entry_points.txt       |    5 +
 .../pip-19.1.dist-info/top_level.txt          |    1 +
 .../python2.7/site-packages/pip/__init__.py   |    1 +
 .../python2.7/site-packages/pip/__init__.pyc  |  Bin 0 -> 213 bytes
 .../python2.7/site-packages/pip/__main__.py   |   19 +
 .../python2.7/site-packages/pip/__main__.pyc  |  Bin 0 -> 562 bytes
 .../site-packages/pip/_internal/__init__.py   |   78 +
 .../site-packages/pip/_internal/__init__.pyc  |  Bin 0 -> 2298 bytes
 .../site-packages/pip/_internal/build_env.py  |  215 +
 .../site-packages/pip/_internal/build_env.pyc |  Bin 0 -> 10101 bytes
 .../site-packages/pip/_internal/cache.py      |  224 +
 .../site-packages/pip/_internal/cache.pyc     |  Bin 0 -> 9463 bytes
 .../pip/_internal/cli/__init__.py             |    4 +
 .../pip/_internal/cli/__init__.pyc            |  Bin 0 -> 290 bytes
 .../pip/_internal/cli/autocompletion.py       |  152 +
 .../pip/_internal/cli/autocompletion.pyc      |  Bin 0 -> 5912 bytes
 .../pip/_internal/cli/base_command.py         |  340 +
 .../pip/_internal/cli/base_command.pyc        |  Bin 0 -> 10137 bytes
 .../pip/_internal/cli/cmdoptions.py           |  809 ++
 .../pip/_internal/cli/cmdoptions.pyc          |  Bin 0 -> 21201 bytes
 .../pip/_internal/cli/main_parser.py          |  104 +
 .../pip/_internal/cli/main_parser.pyc         |  Bin 0 -> 2974 bytes
 .../site-packages/pip/_internal/cli/parser.py |  261 +
 .../pip/_internal/cli/parser.pyc              |  Bin 0 -> 11559 bytes
 .../pip/_internal/cli/status_codes.py         |    8 +
 .../pip/_internal/cli/status_codes.pyc        |  Bin 0 -> 454 bytes
 .../pip/_internal/commands/__init__.py        |   79 +
 .../pip/_internal/commands/__init__.pyc       |  Bin 0 -> 3475 bytes
 .../pip/_internal/commands/check.py           |   41 +
 .../pip/_internal/commands/check.pyc          |  Bin 0 -> 1725 bytes
 .../pip/_internal/commands/completion.py      |   94 +
 .../pip/_internal/commands/completion.pyc     |  Bin 0 -> 3577 bytes
 .../pip/_internal/commands/configuration.py   |  253 +
 .../pip/_internal/commands/configuration.pyc  |  Bin 0 -> 8747 bytes
 .../pip/_internal/commands/download.py        |  176 +
 .../pip/_internal/commands/download.pyc       |  Bin 0 -> 5692 bytes
 .../pip/_internal/commands/freeze.py          |   96 +
 .../pip/_internal/commands/freeze.pyc         |  Bin 0 -> 3677 bytes
 .../pip/_internal/commands/hash.py            |   57 +
 .../pip/_internal/commands/hash.pyc           |  Bin 0 -> 2783 bytes
 .../pip/_internal/commands/help.py            |   37 +
 .../pip/_internal/commands/help.pyc           |  Bin 0 -> 1651 bytes
 .../pip/_internal/commands/install.py         |  587 ++
 .../pip/_internal/commands/install.pyc        |  Bin 0 -> 16064 bytes
 .../pip/_internal/commands/list.py            |  302 +
 .../pip/_internal/commands/list.pyc           |  Bin 0 -> 11121 bytes
 .../pip/_internal/commands/search.py          |  135 +
 .../pip/_internal/commands/search.pyc         |  Bin 0 -> 5521 bytes
 .../pip/_internal/commands/show.py            |  168 +
 .../pip/_internal/commands/show.pyc           |  Bin 0 -> 6435 bytes
 .../pip/_internal/commands/uninstall.py       |   78 +
 .../pip/_internal/commands/uninstall.pyc      |  Bin 0 -> 3344 bytes
 .../pip/_internal/commands/wheel.py           |  186 +
 .../pip/_internal/commands/wheel.pyc          |  Bin 0 -> 6127 bytes
 .../pip/_internal/configuration.py            |  384 +
 .../pip/_internal/configuration.pyc           |  Bin 0 -> 13105 bytes
 .../site-packages/pip/_internal/download.py   |  979 ++
 .../site-packages/pip/_internal/download.pyc  |  Bin 0 -> 28623 bytes
 .../site-packages/pip/_internal/exceptions.py |  274 +
 .../pip/_internal/exceptions.pyc              |  Bin 0 -> 16273 bytes
 .../site-packages/pip/_internal/index.py      | 1105 +++
 .../site-packages/pip/_internal/index.pyc     |  Bin 0 -> 36261 bytes
 .../site-packages/pip/_internal/locations.py  |  211 +
 .../site-packages/pip/_internal/locations.pyc |  Bin 0 -> 5685 bytes
 .../pip/_internal/models/__init__.py          |    2 +
 .../pip/_internal/models/__init__.pyc         |  Bin 0 -> 278 bytes
 .../pip/_internal/models/candidate.py         |   31 +
 .../pip/_internal/models/candidate.pyc        |  Bin 0 -> 1709 bytes
 .../pip/_internal/models/format_control.py    |   73 +
 .../pip/_internal/models/format_control.pyc   |  Bin 0 -> 3380 bytes
 .../pip/_internal/models/index.py             |   31 +
 .../pip/_internal/models/index.pyc            |  Bin 0 -> 1555 bytes
 .../pip/_internal/models/link.py              |  163 +
 .../pip/_internal/models/link.pyc             |  Bin 0 -> 7361 bytes
 .../pip/_internal/operations/__init__.py      |    0
 .../pip/_internal/operations/__init__.pyc     |  Bin 0 -> 203 bytes
 .../pip/_internal/operations/check.py         |  155 +
 .../pip/_internal/operations/check.pyc        |  Bin 0 -> 4985 bytes
 .../pip/_internal/operations/freeze.py        |  247 +
 .../pip/_internal/operations/freeze.pyc       |  Bin 0 -> 7528 bytes
 .../pip/_internal/operations/prepare.py       |  432 +
 .../pip/_internal/operations/prepare.pyc      |  Bin 0 -> 13711 bytes
 .../site-packages/pip/_internal/pep425tags.py |  381 +
 .../pip/_internal/pep425tags.pyc              |  Bin 0 -> 11594 bytes
 .../site-packages/pip/_internal/pyproject.py  |  282 +
 .../site-packages/pip/_internal/pyproject.pyc |  Bin 0 -> 7954 bytes
 .../pip/_internal/req/__init__.py             |   78 +
 .../pip/_internal/req/__init__.pyc            |  Bin 0 -> 1982 bytes
 .../pip/_internal/req/constructors.py         |  340 +
 .../pip/_internal/req/constructors.pyc        |  Bin 0 -> 9643 bytes
 .../pip/_internal/req/req_file.py             |  383 +
 .../pip/_internal/req/req_file.pyc            |  Bin 0 -> 11785 bytes
 .../pip/_internal/req/req_install.py          | 1030 +++
 .../pip/_internal/req/req_install.pyc         |  Bin 0 -> 32293 bytes
 .../pip/_internal/req/req_set.py              |  193 +
 .../pip/_internal/req/req_set.pyc             |  Bin 0 -> 6797 bytes
 .../pip/_internal/req/req_tracker.py          |   96 +
 .../pip/_internal/req/req_tracker.pyc         |  Bin 0 -> 4564 bytes
 .../pip/_internal/req/req_uninstall.py        |  633 ++
 .../pip/_internal/req/req_uninstall.pyc       |  Bin 0 -> 23635 bytes
 .../site-packages/pip/_internal/resolve.py    |  393 +
 .../site-packages/pip/_internal/resolve.pyc   |  Bin 0 -> 11222 bytes
 .../pip/_internal/utils/__init__.py           |    0
 .../pip/_internal/utils/__init__.pyc          |  Bin 0 -> 198 bytes
 .../pip/_internal/utils/appdirs.py            |  268 +
 .../pip/_internal/utils/appdirs.pyc           |  Bin 0 -> 9403 bytes
 .../pip/_internal/utils/compat.py             |  264 +
 .../pip/_internal/utils/compat.pyc            |  Bin 0 -> 8638 bytes
 .../pip/_internal/utils/deprecation.py        |   93 +
 .../pip/_internal/utils/deprecation.pyc       |  Bin 0 -> 3408 bytes
 .../pip/_internal/utils/encoding.py           |   39 +
 .../pip/_internal/utils/encoding.pyc          |  Bin 0 -> 1649 bytes
 .../pip/_internal/utils/filesystem.py         |   30 +
 .../pip/_internal/utils/filesystem.pyc        |  Bin 0 -> 912 bytes
 .../pip/_internal/utils/glibc.py              |   93 +
 .../pip/_internal/utils/glibc.pyc             |  Bin 0 -> 2406 bytes
 .../pip/_internal/utils/hashes.py             |  115 +
 .../pip/_internal/utils/hashes.pyc            |  Bin 0 -> 5026 bytes
 .../pip/_internal/utils/logging.py            |  371 +
 .../pip/_internal/utils/logging.pyc           |  Bin 0 -> 12636 bytes
 .../site-packages/pip/_internal/utils/misc.py | 1011 ++
 .../pip/_internal/utils/misc.pyc              |  Bin 0 -> 34905 bytes
 .../pip/_internal/utils/models.py             |   40 +
 .../pip/_internal/utils/models.pyc            |  Bin 0 -> 2950 bytes
 .../pip/_internal/utils/outdated.py           |  162 +
 .../pip/_internal/utils/outdated.pyc          |  Bin 0 -> 5214 bytes
 .../pip/_internal/utils/packaging.py          |   85 +
 .../pip/_internal/utils/packaging.pyc         |  Bin 0 -> 3489 bytes
 .../pip/_internal/utils/setuptools_build.py   |    8 +
 .../pip/_internal/utils/setuptools_build.pyc  |  Bin 0 -> 404 bytes
 .../pip/_internal/utils/temp_dir.py           |  155 +
 .../pip/_internal/utils/temp_dir.pyc          |  Bin 0 -> 6397 bytes
 .../pip/_internal/utils/typing.py             |   29 +
 .../pip/_internal/utils/typing.pyc            |  Bin 0 -> 1350 bytes
 .../site-packages/pip/_internal/utils/ui.py   |  424 +
 .../site-packages/pip/_internal/utils/ui.pyc  |  Bin 0 -> 17200 bytes
 .../pip/_internal/vcs/__init__.py             |  604 ++
 .../pip/_internal/vcs/__init__.pyc            |  Bin 0 -> 22654 bytes
 .../site-packages/pip/_internal/vcs/bazaar.py |  103 +
 .../pip/_internal/vcs/bazaar.pyc              |  Bin 0 -> 5100 bytes
 .../site-packages/pip/_internal/vcs/git.py    |  362 +
 .../site-packages/pip/_internal/vcs/git.pyc   |  Bin 0 -> 12424 bytes
 .../pip/_internal/vcs/mercurial.py            |  105 +
 .../pip/_internal/vcs/mercurial.pyc           |  Bin 0 -> 5223 bytes
 .../pip/_internal/vcs/subversion.py           |  234 +
 .../pip/_internal/vcs/subversion.pyc          |  Bin 0 -> 8821 bytes
 .../site-packages/pip/_internal/wheel.py      | 1098 +++
 .../site-packages/pip/_internal/wheel.pyc     |  Bin 0 -> 32820 bytes
 .../site-packages/pip/_vendor/__init__.py     |  109 +
 .../site-packages/pip/_vendor/__init__.pyc    |  Bin 0 -> 3389 bytes
 .../site-packages/pip/_vendor/appdirs.py      |  604 ++
 .../site-packages/pip/_vendor/appdirs.pyc     |  Bin 0 -> 23990 bytes
 .../pip/_vendor/cachecontrol/__init__.py      |   11 +
 .../pip/_vendor/cachecontrol/__init__.pyc     |  Bin 0 -> 630 bytes
 .../pip/_vendor/cachecontrol/_cmd.py          |   57 +
 .../pip/_vendor/cachecontrol/_cmd.pyc         |  Bin 0 -> 2288 bytes
 .../pip/_vendor/cachecontrol/adapter.py       |  133 +
 .../pip/_vendor/cachecontrol/adapter.pyc      |  Bin 0 -> 4045 bytes
 .../pip/_vendor/cachecontrol/cache.py         |   39 +
 .../pip/_vendor/cachecontrol/cache.pyc        |  Bin 0 -> 2923 bytes
 .../_vendor/cachecontrol/caches/__init__.py   |    2 +
 .../_vendor/cachecontrol/caches/__init__.pyc  |  Bin 0 -> 329 bytes
 .../_vendor/cachecontrol/caches/file_cache.py |  146 +
 .../cachecontrol/caches/file_cache.pyc        |  Bin 0 -> 4755 bytes
 .../cachecontrol/caches/redis_cache.py        |   33 +
 .../cachecontrol/caches/redis_cache.pyc       |  Bin 0 -> 2500 bytes
 .../pip/_vendor/cachecontrol/compat.py        |   29 +
 .../pip/_vendor/cachecontrol/compat.pyc       |  Bin 0 -> 849 bytes
 .../pip/_vendor/cachecontrol/controller.py    |  367 +
 .../pip/_vendor/cachecontrol/controller.pyc   |  Bin 0 -> 10121 bytes
 .../pip/_vendor/cachecontrol/filewrapper.py   |   80 +
 .../pip/_vendor/cachecontrol/filewrapper.pyc  |  Bin 0 -> 3043 bytes
 .../pip/_vendor/cachecontrol/heuristics.py    |  135 +
 .../pip/_vendor/cachecontrol/heuristics.pyc   |  Bin 0 -> 6673 bytes
 .../pip/_vendor/cachecontrol/serialize.py     |  186 +
 .../pip/_vendor/cachecontrol/serialize.pyc    |  Bin 0 -> 6411 bytes
 .../pip/_vendor/cachecontrol/wrapper.py       |   29 +
 .../pip/_vendor/cachecontrol/wrapper.pyc      |  Bin 0 -> 906 bytes
 .../pip/_vendor/certifi/__init__.py           |    3 +
 .../pip/_vendor/certifi/__init__.pyc          |  Bin 0 -> 287 bytes
 .../pip/_vendor/certifi/__main__.py           |    2 +
 .../pip/_vendor/certifi/__main__.pyc          |  Bin 0 -> 273 bytes
 .../pip/_vendor/certifi/cacert.pem            | 4658 ++++++++++
 .../site-packages/pip/_vendor/certifi/core.py |   15 +
 .../pip/_vendor/certifi/core.pyc              |  Bin 0 -> 633 bytes
 .../pip/_vendor/chardet/__init__.py           |   39 +
 .../pip/_vendor/chardet/__init__.pyc          |  Bin 0 -> 1088 bytes
 .../pip/_vendor/chardet/big5freq.py           |  386 +
 .../pip/_vendor/chardet/big5freq.pyc          |  Bin 0 -> 54748 bytes
 .../pip/_vendor/chardet/big5prober.py         |   47 +
 .../pip/_vendor/chardet/big5prober.pyc        |  Bin 0 -> 1592 bytes
 .../pip/_vendor/chardet/chardistribution.py   |  233 +
 .../pip/_vendor/chardet/chardistribution.pyc  |  Bin 0 -> 9073 bytes
 .../pip/_vendor/chardet/charsetgroupprober.py |  106 +
 .../_vendor/chardet/charsetgroupprober.pyc    |  Bin 0 -> 3249 bytes
 .../pip/_vendor/chardet/charsetprober.py      |  145 +
 .../pip/_vendor/chardet/charsetprober.pyc     |  Bin 0 -> 4666 bytes
 .../pip/_vendor/chardet/cli/__init__.py       |    1 +
 .../pip/_vendor/chardet/cli/__init__.pyc      |  Bin 0 -> 202 bytes
 .../pip/_vendor/chardet/cli/chardetect.py     |   85 +
 .../pip/_vendor/chardet/cli/chardetect.pyc    |  Bin 0 -> 3331 bytes
 .../pip/_vendor/chardet/codingstatemachine.py |   88 +
 .../_vendor/chardet/codingstatemachine.pyc    |  Bin 0 -> 3736 bytes
 .../pip/_vendor/chardet/compat.py             |   34 +
 .../pip/_vendor/chardet/compat.pyc            |  Bin 0 -> 451 bytes
 .../pip/_vendor/chardet/cp949prober.py        |   49 +
 .../pip/_vendor/chardet/cp949prober.pyc       |  Bin 0 -> 1600 bytes
 .../pip/_vendor/chardet/enums.py              |   76 +
 .../pip/_vendor/chardet/enums.pyc             |  Bin 0 -> 3505 bytes
 .../pip/_vendor/chardet/escprober.py          |  101 +
 .../pip/_vendor/chardet/escprober.pyc         |  Bin 0 -> 3607 bytes
 .../pip/_vendor/chardet/escsm.py              |  246 +
 .../pip/_vendor/chardet/escsm.pyc             |  Bin 0 -> 8062 bytes
 .../pip/_vendor/chardet/eucjpprober.py        |   92 +
 .../pip/_vendor/chardet/eucjpprober.pyc       |  Bin 0 -> 3422 bytes
 .../pip/_vendor/chardet/euckrfreq.py          |  195 +
 .../pip/_vendor/chardet/euckrfreq.pyc         |  Bin 0 -> 24134 bytes
 .../pip/_vendor/chardet/euckrprober.py        |   47 +
 .../pip/_vendor/chardet/euckrprober.pyc       |  Bin 0 -> 1601 bytes
 .../pip/_vendor/chardet/euctwfreq.py          |  387 +
 .../pip/_vendor/chardet/euctwfreq.pyc         |  Bin 0 -> 54757 bytes
 .../pip/_vendor/chardet/euctwprober.py        |   46 +
 .../pip/_vendor/chardet/euctwprober.pyc       |  Bin 0 -> 1601 bytes
 .../pip/_vendor/chardet/gb2312freq.py         |  283 +
 .../pip/_vendor/chardet/gb2312freq.pyc        |  Bin 0 -> 38399 bytes
 .../pip/_vendor/chardet/gb2312prober.py       |   46 +
 .../pip/_vendor/chardet/gb2312prober.pyc      |  Bin 0 -> 1610 bytes
 .../pip/_vendor/chardet/hebrewprober.py       |  292 +
 .../pip/_vendor/chardet/hebrewprober.pyc      |  Bin 0 -> 4331 bytes
 .../pip/_vendor/chardet/jisfreq.py            |  325 +
 .../pip/_vendor/chardet/jisfreq.pyc           |  Bin 0 -> 44543 bytes
 .../pip/_vendor/chardet/jpcntx.py             |  233 +
 .../pip/_vendor/chardet/jpcntx.pyc            |  Bin 0 -> 25988 bytes
 .../pip/_vendor/chardet/langbulgarianmodel.py |  228 +
 .../_vendor/chardet/langbulgarianmodel.pyc    |  Bin 0 -> 25011 bytes
 .../pip/_vendor/chardet/langcyrillicmodel.py  |  333 +
 .../pip/_vendor/chardet/langcyrillicmodel.pyc |  Bin 0 -> 30731 bytes
 .../pip/_vendor/chardet/langgreekmodel.py     |  225 +
 .../pip/_vendor/chardet/langgreekmodel.pyc    |  Bin 0 -> 24686 bytes
 .../pip/_vendor/chardet/langhebrewmodel.py    |  200 +
 .../pip/_vendor/chardet/langhebrewmodel.pyc   |  Bin 0 -> 23497 bytes
 .../pip/_vendor/chardet/langhungarianmodel.py |  225 +
 .../_vendor/chardet/langhungarianmodel.pyc    |  Bin 0 -> 24981 bytes
 .../pip/_vendor/chardet/langthaimodel.py      |  199 +
 .../pip/_vendor/chardet/langthaimodel.pyc     |  Bin 0 -> 23476 bytes
 .../pip/_vendor/chardet/langturkishmodel.py   |  193 +
 .../pip/_vendor/chardet/langturkishmodel.pyc  |  Bin 0 -> 23493 bytes
 .../pip/_vendor/chardet/latin1prober.py       |  145 +
 .../pip/_vendor/chardet/latin1prober.pyc      |  Bin 0 -> 4117 bytes
 .../pip/_vendor/chardet/mbcharsetprober.py    |   91 +
 .../pip/_vendor/chardet/mbcharsetprober.pyc   |  Bin 0 -> 3171 bytes
 .../pip/_vendor/chardet/mbcsgroupprober.py    |   54 +
 .../pip/_vendor/chardet/mbcsgroupprober.pyc   |  Bin 0 -> 1477 bytes
 .../pip/_vendor/chardet/mbcssm.py             |  572 ++
 .../pip/_vendor/chardet/mbcssm.pyc            |  Bin 0 -> 19168 bytes
 .../pip/_vendor/chardet/sbcharsetprober.py    |  132 +
 .../pip/_vendor/chardet/sbcharsetprober.pyc   |  Bin 0 -> 4050 bytes
 .../pip/_vendor/chardet/sbcsgroupprober.py    |   73 +
 .../pip/_vendor/chardet/sbcsgroupprober.pyc   |  Bin 0 -> 2070 bytes
 .../pip/_vendor/chardet/sjisprober.py         |   92 +
 .../pip/_vendor/chardet/sjisprober.pyc        |  Bin 0 -> 3443 bytes
 .../pip/_vendor/chardet/universaldetector.py  |  286 +
 .../pip/_vendor/chardet/universaldetector.pyc |  Bin 0 -> 7403 bytes
 .../pip/_vendor/chardet/utf8prober.py         |   82 +
 .../pip/_vendor/chardet/utf8prober.pyc        |  Bin 0 -> 2892 bytes
 .../pip/_vendor/chardet/version.py            |    9 +
 .../pip/_vendor/chardet/version.pyc           |  Bin 0 -> 478 bytes
 .../pip/_vendor/colorama/__init__.py          |    6 +
 .../pip/_vendor/colorama/__init__.pyc         |  Bin 0 -> 530 bytes
 .../pip/_vendor/colorama/ansi.py              |  102 +
 .../pip/_vendor/colorama/ansi.pyc             |  Bin 0 -> 5184 bytes
 .../pip/_vendor/colorama/ansitowin32.py       |  257 +
 .../pip/_vendor/colorama/ansitowin32.pyc      |  Bin 0 -> 11113 bytes
 .../pip/_vendor/colorama/initialise.py        |   80 +
 .../pip/_vendor/colorama/initialise.pyc       |  Bin 0 -> 2683 bytes
 .../pip/_vendor/colorama/win32.py             |  152 +
 .../pip/_vendor/colorama/win32.pyc            |  Bin 0 -> 5862 bytes
 .../pip/_vendor/colorama/winterm.py           |  169 +
 .../pip/_vendor/colorama/winterm.pyc          |  Bin 0 -> 6935 bytes
 .../pip/_vendor/distlib/__init__.py           |   23 +
 .../pip/_vendor/distlib/__init__.pyc          |  Bin 0 -> 1623 bytes
 .../pip/_vendor/distlib/_backport/__init__.py |    6 +
 .../_vendor/distlib/_backport/__init__.pyc    |  Bin 0 -> 498 bytes
 .../pip/_vendor/distlib/_backport/misc.py     |   41 +
 .../pip/_vendor/distlib/_backport/misc.pyc    |  Bin 0 -> 1616 bytes
 .../pip/_vendor/distlib/_backport/shutil.py   |  761 ++
 .../pip/_vendor/distlib/_backport/shutil.pyc  |  Bin 0 -> 28427 bytes
 .../_vendor/distlib/_backport/sysconfig.cfg   |   84 +
 .../_vendor/distlib/_backport/sysconfig.py    |  788 ++
 .../_vendor/distlib/_backport/sysconfig.pyc   |  Bin 0 -> 22518 bytes
 .../pip/_vendor/distlib/_backport/tarfile.py  | 2607 ++++++
 .../pip/_vendor/distlib/_backport/tarfile.pyc |  Bin 0 -> 86950 bytes
 .../pip/_vendor/distlib/compat.py             | 1120 +++
 .../pip/_vendor/distlib/compat.pyc            |  Bin 0 -> 44256 bytes
 .../pip/_vendor/distlib/database.py           | 1339 +++
 .../pip/_vendor/distlib/database.pyc          |  Bin 0 -> 53896 bytes
 .../pip/_vendor/distlib/index.py              |  516 ++
 .../pip/_vendor/distlib/index.pyc             |  Bin 0 -> 20999 bytes
 .../pip/_vendor/distlib/locators.py           | 1295 +++
 .../pip/_vendor/distlib/locators.pyc          |  Bin 0 -> 49817 bytes
 .../pip/_vendor/distlib/manifest.py           |  393 +
 .../pip/_vendor/distlib/manifest.pyc          |  Bin 0 -> 12954 bytes
 .../pip/_vendor/distlib/markers.py            |  131 +
 .../pip/_vendor/distlib/markers.pyc           |  Bin 0 -> 7112 bytes
 .../pip/_vendor/distlib/metadata.py           | 1094 +++
 .../pip/_vendor/distlib/metadata.pyc          |  Bin 0 -> 38836 bytes
 .../pip/_vendor/distlib/resources.py          |  355 +
 .../pip/_vendor/distlib/resources.pyc         |  Bin 0 -> 15896 bytes
 .../pip/_vendor/distlib/scripts.py            |  417 +
 .../pip/_vendor/distlib/scripts.pyc           |  Bin 0 -> 14496 bytes
 .../site-packages/pip/_vendor/distlib/t32.exe |  Bin 0 -> 92672 bytes
 .../site-packages/pip/_vendor/distlib/t64.exe |  Bin 0 -> 102400 bytes
 .../site-packages/pip/_vendor/distlib/util.py | 1756 ++++
 .../pip/_vendor/distlib/util.pyc              |  Bin 0 -> 67805 bytes
 .../pip/_vendor/distlib/version.py            |  736 ++
 .../pip/_vendor/distlib/version.pyc           |  Bin 0 -> 29804 bytes
 .../site-packages/pip/_vendor/distlib/w32.exe |  Bin 0 -> 89088 bytes
 .../site-packages/pip/_vendor/distlib/w64.exe |  Bin 0 -> 99328 bytes
 .../pip/_vendor/distlib/wheel.py              |  988 ++
 .../pip/_vendor/distlib/wheel.pyc             |  Bin 0 -> 33453 bytes
 .../site-packages/pip/_vendor/distro.py       | 1216 +++
 .../site-packages/pip/_vendor/distro.pyc      |  Bin 0 -> 42880 bytes
 .../pip/_vendor/html5lib/__init__.py          |   35 +
 .../pip/_vendor/html5lib/__init__.pyc         |  Bin 0 -> 1495 bytes
 .../pip/_vendor/html5lib/_ihatexml.py         |  288 +
 .../pip/_vendor/html5lib/_ihatexml.pyc        |  Bin 0 -> 16440 bytes
 .../pip/_vendor/html5lib/_inputstream.py      |  923 ++
 .../pip/_vendor/html5lib/_inputstream.pyc     |  Bin 0 -> 30522 bytes
 .../pip/_vendor/html5lib/_tokenizer.py        | 1721 ++++
 .../pip/_vendor/html5lib/_tokenizer.pyc       |  Bin 0 -> 57395 bytes
 .../pip/_vendor/html5lib/_trie/__init__.py    |   14 +
 .../pip/_vendor/html5lib/_trie/__init__.pyc   |  Bin 0 -> 489 bytes
 .../pip/_vendor/html5lib/_trie/_base.py       |   37 +
 .../pip/_vendor/html5lib/_trie/_base.pyc      |  Bin 0 -> 2266 bytes
 .../pip/_vendor/html5lib/_trie/datrie.py      |   44 +
 .../pip/_vendor/html5lib/_trie/datrie.pyc     |  Bin 0 -> 3296 bytes
 .../pip/_vendor/html5lib/_trie/py.py          |   67 +
 .../pip/_vendor/html5lib/_trie/py.pyc         |  Bin 0 -> 3489 bytes
 .../pip/_vendor/html5lib/_utils.py            |  124 +
 .../pip/_vendor/html5lib/_utils.pyc           |  Bin 0 -> 4808 bytes
 .../pip/_vendor/html5lib/constants.py         | 2947 ++++++
 .../pip/_vendor/html5lib/constants.pyc        |  Bin 0 -> 83207 bytes
 .../pip/_vendor/html5lib/filters/__init__.py  |    0
 .../pip/_vendor/html5lib/filters/__init__.pyc |  Bin 0 -> 207 bytes
 .../filters/alphabeticalattributes.py         |   29 +
 .../filters/alphabeticalattributes.pyc        |  Bin 0 -> 1876 bytes
 .../pip/_vendor/html5lib/filters/base.py      |   12 +
 .../pip/_vendor/html5lib/filters/base.pyc     |  Bin 0 -> 1341 bytes
 .../html5lib/filters/inject_meta_charset.py   |   73 +
 .../html5lib/filters/inject_meta_charset.pyc  |  Bin 0 -> 2648 bytes
 .../pip/_vendor/html5lib/filters/lint.py      |   93 +
 .../pip/_vendor/html5lib/filters/lint.pyc     |  Bin 0 -> 3500 bytes
 .../_vendor/html5lib/filters/optionaltags.py  |  207 +
 .../_vendor/html5lib/filters/optionaltags.pyc |  Bin 0 -> 4754 bytes
 .../pip/_vendor/html5lib/filters/sanitizer.py |  896 ++
 .../_vendor/html5lib/filters/sanitizer.pyc    |  Bin 0 -> 27270 bytes
 .../_vendor/html5lib/filters/whitespace.py    |   38 +
 .../_vendor/html5lib/filters/whitespace.pyc   |  Bin 0 -> 1941 bytes
 .../pip/_vendor/html5lib/html5parser.py       | 2791 ++++++
 .../pip/_vendor/html5lib/html5parser.pyc      |  Bin 0 -> 141299 bytes
 .../pip/_vendor/html5lib/serializer.py        |  409 +
 .../pip/_vendor/html5lib/serializer.pyc       |  Bin 0 -> 13932 bytes
 .../_vendor/html5lib/treeadapters/__init__.py |   30 +
 .../html5lib/treeadapters/__init__.pyc        |  Bin 0 -> 1022 bytes
 .../_vendor/html5lib/treeadapters/genshi.py   |   54 +
 .../_vendor/html5lib/treeadapters/genshi.pyc  |  Bin 0 -> 1973 bytes
 .../pip/_vendor/html5lib/treeadapters/sax.py  |   50 +
 .../pip/_vendor/html5lib/treeadapters/sax.pyc |  Bin 0 -> 1970 bytes
 .../_vendor/html5lib/treebuilders/__init__.py |   88 +
 .../html5lib/treebuilders/__init__.pyc        |  Bin 0 -> 3662 bytes
 .../pip/_vendor/html5lib/treebuilders/base.py |  417 +
 .../_vendor/html5lib/treebuilders/base.pyc    |  Bin 0 -> 16123 bytes
 .../pip/_vendor/html5lib/treebuilders/dom.py  |  236 +
 .../pip/_vendor/html5lib/treebuilders/dom.pyc |  Bin 0 -> 13400 bytes
 .../_vendor/html5lib/treebuilders/etree.py    |  340 +
 .../_vendor/html5lib/treebuilders/etree.pyc   |  Bin 0 -> 16763 bytes
 .../html5lib/treebuilders/etree_lxml.py       |  366 +
 .../html5lib/treebuilders/etree_lxml.pyc      |  Bin 0 -> 16913 bytes
 .../_vendor/html5lib/treewalkers/__init__.py  |  154 +
 .../_vendor/html5lib/treewalkers/__init__.pyc |  Bin 0 -> 5071 bytes
 .../pip/_vendor/html5lib/treewalkers/base.py  |  252 +
 .../pip/_vendor/html5lib/treewalkers/base.pyc |  Bin 0 -> 9693 bytes
 .../pip/_vendor/html5lib/treewalkers/dom.py   |   43 +
 .../pip/_vendor/html5lib/treewalkers/dom.pyc  |  Bin 0 -> 2517 bytes
 .../pip/_vendor/html5lib/treewalkers/etree.py |  130 +
 .../_vendor/html5lib/treewalkers/etree.pyc    |  Bin 0 -> 4770 bytes
 .../html5lib/treewalkers/etree_lxml.py        |  213 +
 .../html5lib/treewalkers/etree_lxml.pyc       |  Bin 0 -> 10584 bytes
 .../_vendor/html5lib/treewalkers/genshi.py    |   69 +
 .../_vendor/html5lib/treewalkers/genshi.pyc   |  Bin 0 -> 2626 bytes
 .../pip/_vendor/idna/__init__.py              |    2 +
 .../pip/_vendor/idna/__init__.pyc             |  Bin 0 -> 291 bytes
 .../site-packages/pip/_vendor/idna/codec.py   |  118 +
 .../site-packages/pip/_vendor/idna/codec.pyc  |  Bin 0 -> 4486 bytes
 .../site-packages/pip/_vendor/idna/compat.py  |   12 +
 .../site-packages/pip/_vendor/idna/compat.pyc |  Bin 0 -> 999 bytes
 .../site-packages/pip/_vendor/idna/core.py    |  396 +
 .../site-packages/pip/_vendor/idna/core.pyc   |  Bin 0 -> 13150 bytes
 .../pip/_vendor/idna/idnadata.py              | 1979 ++++
 .../pip/_vendor/idna/idnadata.pyc             |  Bin 0 -> 35078 bytes
 .../pip/_vendor/idna/intranges.py             |   53 +
 .../pip/_vendor/idna/intranges.pyc            |  Bin 0 -> 2452 bytes
 .../pip/_vendor/idna/package_data.py          |    2 +
 .../pip/_vendor/idna/package_data.pyc         |  Bin 0 -> 229 bytes
 .../pip/_vendor/idna/uts46data.py             | 8205 +++++++++++++++++
 .../pip/_vendor/idna/uts46data.pyc            |  Bin 0 -> 296556 bytes
 .../site-packages/pip/_vendor/ipaddress.py    | 2419 +++++
 .../site-packages/pip/_vendor/ipaddress.pyc   |  Bin 0 -> 85785 bytes
 .../pip/_vendor/lockfile/__init__.py          |  347 +
 .../pip/_vendor/lockfile/__init__.pyc         |  Bin 0 -> 13475 bytes
 .../pip/_vendor/lockfile/linklockfile.py      |   73 +
 .../pip/_vendor/lockfile/linklockfile.pyc     |  Bin 0 -> 3238 bytes
 .../pip/_vendor/lockfile/mkdirlockfile.py     |   84 +
 .../pip/_vendor/lockfile/mkdirlockfile.pyc    |  Bin 0 -> 3802 bytes
 .../pip/_vendor/lockfile/pidlockfile.py       |  190 +
 .../pip/_vendor/lockfile/pidlockfile.pyc      |  Bin 0 -> 6473 bytes
 .../pip/_vendor/lockfile/sqlitelockfile.py    |  156 +
 .../pip/_vendor/lockfile/sqlitelockfile.pyc   |  Bin 0 -> 5126 bytes
 .../pip/_vendor/lockfile/symlinklockfile.py   |   70 +
 .../pip/_vendor/lockfile/symlinklockfile.pyc  |  Bin 0 -> 3201 bytes
 .../pip/_vendor/msgpack/__init__.py           |   66 +
 .../pip/_vendor/msgpack/__init__.pyc          |  Bin 0 -> 2871 bytes
 .../pip/_vendor/msgpack/_version.py           |    1 +
 .../pip/_vendor/msgpack/_version.pyc          |  Bin 0 -> 251 bytes
 .../pip/_vendor/msgpack/exceptions.py         |   41 +
 .../pip/_vendor/msgpack/exceptions.pyc        |  Bin 0 -> 3313 bytes
 .../pip/_vendor/msgpack/fallback.py           |  977 ++
 .../pip/_vendor/msgpack/fallback.pyc          |  Bin 0 -> 32803 bytes
 .../pip/_vendor/packaging/__about__.py        |   27 +
 .../pip/_vendor/packaging/__about__.pyc       |  Bin 0 -> 841 bytes
 .../pip/_vendor/packaging/__init__.py         |   26 +
 .../pip/_vendor/packaging/__init__.pyc        |  Bin 0 -> 663 bytes
 .../pip/_vendor/packaging/_compat.py          |   31 +
 .../pip/_vendor/packaging/_compat.pyc         |  Bin 0 -> 1404 bytes
 .../pip/_vendor/packaging/_structures.py      |   68 +
 .../pip/_vendor/packaging/_structures.pyc     |  Bin 0 -> 5013 bytes
 .../pip/_vendor/packaging/markers.py          |  296 +
 .../pip/_vendor/packaging/markers.pyc         |  Bin 0 -> 13362 bytes
 .../pip/_vendor/packaging/requirements.py     |  138 +
 .../pip/_vendor/packaging/requirements.pyc    |  Bin 0 -> 5695 bytes
 .../pip/_vendor/packaging/specifiers.py       |  749 ++
 .../pip/_vendor/packaging/specifiers.pyc      |  Bin 0 -> 28139 bytes
 .../pip/_vendor/packaging/utils.py            |   57 +
 .../pip/_vendor/packaging/utils.pyc           |  Bin 0 -> 2143 bytes
 .../pip/_vendor/packaging/version.py          |  420 +
 .../pip/_vendor/packaging/version.pyc         |  Bin 0 -> 19025 bytes
 .../pip/_vendor/pep517/__init__.py            |    4 +
 .../pip/_vendor/pep517/__init__.pyc           |  Bin 0 -> 308 bytes
 .../pip/_vendor/pep517/_in_process.py         |  207 +
 .../pip/_vendor/pep517/_in_process.pyc        |  Bin 0 -> 7785 bytes
 .../site-packages/pip/_vendor/pep517/build.py |  108 +
 .../pip/_vendor/pep517/build.pyc              |  Bin 0 -> 3865 bytes
 .../site-packages/pip/_vendor/pep517/check.py |  202 +
 .../pip/_vendor/pep517/check.pyc              |  Bin 0 -> 6183 bytes
 .../pip/_vendor/pep517/colorlog.py            |  115 +
 .../pip/_vendor/pep517/colorlog.pyc           |  Bin 0 -> 3906 bytes
 .../pip/_vendor/pep517/compat.py              |   23 +
 .../pip/_vendor/pep517/compat.pyc             |  Bin 0 -> 1587 bytes
 .../pip/_vendor/pep517/envbuild.py            |  158 +
 .../pip/_vendor/pep517/envbuild.pyc           |  Bin 0 -> 5625 bytes
 .../pip/_vendor/pep517/wrappers.py            |  163 +
 .../pip/_vendor/pep517/wrappers.pyc           |  Bin 0 -> 7144 bytes
 .../pip/_vendor/pkg_resources/__init__.py     | 3286 +++++++
 .../pip/_vendor/pkg_resources/__init__.pyc    |  Bin 0 -> 137751 bytes
 .../pip/_vendor/pkg_resources/py31compat.py   |   23 +
 .../pip/_vendor/pkg_resources/py31compat.pyc  |  Bin 0 -> 881 bytes
 .../pip/_vendor/progress/__init__.py          |  177 +
 .../pip/_vendor/progress/__init__.pyc         |  Bin 0 -> 8933 bytes
 .../site-packages/pip/_vendor/progress/bar.py |   91 +
 .../pip/_vendor/progress/bar.pyc              |  Bin 0 -> 4043 bytes
 .../pip/_vendor/progress/counter.py           |   41 +
 .../pip/_vendor/progress/counter.pyc          |  Bin 0 -> 2422 bytes
 .../pip/_vendor/progress/spinner.py           |   43 +
 .../pip/_vendor/progress/spinner.pyc          |  Bin 0 -> 2211 bytes
 .../site-packages/pip/_vendor/pyparsing.py    | 6493 +++++++++++++
 .../site-packages/pip/_vendor/pyparsing.pyc   |  Bin 0 -> 277107 bytes
 .../pip/_vendor/pytoml/__init__.py            |    4 +
 .../pip/_vendor/pytoml/__init__.pyc           |  Bin 0 -> 448 bytes
 .../site-packages/pip/_vendor/pytoml/core.py  |   13 +
 .../site-packages/pip/_vendor/pytoml/core.pyc |  Bin 0 -> 1400 bytes
 .../pip/_vendor/pytoml/parser.py              |  341 +
 .../pip/_vendor/pytoml/parser.pyc             |  Bin 0 -> 14699 bytes
 .../site-packages/pip/_vendor/pytoml/test.py  |   30 +
 .../site-packages/pip/_vendor/pytoml/test.pyc |  Bin 0 -> 1551 bytes
 .../site-packages/pip/_vendor/pytoml/utils.py |   67 +
 .../pip/_vendor/pytoml/utils.pyc              |  Bin 0 -> 3298 bytes
 .../pip/_vendor/pytoml/writer.py              |  106 +
 .../pip/_vendor/pytoml/writer.pyc             |  Bin 0 -> 5606 bytes
 .../pip/_vendor/requests/__init__.py          |  133 +
 .../pip/_vendor/requests/__init__.pyc         |  Bin 0 -> 4332 bytes
 .../pip/_vendor/requests/__version__.py       |   14 +
 .../pip/_vendor/requests/__version__.pyc      |  Bin 0 -> 634 bytes
 .../pip/_vendor/requests/_internal_utils.py   |   42 +
 .../pip/_vendor/requests/_internal_utils.pyc  |  Bin 0 -> 1676 bytes
 .../pip/_vendor/requests/adapters.py          |  533 ++
 .../pip/_vendor/requests/adapters.pyc         |  Bin 0 -> 20399 bytes
 .../site-packages/pip/_vendor/requests/api.py |  158 +
 .../pip/_vendor/requests/api.pyc              |  Bin 0 -> 7499 bytes
 .../pip/_vendor/requests/auth.py              |  305 +
 .../pip/_vendor/requests/auth.pyc             |  Bin 0 -> 11699 bytes
 .../pip/_vendor/requests/certs.py             |   18 +
 .../pip/_vendor/requests/certs.pyc            |  Bin 0 -> 665 bytes
 .../pip/_vendor/requests/compat.py            |   74 +
 .../pip/_vendor/requests/compat.pyc           |  Bin 0 -> 2003 bytes
 .../pip/_vendor/requests/cookies.py           |  549 ++
 .../pip/_vendor/requests/cookies.pyc          |  Bin 0 -> 25235 bytes
 .../pip/_vendor/requests/exceptions.py        |  126 +
 .../pip/_vendor/requests/exceptions.pyc       |  Bin 0 -> 8345 bytes
 .../pip/_vendor/requests/help.py              |  119 +
 .../pip/_vendor/requests/help.pyc             |  Bin 0 -> 3572 bytes
 .../pip/_vendor/requests/hooks.py             |   34 +
 .../pip/_vendor/requests/hooks.pyc            |  Bin 0 -> 1398 bytes
 .../pip/_vendor/requests/models.py            |  953 ++
 .../pip/_vendor/requests/models.pyc           |  Bin 0 -> 31863 bytes
 .../pip/_vendor/requests/packages.py          |   16 +
 .../pip/_vendor/requests/packages.pyc         |  Bin 0 -> 643 bytes
 .../pip/_vendor/requests/sessions.py          |  770 ++
 .../pip/_vendor/requests/sessions.pyc         |  Bin 0 -> 24341 bytes
 .../pip/_vendor/requests/status_codes.py      |  120 +
 .../pip/_vendor/requests/status_codes.pyc     |  Bin 0 -> 7881 bytes
 .../pip/_vendor/requests/structures.py        |  103 +
 .../pip/_vendor/requests/structures.pyc       |  Bin 0 -> 6281 bytes
 .../pip/_vendor/requests/utils.py             |  977 ++
 .../pip/_vendor/requests/utils.pyc            |  Bin 0 -> 29364 bytes
 .../site-packages/pip/_vendor/retrying.py     |  267 +
 .../site-packages/pip/_vendor/retrying.pyc    |  Bin 0 -> 11662 bytes
 .../site-packages/pip/_vendor/six.py          |  952 ++
 .../site-packages/pip/_vendor/six.pyc         |  Bin 0 -> 37306 bytes
 .../pip/_vendor/urllib3/__init__.py           |   92 +
 .../pip/_vendor/urllib3/__init__.pyc          |  Bin 0 -> 3012 bytes
 .../pip/_vendor/urllib3/_collections.py       |  329 +
 .../pip/_vendor/urllib3/_collections.pyc      |  Bin 0 -> 15104 bytes
 .../pip/_vendor/urllib3/connection.py         |  391 +
 .../pip/_vendor/urllib3/connection.pyc        |  Bin 0 -> 13186 bytes
 .../pip/_vendor/urllib3/connectionpool.py     |  896 ++
 .../pip/_vendor/urllib3/connectionpool.pyc    |  Bin 0 -> 28575 bytes
 .../pip/_vendor/urllib3/contrib/__init__.py   |    0
 .../pip/_vendor/urllib3/contrib/__init__.pyc  |  Bin 0 -> 206 bytes
 .../urllib3/contrib/_appengine_environ.py     |   30 +
 .../urllib3/contrib/_appengine_environ.pyc    |  Bin 0 -> 1838 bytes
 .../contrib/_securetransport/__init__.py      |    0
 .../contrib/_securetransport/__init__.pyc     |  Bin 0 -> 223 bytes
 .../contrib/_securetransport/bindings.py      |  593 ++
 .../contrib/_securetransport/bindings.pyc     |  Bin 0 -> 12359 bytes
 .../contrib/_securetransport/low_level.py     |  346 +
 .../contrib/_securetransport/low_level.pyc    |  Bin 0 -> 10132 bytes
 .../pip/_vendor/urllib3/contrib/appengine.py  |  289 +
 .../pip/_vendor/urllib3/contrib/appengine.pyc |  Bin 0 -> 10129 bytes
 .../pip/_vendor/urllib3/contrib/ntlmpool.py   |  111 +
 .../pip/_vendor/urllib3/contrib/ntlmpool.pyc  |  Bin 0 -> 4173 bytes
 .../pip/_vendor/urllib3/contrib/pyopenssl.py  |  466 +
 .../pip/_vendor/urllib3/contrib/pyopenssl.pyc |  Bin 0 -> 19914 bytes
 .../urllib3/contrib/securetransport.py        |  804 ++
 .../urllib3/contrib/securetransport.pyc       |  Bin 0 -> 24494 bytes
 .../pip/_vendor/urllib3/contrib/socks.py      |  192 +
 .../pip/_vendor/urllib3/contrib/socks.pyc     |  Bin 0 -> 6298 bytes
 .../pip/_vendor/urllib3/exceptions.py         |  246 +
 .../pip/_vendor/urllib3/exceptions.pyc        |  Bin 0 -> 15502 bytes
 .../pip/_vendor/urllib3/fields.py             |  178 +
 .../pip/_vendor/urllib3/fields.pyc            |  Bin 0 -> 7346 bytes
 .../pip/_vendor/urllib3/filepost.py           |   98 +
 .../pip/_vendor/urllib3/filepost.pyc          |  Bin 0 -> 3780 bytes
 .../pip/_vendor/urllib3/packages/__init__.py  |    5 +
 .../pip/_vendor/urllib3/packages/__init__.pyc |  Bin 0 -> 387 bytes
 .../urllib3/packages/backports/__init__.py    |    0
 .../urllib3/packages/backports/__init__.pyc   |  Bin 0 -> 217 bytes
 .../urllib3/packages/backports/makefile.py    |   53 +
 .../urllib3/packages/backports/makefile.pyc   |  Bin 0 -> 1713 bytes
 .../pip/_vendor/urllib3/packages/six.py       |  868 ++
 .../pip/_vendor/urllib3/packages/six.pyc      |  Bin 0 -> 36102 bytes
 .../packages/ssl_match_hostname/__init__.py   |   19 +
 .../packages/ssl_match_hostname/__init__.pyc  |  Bin 0 -> 697 bytes
 .../ssl_match_hostname/_implementation.py     |  156 +
 .../ssl_match_hostname/_implementation.pyc    |  Bin 0 -> 4598 bytes
 .../pip/_vendor/urllib3/poolmanager.py        |  450 +
 .../pip/_vendor/urllib3/poolmanager.pyc       |  Bin 0 -> 16523 bytes
 .../pip/_vendor/urllib3/request.py            |  150 +
 .../pip/_vendor/urllib3/request.pyc           |  Bin 0 -> 6445 bytes
 .../pip/_vendor/urllib3/response.py           |  705 ++
 .../pip/_vendor/urllib3/response.pyc          |  Bin 0 -> 24614 bytes
 .../pip/_vendor/urllib3/util/__init__.py      |   54 +
 .../pip/_vendor/urllib3/util/__init__.pyc     |  Bin 0 -> 1567 bytes
 .../pip/_vendor/urllib3/util/connection.py    |  134 +
 .../pip/_vendor/urllib3/util/connection.pyc   |  Bin 0 -> 4192 bytes
 .../pip/_vendor/urllib3/util/queue.py         |   21 +
 .../pip/_vendor/urllib3/util/queue.pyc        |  Bin 0 -> 1665 bytes
 .../pip/_vendor/urllib3/util/request.py       |  118 +
 .../pip/_vendor/urllib3/util/request.pyc      |  Bin 0 -> 3945 bytes
 .../pip/_vendor/urllib3/util/response.py      |   87 +
 .../pip/_vendor/urllib3/util/response.pyc     |  Bin 0 -> 2583 bytes
 .../pip/_vendor/urllib3/util/retry.py         |  411 +
 .../pip/_vendor/urllib3/util/retry.pyc        |  Bin 0 -> 15622 bytes
 .../pip/_vendor/urllib3/util/ssl_.py          |  381 +
 .../pip/_vendor/urllib3/util/ssl_.pyc         |  Bin 0 -> 12270 bytes
 .../pip/_vendor/urllib3/util/timeout.py       |  242 +
 .../pip/_vendor/urllib3/util/timeout.pyc      |  Bin 0 -> 10233 bytes
 .../pip/_vendor/urllib3/util/url.py           |  230 +
 .../pip/_vendor/urllib3/util/url.pyc          |  Bin 0 -> 6910 bytes
 .../pip/_vendor/urllib3/util/wait.py          |  150 +
 .../pip/_vendor/urllib3/util/wait.pyc         |  Bin 0 -> 4842 bytes
 .../pip/_vendor/webencodings/__init__.py      |  342 +
 .../pip/_vendor/webencodings/__init__.pyc     |  Bin 0 -> 12364 bytes
 .../pip/_vendor/webencodings/labels.py        |  231 +
 .../pip/_vendor/webencodings/labels.pyc       |  Bin 0 -> 5361 bytes
 .../pip/_vendor/webencodings/mklabels.py      |   59 +
 .../pip/_vendor/webencodings/mklabels.pyc     |  Bin 0 -> 2486 bytes
 .../pip/_vendor/webencodings/tests.py         |  153 +
 .../pip/_vendor/webencodings/tests.pyc        |  Bin 0 -> 7341 bytes
 .../_vendor/webencodings/x_user_defined.py    |  325 +
 .../_vendor/webencodings/x_user_defined.pyc   |  Bin 0 -> 3842 bytes
 .../site-packages/pkg_resources/__init__.py   | 3286 +++++++
 .../site-packages/pkg_resources/__init__.pyc  |  Bin 0 -> 136325 bytes
 .../pkg_resources/_vendor/__init__.py         |    0
 .../pkg_resources/_vendor/__init__.pyc        |  Bin 0 -> 207 bytes
 .../pkg_resources/_vendor/appdirs.py          |  608 ++
 .../pkg_resources/_vendor/appdirs.pyc         |  Bin 0 -> 24415 bytes
 .../_vendor/packaging/__about__.py            |   21 +
 .../_vendor/packaging/__about__.pyc           |  Bin 0 -> 846 bytes
 .../_vendor/packaging/__init__.py             |   14 +
 .../_vendor/packaging/__init__.pyc            |  Bin 0 -> 668 bytes
 .../_vendor/packaging/_compat.py              |   30 +
 .../_vendor/packaging/_compat.pyc             |  Bin 0 -> 1472 bytes
 .../_vendor/packaging/_structures.py          |   68 +
 .../_vendor/packaging/_structures.pyc         |  Bin 0 -> 5370 bytes
 .../_vendor/packaging/markers.py              |  301 +
 .../_vendor/packaging/markers.pyc             |  Bin 0 -> 13962 bytes
 .../_vendor/packaging/requirements.py         |  127 +
 .../_vendor/packaging/requirements.pyc        |  Bin 0 -> 5683 bytes
 .../_vendor/packaging/specifiers.py           |  774 ++
 .../_vendor/packaging/specifiers.pyc          |  Bin 0 -> 29374 bytes
 .../pkg_resources/_vendor/packaging/utils.py  |   14 +
 .../pkg_resources/_vendor/packaging/utils.pyc |  Bin 0 -> 708 bytes
 .../_vendor/packaging/version.py              |  393 +
 .../_vendor/packaging/version.pyc             |  Bin 0 -> 17248 bytes
 .../pkg_resources/_vendor/pyparsing.py        | 5742 ++++++++++++
 .../pkg_resources/_vendor/pyparsing.pyc       |  Bin 0 -> 260233 bytes
 .../pkg_resources/_vendor/six.py              |  868 ++
 .../pkg_resources/_vendor/six.pyc             |  Bin 0 -> 36102 bytes
 .../pkg_resources/extern/__init__.py          |   73 +
 .../pkg_resources/extern/__init__.pyc         |  Bin 0 -> 3353 bytes
 .../site-packages/pkg_resources/py31compat.py |   23 +
 .../pkg_resources/py31compat.pyc              |  Bin 0 -> 866 bytes
 .../setuptools-41.0.1.dist-info/INSTALLER     |    1 +
 .../setuptools-41.0.1.dist-info/LICENSE       |   19 +
 .../setuptools-41.0.1.dist-info/METADATA      |   77 +
 .../setuptools-41.0.1.dist-info/RECORD        |  186 +
 .../setuptools-41.0.1.dist-info/WHEEL         |    6 +
 .../dependency_links.txt                      |    2 +
 .../entry_points.txt                          |   65 +
 .../setuptools-41.0.1.dist-info/top_level.txt |    3 +
 .../setuptools-41.0.1.dist-info/zip-safe      |    1 +
 .../site-packages/setuptools/__init__.py      |  228 +
 .../site-packages/setuptools/__init__.pyc     |  Bin 0 -> 10555 bytes
 .../setuptools/_deprecation_warning.py        |    7 +
 .../setuptools/_deprecation_warning.pyc       |  Bin 0 -> 690 bytes
 .../setuptools/_vendor/__init__.py            |    0
 .../setuptools/_vendor/__init__.pyc           |  Bin 0 -> 204 bytes
 .../setuptools/_vendor/packaging/__about__.py |   21 +
 .../_vendor/packaging/__about__.pyc           |  Bin 0 -> 843 bytes
 .../setuptools/_vendor/packaging/__init__.py  |   14 +
 .../setuptools/_vendor/packaging/__init__.pyc |  Bin 0 -> 665 bytes
 .../setuptools/_vendor/packaging/_compat.py   |   30 +
 .../setuptools/_vendor/packaging/_compat.pyc  |  Bin 0 -> 1460 bytes
 .../_vendor/packaging/_structures.py          |   68 +
 .../_vendor/packaging/_structures.pyc         |  Bin 0 -> 5307 bytes
 .../setuptools/_vendor/packaging/markers.py   |  301 +
 .../setuptools/_vendor/packaging/markers.pyc  |  Bin 0 -> 13854 bytes
 .../_vendor/packaging/requirements.py         |  127 +
 .../_vendor/packaging/requirements.pyc        |  Bin 0 -> 5650 bytes
 .../_vendor/packaging/specifiers.py           |  774 ++
 .../_vendor/packaging/specifiers.pyc          |  Bin 0 -> 29161 bytes
 .../setuptools/_vendor/packaging/utils.py     |   14 +
 .../setuptools/_vendor/packaging/utils.pyc    |  Bin 0 -> 702 bytes
 .../setuptools/_vendor/packaging/version.py   |  393 +
 .../setuptools/_vendor/packaging/version.pyc  |  Bin 0 -> 17101 bytes
 .../setuptools/_vendor/pyparsing.py           | 5742 ++++++++++++
 .../setuptools/_vendor/pyparsing.pyc          |  Bin 0 -> 258922 bytes
 .../site-packages/setuptools/_vendor/six.py   |  868 ++
 .../site-packages/setuptools/_vendor/six.pyc  |  Bin 0 -> 35865 bytes
 .../site-packages/setuptools/archive_util.py  |  173 +
 .../site-packages/setuptools/archive_util.pyc |  Bin 0 -> 6574 bytes
 .../site-packages/setuptools/build_meta.py    |  254 +
 .../site-packages/setuptools/build_meta.pyc   |  Bin 0 -> 10676 bytes
 .../site-packages/setuptools/cli-32.exe       |  Bin 0 -> 65536 bytes
 .../site-packages/setuptools/cli-64.exe       |  Bin 0 -> 74752 bytes
 .../site-packages/setuptools/cli.exe          |  Bin 0 -> 65536 bytes
 .../setuptools/command/__init__.py            |   18 +
 .../setuptools/command/__init__.pyc           |  Bin 0 -> 936 bytes
 .../site-packages/setuptools/command/alias.py |   80 +
 .../setuptools/command/alias.pyc              |  Bin 0 -> 3482 bytes
 .../setuptools/command/bdist_egg.py           |  502 +
 .../setuptools/command/bdist_egg.pyc          |  Bin 0 -> 19800 bytes
 .../setuptools/command/bdist_rpm.py           |   43 +
 .../setuptools/command/bdist_rpm.pyc          |  Bin 0 -> 2130 bytes
 .../setuptools/command/bdist_wininst.py       |   21 +
 .../setuptools/command/bdist_wininst.pyc      |  Bin 0 -> 1425 bytes
 .../setuptools/command/build_clib.py          |   98 +
 .../setuptools/command/build_clib.pyc         |  Bin 0 -> 3006 bytes
 .../setuptools/command/build_ext.py           |  321 +
 .../setuptools/command/build_ext.pyc          |  Bin 0 -> 13452 bytes
 .../setuptools/command/build_py.py            |  270 +
 .../setuptools/command/build_py.pyc           |  Bin 0 -> 11963 bytes
 .../setuptools/command/develop.py             |  221 +
 .../setuptools/command/develop.pyc            |  Bin 0 -> 8733 bytes
 .../setuptools/command/dist_info.py           |   36 +
 .../setuptools/command/dist_info.pyc          |  Bin 0 -> 2069 bytes
 .../setuptools/command/easy_install.py        | 2342 +++++
 .../setuptools/command/easy_install.pyc       |  Bin 0 -> 88096 bytes
 .../setuptools/command/egg_info.py            |  717 ++
 .../setuptools/command/egg_info.pyc           |  Bin 0 -> 29768 bytes
 .../setuptools/command/install.py             |  125 +
 .../setuptools/command/install.pyc            |  Bin 0 -> 5493 bytes
 .../setuptools/command/install_egg_info.py    |   62 +
 .../setuptools/command/install_egg_info.pyc   |  Bin 0 -> 3639 bytes
 .../setuptools/command/install_lib.py         |  121 +
 .../setuptools/command/install_lib.pyc        |  Bin 0 -> 5518 bytes
 .../setuptools/command/install_scripts.py     |   65 +
 .../setuptools/command/install_scripts.pyc    |  Bin 0 -> 3161 bytes
 .../setuptools/command/launcher manifest.xml  |   15 +
 .../setuptools/command/py36compat.py          |  136 +
 .../setuptools/command/py36compat.pyc         |  Bin 0 -> 6198 bytes
 .../setuptools/command/register.py            |   18 +
 .../setuptools/command/register.pyc           |  Bin 0 -> 1080 bytes
 .../setuptools/command/rotate.py              |   66 +
 .../setuptools/command/rotate.pyc             |  Bin 0 -> 3322 bytes
 .../setuptools/command/saveopts.py            |   22 +
 .../setuptools/command/saveopts.pyc           |  Bin 0 -> 1291 bytes
 .../site-packages/setuptools/command/sdist.py |  221 +
 .../setuptools/command/sdist.pyc              |  Bin 0 -> 9479 bytes
 .../setuptools/command/setopt.py              |  149 +
 .../setuptools/command/setopt.pyc             |  Bin 0 -> 6596 bytes
 .../site-packages/setuptools/command/test.py  |  271 +
 .../site-packages/setuptools/command/test.pyc |  Bin 0 -> 11758 bytes
 .../setuptools/command/upload.py              |  196 +
 .../setuptools/command/upload.pyc             |  Bin 0 -> 6915 bytes
 .../setuptools/command/upload_docs.py         |  206 +
 .../setuptools/command/upload_docs.pyc        |  Bin 0 -> 8436 bytes
 .../site-packages/setuptools/config.py        |  656 ++
 .../site-packages/setuptools/config.pyc       |  Bin 0 -> 22827 bytes
 .../site-packages/setuptools/dep_util.py      |   23 +
 .../site-packages/setuptools/dep_util.pyc     |  Bin 0 -> 1073 bytes
 .../site-packages/setuptools/depends.py       |  186 +
 .../site-packages/setuptools/depends.pyc      |  Bin 0 -> 7166 bytes
 .../site-packages/setuptools/dist.py          | 1278 +++
 .../site-packages/setuptools/dist.pyc         |  Bin 0 -> 51591 bytes
 .../site-packages/setuptools/extension.py     |   57 +
 .../site-packages/setuptools/extension.pyc    |  Bin 0 -> 2742 bytes
 .../setuptools/extern/__init__.py             |   73 +
 .../setuptools/extern/__init__.pyc            |  Bin 0 -> 3323 bytes
 .../site-packages/setuptools/glibc.py         |   86 +
 .../site-packages/setuptools/glibc.pyc        |  Bin 0 -> 2230 bytes
 .../site-packages/setuptools/glob.py          |  174 +
 .../site-packages/setuptools/glob.pyc         |  Bin 0 -> 5311 bytes
 .../site-packages/setuptools/gui-32.exe       |  Bin 0 -> 65536 bytes
 .../site-packages/setuptools/gui-64.exe       |  Bin 0 -> 75264 bytes
 .../site-packages/setuptools/gui.exe          |  Bin 0 -> 65536 bytes
 .../site-packages/setuptools/launch.py        |   35 +
 .../site-packages/setuptools/launch.pyc       |  Bin 0 -> 1108 bytes
 .../site-packages/setuptools/lib2to3_ex.py    |   62 +
 .../site-packages/setuptools/lib2to3_ex.pyc   |  Bin 0 -> 3490 bytes
 .../site-packages/setuptools/monkey.py        |  179 +
 .../site-packages/setuptools/monkey.pyc       |  Bin 0 -> 6478 bytes
 .../site-packages/setuptools/msvc.py          | 1301 +++
 .../site-packages/setuptools/msvc.pyc         |  Bin 0 -> 44716 bytes
 .../site-packages/setuptools/namespaces.py    |  107 +
 .../site-packages/setuptools/namespaces.pyc   |  Bin 0 -> 5681 bytes
 .../site-packages/setuptools/package_index.py | 1136 +++
 .../setuptools/package_index.pyc              |  Bin 0 -> 44744 bytes
 .../site-packages/setuptools/pep425tags.py    |  319 +
 .../site-packages/setuptools/pep425tags.pyc   |  Bin 0 -> 10313 bytes
 .../site-packages/setuptools/py27compat.py    |   28 +
 .../site-packages/setuptools/py27compat.pyc   |  Bin 0 -> 1261 bytes
 .../site-packages/setuptools/py31compat.py    |   32 +
 .../site-packages/setuptools/py31compat.pyc   |  Bin 0 -> 1712 bytes
 .../site-packages/setuptools/py33compat.py    |   55 +
 .../site-packages/setuptools/py33compat.pyc   |  Bin 0 -> 1962 bytes
 .../site-packages/setuptools/sandbox.py       |  491 +
 .../site-packages/setuptools/sandbox.pyc      |  Bin 0 -> 21826 bytes
 .../setuptools/script (dev).tmpl              |    6 +
 .../site-packages/setuptools/script.tmpl      |    3 +
 .../site-packages/setuptools/site-patch.py    |   74 +
 .../site-packages/setuptools/site-patch.pyc   |  Bin 0 -> 1847 bytes
 .../site-packages/setuptools/ssl_support.py   |  260 +
 .../site-packages/setuptools/ssl_support.pyc  |  Bin 0 -> 9597 bytes
 .../site-packages/setuptools/unicode_utils.py |   44 +
 .../setuptools/unicode_utils.pyc              |  Bin 0 -> 1688 bytes
 .../site-packages/setuptools/version.py       |    6 +
 .../site-packages/setuptools/version.pyc      |  Bin 0 -> 376 bytes
 .../site-packages/setuptools/wheel.py         |  211 +
 .../site-packages/setuptools/wheel.pyc        |  Bin 0 -> 9864 bytes
 .../setuptools/windows_support.py             |   29 +
 .../setuptools/windows_support.pyc            |  Bin 0 -> 1490 bytes
 .../wheel-0.33.1.dist-info/INSTALLER          |    1 +
 .../wheel-0.33.1.dist-info/LICENSE.txt        |   22 +
 .../wheel-0.33.1.dist-info/METADATA           |   60 +
 .../wheel-0.33.1.dist-info/RECORD             |   32 +
 .../wheel-0.33.1.dist-info/WHEEL              |    6 +
 .../wheel-0.33.1.dist-info/entry_points.txt   |    6 +
 .../wheel-0.33.1.dist-info/top_level.txt      |    1 +
 .../python2.7/site-packages/wheel/__init__.py |    2 +
 .../site-packages/wheel/__init__.pyc          |  Bin 0 -> 219 bytes
 .../python2.7/site-packages/wheel/__main__.py |   19 +
 .../site-packages/wheel/__main__.pyc          |  Bin 0 -> 811 bytes
 .../site-packages/wheel/bdist_wheel.py        |  372 +
 .../site-packages/wheel/bdist_wheel.pyc       |  Bin 0 -> 14392 bytes
 .../site-packages/wheel/cli/__init__.py       |   88 +
 .../site-packages/wheel/cli/__init__.pyc      |  Bin 0 -> 4405 bytes
 .../site-packages/wheel/cli/convert.py        |  269 +
 .../site-packages/wheel/cli/convert.pyc       |  Bin 0 -> 7962 bytes
 .../python2.7/site-packages/wheel/cli/pack.py |   58 +
 .../site-packages/wheel/cli/pack.pyc          |  Bin 0 -> 3102 bytes
 .../site-packages/wheel/cli/unpack.py         |   25 +
 .../site-packages/wheel/cli/unpack.pyc        |  Bin 0 -> 1182 bytes
 .../python2.7/site-packages/wheel/metadata.py |  141 +
 .../site-packages/wheel/metadata.pyc          |  Bin 0 -> 5114 bytes
 .../site-packages/wheel/pep425tags.py         |  185 +
 .../site-packages/wheel/pep425tags.pyc        |  Bin 0 -> 6677 bytes
 .../python2.7/site-packages/wheel/pkginfo.py  |   43 +
 .../python2.7/site-packages/wheel/pkginfo.pyc |  Bin 0 -> 2403 bytes
 .../lib/python2.7/site-packages/wheel/util.py |   46 +
 .../python2.7/site-packages/wheel/util.pyc    |  Bin 0 -> 2061 bytes
 .../site-packages/wheel/wheelfile.py          |  168 +
 .../site-packages/wheel/wheelfile.pyc         |  Bin 0 -> 7456 bytes
 .../assert_test01/venv/lib/python2.7/site.py  |  851 ++
 .../assert_test01/venv/lib/python2.7/site.pyc |  Bin 0 -> 28489 bytes
 .../assert_test01/venv/lib/python2.7/sre.py   |    1 +
 .../venv/lib/python2.7/sre_compile.py         |    1 +
 .../venv/lib/python2.7/sre_compile.pyc        |  Bin 0 -> 13414 bytes
 .../venv/lib/python2.7/sre_constants.py       |    1 +
 .../venv/lib/python2.7/sre_constants.pyc      |  Bin 0 -> 6480 bytes
 .../venv/lib/python2.7/sre_parse.py           |    1 +
 .../venv/lib/python2.7/sre_parse.pyc          |  Bin 0 -> 22069 bytes
 .../assert_test01/venv/lib/python2.7/stat.py  |    1 +
 .../assert_test01/venv/lib/python2.7/stat.pyc |  Bin 0 -> 3321 bytes
 .../assert_test01/venv/lib/python2.7/types.py |    1 +
 .../venv/lib/python2.7/types.pyc              |  Bin 0 -> 3124 bytes
 .../venv/lib/python2.7/warnings.py            |    1 +
 .../venv/lib/python2.7/warnings.pyc           |  Bin 0 -> 14489 bytes
 .../src/app/app.component.css                 |    5 +
 .../src/app/app.component.html                |    3 -
 .../app/compilateur/compilateur.component.css |   43 +
 .../compilateur/compilateur.component.html    |   17 +-
 .../app/compilateur/compilateur.component.ts  |   34 +-
 .../src/app/compilation.service.ts            |    5 +-
 .../front-end-compilation/src/styles.css      |    3 +
 .../server_rest/.idea/compiler.xml            |    1 +
 .../server_rest/.idea/workspace.xml           |  127 +-
 .../server_rest/src/main/java/app.java        |    3 +-
 .../server_rest/target/classes/app.class      |  Bin 0 -> 3028 bytes
 .../serveur_compilation/.idea/compiler.xml    |    1 +
 .../serveur_compilation/.idea/workspace.xml   |  199 +-
 .../__pycache__/sample.cpython-37.pyc         |  Bin 0 -> 268 bytes
 .../src/main/java/compilation.java            |   18 +-
 .../target/classes/compilation.class          |  Bin 4342 -> 4737 bytes
 934 files changed, 147209 insertions(+), 143 deletions(-)
 create mode 100644 tests/python/assert_test01/.idea/assert_test01.iml
 create mode 100644 tests/python/assert_test01/.idea/misc.xml
 create mode 100644 tests/python/assert_test01/.idea/modules.xml
 create mode 100644 tests/python/assert_test01/.idea/vcs.xml
 create mode 100644 tests/python/assert_test01/.idea/workspace.xml
 create mode 100644 tests/python/assert_test01/main.py
 create mode 100644 tests/python/assert_test01/main.pyc
 create mode 100644 tests/python/assert_test01/test.py
 create mode 100644 tests/python/assert_test01/test.pyc
 create mode 120000 tests/python/assert_test01/venv/.Python
 create mode 100644 tests/python/assert_test01/venv/bin/activate
 create mode 100644 tests/python/assert_test01/venv/bin/activate.csh
 create mode 100644 tests/python/assert_test01/venv/bin/activate.fish
 create mode 100644 tests/python/assert_test01/venv/bin/activate.ps1
 create mode 100644 tests/python/assert_test01/venv/bin/activate_this.py
 create mode 100755 tests/python/assert_test01/venv/bin/easy_install
 create mode 100755 tests/python/assert_test01/venv/bin/easy_install-2.7
 create mode 100755 tests/python/assert_test01/venv/bin/pip
 create mode 100755 tests/python/assert_test01/venv/bin/pip2
 create mode 100755 tests/python/assert_test01/venv/bin/pip2.7
 create mode 100755 tests/python/assert_test01/venv/bin/python
 create mode 100755 tests/python/assert_test01/venv/bin/python-config
 create mode 120000 tests/python/assert_test01/venv/bin/python2
 create mode 120000 tests/python/assert_test01/venv/bin/python2.7
 create mode 100755 tests/python/assert_test01/venv/bin/wheel
 create mode 120000 tests/python/assert_test01/venv/include/python2.7
 create mode 120000 tests/python/assert_test01/venv/lib/python2.7/LICENSE.txt
 create mode 120000 tests/python/assert_test01/venv/lib/python2.7/UserDict.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/UserDict.pyc
 create mode 120000 tests/python/assert_test01/venv/lib/python2.7/_abcoll.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/_abcoll.pyc
 create mode 120000 tests/python/assert_test01/venv/lib/python2.7/_weakrefset.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/_weakrefset.pyc
 create mode 120000 tests/python/assert_test01/venv/lib/python2.7/abc.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/abc.pyc
 create mode 120000 tests/python/assert_test01/venv/lib/python2.7/codecs.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/codecs.pyc
 create mode 120000 tests/python/assert_test01/venv/lib/python2.7/config
 create mode 120000 tests/python/assert_test01/venv/lib/python2.7/copy_reg.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/copy_reg.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/distutils/__init__.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/distutils/__init__.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/distutils/distutils.cfg
 create mode 120000 tests/python/assert_test01/venv/lib/python2.7/encodings
 create mode 120000 tests/python/assert_test01/venv/lib/python2.7/fnmatch.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/fnmatch.pyc
 create mode 120000 tests/python/assert_test01/venv/lib/python2.7/genericpath.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/genericpath.pyc
 create mode 120000 tests/python/assert_test01/venv/lib/python2.7/lib-dynload
 create mode 120000 tests/python/assert_test01/venv/lib/python2.7/linecache.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/linecache.pyc
 create mode 120000 tests/python/assert_test01/venv/lib/python2.7/locale.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/locale.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/no-global-site-packages.txt
 create mode 120000 tests/python/assert_test01/venv/lib/python2.7/ntpath.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/ntpath.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/orig-prefix.txt
 create mode 120000 tests/python/assert_test01/venv/lib/python2.7/os.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/os.pyc
 create mode 120000 tests/python/assert_test01/venv/lib/python2.7/posixpath.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/posixpath.pyc
 create mode 120000 tests/python/assert_test01/venv/lib/python2.7/re.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/re.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/assertpy-0.14.dist-info/INSTALLER
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/assertpy-0.14.dist-info/LICENSE
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/assertpy-0.14.dist-info/METADATA
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/assertpy-0.14.dist-info/RECORD
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/assertpy-0.14.dist-info/WHEEL
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/assertpy-0.14.dist-info/top_level.txt
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/assertpy/__init__.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/assertpy/__init__.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/assertpy/assertpy.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/assertpy/assertpy.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/easy_install.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/easy_install.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip-19.1.dist-info/INSTALLER
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip-19.1.dist-info/LICENSE.txt
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip-19.1.dist-info/METADATA
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip-19.1.dist-info/RECORD
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip-19.1.dist-info/WHEEL
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip-19.1.dist-info/entry_points.txt
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip-19.1.dist-info/top_level.txt
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/__init__.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/__init__.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/__main__.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/__main__.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/__init__.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/__init__.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/build_env.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/build_env.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/cache.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/cache.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/cli/__init__.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/cli/__init__.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/cli/autocompletion.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/cli/autocompletion.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/cli/base_command.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/cli/base_command.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/cli/cmdoptions.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/cli/cmdoptions.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/cli/main_parser.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/cli/main_parser.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/cli/parser.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/cli/parser.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/cli/status_codes.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/cli/status_codes.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/commands/__init__.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/commands/__init__.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/commands/check.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/commands/check.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/commands/completion.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/commands/completion.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/commands/configuration.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/commands/configuration.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/commands/download.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/commands/download.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/commands/freeze.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/commands/freeze.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/commands/hash.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/commands/hash.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/commands/help.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/commands/help.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/commands/install.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/commands/install.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/commands/list.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/commands/list.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/commands/search.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/commands/search.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/commands/show.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/commands/show.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/commands/uninstall.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/commands/uninstall.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/commands/wheel.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/commands/wheel.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/configuration.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/configuration.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/download.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/download.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/exceptions.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/exceptions.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/index.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/index.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/locations.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/locations.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/models/__init__.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/models/__init__.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/models/candidate.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/models/candidate.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/models/format_control.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/models/format_control.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/models/index.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/models/index.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/models/link.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/models/link.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/operations/__init__.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/operations/__init__.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/operations/check.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/operations/check.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/operations/freeze.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/operations/freeze.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/operations/prepare.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/operations/prepare.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/pep425tags.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/pep425tags.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/pyproject.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/pyproject.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/req/__init__.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/req/__init__.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/req/constructors.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/req/constructors.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/req/req_file.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/req/req_file.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/req/req_install.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/req/req_install.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/req/req_set.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/req/req_set.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/req/req_tracker.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/req/req_tracker.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/req/req_uninstall.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/req/req_uninstall.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/resolve.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/resolve.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/utils/__init__.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/utils/__init__.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/utils/appdirs.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/utils/appdirs.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/utils/compat.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/utils/compat.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/utils/deprecation.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/utils/deprecation.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/utils/encoding.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/utils/encoding.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/utils/filesystem.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/utils/filesystem.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/utils/glibc.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/utils/glibc.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/utils/hashes.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/utils/hashes.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/utils/logging.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/utils/logging.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/utils/misc.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/utils/misc.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/utils/models.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/utils/models.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/utils/outdated.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/utils/outdated.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/utils/packaging.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/utils/packaging.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/utils/setuptools_build.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/utils/setuptools_build.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/utils/temp_dir.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/utils/temp_dir.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/utils/typing.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/utils/typing.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/utils/ui.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/utils/ui.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/vcs/__init__.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/vcs/__init__.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/vcs/bazaar.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/vcs/bazaar.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/vcs/git.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/vcs/git.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/vcs/mercurial.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/vcs/mercurial.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/vcs/subversion.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/vcs/subversion.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/wheel.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/wheel.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/__init__.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/__init__.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/appdirs.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/appdirs.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/cachecontrol/__init__.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/cachecontrol/__init__.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/cachecontrol/_cmd.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/cachecontrol/_cmd.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/cachecontrol/adapter.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/cachecontrol/adapter.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/cachecontrol/cache.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/cachecontrol/cache.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/cachecontrol/caches/__init__.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/cachecontrol/caches/__init__.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/cachecontrol/caches/file_cache.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/cachecontrol/caches/file_cache.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/cachecontrol/caches/redis_cache.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/cachecontrol/caches/redis_cache.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/cachecontrol/compat.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/cachecontrol/compat.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/cachecontrol/controller.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/cachecontrol/controller.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/cachecontrol/filewrapper.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/cachecontrol/filewrapper.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/cachecontrol/heuristics.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/cachecontrol/heuristics.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/cachecontrol/serialize.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/cachecontrol/serialize.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/cachecontrol/wrapper.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/cachecontrol/wrapper.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/certifi/__init__.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/certifi/__init__.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/certifi/__main__.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/certifi/__main__.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/certifi/cacert.pem
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/certifi/core.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/certifi/core.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/__init__.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/__init__.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/big5freq.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/big5freq.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/big5prober.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/big5prober.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/chardistribution.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/chardistribution.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/charsetgroupprober.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/charsetgroupprober.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/charsetprober.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/charsetprober.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/cli/__init__.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/cli/__init__.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/cli/chardetect.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/cli/chardetect.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/codingstatemachine.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/codingstatemachine.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/compat.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/compat.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/cp949prober.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/cp949prober.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/enums.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/enums.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/escprober.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/escprober.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/escsm.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/escsm.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/eucjpprober.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/eucjpprober.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/euckrfreq.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/euckrfreq.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/euckrprober.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/euckrprober.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/euctwfreq.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/euctwfreq.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/euctwprober.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/euctwprober.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/gb2312freq.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/gb2312freq.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/gb2312prober.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/gb2312prober.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/hebrewprober.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/hebrewprober.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/jisfreq.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/jisfreq.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/jpcntx.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/jpcntx.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/langbulgarianmodel.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/langbulgarianmodel.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/langcyrillicmodel.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/langcyrillicmodel.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/langgreekmodel.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/langgreekmodel.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/langhebrewmodel.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/langhebrewmodel.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/langhungarianmodel.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/langhungarianmodel.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/langthaimodel.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/langthaimodel.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/langturkishmodel.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/langturkishmodel.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/latin1prober.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/latin1prober.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/mbcharsetprober.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/mbcharsetprober.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/mbcsgroupprober.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/mbcsgroupprober.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/mbcssm.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/mbcssm.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/sbcharsetprober.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/sbcharsetprober.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/sbcsgroupprober.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/sbcsgroupprober.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/sjisprober.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/sjisprober.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/universaldetector.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/universaldetector.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/utf8prober.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/utf8prober.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/version.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/version.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/colorama/__init__.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/colorama/__init__.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/colorama/ansi.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/colorama/ansi.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/colorama/ansitowin32.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/colorama/ansitowin32.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/colorama/initialise.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/colorama/initialise.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/colorama/win32.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/colorama/win32.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/colorama/winterm.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/colorama/winterm.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/__init__.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/__init__.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/_backport/__init__.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/_backport/__init__.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/_backport/misc.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/_backport/misc.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/_backport/shutil.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/_backport/shutil.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/_backport/sysconfig.cfg
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/_backport/sysconfig.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/_backport/sysconfig.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/_backport/tarfile.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/_backport/tarfile.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/compat.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/compat.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/database.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/database.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/index.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/index.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/locators.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/locators.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/manifest.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/manifest.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/markers.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/markers.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/metadata.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/metadata.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/resources.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/resources.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/scripts.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/scripts.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/t32.exe
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/t64.exe
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/util.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/util.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/version.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/version.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/w32.exe
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/w64.exe
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/wheel.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/wheel.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distro.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distro.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/__init__.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/__init__.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/_ihatexml.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/_ihatexml.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/_inputstream.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/_inputstream.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/_tokenizer.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/_tokenizer.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/_trie/__init__.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/_trie/__init__.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/_trie/_base.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/_trie/_base.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/_trie/datrie.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/_trie/datrie.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/_trie/py.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/_trie/py.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/_utils.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/_utils.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/constants.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/constants.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/filters/__init__.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/filters/__init__.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/filters/alphabeticalattributes.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/filters/alphabeticalattributes.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/filters/base.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/filters/base.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/filters/inject_meta_charset.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/filters/inject_meta_charset.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/filters/lint.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/filters/lint.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/filters/optionaltags.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/filters/optionaltags.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/filters/sanitizer.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/filters/sanitizer.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/filters/whitespace.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/filters/whitespace.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/html5parser.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/html5parser.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/serializer.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/serializer.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/treeadapters/__init__.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/treeadapters/__init__.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/treeadapters/genshi.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/treeadapters/genshi.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/treeadapters/sax.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/treeadapters/sax.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/treebuilders/__init__.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/treebuilders/__init__.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/treebuilders/base.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/treebuilders/base.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/treebuilders/dom.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/treebuilders/dom.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/treebuilders/etree.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/treebuilders/etree.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/treebuilders/etree_lxml.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/treebuilders/etree_lxml.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/treewalkers/__init__.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/treewalkers/__init__.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/treewalkers/base.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/treewalkers/base.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/treewalkers/dom.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/treewalkers/dom.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/treewalkers/etree.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/treewalkers/etree.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/treewalkers/etree_lxml.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/treewalkers/etree_lxml.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/treewalkers/genshi.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/treewalkers/genshi.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/idna/__init__.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/idna/__init__.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/idna/codec.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/idna/codec.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/idna/compat.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/idna/compat.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/idna/core.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/idna/core.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/idna/idnadata.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/idna/idnadata.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/idna/intranges.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/idna/intranges.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/idna/package_data.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/idna/package_data.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/idna/uts46data.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/idna/uts46data.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/ipaddress.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/ipaddress.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/lockfile/__init__.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/lockfile/__init__.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/lockfile/linklockfile.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/lockfile/linklockfile.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/lockfile/mkdirlockfile.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/lockfile/mkdirlockfile.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/lockfile/pidlockfile.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/lockfile/pidlockfile.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/lockfile/sqlitelockfile.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/lockfile/sqlitelockfile.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/lockfile/symlinklockfile.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/lockfile/symlinklockfile.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/msgpack/__init__.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/msgpack/__init__.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/msgpack/_version.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/msgpack/_version.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/msgpack/exceptions.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/msgpack/exceptions.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/msgpack/fallback.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/msgpack/fallback.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/packaging/__about__.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/packaging/__about__.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/packaging/__init__.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/packaging/__init__.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/packaging/_compat.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/packaging/_compat.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/packaging/_structures.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/packaging/_structures.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/packaging/markers.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/packaging/markers.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/packaging/requirements.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/packaging/requirements.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/packaging/specifiers.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/packaging/specifiers.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/packaging/utils.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/packaging/utils.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/packaging/version.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/packaging/version.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/pep517/__init__.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/pep517/__init__.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/pep517/_in_process.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/pep517/_in_process.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/pep517/build.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/pep517/build.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/pep517/check.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/pep517/check.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/pep517/colorlog.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/pep517/colorlog.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/pep517/compat.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/pep517/compat.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/pep517/envbuild.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/pep517/envbuild.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/pep517/wrappers.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/pep517/wrappers.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/pkg_resources/__init__.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/pkg_resources/__init__.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/pkg_resources/py31compat.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/pkg_resources/py31compat.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/progress/__init__.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/progress/__init__.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/progress/bar.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/progress/bar.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/progress/counter.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/progress/counter.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/progress/spinner.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/progress/spinner.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/pyparsing.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/pyparsing.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/pytoml/__init__.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/pytoml/__init__.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/pytoml/core.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/pytoml/core.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/pytoml/parser.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/pytoml/parser.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/pytoml/test.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/pytoml/test.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/pytoml/utils.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/pytoml/utils.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/pytoml/writer.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/pytoml/writer.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/requests/__init__.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/requests/__init__.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/requests/__version__.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/requests/__version__.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/requests/_internal_utils.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/requests/_internal_utils.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/requests/adapters.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/requests/adapters.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/requests/api.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/requests/api.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/requests/auth.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/requests/auth.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/requests/certs.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/requests/certs.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/requests/compat.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/requests/compat.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/requests/cookies.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/requests/cookies.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/requests/exceptions.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/requests/exceptions.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/requests/help.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/requests/help.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/requests/hooks.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/requests/hooks.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/requests/models.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/requests/models.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/requests/packages.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/requests/packages.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/requests/sessions.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/requests/sessions.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/requests/status_codes.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/requests/status_codes.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/requests/structures.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/requests/structures.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/requests/utils.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/requests/utils.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/retrying.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/retrying.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/six.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/six.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/__init__.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/__init__.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/_collections.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/_collections.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/connection.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/connection.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/connectionpool.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/connectionpool.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/contrib/__init__.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/contrib/__init__.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/contrib/_appengine_environ.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/contrib/_appengine_environ.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/contrib/_securetransport/__init__.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/contrib/_securetransport/__init__.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/contrib/_securetransport/bindings.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/contrib/_securetransport/bindings.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/contrib/_securetransport/low_level.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/contrib/_securetransport/low_level.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/contrib/appengine.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/contrib/appengine.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/contrib/ntlmpool.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/contrib/ntlmpool.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/contrib/pyopenssl.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/contrib/pyopenssl.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/contrib/securetransport.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/contrib/securetransport.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/contrib/socks.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/contrib/socks.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/exceptions.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/exceptions.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/fields.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/fields.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/filepost.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/filepost.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/packages/__init__.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/packages/__init__.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/packages/backports/__init__.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/packages/backports/__init__.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/packages/backports/makefile.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/packages/backports/makefile.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/packages/six.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/packages/six.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/packages/ssl_match_hostname/__init__.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/packages/ssl_match_hostname/__init__.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/packages/ssl_match_hostname/_implementation.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/packages/ssl_match_hostname/_implementation.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/poolmanager.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/poolmanager.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/request.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/request.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/response.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/response.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/util/__init__.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/util/__init__.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/util/connection.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/util/connection.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/util/queue.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/util/queue.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/util/request.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/util/request.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/util/response.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/util/response.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/util/retry.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/util/retry.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/util/ssl_.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/util/ssl_.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/util/timeout.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/util/timeout.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/util/url.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/util/url.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/util/wait.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/util/wait.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/webencodings/__init__.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/webencodings/__init__.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/webencodings/labels.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/webencodings/labels.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/webencodings/mklabels.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/webencodings/mklabels.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/webencodings/tests.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/webencodings/tests.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/webencodings/x_user_defined.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/webencodings/x_user_defined.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pkg_resources/__init__.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pkg_resources/__init__.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pkg_resources/_vendor/__init__.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pkg_resources/_vendor/__init__.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pkg_resources/_vendor/appdirs.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pkg_resources/_vendor/appdirs.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pkg_resources/_vendor/packaging/__about__.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pkg_resources/_vendor/packaging/__about__.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pkg_resources/_vendor/packaging/__init__.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pkg_resources/_vendor/packaging/__init__.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pkg_resources/_vendor/packaging/_compat.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pkg_resources/_vendor/packaging/_compat.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pkg_resources/_vendor/packaging/_structures.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pkg_resources/_vendor/packaging/_structures.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pkg_resources/_vendor/packaging/markers.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pkg_resources/_vendor/packaging/markers.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pkg_resources/_vendor/packaging/requirements.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pkg_resources/_vendor/packaging/requirements.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pkg_resources/_vendor/packaging/specifiers.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pkg_resources/_vendor/packaging/specifiers.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pkg_resources/_vendor/packaging/utils.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pkg_resources/_vendor/packaging/utils.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pkg_resources/_vendor/packaging/version.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pkg_resources/_vendor/packaging/version.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pkg_resources/_vendor/pyparsing.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pkg_resources/_vendor/pyparsing.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pkg_resources/_vendor/six.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pkg_resources/_vendor/six.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pkg_resources/extern/__init__.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pkg_resources/extern/__init__.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pkg_resources/py31compat.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/pkg_resources/py31compat.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools-41.0.1.dist-info/INSTALLER
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools-41.0.1.dist-info/LICENSE
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools-41.0.1.dist-info/METADATA
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools-41.0.1.dist-info/RECORD
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools-41.0.1.dist-info/WHEEL
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools-41.0.1.dist-info/dependency_links.txt
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools-41.0.1.dist-info/entry_points.txt
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools-41.0.1.dist-info/top_level.txt
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools-41.0.1.dist-info/zip-safe
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/__init__.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/__init__.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/_deprecation_warning.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/_deprecation_warning.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/_vendor/__init__.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/_vendor/__init__.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/_vendor/packaging/__about__.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/_vendor/packaging/__about__.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/_vendor/packaging/__init__.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/_vendor/packaging/__init__.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/_vendor/packaging/_compat.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/_vendor/packaging/_compat.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/_vendor/packaging/_structures.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/_vendor/packaging/_structures.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/_vendor/packaging/markers.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/_vendor/packaging/markers.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/_vendor/packaging/requirements.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/_vendor/packaging/requirements.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/_vendor/packaging/specifiers.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/_vendor/packaging/specifiers.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/_vendor/packaging/utils.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/_vendor/packaging/utils.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/_vendor/packaging/version.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/_vendor/packaging/version.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/_vendor/pyparsing.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/_vendor/pyparsing.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/_vendor/six.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/_vendor/six.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/archive_util.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/archive_util.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/build_meta.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/build_meta.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/cli-32.exe
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/cli-64.exe
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/cli.exe
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/__init__.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/__init__.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/alias.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/alias.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/bdist_egg.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/bdist_egg.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/bdist_rpm.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/bdist_rpm.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/bdist_wininst.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/bdist_wininst.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/build_clib.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/build_clib.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/build_ext.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/build_ext.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/build_py.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/build_py.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/develop.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/develop.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/dist_info.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/dist_info.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/easy_install.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/easy_install.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/egg_info.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/egg_info.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/install.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/install.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/install_egg_info.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/install_egg_info.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/install_lib.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/install_lib.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/install_scripts.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/install_scripts.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/launcher manifest.xml
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/py36compat.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/py36compat.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/register.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/register.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/rotate.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/rotate.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/saveopts.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/saveopts.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/sdist.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/sdist.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/setopt.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/setopt.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/test.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/test.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/upload.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/upload.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/upload_docs.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/upload_docs.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/config.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/config.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/dep_util.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/dep_util.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/depends.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/depends.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/dist.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/dist.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/extension.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/extension.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/extern/__init__.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/extern/__init__.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/glibc.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/glibc.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/glob.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/glob.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/gui-32.exe
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/gui-64.exe
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/gui.exe
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/launch.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/launch.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/lib2to3_ex.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/lib2to3_ex.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/monkey.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/monkey.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/msvc.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/msvc.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/namespaces.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/namespaces.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/package_index.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/package_index.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/pep425tags.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/pep425tags.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/py27compat.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/py27compat.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/py31compat.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/py31compat.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/py33compat.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/py33compat.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/sandbox.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/sandbox.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/script (dev).tmpl
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/script.tmpl
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/site-patch.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/site-patch.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/ssl_support.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/ssl_support.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/unicode_utils.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/unicode_utils.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/version.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/version.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/wheel.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/wheel.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/windows_support.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/windows_support.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/wheel-0.33.1.dist-info/INSTALLER
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/wheel-0.33.1.dist-info/LICENSE.txt
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/wheel-0.33.1.dist-info/METADATA
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/wheel-0.33.1.dist-info/RECORD
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/wheel-0.33.1.dist-info/WHEEL
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/wheel-0.33.1.dist-info/entry_points.txt
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/wheel-0.33.1.dist-info/top_level.txt
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/wheel/__init__.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/wheel/__init__.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/wheel/__main__.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/wheel/__main__.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/wheel/bdist_wheel.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/wheel/bdist_wheel.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/wheel/cli/__init__.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/wheel/cli/__init__.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/wheel/cli/convert.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/wheel/cli/convert.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/wheel/cli/pack.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/wheel/cli/pack.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/wheel/cli/unpack.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/wheel/cli/unpack.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/wheel/metadata.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/wheel/metadata.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/wheel/pep425tags.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/wheel/pep425tags.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/wheel/pkginfo.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/wheel/pkginfo.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/wheel/util.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/wheel/util.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/wheel/wheelfile.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site-packages/wheel/wheelfile.pyc
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/site.pyc
 create mode 120000 tests/python/assert_test01/venv/lib/python2.7/sre.py
 create mode 120000 tests/python/assert_test01/venv/lib/python2.7/sre_compile.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/sre_compile.pyc
 create mode 120000 tests/python/assert_test01/venv/lib/python2.7/sre_constants.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/sre_constants.pyc
 create mode 120000 tests/python/assert_test01/venv/lib/python2.7/sre_parse.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/sre_parse.pyc
 create mode 120000 tests/python/assert_test01/venv/lib/python2.7/stat.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/stat.pyc
 create mode 120000 tests/python/assert_test01/venv/lib/python2.7/types.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/types.pyc
 create mode 120000 tests/python/assert_test01/venv/lib/python2.7/warnings.py
 create mode 100644 tests/python/assert_test01/venv/lib/python2.7/warnings.pyc
 create mode 100644 tests/serveur_compilation/server_rest/target/classes/app.class
 create mode 100644 tests/serveur_compilation/serveur_compilation/__pycache__/sample.cpython-37.pyc

diff --git a/tests/python/assert_test01/.idea/assert_test01.iml b/tests/python/assert_test01/.idea/assert_test01.iml
new file mode 100644
index 0000000..85c7612
--- /dev/null
+++ b/tests/python/assert_test01/.idea/assert_test01.iml
@@ -0,0 +1,13 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<module type="PYTHON_MODULE" version="4">
+  <component name="NewModuleRootManager">
+    <content url="file://$MODULE_DIR$">
+      <excludeFolder url="file://$MODULE_DIR$/venv" />
+    </content>
+    <orderEntry type="inheritedJdk" />
+    <orderEntry type="sourceFolder" forTests="false" />
+  </component>
+  <component name="TestRunnerService">
+    <option name="PROJECT_TEST_RUNNER" value="Unittests" />
+  </component>
+</module>
\ No newline at end of file
diff --git a/tests/python/assert_test01/.idea/misc.xml b/tests/python/assert_test01/.idea/misc.xml
new file mode 100644
index 0000000..fde52a2
--- /dev/null
+++ b/tests/python/assert_test01/.idea/misc.xml
@@ -0,0 +1,7 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<project version="4">
+  <component name="JavaScriptSettings">
+    <option name="languageLevel" value="ES6" />
+  </component>
+  <component name="ProjectRootManager" version="2" project-jdk-name="Python 2.7 (assert_test01)" project-jdk-type="Python SDK" />
+</project>
\ No newline at end of file
diff --git a/tests/python/assert_test01/.idea/modules.xml b/tests/python/assert_test01/.idea/modules.xml
new file mode 100644
index 0000000..79650b8
--- /dev/null
+++ b/tests/python/assert_test01/.idea/modules.xml
@@ -0,0 +1,8 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<project version="4">
+  <component name="ProjectModuleManager">
+    <modules>
+      <module fileurl="file://$PROJECT_DIR$/.idea/assert_test01.iml" filepath="$PROJECT_DIR$/.idea/assert_test01.iml" />
+    </modules>
+  </component>
+</project>
\ No newline at end of file
diff --git a/tests/python/assert_test01/.idea/vcs.xml b/tests/python/assert_test01/.idea/vcs.xml
new file mode 100644
index 0000000..c2365ab
--- /dev/null
+++ b/tests/python/assert_test01/.idea/vcs.xml
@@ -0,0 +1,6 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<project version="4">
+  <component name="VcsDirectoryMappings">
+    <mapping directory="$PROJECT_DIR$/../../.." vcs="Git" />
+  </component>
+</project>
\ No newline at end of file
diff --git a/tests/python/assert_test01/.idea/workspace.xml b/tests/python/assert_test01/.idea/workspace.xml
new file mode 100644
index 0000000..340adcf
--- /dev/null
+++ b/tests/python/assert_test01/.idea/workspace.xml
@@ -0,0 +1,213 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<project version="4">
+  <component name="ChangeListManager">
+    <list default="true" id="9effdb46-08d0-4cbd-b283-1a3f84f5311a" name="Default Changelist" comment="">
+      <change afterPath="$PROJECT_DIR$/.idea/assert_test01.iml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/.idea/misc.xml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/.idea/modules.xml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/.idea/vcs.xml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/main.py" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/test.py" afterDir="false" />
+      <change beforePath="$PROJECT_DIR$/../../serveur_compilation/front-end-compilation/src/app/app.component.html" beforeDir="false" afterPath="$PROJECT_DIR$/../../serveur_compilation/front-end-compilation/src/app/app.component.html" afterDir="false" />
+    </list>
+    <option name="EXCLUDED_CONVERTED_TO_IGNORED" value="true" />
+    <option name="SHOW_DIALOG" value="false" />
+    <option name="HIGHLIGHT_CONFLICTS" value="true" />
+    <option name="HIGHLIGHT_NON_ACTIVE_CHANGELIST" value="false" />
+    <option name="LAST_RESOLUTION" value="IGNORE" />
+  </component>
+  <component name="FileEditorManager">
+    <leaf SIDE_TABS_SIZE_LIMIT_KEY="300">
+      <file pinned="false" current-in-tab="false">
+        <entry file="file://$PROJECT_DIR$/main.py">
+          <provider selected="true" editor-type-id="text-editor">
+            <state>
+              <caret selection-end-column="16" />
+            </state>
+          </provider>
+        </entry>
+      </file>
+      <file pinned="false" current-in-tab="true">
+        <entry file="file://$PROJECT_DIR$/test.py">
+          <provider selected="true" editor-type-id="text-editor">
+            <state>
+              <caret selection-end-line="5" selection-end-column="45" />
+              <folding>
+                <element signature="e#0#32#0" expanded="true" />
+              </folding>
+            </state>
+          </provider>
+        </entry>
+      </file>
+    </leaf>
+  </component>
+  <component name="FileTemplateManagerImpl">
+    <option name="RECENT_TEMPLATES">
+      <list>
+        <option value="Python Script" />
+      </list>
+    </option>
+  </component>
+  <component name="Git.Settings">
+    <option name="RECENT_GIT_ROOT_PATH" value="$PROJECT_DIR$/../../.." />
+  </component>
+  <component name="IdeDocumentHistory">
+    <option name="CHANGED_PATHS">
+      <list>
+        <option value="$PROJECT_DIR$/main.py" />
+        <option value="$PROJECT_DIR$/test.py" />
+      </list>
+    </option>
+  </component>
+  <component name="ProjectFrameBounds">
+    <option name="x" value="355" />
+    <option name="y" value="87" />
+    <option name="width" value="1400" />
+    <option name="height" value="1000" />
+  </component>
+  <component name="ProjectLevelVcsManager" settingsEditedManually="true" />
+  <component name="ProjectView">
+    <navigator proportions="" version="1">
+      <foldersAlwaysOnTop value="true" />
+    </navigator>
+    <panes>
+      <pane id="Scope" />
+      <pane id="ProjectPane">
+        <subPane>
+          <expand>
+            <path>
+              <item name="assert_test01" type="b2602c69:ProjectViewProjectNode" />
+              <item name="assert_test01" type="462c0819:PsiDirectoryNode" />
+            </path>
+          </expand>
+          <select />
+        </subPane>
+      </pane>
+    </panes>
+  </component>
+  <component name="PropertiesComponent">
+    <property name="ASKED_SHARE_PROJECT_CONFIGURATION_FILES" value="true" />
+    <property name="SHARE_PROJECT_CONFIGURATION_FILES" value="true" />
+    <property name="WebServerToolWindowFactoryState" value="false" />
+    <property name="node.js.detected.package.eslint" value="true" />
+    <property name="node.js.path.for.package.eslint" value="project" />
+    <property name="node.js.selected.package.eslint" value="(autodetect)" />
+  </component>
+  <component name="RunDashboard">
+    <option name="ruleStates">
+      <list>
+        <RuleState>
+          <option name="name" value="ConfigurationTypeDashboardGroupingRule" />
+        </RuleState>
+        <RuleState>
+          <option name="name" value="StatusDashboardGroupingRule" />
+        </RuleState>
+      </list>
+    </option>
+  </component>
+  <component name="RunManager">
+    <configuration name="test" type="PythonConfigurationType" factoryName="Python" temporary="true">
+      <module name="assert_test01" />
+      <option name="INTERPRETER_OPTIONS" value="" />
+      <option name="PARENT_ENVS" value="true" />
+      <envs>
+        <env name="PYTHONUNBUFFERED" value="1" />
+      </envs>
+      <option name="SDK_HOME" value="" />
+      <option name="WORKING_DIRECTORY" value="$PROJECT_DIR$" />
+      <option name="IS_MODULE_SDK" value="true" />
+      <option name="ADD_CONTENT_ROOTS" value="true" />
+      <option name="ADD_SOURCE_ROOTS" value="true" />
+      <EXTENSION ID="PythonCoverageRunConfigurationExtension" runner="coverage.py" />
+      <option name="SCRIPT_NAME" value="$PROJECT_DIR$/test.py" />
+      <option name="PARAMETERS" value="" />
+      <option name="SHOW_COMMAND_LINE" value="false" />
+      <option name="EMULATE_TERMINAL" value="false" />
+      <option name="MODULE_MODE" value="false" />
+      <option name="REDIRECT_INPUT" value="false" />
+      <option name="INPUT_FILE" value="" />
+      <method v="2" />
+    </configuration>
+    <recent_temporary>
+      <list>
+        <item itemvalue="Python.test" />
+      </list>
+    </recent_temporary>
+  </component>
+  <component name="SvnConfiguration">
+    <configuration />
+  </component>
+  <component name="TaskManager">
+    <task active="true" id="Default" summary="Default task">
+      <changelist id="9effdb46-08d0-4cbd-b283-1a3f84f5311a" name="Default Changelist" comment="" />
+      <created>1556636994757</created>
+      <option name="number" value="Default" />
+      <option name="presentableId" value="Default" />
+      <updated>1556636994757</updated>
+      <workItem from="1556636997623" duration="502000" />
+      <workItem from="1556696058143" duration="2446000" />
+    </task>
+    <servers />
+  </component>
+  <component name="TimeTrackingManager">
+    <option name="totallyTimeSpent" value="2948000" />
+  </component>
+  <component name="ToolWindowManager">
+    <frame x="355" y="87" width="1400" height="1000" extended-state="0" />
+    <layout>
+      <window_info content_ui="combo" id="Project" order="0" visible="true" weight="0.2533137" />
+      <window_info id="Structure" order="1" side_tool="true" weight="0.25" />
+      <window_info id="Favorites" order="2" side_tool="true" />
+      <window_info anchor="bottom" id="Message" order="0" />
+      <window_info anchor="bottom" id="Find" order="1" />
+      <window_info anchor="bottom" id="Run" order="2" weight="0.32929516" />
+      <window_info anchor="bottom" id="Debug" order="3" weight="0.4" />
+      <window_info anchor="bottom" id="Cvs" order="4" weight="0.25" />
+      <window_info anchor="bottom" id="Inspection" order="5" weight="0.4" />
+      <window_info anchor="bottom" id="TODO" order="6" />
+      <window_info anchor="bottom" id="Docker" order="7" show_stripe_button="false" />
+      <window_info anchor="bottom" id="Version Control" order="8" />
+      <window_info anchor="bottom" id="Database Changes" order="9" />
+      <window_info anchor="bottom" id="Event Log" order="10" side_tool="true" />
+      <window_info active="true" anchor="bottom" id="Terminal" order="11" visible="true" weight="0.32929516" />
+      <window_info anchor="bottom" id="Python Console" order="12" weight="0.32929516" />
+      <window_info anchor="right" id="Commander" internal_type="SLIDING" order="0" type="SLIDING" weight="0.4" />
+      <window_info anchor="right" id="Ant Build" order="1" weight="0.25" />
+      <window_info anchor="right" content_ui="combo" id="Hierarchy" order="2" weight="0.25" />
+      <window_info anchor="right" id="SciView" order="3" />
+      <window_info anchor="right" id="Database" order="4" />
+    </layout>
+  </component>
+  <component name="TypeScriptGeneratedFilesManager">
+    <option name="version" value="1" />
+  </component>
+  <component name="com.intellij.coverage.CoverageDataManagerImpl">
+    <SUITE FILE_PATH="coverage/assert_test01$test.coverage" NAME="test Coverage Results" MODIFIED="1556698154387" SOURCE_PROVIDER="com.intellij.coverage.DefaultCoverageFileProvider" RUNNER="coverage.py" COVERAGE_BY_TEST_ENABLED="true" COVERAGE_TRACING_ENABLED="false" WORKING_DIRECTORY="$PROJECT_DIR$" />
+  </component>
+  <component name="editorHistoryManager">
+    <entry file="file://$PROJECT_DIR$/venv/lib/python2.7/site-packages/assertpy/assertpy.py">
+      <provider selected="true" editor-type-id="text-editor">
+        <state relative-caret-position="194">
+          <caret line="1102" selection-start-line="1102" selection-end-line="1102" />
+        </state>
+      </provider>
+    </entry>
+    <entry file="file://$PROJECT_DIR$/main.py">
+      <provider selected="true" editor-type-id="text-editor">
+        <state>
+          <caret selection-end-column="16" />
+        </state>
+      </provider>
+    </entry>
+    <entry file="file://$PROJECT_DIR$/test.py">
+      <provider selected="true" editor-type-id="text-editor">
+        <state>
+          <caret selection-end-line="5" selection-end-column="45" />
+          <folding>
+            <element signature="e#0#32#0" expanded="true" />
+          </folding>
+        </state>
+      </provider>
+    </entry>
+  </component>
+</project>
\ No newline at end of file
diff --git a/tests/python/assert_test01/main.py b/tests/python/assert_test01/main.py
new file mode 100644
index 0000000..fede9b5
--- /dev/null
+++ b/tests/python/assert_test01/main.py
@@ -0,0 +1,3 @@
+def easyline(n):
+    return [i * 2 for i in n]
+
diff --git a/tests/python/assert_test01/main.pyc b/tests/python/assert_test01/main.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..b66f0ef4656174bc90e557a487018bd91a62678a
GIT binary patch
literal 354
zcmZSn%*&+}axx~F0SXuy7#JKF7#NCq85kH+7#La@7@`;$QWzP6HJBI}7?MHqAO;Hq
z1A{Y2oiqajLplRP4FiKqtN=qTBSQ@%NV!NH6GI_8RF_{SNQ(x@3a}|9AXD<dWF|xu
zBvtIhz`&p%TAW%`te;ktnwYKcl3JWyl3$>olAo2Yn~_?OnW$fqT3k}BUr<?+k)NlZ
zSX`W1R1yyoGceT8P0Y;GE2u2tU|?WKO)Rd=$;?XySyT+NoPp6#1H=geaS(QbS=6-H
RCO1E&G$+*#WLGiBR{$)eOLqVO

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/test.py b/tests/python/assert_test01/test.py
new file mode 100644
index 0000000..fb4a471
--- /dev/null
+++ b/tests/python/assert_test01/test.py
@@ -0,0 +1,6 @@
+from assertpy import assert_that
+import main as m
+
+assert_that(m.easyline([1,2])).is_equal_to([2,4])
+assert_that(m.easyline([45,53,12])).is_equal_to([90,106,24])
+assert_that(m.easyline([3])).is_equal_to([6])
\ No newline at end of file
diff --git a/tests/python/assert_test01/test.pyc b/tests/python/assert_test01/test.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..b0a63a539bf2b4a7c86f753b811caab639d5fd9a
GIT binary patch
literal 628
zcmZSn%**vJ^+ZfE0~9bbFfceUFfbHXGB7ZtFfgPrGUPBY<T5fuF)}cM_)H8rObofq
z3{lJsj48|vEes4%EDWhE45`cvDJ%@lj0`EP49!doj8Gvqun;@45C>R@6IqB0EW`~K
zO5tG$*5GAeV95Oc|NnmtMg|6k5*7vqhLF_a5(tljfq@}4vA8lPGcPrniGhIugh38>
z202^=q=A7Ui;<y*fuV*GVkQGaFj%jj21soX$g?FNI}(eFQ;SOCQwvKIbBe)oC2R}~
z42j7lrHMHuV2dgWQj<$kQ#3$&z(lbV0|SG8XmM&$v3^=nYGSs&OKNd;Nq&KTN`6+p
zZboWBW}<#cYH>-ienDkPMt+_?)E1DKfgxB*ub{Go9puo|;*!j~bda6JAeS*PW`cw>
zGk6&oGC>Z^jMzMnAybfnfx**<QKB2<h)iJ+Z^xUxRv`EJX|RIK5ocgvD9y_(0okDk
zC*qS6i&G)K1qESlVrE_tC_sZidcdAR5Y+M($Wb=A`6;D2sdgZ{ig_3q7zCIEm^oR5
H89@*LZ6JmX

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/.Python b/tests/python/assert_test01/venv/.Python
new file mode 120000
index 0000000..cc24a1e
--- /dev/null
+++ b/tests/python/assert_test01/venv/.Python
@@ -0,0 +1 @@
+/System/Library/Frameworks/Python.framework/Versions/2.7/Python
\ No newline at end of file
diff --git a/tests/python/assert_test01/venv/bin/activate b/tests/python/assert_test01/venv/bin/activate
new file mode 100644
index 0000000..b65309e
--- /dev/null
+++ b/tests/python/assert_test01/venv/bin/activate
@@ -0,0 +1,78 @@
+# This file must be used with "source bin/activate" *from bash*
+# you cannot run it directly
+
+deactivate () {
+    unset -f pydoc >/dev/null 2>&1
+
+    # reset old environment variables
+    # ! [ -z ${VAR+_} ] returns true if VAR is declared at all
+    if ! [ -z "${_OLD_VIRTUAL_PATH+_}" ] ; then
+        PATH="$_OLD_VIRTUAL_PATH"
+        export PATH
+        unset _OLD_VIRTUAL_PATH
+    fi
+    if ! [ -z "${_OLD_VIRTUAL_PYTHONHOME+_}" ] ; then
+        PYTHONHOME="$_OLD_VIRTUAL_PYTHONHOME"
+        export PYTHONHOME
+        unset _OLD_VIRTUAL_PYTHONHOME
+    fi
+
+    # This should detect bash and zsh, which have a hash command that must
+    # be called to get it to forget past commands.  Without forgetting
+    # past commands the $PATH changes we made may not be respected
+    if [ -n "${BASH-}" ] || [ -n "${ZSH_VERSION-}" ] ; then
+        hash -r 2>/dev/null
+    fi
+
+    if ! [ -z "${_OLD_VIRTUAL_PS1+_}" ] ; then
+        PS1="$_OLD_VIRTUAL_PS1"
+        export PS1
+        unset _OLD_VIRTUAL_PS1
+    fi
+
+    unset VIRTUAL_ENV
+    if [ ! "${1-}" = "nondestructive" ] ; then
+    # Self destruct!
+        unset -f deactivate
+    fi
+}
+
+# unset irrelevant variables
+deactivate nondestructive
+
+VIRTUAL_ENV="/Users/freak/Desktop/dojo-hepia/tests/python/assert_test01/venv"
+export VIRTUAL_ENV
+
+_OLD_VIRTUAL_PATH="$PATH"
+PATH="$VIRTUAL_ENV/bin:$PATH"
+export PATH
+
+# unset PYTHONHOME if set
+if ! [ -z "${PYTHONHOME+_}" ] ; then
+    _OLD_VIRTUAL_PYTHONHOME="$PYTHONHOME"
+    unset PYTHONHOME
+fi
+
+if [ -z "${VIRTUAL_ENV_DISABLE_PROMPT-}" ] ; then
+    _OLD_VIRTUAL_PS1="${PS1-}"
+    if [ "x" != x ] ; then
+        PS1="${PS1-}"
+    else
+        PS1="(`basename \"$VIRTUAL_ENV\"`) ${PS1-}"
+    fi
+    export PS1
+fi
+
+# Make sure to unalias pydoc if it's already there
+alias pydoc 2>/dev/null >/dev/null && unalias pydoc || true
+
+pydoc () {
+    python -m pydoc "$@"
+}
+
+# This should detect bash and zsh, which have a hash command that must
+# be called to get it to forget past commands.  Without forgetting
+# past commands the $PATH changes we made may not be respected
+if [ -n "${BASH-}" ] || [ -n "${ZSH_VERSION-}" ] ; then
+    hash -r 2>/dev/null
+fi
diff --git a/tests/python/assert_test01/venv/bin/activate.csh b/tests/python/assert_test01/venv/bin/activate.csh
new file mode 100644
index 0000000..d55f88d
--- /dev/null
+++ b/tests/python/assert_test01/venv/bin/activate.csh
@@ -0,0 +1,42 @@
+# This file must be used with "source bin/activate.csh" *from csh*.
+# You cannot run it directly.
+# Created by Davide Di Blasi <davidedb@gmail.com>.
+
+set newline='\
+'
+
+alias deactivate 'test $?_OLD_VIRTUAL_PATH != 0 && setenv PATH "$_OLD_VIRTUAL_PATH:q" && unset _OLD_VIRTUAL_PATH; rehash; test $?_OLD_VIRTUAL_PROMPT != 0 && set prompt="$_OLD_VIRTUAL_PROMPT:q" && unset _OLD_VIRTUAL_PROMPT; unsetenv VIRTUAL_ENV; test "\!:*" != "nondestructive" && unalias deactivate && unalias pydoc'
+
+# Unset irrelevant variables.
+deactivate nondestructive
+
+setenv VIRTUAL_ENV "/Users/freak/Desktop/dojo-hepia/tests/python/assert_test01/venv"
+
+set _OLD_VIRTUAL_PATH="$PATH:q"
+setenv PATH "$VIRTUAL_ENV:q/bin:$PATH:q"
+
+
+
+if ("" != "") then
+    set env_name = ""
+else
+    set env_name = "$VIRTUAL_ENV:t:q"
+endif
+
+# Could be in a non-interactive environment,
+# in which case, $prompt is undefined and we wouldn't
+# care about the prompt anyway.
+if ( $?prompt ) then
+    set _OLD_VIRTUAL_PROMPT="$prompt:q"
+if ( "$prompt:q" =~ *"$newline:q"* ) then
+    :
+else
+    set prompt = "[$env_name:q] $prompt:q"
+endif
+endif
+
+unset env_name
+
+alias pydoc python -m pydoc
+
+rehash
diff --git a/tests/python/assert_test01/venv/bin/activate.fish b/tests/python/assert_test01/venv/bin/activate.fish
new file mode 100644
index 0000000..80ffeec
--- /dev/null
+++ b/tests/python/assert_test01/venv/bin/activate.fish
@@ -0,0 +1,101 @@
+# This file must be used using `source bin/activate.fish` *within a running fish ( http://fishshell.com ) session*.
+# Do not run it directly.
+
+function _bashify_path -d "Converts a fish path to something bash can recognize"
+    set fishy_path $argv
+    set bashy_path $fishy_path[1]
+    for path_part in $fishy_path[2..-1]
+        set bashy_path "$bashy_path:$path_part"
+    end
+    echo $bashy_path
+end
+
+function _fishify_path -d "Converts a bash path to something fish can recognize"
+    echo $argv | tr ':' '\n'
+end
+
+function deactivate -d 'Exit virtualenv mode and return to the normal environment.'
+    # reset old environment variables
+    if test -n "$_OLD_VIRTUAL_PATH"
+        # https://github.com/fish-shell/fish-shell/issues/436 altered PATH handling
+        if test (echo $FISH_VERSION | tr "." "\n")[1] -lt 3
+            set -gx PATH (_fishify_path $_OLD_VIRTUAL_PATH)
+        else
+            set -gx PATH $_OLD_VIRTUAL_PATH
+        end
+        set -e _OLD_VIRTUAL_PATH
+    end
+
+    if test -n "$_OLD_VIRTUAL_PYTHONHOME"
+        set -gx PYTHONHOME $_OLD_VIRTUAL_PYTHONHOME
+        set -e _OLD_VIRTUAL_PYTHONHOME
+    end
+
+    if test -n "$_OLD_FISH_PROMPT_OVERRIDE"
+        # Set an empty local `$fish_function_path` to allow the removal of `fish_prompt` using `functions -e`.
+        set -l fish_function_path
+
+        # Erase virtualenv's `fish_prompt` and restore the original.
+        functions -e fish_prompt
+        functions -c _old_fish_prompt fish_prompt
+        functions -e _old_fish_prompt
+        set -e _OLD_FISH_PROMPT_OVERRIDE
+    end
+
+    set -e VIRTUAL_ENV
+
+    if test "$argv[1]" != 'nondestructive'
+        # Self-destruct!
+        functions -e pydoc
+        functions -e deactivate
+        functions -e _bashify_path
+        functions -e _fishify_path
+    end
+end
+
+# Unset irrelevant variables.
+deactivate nondestructive
+
+set -gx VIRTUAL_ENV "/Users/freak/Desktop/dojo-hepia/tests/python/assert_test01/venv"
+
+# https://github.com/fish-shell/fish-shell/issues/436 altered PATH handling
+if test (echo $FISH_VERSION | tr "." "\n")[1] -lt 3
+   set -gx _OLD_VIRTUAL_PATH (_bashify_path $PATH)
+else
+    set -gx _OLD_VIRTUAL_PATH $PATH
+end
+set -gx PATH "$VIRTUAL_ENV/bin" $PATH
+
+# Unset `$PYTHONHOME` if set.
+if set -q PYTHONHOME
+    set -gx _OLD_VIRTUAL_PYTHONHOME $PYTHONHOME
+    set -e PYTHONHOME
+end
+
+function pydoc
+    python -m pydoc $argv
+end
+
+if test -z "$VIRTUAL_ENV_DISABLE_PROMPT"
+    # Copy the current `fish_prompt` function as `_old_fish_prompt`.
+    functions -c fish_prompt _old_fish_prompt
+
+    function fish_prompt
+        # Save the current $status, for fish_prompts that display it.
+        set -l old_status $status
+
+        # Prompt override provided?
+        # If not, just prepend the environment name.
+        if test -n ""
+            printf '%s%s' "" (set_color normal)
+        else
+            printf '%s(%s) ' (set_color normal) (basename "$VIRTUAL_ENV")
+        end
+
+        # Restore the original $status
+        echo "exit $old_status" | source
+        _old_fish_prompt
+    end
+
+    set -gx _OLD_FISH_PROMPT_OVERRIDE "$VIRTUAL_ENV"
+end
diff --git a/tests/python/assert_test01/venv/bin/activate.ps1 b/tests/python/assert_test01/venv/bin/activate.ps1
new file mode 100644
index 0000000..6d8ae2a
--- /dev/null
+++ b/tests/python/assert_test01/venv/bin/activate.ps1
@@ -0,0 +1,60 @@
+# This file must be dot sourced from PoSh; you cannot run it directly. Do this: . ./activate.ps1
+
+$script:THIS_PATH = $myinvocation.mycommand.path
+$script:BASE_DIR = split-path (resolve-path "$THIS_PATH/..") -Parent
+
+function global:deactivate([switch] $NonDestructive)
+{
+    if (test-path variable:_OLD_VIRTUAL_PATH)
+    {
+        $env:PATH = $variable:_OLD_VIRTUAL_PATH
+        remove-variable "_OLD_VIRTUAL_PATH" -scope global
+    }
+
+    if (test-path function:_old_virtual_prompt)
+    {
+        $function:prompt = $function:_old_virtual_prompt
+        remove-item function:\_old_virtual_prompt
+    }
+
+    if ($env:VIRTUAL_ENV)
+    {
+        $old_env = split-path $env:VIRTUAL_ENV -leaf
+        remove-item env:VIRTUAL_ENV -erroraction silentlycontinue
+    }
+
+    if (!$NonDestructive)
+    {
+        # Self destruct!
+        remove-item function:deactivate
+        remove-item function:pydoc
+    }
+}
+
+function global:pydoc
+{
+    python -m pydoc $args
+}
+
+# unset irrelevant variables
+deactivate -nondestructive
+
+$VIRTUAL_ENV = $BASE_DIR
+$env:VIRTUAL_ENV = $VIRTUAL_ENV
+
+$global:_OLD_VIRTUAL_PATH = $env:PATH
+$env:PATH = "$env:VIRTUAL_ENV/bin:" + $env:PATH
+if (!$env:VIRTUAL_ENV_DISABLE_PROMPT)
+{
+    function global:_old_virtual_prompt
+    {
+        ""
+    }
+    $function:_old_virtual_prompt = $function:prompt
+    function global:prompt
+    {
+        # Add a prefix to the current prompt, but don't discard it.
+        write-host "($( split-path $env:VIRTUAL_ENV -leaf )) " -nonewline
+        & $function:_old_virtual_prompt
+    }
+}
diff --git a/tests/python/assert_test01/venv/bin/activate_this.py b/tests/python/assert_test01/venv/bin/activate_this.py
new file mode 100644
index 0000000..59b5d72
--- /dev/null
+++ b/tests/python/assert_test01/venv/bin/activate_this.py
@@ -0,0 +1,46 @@
+"""Activate virtualenv for current interpreter:
+
+Use exec(open(this_file).read(), {'__file__': this_file}).
+
+This can be used when you must use an existing Python interpreter, not the virtualenv bin/python.
+"""
+import os
+import site
+import sys
+
+try:
+    __file__
+except NameError:
+    raise AssertionError("You must use exec(open(this_file).read(), {'__file__': this_file}))")
+
+# prepend bin to PATH (this file is inside the bin directory)
+bin_dir = os.path.dirname(os.path.abspath(__file__))
+os.environ["PATH"] = os.pathsep.join([bin_dir] + os.environ.get("PATH", "").split(os.pathsep))
+
+base = os.path.dirname(bin_dir)
+
+# virtual env is right above bin directory
+os.environ["VIRTUAL_ENV"] = base
+
+# add the virtual environments site-package to the host python import mechanism
+IS_PYPY = hasattr(sys, "pypy_version_info")
+IS_JYTHON = sys.platform.startswith("java")
+if IS_JYTHON:
+    site_packages = os.path.join(base, "Lib", "site-packages")
+elif IS_PYPY:
+    site_packages = os.path.join(base, "site-packages")
+else:
+    IS_WIN = sys.platform == "win32"
+    if IS_WIN:
+        site_packages = os.path.join(base, "Lib", "site-packages")
+    else:
+        site_packages = os.path.join(base, "lib", "python{}".format(sys.version[:3]), "site-packages")
+
+prev = set(sys.path)
+site.addsitedir(site_packages)
+sys.real_prefix = sys.prefix
+sys.prefix = base
+
+# Move the added items to the front of the path, in place
+new = list(sys.path)
+sys.path[:] = [i for i in new if i not in prev] + [i for i in new if i in prev]
diff --git a/tests/python/assert_test01/venv/bin/easy_install b/tests/python/assert_test01/venv/bin/easy_install
new file mode 100755
index 0000000..9f784ce
--- /dev/null
+++ b/tests/python/assert_test01/venv/bin/easy_install
@@ -0,0 +1,10 @@
+#!/Users/freak/Desktop/dojo-hepia/tests/python/assert_test01/venv/bin/python
+# -*- coding: utf-8 -*-
+import re
+import sys
+
+from setuptools.command.easy_install import main
+
+if __name__ == '__main__':
+    sys.argv[0] = re.sub(r'(-script\.pyw?|\.exe)?$', '', sys.argv[0])
+    sys.exit(main())
diff --git a/tests/python/assert_test01/venv/bin/easy_install-2.7 b/tests/python/assert_test01/venv/bin/easy_install-2.7
new file mode 100755
index 0000000..9f784ce
--- /dev/null
+++ b/tests/python/assert_test01/venv/bin/easy_install-2.7
@@ -0,0 +1,10 @@
+#!/Users/freak/Desktop/dojo-hepia/tests/python/assert_test01/venv/bin/python
+# -*- coding: utf-8 -*-
+import re
+import sys
+
+from setuptools.command.easy_install import main
+
+if __name__ == '__main__':
+    sys.argv[0] = re.sub(r'(-script\.pyw?|\.exe)?$', '', sys.argv[0])
+    sys.exit(main())
diff --git a/tests/python/assert_test01/venv/bin/pip b/tests/python/assert_test01/venv/bin/pip
new file mode 100755
index 0000000..3c28ffe
--- /dev/null
+++ b/tests/python/assert_test01/venv/bin/pip
@@ -0,0 +1,10 @@
+#!/Users/freak/Desktop/dojo-hepia/tests/python/assert_test01/venv/bin/python
+# -*- coding: utf-8 -*-
+import re
+import sys
+
+from pip._internal import main
+
+if __name__ == '__main__':
+    sys.argv[0] = re.sub(r'(-script\.pyw?|\.exe)?$', '', sys.argv[0])
+    sys.exit(main())
diff --git a/tests/python/assert_test01/venv/bin/pip2 b/tests/python/assert_test01/venv/bin/pip2
new file mode 100755
index 0000000..3c28ffe
--- /dev/null
+++ b/tests/python/assert_test01/venv/bin/pip2
@@ -0,0 +1,10 @@
+#!/Users/freak/Desktop/dojo-hepia/tests/python/assert_test01/venv/bin/python
+# -*- coding: utf-8 -*-
+import re
+import sys
+
+from pip._internal import main
+
+if __name__ == '__main__':
+    sys.argv[0] = re.sub(r'(-script\.pyw?|\.exe)?$', '', sys.argv[0])
+    sys.exit(main())
diff --git a/tests/python/assert_test01/venv/bin/pip2.7 b/tests/python/assert_test01/venv/bin/pip2.7
new file mode 100755
index 0000000..3c28ffe
--- /dev/null
+++ b/tests/python/assert_test01/venv/bin/pip2.7
@@ -0,0 +1,10 @@
+#!/Users/freak/Desktop/dojo-hepia/tests/python/assert_test01/venv/bin/python
+# -*- coding: utf-8 -*-
+import re
+import sys
+
+from pip._internal import main
+
+if __name__ == '__main__':
+    sys.argv[0] = re.sub(r'(-script\.pyw?|\.exe)?$', '', sys.argv[0])
+    sys.exit(main())
diff --git a/tests/python/assert_test01/venv/bin/python b/tests/python/assert_test01/venv/bin/python
new file mode 100755
index 0000000000000000000000000000000000000000..ab5271048ecab0fc6b5d3ecb2620380dd3d53f46
GIT binary patch
literal 51744
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

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/bin/python-config b/tests/python/assert_test01/venv/bin/python-config
new file mode 100755
index 0000000..ee597c2
--- /dev/null
+++ b/tests/python/assert_test01/venv/bin/python-config
@@ -0,0 +1,78 @@
+#!/Users/freak/Desktop/dojo-hepia/tests/python/assert_test01/venv/bin/python
+
+import sys
+import getopt
+import sysconfig
+
+valid_opts = ['prefix', 'exec-prefix', 'includes', 'libs', 'cflags',
+              'ldflags', 'help']
+
+if sys.version_info >= (3, 2):
+    valid_opts.insert(-1, 'extension-suffix')
+    valid_opts.append('abiflags')
+if sys.version_info >= (3, 3):
+    valid_opts.append('configdir')
+
+
+def exit_with_usage(code=1):
+    sys.stderr.write("Usage: {0} [{1}]\n".format(
+        sys.argv[0], '|'.join('--'+opt for opt in valid_opts)))
+    sys.exit(code)
+
+try:
+    opts, args = getopt.getopt(sys.argv[1:], '', valid_opts)
+except getopt.error:
+    exit_with_usage()
+
+if not opts:
+    exit_with_usage()
+
+pyver = sysconfig.get_config_var('VERSION')
+getvar = sysconfig.get_config_var
+
+opt_flags = [flag for (flag, val) in opts]
+
+if '--help' in opt_flags:
+    exit_with_usage(code=0)
+
+for opt in opt_flags:
+    if opt == '--prefix':
+        print(sysconfig.get_config_var('prefix'))
+
+    elif opt == '--exec-prefix':
+        print(sysconfig.get_config_var('exec_prefix'))
+
+    elif opt in ('--includes', '--cflags'):
+        flags = ['-I' + sysconfig.get_path('include'),
+                 '-I' + sysconfig.get_path('platinclude')]
+        if opt == '--cflags':
+            flags.extend(getvar('CFLAGS').split())
+        print(' '.join(flags))
+
+    elif opt in ('--libs', '--ldflags'):
+        abiflags = getattr(sys, 'abiflags', '')
+        libs = ['-lpython' + pyver + abiflags]
+        libs += getvar('LIBS').split()
+        libs += getvar('SYSLIBS').split()
+        # add the prefix/lib/pythonX.Y/config dir, but only if there is no
+        # shared library in prefix/lib/.
+        if opt == '--ldflags':
+            if not getvar('Py_ENABLE_SHARED'):
+                libs.insert(0, '-L' + getvar('LIBPL'))
+            if not getvar('PYTHONFRAMEWORK'):
+                libs.extend(getvar('LINKFORSHARED').split())
+        print(' '.join(libs))
+
+    elif opt == '--extension-suffix':
+        ext_suffix = sysconfig.get_config_var('EXT_SUFFIX')
+        if ext_suffix is None:
+            ext_suffix = sysconfig.get_config_var('SO')
+        print(ext_suffix)
+
+    elif opt == '--abiflags':
+        if not getattr(sys, 'abiflags', None):
+            exit_with_usage()
+        print(sys.abiflags)
+
+    elif opt == '--configdir':
+        print(sysconfig.get_config_var('LIBPL'))
diff --git a/tests/python/assert_test01/venv/bin/python2 b/tests/python/assert_test01/venv/bin/python2
new file mode 120000
index 0000000..d8654aa
--- /dev/null
+++ b/tests/python/assert_test01/venv/bin/python2
@@ -0,0 +1 @@
+python
\ No newline at end of file
diff --git a/tests/python/assert_test01/venv/bin/python2.7 b/tests/python/assert_test01/venv/bin/python2.7
new file mode 120000
index 0000000..d8654aa
--- /dev/null
+++ b/tests/python/assert_test01/venv/bin/python2.7
@@ -0,0 +1 @@
+python
\ No newline at end of file
diff --git a/tests/python/assert_test01/venv/bin/wheel b/tests/python/assert_test01/venv/bin/wheel
new file mode 100755
index 0000000..c128bba
--- /dev/null
+++ b/tests/python/assert_test01/venv/bin/wheel
@@ -0,0 +1,10 @@
+#!/Users/freak/Desktop/dojo-hepia/tests/python/assert_test01/venv/bin/python
+# -*- coding: utf-8 -*-
+import re
+import sys
+
+from wheel.cli import main
+
+if __name__ == '__main__':
+    sys.argv[0] = re.sub(r'(-script\.pyw?|\.exe)?$', '', sys.argv[0])
+    sys.exit(main())
diff --git a/tests/python/assert_test01/venv/include/python2.7 b/tests/python/assert_test01/venv/include/python2.7
new file mode 120000
index 0000000..3fe034f
--- /dev/null
+++ b/tests/python/assert_test01/venv/include/python2.7
@@ -0,0 +1 @@
+/System/Library/Frameworks/Python.framework/Versions/2.7/include/python2.7
\ No newline at end of file
diff --git a/tests/python/assert_test01/venv/lib/python2.7/LICENSE.txt b/tests/python/assert_test01/venv/lib/python2.7/LICENSE.txt
new file mode 120000
index 0000000..1a3e118
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/LICENSE.txt
@@ -0,0 +1 @@
+/System/Library/Frameworks/Python.framework/Versions/2.7/lib/python2.7/LICENSE.txt
\ No newline at end of file
diff --git a/tests/python/assert_test01/venv/lib/python2.7/UserDict.py b/tests/python/assert_test01/venv/lib/python2.7/UserDict.py
new file mode 120000
index 0000000..b735f02
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/UserDict.py
@@ -0,0 +1 @@
+/System/Library/Frameworks/Python.framework/Versions/2.7/lib/python2.7/UserDict.py
\ No newline at end of file
diff --git a/tests/python/assert_test01/venv/lib/python2.7/UserDict.pyc b/tests/python/assert_test01/venv/lib/python2.7/UserDict.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..ef6e477370159a8e2a9c99c102675e4997581bef
GIT binary patch
literal 11385
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

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/_abcoll.py b/tests/python/assert_test01/venv/lib/python2.7/_abcoll.py
new file mode 120000
index 0000000..4a595bc
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/_abcoll.py
@@ -0,0 +1 @@
+/System/Library/Frameworks/Python.framework/Versions/2.7/lib/python2.7/_abcoll.py
\ No newline at end of file
diff --git a/tests/python/assert_test01/venv/lib/python2.7/_abcoll.pyc b/tests/python/assert_test01/venv/lib/python2.7/_abcoll.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..ac815f11cc734ac2253c066f813bd34dd6315a4c
GIT binary patch
literal 31478
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
O%O<14%Ls<dV&(uCjuV;y

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/_weakrefset.py b/tests/python/assert_test01/venv/lib/python2.7/_weakrefset.py
new file mode 120000
index 0000000..b8b09b7
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/_weakrefset.py
@@ -0,0 +1 @@
+/System/Library/Frameworks/Python.framework/Versions/2.7/lib/python2.7/_weakrefset.py
\ No newline at end of file
diff --git a/tests/python/assert_test01/venv/lib/python2.7/_weakrefset.pyc b/tests/python/assert_test01/venv/lib/python2.7/_weakrefset.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..89950054fcd6a9383b557911f1ba6f835e270a9b
GIT binary patch
literal 12414
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
OgIDYdFmW=ANdf?i-+K`N

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/abc.py b/tests/python/assert_test01/venv/lib/python2.7/abc.py
new file mode 120000
index 0000000..87956e5
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/abc.py
@@ -0,0 +1 @@
+/System/Library/Frameworks/Python.framework/Versions/2.7/lib/python2.7/abc.py
\ No newline at end of file
diff --git a/tests/python/assert_test01/venv/lib/python2.7/abc.pyc b/tests/python/assert_test01/venv/lib/python2.7/abc.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..ed2ac8f39ab7607d840d444b50cf2048f975d077
GIT binary patch
literal 6770
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
LjQq@;qGGZDb5es<

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/codecs.py b/tests/python/assert_test01/venv/lib/python2.7/codecs.py
new file mode 120000
index 0000000..b18c8d6
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/codecs.py
@@ -0,0 +1 @@
+/System/Library/Frameworks/Python.framework/Versions/2.7/lib/python2.7/codecs.py
\ No newline at end of file
diff --git a/tests/python/assert_test01/venv/lib/python2.7/codecs.pyc b/tests/python/assert_test01/venv/lib/python2.7/codecs.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..81928a04d93b8d764cf4badcc3553035a148c0fe
GIT binary patch
literal 42067
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

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/config b/tests/python/assert_test01/venv/lib/python2.7/config
new file mode 120000
index 0000000..88ddfa1
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/config
@@ -0,0 +1 @@
+/System/Library/Frameworks/Python.framework/Versions/2.7/lib/python2.7/config
\ No newline at end of file
diff --git a/tests/python/assert_test01/venv/lib/python2.7/copy_reg.py b/tests/python/assert_test01/venv/lib/python2.7/copy_reg.py
new file mode 120000
index 0000000..8d0265c
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/copy_reg.py
@@ -0,0 +1 @@
+/System/Library/Frameworks/Python.framework/Versions/2.7/lib/python2.7/copy_reg.py
\ No newline at end of file
diff --git a/tests/python/assert_test01/venv/lib/python2.7/copy_reg.pyc b/tests/python/assert_test01/venv/lib/python2.7/copy_reg.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..66c3dcfedc7c3445cd653b510a91beff21fd86c6
GIT binary patch
literal 5740
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

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/distutils/__init__.py b/tests/python/assert_test01/venv/lib/python2.7/distutils/__init__.py
new file mode 100644
index 0000000..b9b0f24
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/distutils/__init__.py
@@ -0,0 +1,134 @@
+import os
+import sys
+import warnings
+
+# opcode is not a virtualenv module, so we can use it to find the stdlib
+# Important! To work on pypy, this must be a module that resides in the
+# lib-python/modified-x.y.z directory
+import opcode
+
+dirname = os.path.dirname
+
+distutils_path = os.path.join(os.path.dirname(opcode.__file__), "distutils")
+if os.path.normpath(distutils_path) == os.path.dirname(os.path.normpath(__file__)):
+    warnings.warn("The virtualenv distutils package at %s appears to be in the same location as the system distutils?")
+else:
+    __path__.insert(0, distutils_path)  # noqa: F821
+    if sys.version_info < (3, 4):
+        import imp
+
+        real_distutils = imp.load_module("_virtualenv_distutils", None, distutils_path, ("", "", imp.PKG_DIRECTORY))
+    else:
+        import importlib.machinery
+
+        distutils_path = os.path.join(distutils_path, "__init__.py")
+        loader = importlib.machinery.SourceFileLoader("_virtualenv_distutils", distutils_path)
+        if sys.version_info < (3, 5):
+            import types
+
+            real_distutils = types.ModuleType(loader.name)
+        else:
+            import importlib.util
+
+            spec = importlib.util.spec_from_loader(loader.name, loader)
+            real_distutils = importlib.util.module_from_spec(spec)
+        loader.exec_module(real_distutils)
+
+    # Copy the relevant attributes
+    try:
+        __revision__ = real_distutils.__revision__
+    except AttributeError:
+        pass
+    __version__ = real_distutils.__version__
+
+from distutils import dist, sysconfig  # isort:skip
+
+try:
+    basestring
+except NameError:
+    basestring = str
+
+# patch build_ext (distutils doesn't know how to get the libs directory
+# path on windows - it hardcodes the paths around the patched sys.prefix)
+
+if sys.platform == "win32":
+    from distutils.command.build_ext import build_ext as old_build_ext
+
+    class build_ext(old_build_ext):
+        def finalize_options(self):
+            if self.library_dirs is None:
+                self.library_dirs = []
+            elif isinstance(self.library_dirs, basestring):
+                self.library_dirs = self.library_dirs.split(os.pathsep)
+
+            self.library_dirs.insert(0, os.path.join(sys.real_prefix, "Libs"))
+            old_build_ext.finalize_options(self)
+
+    from distutils.command import build_ext as build_ext_module
+
+    build_ext_module.build_ext = build_ext
+
+# distutils.dist patches:
+
+old_find_config_files = dist.Distribution.find_config_files
+
+
+def find_config_files(self):
+    found = old_find_config_files(self)
+    if os.name == "posix":
+        user_filename = ".pydistutils.cfg"
+    else:
+        user_filename = "pydistutils.cfg"
+    user_filename = os.path.join(sys.prefix, user_filename)
+    if os.path.isfile(user_filename):
+        for item in list(found):
+            if item.endswith("pydistutils.cfg"):
+                found.remove(item)
+        found.append(user_filename)
+    return found
+
+
+dist.Distribution.find_config_files = find_config_files
+
+# distutils.sysconfig patches:
+
+old_get_python_inc = sysconfig.get_python_inc
+
+
+def sysconfig_get_python_inc(plat_specific=0, prefix=None):
+    if prefix is None:
+        prefix = sys.real_prefix
+    return old_get_python_inc(plat_specific, prefix)
+
+
+sysconfig_get_python_inc.__doc__ = old_get_python_inc.__doc__
+sysconfig.get_python_inc = sysconfig_get_python_inc
+
+old_get_python_lib = sysconfig.get_python_lib
+
+
+def sysconfig_get_python_lib(plat_specific=0, standard_lib=0, prefix=None):
+    if standard_lib and prefix is None:
+        prefix = sys.real_prefix
+    return old_get_python_lib(plat_specific, standard_lib, prefix)
+
+
+sysconfig_get_python_lib.__doc__ = old_get_python_lib.__doc__
+sysconfig.get_python_lib = sysconfig_get_python_lib
+
+old_get_config_vars = sysconfig.get_config_vars
+
+
+def sysconfig_get_config_vars(*args):
+    real_vars = old_get_config_vars(*args)
+    if sys.platform == "win32":
+        lib_dir = os.path.join(sys.real_prefix, "libs")
+        if isinstance(real_vars, dict) and "LIBDIR" not in real_vars:
+            real_vars["LIBDIR"] = lib_dir  # asked for all
+        elif isinstance(real_vars, list) and "LIBDIR" in args:
+            real_vars = real_vars + [lib_dir]  # asked for list
+    return real_vars
+
+
+sysconfig_get_config_vars.__doc__ = old_get_config_vars.__doc__
+sysconfig.get_config_vars = sysconfig_get_config_vars
diff --git a/tests/python/assert_test01/venv/lib/python2.7/distutils/__init__.pyc b/tests/python/assert_test01/venv/lib/python2.7/distutils/__init__.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..4c1b4a7bc4d2bc3dca8f5f8a2c92ebd78ab16410
GIT binary patch
literal 4443
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
R@i1~SaWV@*X-;k)MgVD|{lNeL

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/distutils/distutils.cfg b/tests/python/assert_test01/venv/lib/python2.7/distutils/distutils.cfg
new file mode 100644
index 0000000..1af230e
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/distutils/distutils.cfg
@@ -0,0 +1,6 @@
+# This is a config file local to this virtualenv installation
+# You may include options that will be used by all distutils commands,
+# and by easy_install.  For instance:
+#
+#   [easy_install]
+#   find_links = http://mylocalsite
diff --git a/tests/python/assert_test01/venv/lib/python2.7/encodings b/tests/python/assert_test01/venv/lib/python2.7/encodings
new file mode 120000
index 0000000..8732f85
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/encodings
@@ -0,0 +1 @@
+/System/Library/Frameworks/Python.framework/Versions/2.7/lib/python2.7/encodings
\ No newline at end of file
diff --git a/tests/python/assert_test01/venv/lib/python2.7/fnmatch.py b/tests/python/assert_test01/venv/lib/python2.7/fnmatch.py
new file mode 120000
index 0000000..49b6bc0
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/fnmatch.py
@@ -0,0 +1 @@
+/System/Library/Frameworks/Python.framework/Versions/2.7/lib/python2.7/fnmatch.py
\ No newline at end of file
diff --git a/tests/python/assert_test01/venv/lib/python2.7/fnmatch.pyc b/tests/python/assert_test01/venv/lib/python2.7/fnmatch.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..cf4de23b0f87141858394905db5f9ae1bd21c455
GIT binary patch
literal 3956
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

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/genericpath.py b/tests/python/assert_test01/venv/lib/python2.7/genericpath.py
new file mode 120000
index 0000000..7843bce
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/genericpath.py
@@ -0,0 +1 @@
+/System/Library/Frameworks/Python.framework/Versions/2.7/lib/python2.7/genericpath.py
\ No newline at end of file
diff --git a/tests/python/assert_test01/venv/lib/python2.7/genericpath.pyc b/tests/python/assert_test01/venv/lib/python2.7/genericpath.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..008e436e6623dba7100521d3eea1ed4eabb2164f
GIT binary patch
literal 4144
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

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/lib-dynload b/tests/python/assert_test01/venv/lib/python2.7/lib-dynload
new file mode 120000
index 0000000..24c555e
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/lib-dynload
@@ -0,0 +1 @@
+/System/Library/Frameworks/Python.framework/Versions/2.7/lib/python2.7/lib-dynload
\ No newline at end of file
diff --git a/tests/python/assert_test01/venv/lib/python2.7/linecache.py b/tests/python/assert_test01/venv/lib/python2.7/linecache.py
new file mode 120000
index 0000000..1f79a61
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/linecache.py
@@ -0,0 +1 @@
+/System/Library/Frameworks/Python.framework/Versions/2.7/lib/python2.7/linecache.py
\ No newline at end of file
diff --git a/tests/python/assert_test01/venv/lib/python2.7/linecache.pyc b/tests/python/assert_test01/venv/lib/python2.7/linecache.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..b3ee6a858de5c824b976e2c818258893acfbc82c
GIT binary patch
literal 3614
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
Y7K0K78@M9kXX4>vW9DS%;p34607hOeIRF3v

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/locale.py b/tests/python/assert_test01/venv/lib/python2.7/locale.py
new file mode 120000
index 0000000..cc8a5a7
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/locale.py
@@ -0,0 +1 @@
+/System/Library/Frameworks/Python.framework/Versions/2.7/lib/python2.7/locale.py
\ No newline at end of file
diff --git a/tests/python/assert_test01/venv/lib/python2.7/locale.pyc b/tests/python/assert_test01/venv/lib/python2.7/locale.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..7de37c17322611290297a5c14f224d44537aadcd
GIT binary patch
literal 56908
zcmZSn%*(ayMnOz60~CleFfceUFfbJRt1vL6Ffc?hFr+Xtq%bk$Ffv3j!q`j<QA{v4
zGZLGHA&Lbi&dLzQ3S+Y|M6oecaxtW`GemJPgy*R<u%vP_WOFeTH8L<VGNv#yq;fH&
zF*2mEFtji*G&3+nMsYCYF)~D?urj2uF{H3Fq;N2#a5AKDF{E%ar0_7L@G_+EF{JP_
zqzEvi2r{GyF{B7Hq=+!2h%%&zF{Fqyq)0HNNHU~IF{DT{q>D2|aWho%fn6iRki)|e
z5}udGz>>-fc7it}$O*CxQG5(3atu-Y3@P#qQ34Dp3Jg(#3@M5XQ9=wUN(@oL3@OSC
zQ6dZ}DhyGg45?xaQQ{0Ksv!49Nq_<<MUA0_ks(ToAw?Z5D9w<f0cOa6eUd7{5GBiy
z$-odL$B@d#kR{KMD$CH!$dIB5Qq;`I05U}j#Ew#6NL6G=(FPl*#E_x`7F1?PWnsut
zVMx&h>55VXsR1d|V`yPwh*E=b^}$?q5I4mDY=Q<uswRjFQf$c3!psn*#gJkIHdC7+
zRfi$P7_3Z}A;knNsK=0E3TEgtq)IVF88D=nF=QDsq?m&QQ;ir>EI<x$X=VgbQN|1@
zmLQ2J6NVHkFvFA~#Tv{oV@R<9Gt3!Mn%PtA!PZzXqzW>mIDpxf;9zqEv!xhP`5982
zz-%jqR7Qp@YlbWvh7@OzEk(1KQZ*S;T)?un40$FDl^hJIb_|T+d9v`7bdZUWkrAZK
z6{d`rAp*pAgYq-w8B*LCQal*UK$ItgS&A1!iZ_E<iVs7IFNE@AFiY`gNC|+*1wyDG
z2o=m=mJ-5{63Sqf62_1c&R~`j!H^QkV3rcakP^*cmJ-8|63bwg6337d&tR64z>t#2
zV3v}^kdn+`mXgAdlFDF~lE#pd&R~|3!H|;4V3v}_kdn<{mXgDelFMM0lE;ve4{<~R
zgIP);LrM{YSxPZON(sbCr3_{%Weh3h3}z`63@MciW+_z+Db);SDK!i!wG3ua_6(V)
zm{aN)QtBDZKvV;SYJ^Zt3}z|K3@I%PW+|-<DQyg9DeVj?9SmkEoeU{m5ULwO^)Q&F
z^fILML8yKPvy=%8DH9>oBnGpT$qXq|7|c?pGNep{P}3pQ3<k55nG7kjAk=IIvy?du
zDRUvzJO;Cr`3xxwAk;zzvy?>)DT^W05(cxBr3@*{7|c?ZGo-A5P%9bCQdTjftcFl)
z7|c@EGNi17Q0p1YQZ_K8Y=lso7|c>OGo);RP+J+yQnoRqY==-g7|c?3GNkN+P`eq-
zQuZ*U?1fPK7|c@kGo&1VPzM>zQVubs9EMOw7|c?RGNc@XP{$d}Qcf_WoP<!P7|c>m
zGo+k>P-h{2KL?@CGnl1ZU`V+Lp)N6)rCer6xx!$Ua+M+F8iQHNb%vB15b7p`y2W6Y
za+@LL4ue_BU51o<3}z|!8B!iV1Rp}EM-b{UM9C8f^_0OZ<rzcDa|W}N7Yr#c8O%~%
zF{Hd^FiUyEkn$Eny@OEi8O%~XFr<8BFiZKwkn$NK_=UkN<tszVHwLqm?+htF7|c?B
zGNk-sFiZK(kn)GYEafjl%0C9Pl>ZDV42)okk<l!Li7|y4La{(7Rz|ZFHpUcoMza(S
z#uQEn#l>ir!p)e%1L5&9nx*hDrtmYGr3f&l2tp_!2qnx2cCHAcS&ArQiWnn2Pl_|9
zNHChEh%=^0LIkBClr$qaDatUKrN}a-$Uy|<A(R56S&AZKiV~w)iZWx03WQQ+G)qxq
zOi_nW8jNNsnv5x05S}(fgARn!Wi(6CV@%P9PzH=<DTa(GMvP`D#*8T@5J6K$vlKJN
z6mtk=!DyCZ$(UjVp{yCrQfwGgY#}^5Mza)q#uNt#<;ZB3;>4KZ453^Y%~D($Q`{gt
zcZlsC5RZ96C@)5{6mP~9A4anjU&a(aMza)u#*_d?vy?!_lpsd4lwih`5C|0tp~4_k
zIE0E|G)swOOo?JNONnMoiD5KLiDgWQgHZ7hDuK}~C6O^DiP0=2nK2~=LZw2qr$MN6
z2$jKTmXgVslErA2lFgWs1L5UDs62>ZK7>~Q;T1xtB8XrygerkhrHp1NWsE81jAkhn
zj473jW+_#SDb*0FhS4mgmNBIcLe(>xr8F?6G(vbyjAkj#j43S;s+G|!rHwJA9YS?5
znx%9yrgTAg-Hc`_J&Y;65UP*SETx|@Wdekn2(f(<gqjR-#1sfM6(Tqd!kZ4EW-ywi
z%w$ZN1>wzRG)tMom@=2qEM*>J%6tg5fYB^vA!EuS2(_5eEM*B}%2Eh#8N|%xjAkh-
z7*kd<nx(8_Oj*rnma>L1Wi6vw$~wlB^^9gI8yHhIGMc4qVocc#p|(J%t&C<V+Za=}
zGn%FBU`*M`XqK{zF=aP|w+BM)Wi(6K$C$Dol59ZL*aU`@1B_-V2N_ciF`A_uW=uH(
zp^h?|r5s~SInHR7a)L4CB%@i%DaMr35b6x0S;|?)lyea3Jfm641;&(%jAkj97*j4Y
znx$M}Ot}i7u0g2ljAkh}7*lRSs9TI?DYqF@?m(!!jAkkK7*p;;s0WN@DGwP_9zm$b
zjAkiM7*n1?c+VKkQl2xWykIm-dC8daiqS0PHDk&f2=$iHEae?z%6ka)fzd4GBV)=Z
z2=y7_h%XRNe}z!r7|l|?Gp782@P0ygzaZ3a2=xa-{be*u`Nx>@A3`xOfq9HfW+_Ze
zDa;Uxg~=?1l_`ad$t;DPDTM<<aWa{ua51HDGl2ty2SV{OnWgYCrSL;20f?X=gc4!`
z7goYd;9^Y#!V`s1Vh~E4$t*>JDMgaWEJcbbMViShMTRLw7DCA}nWe}xr6@p@C_*SD
zCbJY}rW6$>vlLaP6g3E?&SaLN!IYv2p|qIHQnZ;;bRd*2lUa%$Q;I%>GGH=GF=R?H
zf>6dxW+^62DW*(jDP~M5<`Bw)$t=Z^Da8sxSwrlzfl#&(%8tn_#hxj}0YW)4nWZ=}
zr8q-)E=*=Au1qOz5Xzm&EX9K<#S=n#F`1=!Go|=IC|@SC6hEdEe+U)8WR?=hloAA?
zf|<-xLYPuQAygQXSxPulN(6+8WHL*MVoHgIP%%tqDX~l`aS$q=$t)#-DJ2m?B{7+$
zBr~O?K&VtEvy?QZlynG{!DN<_$&``>p|Y9GQgWD5av@Y6lUYhWQ%V7ZDr7QCDPl?~
zhEOF;W+|miDP<6<oXISuf+?jELRB$=Gi)`JSxOC4N-cz{g9z3$nWZ!^r8GhWo0!Z}
znwe5sAiP#4vy?Wbly(T!0iimX%u>3TQo12j50hC+FH=e%gx3#BJxnPRnaolqF{Mm~
zP*a%9Ql>JcOk*-jna-3lgUKvqCR55R2sIl*&0#W2nah+i4?@j{2rht73z^JP7BQtP
zhVYg!nWZdcN?8U`xg0{RU@}Wt$&|7RLal~SYnaSZ)-t86gHY?4%u+TmrEFv}OWDMf
zvYE*&WeZcvRtU8XLTzU<OWDDcvJ*n>VlqqF&6KhS!rRLPuJrdosQnP?0FznDL8g>L
z5b7|KS;`Tnl%o*p7=${`WR`M*Ddi-DIt6jWX$W-&LY;*;=^TVQ&t#Tzfhpx8gm;O_
zEafs&$`uH86+&HOGE2G6lyU<?-DEOLxy6)n8^XH-G4n2jx(A`|L#PK3Cq0Dl9zm$b
zOlB!hm{OiHnWa2qN_oy?mhyrr<t39@$}6Un*AVIrgnG+lmhz4%<vo*G$_J*Dj}Yn;
zlUd4Vrj#!b-d85Gly6Ka-yzfwCbN{EOew!0)Ncs&hsiAEFH_1tCbN|POeqY^V2Y6$
zT>COXC}s%7!VIo3Ss^?&2*u89mcqfD!pUrw!o{4z%?!4W2SV{eC_ZMh6n^Fu0SG0?
zY?dO#oFWY2i7<n!EKvw0#%z`%&YU8_Y?dO)oFWCGq#=|HvssEPbBY|ZS&BS!iUNdE
zWHw7tVop(JHcL@qPEmzWYRqOS>dYw`5S}K4rv>3@Lns|)vlLzC6g>!~51|a0%~A}R
zQ;Z;#F*CRkWdfm0A(R<}GG{hRv0zTIWHw8&VotGUHcPQ#PO*hhb`Z)QLOC#-r8qLD
zI5C^0I5VfXFq@^gGN-sPo29rjr+6@%rFb%@ctI#{X0sF@<`iED<;QH6;?JBC0J4uc
zB?uxI4530G8bTpd7=#LEHcN?MPKkt2QOw{9C7Kyr)x|(~u@GJygclFtB`}+%Br>NY
zF`K0%GpD35o28^Or=&rsbY`=Z4Ca(f2$cm<nGK<GAXF|yUmk?YXEsYIU`{E7@QNTx
ziXl`9vsp?hb4nS6Du+-Nkm#s{P*o7Bn%OL+hB>8{*({}wIi;T2ETw@trIFbzrHMJE
z86wyMp;{qS8-!|ysO*4Hoe-)ELUlv5_duv#2-OGC*AJm4K&XijY7&H+3{g1+!kfx$
zmNJbwWjchK0ik9xo2ATRPMHni&0#i6nai9qkJ&6`K6A<f2(=JGEn+rHS<IZW1VSxk
zHcMH?oU)wREM*0A%1Q{eirFk>HFL@u2(=bMt%FeOnaxr*FsE#U@HRoH&CF&gTbNU}
zLa1%bW+~g5Q+7b8oy=w_yO>jUGn=LCVNTf#q4q(j{mf=52bfb1GMl9wVoo^>p^h+{
zr5t5WIR>GQGn=KHU`{#7Y?gA0Ips97S;`sal(WocDd(6|&NG{(TwqSQ$ZVE!i8<vm
zvsua&=9H@t>Ke0I%5~<H8xZOyMDP|w<!uOc2SVLtHcPq3oN}MpEad@n%0meC2tqw(
zHcNTJobr^}Eae$<%5!G3lo!k?FCo+`X0w#n%qee}%~IYnr@Uh}OL@<n@&Q79gixQD
z%~C!yr+k4>UqK}ibINxJ?+1kUli4ig7jw#Q2=#~AEafkA%0Ey6$ehB!VwS?llEMU`
zm|4tHSXfe6Aru>gVrMZ+;b2MOgiu@%ikrnOg@+}Dm&GiFk0phl1>7MPfKY-EN(e#;
zvzVobu%w7WC@~hZ6mgam2^O;yNtP5T7PAy-mJ}HlvlLmD6gd{N6nT~u1s1auMV1sL
z7I5c4nZ+zcg(XFm#VkdQB}JVD+*QzkP?``*i^VKOn<YgDLg})YrRcGw=tFo05K{~x
zlo5n7hL~vrp-frKQp{LV%pp7r7PAyfmJ}-pWeuThAe1eOS&AJ?iamsKU@=Q^WJz&i
zF-vh~NpXSjTp^SjgmPywOYvYy@r3ZaAe1*m&<Dcvg;0JhW-0zGDFF~F5JCm9n56`>
zq=Z1IPzV(Uu`e7#ML?)X2o=R*mJ-d95(A-PA+C;NF-wVONlAcEi4ZD@#VjS6B_#zy
zrLvf%q_L!=vzVo1u%u+Nn5AT~q+~;=92T>bT$YqP7PFLmmXrbrRmftNQpA!{%wm>O
z!je+TVwO_Il2XoMmQulzQVF4|Sj<wYSyE~sR4qhF9fYc9F-vJ+Noj;oO)O?9%`7P`
z5ULeIwXv9`w6mmiK&Va#)diutS<F&;SW<c+R3D33N<T}=1PC>e1>Coo1feFgn59f%
zNtp_vra`FbEM_S)SW;#}w9jHOOPS4*G6$l4E`*u~q2{xgr7U1cSqPyPK{PCeP)i`x
zQi%3t5NbJ#S;`8Ql$8+PDi*Vp)hsD%Ak<n2wGKk9XE96Jz>>0&#VlnLOUh;lZwrfA
z%2t+?Z7gOf+gVa}K;(8p1b4BRrR-)&*~4O%vX>=gAB49b!aD#l^B_duAr`Zg!z?LB
zAk<L^b&SO<<v2^q2^O=IlPoExSj<vRv!tA1F-tkil5&p4Eaf~)$^{7TB7}DdLS1Gt
zOS!_5a+Sp_<r+)Mbr!Rf8!Ra|A=E7vvy|H`DR)@RQtq;(++zVZB<@25A3&5mWHC#5
z#FFxu#Vq9sOUhFS^^C<V<vB~r3kdHei&@GmmXy~J>J5Z?%VL)DjwR(ii&@GCmXwbW
z-X{q48KUG1g!dIfePc08`OcE^gT*Z6CripN7PFM!EGd6j%u@ccr2GSwL@X%`tY#_y
zSyC8T!5u~>2*nJcSRfQDt62&gYYIDr;($<`tY#@(tSQ{AW+^<ZDZCJhj};se{H$gv
z0<0;5tY#@ftSQ2*-~bVUP@)j~#2`w<A(RBGS&AfUiWI~YX^1H@5K0!JPY%M9XEjSv
zU`<hk2r5AgQ-)9~5II$dDQXZ(9YSfanx$y6rf5MZZ3v~qYL=qQnxY4x^dXc1t67R6
zYl;!8S&A`hiV3S(iYaS~8H6%tHA}HzO|gVfR;*?z)~qQu5S}eWpB;p<hfod>Qyd|b
z6RTN@Gi!<qt67RGYl<60i93YyU^PqeWKHp6HB0ekP4R(Hz7Wa}Liw|rr3A311hSf?
z1hJ+BL#Pl|vy@QQlrRVt4xu7g%~B#+Q=%YLG=z#_HA{(QO^Jh0@esiTR<o2u)|4bx
zvy^1kloVF8lvLJ~G*+{ebk>v%R<o2$)|4y=l?|bCSj|#$SyS>LR6c|%U^PoAWKAhz
zHA^XGO(}u!N+DDkt654pYf1%#s)SHgtY#_ItSL1Rs+QF(rH(bF9>Qy2HA`t^O=*H?
zZ-!7UtY#^#tSN1*W-0BgDIE~1lhrJxi#4U2)hwllHKi9K*as2pXEjTiz?w1<LQP@?
zj|5L<HA|VonlhEuEM*#N%5+w<lo_lkGa<ZL5NbArn!{?AGM6=F9)z0DYL>EqHDw`$
zw+KQlW;IJ$!kV%aLM>x8OIgmEvI0V_gixy>)M{3<lr^j=Ya!G+R<o4#tSK8H)J6!k
ziPbD+Gi%Bg2(=YLZDTb{+0L4>gVii$Cu_<sR<o4dtSNg~%~JNVrtE`I`ytc;R<o3Y
ztSN^e)L{s91VSBUHA^|hnsS`gEae1i%1KaKVoW*3YL;@EHRTMeS;|?~lyeZl^Q>km
z7g$p+LgX&7nx$N3O}WBqmU5Lf<r=G5%5~P18xY=22z3jT4Ovs}u$raZWlgyUG3-8s
zdcX=Em3|1J9<iFGJZ4RK0->HlsAsHZQ4S257Z_5Wv!=XYHA{KPn(~U(Eaf$8${SX*
zl((!Y?^w-J-m|8BU^Pqm$eQwr)hy*RYswc^vy`u_Dc@MlQoggM{9rXp`N^8{i`6XU
zH*3ltR<o49tSSFMB?4;-1Djb2BU=g+n^_7oTM7%CSqdv#3LBeQ3Oid02b)<6CtC^^
zn^_7sTM7@GSqd*(3Ll$U3O`$l0GnBgAX|zMn^}r5TZ#yT5@j<>5o1dcXERHYU`vr?
zGfR<TOOa+XOOatqk!3SWkz-4dhfoS^W+{qnDN1Z+DavdqDr{ycs%$B0Y-TCyY$-|%
zW+@tMDVl6%DOzkP+H7ViI&3MrY-TBXY$^I|W+?`2DTZujDMoB5#%yLOCTuCDY-TBD
zY$@h!W+@hIDVA(zDOPML)@)`eHf$-jY-TBTY$^6^W+@JADUNJrDNbxD&TM8WE^H~T
zY-TBLY$@(+W+@(QDV}U*DPC+T-fU(mK5QwzY-TBbY$^V1W+?$|DS>QeDM4&0!E9zJ
zA#5q3Y-TB8Y$@SvW+@SDDUobuDN$@G(QIZZF>EQZY-TBOY$@?<W+@45DT!=mDM@T8
z$q-%&n^{UKTS^+6SxP!vN(P%*N+w%M7Mod0Hd{&#n^{UOTS^|ASxP=zN&%Z$N+DZH
z5t~^`F<VLrn^{UJTS^(5SxPxuN(Gx)N+nxL6`NT~HCsvzn^{UNTS^_9SxP-yN&}l&
zN+VlJ6PsB|Gh0dvn^{ULTS^<7SxP%wN(Y-+N+(-N7n@m1H(N>%n^{UPTS_0BSxP@!
z$^<sEl!<I9li18sCbOkXVKYma%9b*X%`9a)TgnVJvy_=^DYMwjQf9NI%z;pI+00Vr
zv8BvsGfP>(ma>q|EM*Z}%3?ONlqGB_OWDj)ma(NQXERG#!IrX;%`9aVTgqxSvy?S#
zDQnrxQr5AhtY<Sz*}#^vk<Bb+6I;q=HnWs1Y$;pW%u=?orEF(2OWDDevXjj$Wfxn@
zZZ@-&J!~m^+00V*v8C*1GfO$ZmU58IEaebe%3(IMlp|~@N7>9$j<Ka2XERGV!IpB8
z%`D{<TgquRvy?MzDQDTtQqHlZoM$sjxxkikk<BdS5?jh;HnWr~Y$;dS%u=qgrCet-
zOS!?8a+A$0<rZ7YZ8o!%J8UU;+00Vzv8CK+GfR2EmhzCzEaeef%40UOlqYN{Pua{;
zp0TAoXERHA!Itup%`D{=Tgq!Tvy?Y%DR0@#Qr@wpyk|2@`M{R)k<BdS6I;q>HnWs3
zY$;#a%u>FwrF>^IOZmZ;@{`Rh<riDZZ#J`(KWr&~+00V@v8DWHGfQD$Phn&?OJQP9
zVP-c=VPQ{UWj9M<V^3jcH%sAQPvK-YOW|Tq;bu2W;bBkVWj9OVV^86S@B|<{L3Xng
zA@&qucC!=__7qWevlKD*6mfR56bbeeNp`aoDfSd;cC!>2_7qumvlKb@6nO|wf!!=c
zkv&C;-7H0!Jw=7xEJc+)MUCAoMV&oGgWW7elRZU?-7H0$Jw=DzEJc?+MUUMqMV~#z
zfZZ&`kUhnS-7LkJJ;j9GEX9;P#f;r7#hg9Gg54~|l0C(W-7LkLJ;jFIEX9^R#g5%9
z#hyLIf!!>{kv+wU-7LkKJ;jCHEX9>Q#f{x8#hpFHgWW8}lRd?Y-7LkMJ;jIJEX9{S
z#gE-A#h*PTfZZ%5kUb@c-7F=TJtc(QEG3jZC5+uHC7eAag54}7l07Ag-7F=VJtc<S
zEG3pbC63)JC7wMcf!!=6kv%1e-7F=UJtc+REG3maC5_!IC7nGbgWW78lRYJi-7F=W
zJtYT1<+7Wl<gusZvzw(9u%{HVo23-7rxdfBrIfIzl(L(pl(DCjvzw(<u%}eAo268-
zr&P0>rPQ#e)UumJIWnZwv9~ZVL^*+1R|tVtR|qn|*69eVFfuac@i9cCax-K(Go;kB
zH#0IYrn)esG_YqgF%)^Lq%^X-dw8TeftK$udZaXgdHP^p9s_8lN3cc<I|D=UCPoGZ
z1)u!n#GF)x;?jbG{Gt*)E-nQH1%;4|RE6C9l+v73g@U5|vdom!VuhUia^0NNveX=f
z#N_1E;$nr8e1(#XR0U^+oXjM3kUZER#{kb_uo;PYDGG@xDa8sIndun{5S@9Yxk;%-
z3TgR8xrrqunR)37Ams{)#R}!AIXNIYQ6UHHAczq;nTf?9RjGODnR%%o8<X>M3vyC(
zQ}aqdmKUcYIXDqbb!J|2PASOcP``n!Rme@ut5itN&&|!x%c)c-Ely2AwlFU-H?>#+
z<nr9af?|*jxgbl+5_3vZixrAXGfNVaa#Fzt6(kmeorW3;U}qPnmOwnAp{bBonwMOX
znV+Yp;8~)Om{Xju0C!eOYFc7xPKiQlUUGg)W?p(R*xbaN9Ec&12!Xp#0qizCF0Rb~
z|NsB@E8$>ZV2Cfx%S_HsNrkT&V`N}pa00Cv1IeZ`fYylx1#5s7lxZ+AFfc$g#e+<W
zk1yc@nGl}~j^_Ayh$^sB5K$b?z`&p%TAW%`te;ktnwYKcl3JWyl3$>olAo2Yn~_?O
znW$fqT3k}BUr<?+k)NlZSX`W1R1yyoGceRIOU*0O&&f=J${OjJ>qEjsub?srWPudO
znIK28F_v&LFfgRU0<A;<!h;46L|2IjM6jSJH7&KMC^ZEZXeF!+3=FPCMfpWwQ{X{g
z!p*?IP?U<`gM14yD>*-}tb`q8eMwPreohXIU6EFlTfz(xFJWO|U`Q;<PlGWsOV}6~
z7@!H47tV|?E-A{)O9uyRa%oXfYF=_B*dckKB%YI5l?s;fagKKmi41TBhdGGj@8jbb
z;tICe$2mU4)7KU3U?1mrUw=Q>5XYcMm{Pw`U)LZ{XR!4?&hd^uK424_JsgALeH|k-
zKv7--BD6B=85kHcLC(ws`63e(%9)_x$pm>O6Qm{+6yWgG0#fA+@^33hqY!9OUOIS%
zp;-zuXaS%ZXuTmT1DIliQ0xq5=?tJHfM7vR1~bSyK(GcL1~A17QOO74@k4k55S}1}
z5`qW{LwF((o+yJ^u!b1OIVlVb4A5K&iYpCG1zkIZl+5H3J#fwd6;L1?lv+|+lvk{f
zSDKqzl$i|4w)uIfC5c6qQ0=<K1*yrIX_?6i1&Kw8xv3?oMa2k1zySsh&Ge%D(gILC
zg2JqXpMik^7MbzImAOgzIpEmIi!aVh&x<d}FU~6gC4qwY<l^{(qSWNnl+<FdNFIs^
z4+8^3Zhl@o+;lz$28O)&;?#opq{{f>g2d!haLnm}^`@jIXXYm6#24ge=9Pd&@>0_i
zOESw+!PbIB3i69H5h5Vt3Q&y$IXyG4Bp&2^WTzK^%|JN4BqP7HI597!7^J;K5b97=
zQBV#_D@sg`PsvQrEGdSoLUkz2MkJMJMG2To)A9sVeprK2jtVILSa})Q3BY7fJ^*1*
z&H!ft83qQ18b*c`R)%bLh9U`u5=Mp;W`-sv23U;=%2&nUlnF0WG&1u_Qqxn5bRdO*
ztzUj#Dmbk|_=toCO0AB`C7ET3C8@>wg{7%QncxZ)TwxXz<%6oz%)E4jh9Ho0z-hy|
zSPN84LrN}%)ZEgXL{N320It5E6<e`_lCu&t#rtW1a<w1WfFOMa1_nsM5Ar9-c|jm=
zK!iY5L~>$DYI=TACAbs?*K**<0uwZiF;MXv42m(3dl*=F7<m}saRTxHI8H!$tb~D~
z1{^cZObo%`!mc<8R6G<z%5DuvP(xz?9Qc`eXyt@+er`cxQEIV5NqN2kM13)+4U=C4
zs&zs2JE$2031LJOfb9ZT2g$hwkPrivpo!pENdkuun4oDefhw(NP%wegDg#S0$OSMA
z4kA#z)-b?A29i8Wia<3PG-SX*0`WA$Z=m!DD?JmTL84HSkyxUTl$w!PmI`T!B<B`D
z6P0dad16s2LO<B!kN^U?rWnEp<vp5)2B<(vL<$X%g&_MufddW=Wl$RjylTCc0hEJ_
z<UxriiwVRAHInndi3yU7AQ=T*uE#^-9#q$W+ZplsWvN9)nJKBr5}<@yT9A@hl8W$n
z3Y|O-D&O)z9tY)F1}08MHbwzPaAE-E6%Yp1>BU71;Ee*cj0_d2AdkDm#xm40G1P$l
z59%5ygZ2>w*MK(+fcWv?B9DO~n}eaqi=l)G)Hi5mWN2apm3kFI3?<AAMbRKNVT^^o
z4B?>QV`2zntYKoPWn?JiWe86JB|VV+e&E(dF{tU5nOByWlbNCbtMxQMX*9@yfq@}N
z5)?n6G#v(NP(xa6AlZ<j(o}G{6(kK(0m}C|iNz)Hpz^h-EHMXMN5eSu3G)(RP_Ya1
z1KcIWHK1q!wNe-u*%*15co<ojK!q1SBPSydBP*m31Nji-EpVDNV`N|`fuu=rRMaqn
zs+SZ-h5~6&a7)%QgCYndst2lZ3JgIlFUeXKh8h-zVpmW!rm!-kF);+!Fn~5-NT#qe
zfTFGnB$LGm>eSV;g4iWY3^lBvCHnHUY#>%G14AAgsHIj5A=w$y85n9g7%Cz_(OSa-
zQtA@x#Zb!$(#=!64Me4|F-WFxf~&w|Abu@)yGJbpLjWl5IT*57K%zCA4BYad`~)hQ
zIT^SWY8e;`XEKD>FfbJTWvGEE1F3*&V+FaBv4)+YhM6IY4Wy)*kwLtMjX@mbY-W&K
zKnxBLBZZ4WLImVt4N!jf3(^Lq98e_~qzGbxQV2M)f%`$=(pUjp+kqR*28Kq)CZ=ZQ
z7M9@lt_G-{2?AvwaQnFkR1g+`3-z4TydZl}Vgu#t#Dap<ycBS2yePFSwWv51-0aWF
z&&<;RMP`s0NF^xq<wDz+V0lo15d?M_$Wh=#3bvpiHKl|H)cwdz&nSVk^NPU*O-^bW
zoDZ@WoV<#I>_F8ts4xR3ZCVzg;81|HM|(gC8I&s-7&#fm7{wUb7`Ye)7<m{47&)2P
z7(q~&Q5?)-VH9HI2bVcqOd^mZ4oco23{K+hpmK*1RMb@Hfl7-aGjJ+lVvtN>0w-28
zP!dmJW-tepM&O2(1*ibwWC({;@1V^$%nTB>%nVQi%E1OO!wo10C7cvy1`AMbK^Wi#
zPIEO(P+4)sU~pjrDU5<Zo2MYD08~i?ft(7KhQuZ){1bEYOY=&=ahX$)Ukqjx739;Y
zJ}UvW-@zTog7|{O6i{PiH7HVqKuLj-jZu=3i;<5}07@6TGcYiyYS>%FXlU36*kq?x
z+UaT8YsP45+JpGH`6-!cnW;s^cG0@Z2D+9C+FE)UIX<yk_L|YDu4!)R?kSo1r4<p$
zMa8PI$)KnM1po+x%q<4hA0-S7S&X27Z)Riwl_{(YJjEuUTA_xOA&VK5gPR$_Tn11!
z&1PmO@?|IiZ!#+Zmq5*o3}W!wql67)QVk<0=4+Tig;@^^Lom1<RXh`vkD;A6MAHk>
z$WSOQO)4(QEGdPwa?=zN6;$mNpxwCCB5(&#qad{?IW@0D6FT?<3OkVU#2kf8NYe$<
zPlvW_iWSN;GLthDlJoOQ5;OA@^7B#^@{1I5^NUi!#;I$mg9f`G!KYX30q@*vXe#8E
z7K0i^3h9|;sd);i6^Y3uIh9}&R8^BR5@ADG2nXsYs1_^a<(DXcD?xDi1J3&KP&daH
zrGgvVxrrso8Q?St=7LLtAW$C$k_b}^ionHDJj5p&pojtsK#d790)-){*a-r~AGqv8
z1Va$0X$>w+zyvKzlps+5Zzm|(f(l9oc78@xMm9!aMsO12WME(bB{h%}i@6yYK*^v;
z3Ysv|7(rZdv07G!JT9mhhy$wU7$G^IjiG2Os8WQ~Xju%Psu7ep*+HqQs0h@ot6>Kz
zkW66(l>yC+j4@0M5FwjdHc%_3gb9>zYnT~|T0qrjK|5#*qhu`ys1C|v2B`%Z$jVT|
z#!$r0Si%CTI&0V%nwdaZppcz0F9_tc6p({B7_z~NQkWS)4q{>`dINR=E2!641FFP8
zw%4+PWI^>FSTPn889;UfYk&gB4^oMNVi%H0!8KbDs2vNA*C1U`G=qAz;7Thcvs42#
zpaV`a#RWN;B|*L*1t6n>+(4{AP*novg2wOAQb|w*s2T&wLQ+*pY6>{D6{i*ygN-am
zEGj7u0$B%6H(-LMi6@MKf#Db^@qn#jWMdRz;$jkDWCK?>%8Wvc>|mBCBS?&mQJRsB
zQIs(m)Zhg90@OYLmFmTyQoaP-;?H6NMHgg8WGyo&da{^7<61Qg;3#DQ6<ArUph~Kl
zk)dcRxJ|^$P$9-x!_43k>kW#!8a7Z9r5QX>E}6m%uE6p^QI-WxYM@q4p)-_U!U0M+
zS#01m1}^KGLFs^jvCx?zJnsNQ2`9*^5-yPC#T!8EG)7R{IgbHqa|#PXEjvTSG*Iew
ziS5H>|9hx?DNxf7L#<5#xA?NSK}j2wjya&}N_e0On!$bN8g>RrP%nTN<N{FkU}q4A
zQ5+27iap@gAgFzo!Vbz9;^wvN426do!b`Y727*imXVw}<2C-lbP&=r21p@<v8)%HP
zq*wvoh0M$Y4VfzxC+4OqlqXg~x|E<2UKKR74IA<=&o9kM0S&$DfQ#Rx(h`M|#B5Oi
zJR?;BG;jqP+=q0@6f*Nl^1*%eQdqCv9XeD8D(Vvp3UV@2Qxr1O!1k78WEQ0$M*2W1
zN{UKT^@>3qMAc$QUIVoSRKeK{JWdO*H-n@=gP<T;4L(pd0hL=hnZ+eRpwVh@+b%6L
zFD0`iwFsOQi%XNhg82ohMTsT(Md0DN%wpff0?;^ONM%84PzWePx_}5!83`_;GmA6x
zic1pnk|C8qNohe2gp~|xhy;PM12`kPCFT^Tf=dW+12+w9Wm#elq<;j80BAh`$+vl_
z<?(6Y>H)+8b(lb|2Ppw-&jkClxFoR%Yz;WCfeD)CZBSqE9w={v8<{Mkj6zJHMkFtz
z7^47_8WTSw54e#D;Y)z?Ix{0Pqb#EkBM%d}`T(_|K}91tkH1CqqriP5P?0VH%G$7g
z6e}pHLi4K?DCehuQ#GVB3+mf~6^NBELrVxyH<%4n9yBvEg8E48pe!Sv!oeU8D%}|w
zivEG>Cy+JupbhT@O`tvRlC|t$Q3lZN_iP4+qS*{7JPZZ%7*co{z_khs$n+F$29Vr#
z(9ZaRU7*eJlAvxD2Sd?AP>oZ=$xw6|v|qm98feQrxF1x@#!&bV<N}c72e9O4h$K7M
zL7)l+*=%9P6d{HJF~$^O2FY43R5$4}rid^U7%`@ZGDy~PGt_{$>VrCs!Hg+lAUniU
z#36>(fh8rtWn2zp4L4X4RB@()B_zQTt&BBn3^m*k9X?<QDX_#ckVF<Ms79^f1{HB2
zo!Vdp(qIM0VG1}v`ayLn8@R5A+XE_V!TM7KLHa>vae#ac9_#~+ffjorl{00D;JHWC
zaXUzXkzA=zoC=;%giJm{OCpG533M1sFGvrR8+AY#y&jY@Eg2XXoT0Ne$R$)JqzPA$
zUtF9Cn(r%x%=BfXDyTcF!wf41B~4XTJ=M%Ka9s_~YBpffE(nypf@DD!fg1Bc3Ltys
zL4*>BPzMp9?g_Z#8YBneYJvz=5TOPte!vA0*f32{?ZyC}xq-~<fburDK?v^Hf*XzC
zRv5UDNK7gYvH=+Y>iHI>7UU!*r)uzkjLim#g4_(5(SQ^sydWp$m82Hsfrph7bAmw4
zUvM`OGU^ZMEP-m=;#^3H2cPf&Rl&unpotYwLjqJN!KOzbt%}U_JWwz&fC-uwHG-f(
zW@KO}2KCb!m^qon7<m}^nU$FMnAjM_7-bk`nAjL)nPizjEFMNdMjl39C>CYpVH9QI
zVgiq*fdU=mRd9g=3Yrq|nH!MC1GMu3PBZy=WvN9a3TZj{i6sgppgCR0L;$EF1I<^1
z>O5>USTU&ermAOXlnx$51V<Z$1&SSTK!FLGh88F_=z>BER4p<vfydoJX$tQ1C{RiP
z4_SfQy`Vlj6GM>(s9*#24<Vz3Obnm_CfLwc3Nr(EAd8uyC;+AoJcS6#^9-PNIH)HG
z?l%U5Td>8TG#ZdtR1BJKhxXGT)Blh#O-xQk&F0Y1gk^F)$hZrrhyb@&!A)jx?-G(J
z%0ca5kf*>&88j-Bmkv&q;Q4rv$4iP!KvW97#&AK&$q*Fkpw<NgGcTwq%LE~Dro9?)
zn-*Lcf|6#jBdENBq&=io7pR4l2WlyS=AyujB`gyg@ZwPq5=tQFfD4Swyb?$X1SJb_
z;sX;jO@W{wumgn!C<YjqK!XnqAP<5f44n5uAt?|v3C9Sk7#KnIHxsC*2ddPWL20js
zfx$h6mBAfepSyd21|!%&V-vODaejz2D=0lSGcve)fCsBV#Uf;O4ALr0$rL>s%?>VN
z!RaBhI9<N=b>I#;P6tRC3(^oI0V+U2t+*hN(}O@k6~qflVjx$8^%Wa}gAGj3GVH+3
zL+~OCCr|)#flEGKCLu;)CLTs`bplRJpnwIHHK3pc*P%5G46*j0t_NtujS<{D0%yl;
zR)!)gP`3aY){G3<j8KsjCI<05W{_MnBSRQtAu}laAtP+yipdd7MrDF3H$QNy0w<{C
z3`h$(zbFMF2y%;_0a$SbIDEhaEd!|-R5jV8r{<+r6cpKog8~ZV2sXw{P%^_T@Nyvo
zm^BRG9=;MN#ndn`fW{lZN9!omGJ(d@YZyR7oF$A5piU-O0^Y;SVg?V5GlRNupdyc%
zp@bDx1l&1H0S$UHGKfQ}5<f_x1*($4v6`8el3D?7s>2qy6qg8rRt$i;S)ipP@i1|4
zQy;wCDYY0J=IN;=C87)r43JV1t}Y&|20Z8qF8n}ig}}WQxIv&=J0~$O9ke6}+=T(H
zTY>8bM--T#Wo&^L7Q{o_Dsa1_L9qt%J_92UqZkt#6F(C_BPSClBPXP;21PNv#@fLI
zu8H8~WsxE%4zs`$U7+48qzYmH4P%yodj+-NbuKlG;0O-{rEyT(6I{Z8;txClmcjxO
z2aWkufEZb9py4M_kDG}h20Q}>Nfs$=pk$E(&L|+o%V3JZef1P}1_h96W`<f8hCCjS
zTrD%GyAGP+VFnE{)vz!WeFin)K`!6`Nr7Cz25O3fL^zQ|SV1`uG;3lG8Z-lsBZ2xO
zObkT=;LbY>Xj}~3dCy~DC}C&F;sA9wQozFxwTvLUQ@9wiIT?zK7;6|AKofyQa~YxP
zSV7$zkj=>I<}yM9ft{f!52PoBg+aWAi9tNLh7mMMlEMNS`)Xzak&;==;NBECrGt7K
zvp^bx3+FOI`YuIVm};0oqa8I&3`GY>bFT^$!X4ikL8B7j@d!}Oh~^MbSc9h`kQE_Z
z&BRc&g$e3oW^6v*h-6bH6Lv#Ty$-bzHlhegUp0`4k9C+Pa4?7m7j9%K+`<G37SQ}D
zH>fMp0a}ZRn3D%(!$eS?hb>Q30Oeg!9|b(p0U3^l<aY2N3TQ?jl!u`s;vg<)4QCN}
zlpV2#5Nrr!j2tu?lbQlHv9vf<p**uB18x#xg$rzm9b}+qngYyO;Ld_VT4H8Su@2Zl
z`9+!OnR$sh;8lvCffty~a5GEuk~0$X(o<8AoahM|w}JQuRwjXTg9gyE^YY8{Af|&G
zZJGIb3eYuyptYxPgF$U=s5pEnCD>aa2}lq@0xt_RmY<WEoeF9TK_oOZ;l`xorxrt<
z1}=>gi<2`m!IhR3xSR$v9l#9*a5W3=kbwnt!DPH2c)l_y4b)Ts)ym+OC)iV|;6lBm
zC^4@%C$S_IyudLYY<_%BetBw9d~RYv5U9l(1X}9>o;rj$4^n;yO#&GS8bt}30cvxA
zN<Q#t5=0Rw+JmNm8cd+V95$X6G!3L_Dohwu#)FF1py?nHP>RdR&(AI`0IvlFyEG*=
zEjOQDjbTu^o((GCL2G#!1o^=ej66)B&X_b48zT?6!^Xx8nuHW$6k-$vj}!@lMur$!
znAw;>BSfHCcU49%W;XB?C0LFL)UA_X6lH>`5M`8L6lIiyR2ZPj0))X0Owbe*s3in$
z1A!_7aH$6>zC%I9WESjv#b%_k9yDMC84eBw)dZl*gPoxWtR6Z=4_YgRRB3>wv>8Ej
zYM@3dBd8o#Xa*I#jGz${Pzl)qDuIGQ%~lRjeI?e!1R7}y1}CKABcKui+C@T7%4zvU
z&|wHr?1NW6LNXk9%`!Yq7o`@178oZMD}YBD6*NG}pfoW(6`Ub-;MoN^mxGE8M8bk(
z#-dzkSp-@c4O;k|nxasWQIubro&nDN5cP0t!L1Gj$eL|E1xE$MY7dZcMTwc9Ro9t$
z3dxDZsYv?4We41l<itEsDUg&38qh69DK@}POw3D%`$Qo*zo;m+xFA0-1ynRB1i3jY
z7@C`z=_!Cc3JxD|PRz_pN47vADOCZqDoz2}G2mrz#R>@fQ&LM(i*hsbQd2<FhKbNw
zLr{rWng=eVKqCMp8JWcjnXt9#;PMe#ngq=Tjj@0`3ZVW?YH3kExIife<-*M3d|e9*
zQ%hY#Q*eO-Ub0sV${sMYAz^E!pjr%RWBd7mJJ3NOHQ@3hC>@m3!Nmh;{t&W`W)VmX
zR44>31{E2g@`z6DxB^h89=dP}lsNZ;vN>q=HUl3IBM*}VqXY|R*^D?N4<id=4HKw&
z4$hdME^ZA2qJafklgSKTpri;I?5zd2%%C}ugQ3U}lv_cK5m09Z+%QRDW`Oijid#VI
z1f5DVb5cN^Wk@(e(nDHNel9rSL24eXnFF3qU<n5~llbK;fD<`rtS7$+UM+&Skf{vt
zxEm}1fR<r`qudYD(+0&AIGVsS!w`po-2iTz!}4elsPG0y8knGc3p@!FR7f#*7Zh`#
zt}X)ysIUbsaAIKs_al59{oKKB1u;S$-Ce<bPEhp&>db)S@fQOFL!}ZZ%2JpZau`58
zPf$w@ykH5`Vq#*bWo8J^6K7y4VFE2kN@D__0Bg;_$jF%I%@9$-!T@UhLdx43P`kDW
zOs23fD1a8}GBFg@FqE({WU+&GHGmQXc+wWs*axrKtpP6z0WBi}En;V4$l(Mvz-w3-
zvbaEcYFQa7{6S@|OROV!(hWQVoWcYeYydT>*%^wKf?D9v)mD!{?dU8X&~hr!S`{`1
z&^$mM14BUJQij5%4B;u9poVP;FGv}vhzGA4D!#_dz@QKUUh7+uuK+Jbz$p*bVu8dy
zs6_(W4pR&+s-Q(VJO!3yq~?MK$G~ZXs6yNkdH5{AKiD%uM<G$6peR4RC@~kh93mqT
zGRmEtn3I#50=Ep&_VWSnHqcQ}Qqoi?D$OfaKn#O}whDoF!XS-@!%c8b%*g@e1nef|
zq?QybWR`&D|F8u_B4qp?RJx|5rhyCHB+x`+ssbpjDU>A^Wr8f$QwYw?OHNfNPgO|C
z&r>f^C{G0K2!f2n7Nw;k71E%VE!Za1$pBc8gN!K2C@qGrt%g)c;AOCx`H<x%Ah$s0
z6F`%iDXGQDMVU#dDGG^6`DL&TNFYTa`3kv-nUF;$pnXb-C7DT?IhiGu;MTQ5eo01Z
zkwQUEVhL#ay;ujlOa#1+yCeg$5(Q)kiZ?;^C1^uUYKo2mXr44t0W>A4ke>z*h+^o{
z6r^xV%_}QQEGh=on~*IJdf@$BX_-aEB?@WzrFkg|CHbJL4;H}XnK?NMNeCx^c17ta
zz>I;WRB*)#YKIi3CKe@UC=?`?WPl<u1yp&u`-Lii#voEFO041OAhQIrd?qocJh8GE
zzWfGc1}qxERlb5c$j|D~(h?K~t`*6t1t7N;K_V_c1w8Wt=?uWiM@UhQS@Xl~$JGJ=
zRqY_}<FEPQ#w4X8vM#Li0-j3t1NRfkGxLm%z;!ox9MGTwJhvRQ7E}Sx0ui9nA2Ov3
z8cKwguaGg1^wbh)=t7DCaDCvJ3(8%P#j&8#M#qwpqRgbyl2nKgs0mwKSqv_IVQC4x
zlB_&4FD1Xc7-|8e(*UXh!OqGr29Ft~=9Og@<>x_G<AORHL7;hj@Qgl89+Y%~Hh>%s
zZa#o2p`h)cP6McDhjbdicEh4D2-MU7*HB=Bmeo`csQm<*2QCIJQDKl^X5wKKV-#j&
zVOC|5X69lB)l$6R1tTDF4kk88`vTOq0AX;wWCijHcz768RWO38fD%UVWTgS9vH~^g
z*%*opK<nI6n4tSVKts&n@xEYitzBFIYMI0O>Y(HdD_Nkk6Y$<Aq<H~}TLsu&3k9UC
zN_>e9*PWYK2}-=+MQo7nvyXGU7HGLyX{tghB;!CzZaoFh5_l?xrZaFZ25mqC?M53)
zIS$;%wk`&ZHN%4f;!RK)3F;|8H^Zc+K*l>kBjfS#DhND+5AKG8mS%u+5+vz^5=M|A
zD7n)y9fR_)5)%VMF{sJJz{|rZfpz~2XoeWHFx(ilfV>8r0wEKU&5YntJY&!>KBSWg
zUGW5N9fOi9c-aqVcnmxQUmOQYvB9a}J+sh`BU&Pb1*#ro^DjKj<{?)Mu!TN43W<3N
zprtUNsu)xoA@8g~?PP)*H1H-gWW^7th|ezq_q>pjpl3;H5y-q^g~TFI2NgWU3hHPg
zHtir9AW-+g8sYF{4(oKnw>5*eXF`mGc3e|3i&DX>IFWbmBDn(=5(?0q2Fb*U#o$$+
z`RG{=Hf97K6N02XP$^XcS^xy@qJft52JHoP!r(~_Jl+EF0l3Tr6ErP2K{byFD8YdW
zaRweaCQ(Sy2<nxBoC_`*K?|TDV<IKsb-vBu!I5Sr2F4Ud*wWoqpgvVFs0jxu_aJ@%
zrzCi&K|>W<-oRQ}NZ||Wy`#y3vM{`PoT89asQ_w}B6rr&Yf24GJw$;DH4Rp_Ir{iO
zt%L0G0f&ANI37TLh4jHdSsonjV1lNB56a}Opuh(u00s{5giU#79=Oj05&~g(1VDQ$
zs2wKI^g6Ut3vxH4>VY(kGC<vJP`(B&M94@5waAJ<!3i4Y1aEK$?JI;dSHNSJ;PL=c
zzi)&kO7MtdN<LC)39A3W0Rtvz8akj^%0N))fZ~RMi3gD|;o$-rD1mID0j)=XOrC*v
z0g@UJh~fuS1SNrX3Fl{nx+;mFUHIUp5%^>QSlgyp4-#geYyxh4K+?`3P{7e;NF@jq
zI?<re0R;vFGdRtFY7dY&IL&|tP(k}{LO^vy3Am1^Wn`!ngmP0L)92xNg5Zue=$;od
za2K1AA)*8}UsKBjRSl|Rm>59&yMp18!6~4PmmoXAyI&~_a*Smipq6ZEE~syimYH5!
z1Q|C2m!;5QE>Ou81lo%Q-nj~HAm`=8gZcoOd1?9JMys>Gi)*lJ2)Jz)1d1DQ`I?`T
zl9QhdW<rKR!ATiR&^$dSfMN_h=EV#e%w}d3WaMRJ0k1e>VFC~FfeQf>V{>q`CK)_m
z?HTM383_b8*i-YsBQ0K@!RBDKS(%XSDOs7t=HPxuYH6}p09Z|8R%&t(ct9HzSfKsE
zdGUtewoYboKFG*;!(vct2yTG^c=iA;X@Dwgh$@Sw*BDjS7*($cs;mjBtSPFjDXOd)
zs;n7GpctX}#|TBv7)8z)Ma~38&ICoy6h+PyMa~RG4%IE@D01c~`Ycf7EKuYuQRFOP
z-Ze5XGK$YC07qr8muE0oRdGgUT1h-8(m^$Lh@*3eXD~P|mn0^aWEO*&sinyveW0Qs
zwKUl~2rigi1YTzr8sesF0ZuEWC28>%;Pr~${+<@P5S7{anHKRy2+>fmez0h1F=*H?
zu`1p%N)N2V8Js2)jlrfR8pkJAfk&^wEIp8xWN=)<`N_qg#WIPB@h)C^@MH(koEV>y
z1<{-s?;50saAaa)d}<L~CIn5U1Y%-Ze3T=SiJ($3F%4pHT6|SvF{s0w2x93$leZzn
z#N2pSn2BILxez_M@u?7lQ}g0OgOLmd)!B*QV<i&vib2Z@VH||H0-zH@^5R{Qw3$Lo
z&5KVhhB&t<-VxzkGe{s7K@=6mCqkVIV!@0xgX?pJyT%NzAr<1kqWHvA3=K{mm>QBY
zU>cG#Ff_PCVQNUJf@w&p!qDLAj;SFv9i|~Q9iahKVJ8;Fd-@?qVo`i%9?W;1ftW^R
z7Q&3mEJPRuPDe%YUjCRGvhraXvhp!Bc!y(Z$S#Lz$S%jw;Nyg;Atwo@Atwn_LnIar
zm2eG}7#e($lL9E$CW2;uVH$E1F*Nx5V%m_O3)7IFi=iP9iw%YFR91*-LogN%#c&P9
zSTwj`I;l7X=A_~j3?~I+38i9qC>3LdQiva>4JCOn8%pvpY>32?Q!3#(r4o@-z~x(F
zQDRaiw0HtD5$1tYZ80L%f(r`B28+aEP~rub1H~n1SsqkCgEp(D7DGzS%H;R}S7^cq
z%T*@F7o>u>#zRU}Sb=Ei3Mmk(Ao;rrRH}lLJBS5ymSrl~)TGpSr${~L07D~FL$I!-
zRB*8b5eFBd4&a&}Jfx763gv*jl$0Lt<PLEUxR6dtjZaF~D=kTb)D0kRCCrYbO1<O)
zkR8RK)ns5Pz1+;?qWt3gv=XQcsN93dfXqO)C^bH*63PeFA4#dX@ln1Io55iZ5~#|B
z+Eo<q5``jH6rWNBm-BT*lgmwn$bmhB91iK=&`U~>PfCZWNJ@wK0u-DO|HA^^6r7U4
z%3(ol3e)H04yo;ez;y;h4XAP}f`kUh3XISIdo&{-k!nCuo|KUfN-yBh&x?0*f%*lM
z=acf{lTsk&=OHvfWis<1GWqe&$VF#Teta@q2BlC<0^0-fWnNOeAEJyjgoJl~c5Y%0
zxQ0*4&(3|C11^4(isIdZ;CT$1njn=@Qc-+b5hQ>>ELZ>;f)g*AJ`<Q>X+>~#CfF33
zVo_*X3~C*Nt%GYebpTC`LjnNoL~yD`(hN>+U^SrDELbx{3pfsnDiFa5j)S5KP#l25
zCaE~y2~p4)LGlkIV<#2ICqc?PFbn1wNOLo(G$$Q2-;@VQAeDKD1`F7R$~;hu1!O~7
zQM@z4219TrOx8^U9S4>H&ZjUA%mTw=P+L7&54;Mf7}WJm)=SL;=g(w>8c+g)v`ipj
z0kSn2l665HvgG(=a6>OSK3NY^q$MY!6i#5DCMSZ!FgY>a5m9&>f^$uBVtgW`@CLIG
z7K8FQng&QTqN;;LBbpc_PC!nFm;iA)D3l-yQKJzo2G#;|QED+b1turPrxs(l2&J_J
z^B0mjxQmd*z{Z0U79@O7T$EZ24p4|1&;cb7HL&u+(A1$UF()-IITMmhz|KMlfl?ww
z2%IpXzC_7ipuC-&2+LSt7KXQwHNXQJDPzICg)9bfGBlvwpiOC5n4}dUc?;^wv?7QW
zs4G1~kV*llD>F-AfuC7|;Ywr;a91L!gS!%03}PkJm7dT>ILwuqC77<vECFi)ckPoC
zOA>Pu^C0Zhijvg46i6O{ut8Y{WO7vosK87uO?LJJ_qdWXGV@Z4Q+12MkzSP%9}=#Y
zTACaZjv`wE&eq9A8S$aWwGBw16q08$isC&GMWqpV-YdB%Kd~e;5z>@RE{=CbG@~IU
zOERQnNiL30hNff?3l^A0kYrvQpA2bggOtIW+C~r;6(_|9_(1CnaF#DliZ93k`z5(7
zJ}49_1&*?^_@YusXjaC%Bbu;~Vm%phuvc<rd^)5h3ueKb0x8y$QT0KJbyRhbVjWE(
zGy#B&h8qa!(StQZ;t<q?N`|y=lB?q3tkmQTu$xm7<6XRw5+O)=N+P%tL6d^i(JAl-
zsUf7Rm68~rk_`?RFiQ_K+F=L|L?k|>%7+NRdxfApfGPxWJXj3kcu>%%B<5un!yF4@
z!u<-4$CSjp;%talQsZ3^4N*w&r$AbLDX3CVufW@-hLDg<NsV_z&yXpp@rjTO31-3V
zhJ+BR2DmASh>Q!#kf?f*s#%DYh|&<E5Vd>;i-E%f=1nJLZ-UZbN@{!(q`eJhVYm`m
z1KgEK$o>a422k~)y3z^So`yLgDHW~Q0Bc5Zr8A;C45{l<Qsa{$-C-~b!<EPy;I2%D
zcbg5N$pd5x*dj>$r^ctGLed|Ig`EBnd{b}>AO%SPYyh~Rg@~f2O0Yth5IhP~kOB;%
zA5`)|(iTb-reF!2lvETgKAw;w1YDMajycN&hbJs}eL|7)Bs7L|N@4EJDa8moWDW4J
zLsAF#1hN>ai=c%X%n3QAU>8BufT}N$D@(y#aAlB^T3S+^oB_$|`I)Fqzm)t;Sko^r
zC*IEo-8ZEr(DElQCmuO*LVO64MfeaL$Yt@qVUQ4m#ClnLZW$!jtKyxYRT@O5Dn1E1
zpp+W#ipVG?;Fee_WUqf}YJ4grzkpdVyC5ZRY6-GFNYYJBEiTCfhfHctygQ;oGKZK7
zY1XIa#5*JU+R!oLoOoyzkeU;p4r$qgSui`z!6gZ*snC=TRtFAnuuoIr9dF2pT54Xr
zBeYiu_IYYvd}2Dpjd}5o=m`iU3rRp=7R-7>m<HrnfEkwrDLqs3P~r%Z4O8>tlb}f&
zRFH$zAjW&3ftDAa1R3uEDTa^tz^z1XufwcNhP3fg^Wu{cH4V&-C^Z!*SES~_DxcK6
zco%4e4bD;^nH+EehG|BrnxUH0lb|6RpPmFQIY7ggsd*qiEdN6yC=aD>hh#BSb?|UW
zPl7}mG+aE8>sP478QI{Jo|+e*k&O`*o`_Tn56Dbta?Oj+M3h1>mmzC_y9`MkB=e`D
z=tU~tQ}g0Ik&AbTLexqKEQaDOPsAt@!j+Ida%x_@A6m-HgQrYCL~9MMFAvfZOU;YV
zgSW)s$s_>19!brMFM!k|U=~LB1tUgD;WiXQMoCli;)~&<q;Sd7Y*_Lug|t^w^Wsa3
zp$P)i5rgyq5gih6p@*ah(!PNRz>^I$`b&%94ur=8vKS;#K?N*WKZFa{3+93eSUN@-
zeTOEeszg{iu1bVD8=8)*ka7{!C&&iCQwx$hcsj01gjftJfK&4j14%GTbKy?HlJl$J
zIll@i=fjK&hLq*7tXfqL&Z^)clhnL)P+J+I62t_12xgTla;gJ$;8XL`b3pAwi08m;
zczA>7cc2R5OCha91Q%j1Xp{{umX}$Qnxb1=0y-qP7}OKRDx(LQHH1VM*uMBu$Xo+l
zF(m0gb0<s*bf5tov-$B65%4O}7*dDigNH0q^PwRF_FFzUSRj7Sk9S3kE<vV&QuE_e
zAtUf$7R=wqki?J=noohWOTdoJ2c>CHu7)J`{P>CrNFfAbA@qVBSd2M{0i94uEsl3Y
z)PK+{R2-iOt=d2=m|4&qTpaI&a5!8;64c?v@k#Kh1Golf^aev}aeQ(P#I+z6h7HbG
zY)FRNkc`C!EPhCa`ym-Ipau!c;&^9h^9T}n#qr6IK3{5aybBh)Q{Z-|VA}2K43B$w
zaHJ-~e3yzCeS+DQ3N4k2LE|xy4i-3jgZc3C2Al&>BMzFqQPe>TAyhG>j1D#dl5C(!
z0cCs!oRmPCAzGkH+|m0@sm1Z>kbV=Gg%M#M$oUvtpcKbvK;{@yK`aanzK9G1542op
z0xpivt-#RW=ZP80d6}?K&dbEm5P&p%2n+cFXmg}Ez5u--EsjUl01s&-b<lzoq!%Ty
z0x;_LV$k#iG)fE5>-S>NWCl{*0}XN{bqI@)TV%!Y0ay}w0X&fxASH6BnE{CAD?E@3
zAX7!D#qkC3sUpa@MQU+8vIayDAk-mTR*4b>!C{z@Q(Oj%oZ>P><Umt3vIe+CNb2Ag
z6_=q{gfgWJO=qQ$L7~)QP=N@~KF}Zt#S#Ri@E|Bfcnwm#7sn%OfV&Jy9o%K5s6h~h
zB^8uGTY1ItWtgb|Sp(c6Bz16$${?u#JXV%kT#}y$8Y=^bBWlma6jJe&KoWZiyh{XP
zp+x|yMq@~ggrW|c7}S+0noS^)jI0;3MkN&_gcNtBSgN2>h*L{Jv-{xe0%D;#6;&V9
z2`K8IB_OI8#Aa}-18f3P2?$mQsyHEPz$G9^48jGcn^M#X9dJS`1r0cZ3`|Rm_k@lO
zgF`$m5$uh$#Q4l2a4Lc*@C^10^3*jpHZcMRFIZYHvpBOT6D$TcDJ?!2d0HwhExtGp
zVnk-V8&ZJ>iQ2SGa6>f>QPx4m?9wvh(;&UsG*oTi$_^|GZX6kc;|jt@$tS2nknltk
zg9HxP(O^3e;R#WQ8lGS=h!)UPQd(wCe1Hd}B?N91f&>aOz~c^SnR%d5K&Y?5Y(xqG
zMMheFyc=?r3>wl*%ZCJceta6FW=;dK5c)v515F<!<)EsAWHGQ9#Ia!ez*A-L0vZy<
z(1=Bqf{Z&NPar^Ix(KCz4RL7^XhaVjd>|Hbbb$Hr=m5JM)c~l=QPe@>2vrQ?2dE_|
zBYbIKg=ldE5(8_2xiA^h?MN#Eb=DE>5(ppNg~+{qxC@aw`OvThnFY247BtACf^ds7
zAStydJ~;z5Xpn{rAt|IN9@zkd#puI|AV+6_ErwZ=23ZP~2A+pS@f}hO!d!_Y1P^Lt
zF|f%nN2AOXLCnVpYUG)sw4!+A@jaLWb4p<b=9Hp_0@5HKEEJFpfQJH-I=HKm#ZX-B
z18o7ryo@nGm{t^@0~sI$cV*Iw67!xXLRZSA6{W(9LogHUU`XDE%+W%!QfeMj41$lt
zflT4XgG@_K1@Fs75doV6DdtLx;$gE}5Q9sL;xkJiVN?m48vvI<kkG4yjT)y_f`%ti
zWbz=xdFhFuVG-1Poen9w(-Y&N12SM1YB_?Y4>G8Tstz)pgQgG?E2s(~v4SRsh!uzl
zV8?@F1)>l&ErG=#T0lXZo`YJif~Hu~6LV72^TF+f^u(OZWKeqntTqK@&<k9$rKf-c
zFg*p-Ne9)zU=~^kpz4E$07wU19W(?`6+%M*MIoeE09yj~1UP2XQ;T5n2VsI!0Zb|v
zIyIP{T9liJ7&HZM(SwM^L#WDP(6VL-8zuxc37nqNQ>#!{8-N5-ix6_KVP|j<rdGwL
zmOw%%2NFU#uvSVshz0jKI76bv0@ULu>Y!1NDh3V$aEgYQfE4v$g=kR^5(8_2xTq*K
z6*BIa4r0MvWDYT}6fuGiYQChG!Upiu%dn(^GKh&~@KgX|!Ayj7576{MQvr%PXevOp
z02&x53Zbb0BnI{m*vT1*sKbmIiSf{3#*EZ>Ps9*{1vpwVAVdEdsqvXP;5dXR0xx8O
zRLo#0$hsxSfF48uT9H|RmmooeP#0vGf)idwYEn^ZIXD|an6S{WfQW%-NIZj`Jw0_@
zT*Dwv$^?gE26(Onl$XFPy-d)#Hz}!Q5Lf1<A|eK~<Rl|66=GjrD(FrWQ0pcGvUVt=
zC_V$yy92Xe_CqGkGm6R*ONz5I!O1V9I0;l9!pb%yh=IjPuuPRv67K;^-JryfQ4*g4
znN-OrjrTxIEkLH*Ga$|KjMDfF$P5FRg|MEJfq@~TG!MFv2h`lisEl`nElUHNUm2eW
z8BK)9I0pHG0xI4D+yKo0$?7E*<$}V+0$jIbCPEvBAn#{Fnjx8qphh@2M}UJh6TIRB
zRE}j9$9p2J5e6^s&P-0tNz6;hOa@mea30LnkfEr|lz30%6+2+tAO&D%N_-|{6<KCF
zYBJ1B2PH$0H#4(AYm$&$lpUX(2#)#8JctwX;xki%KzIK^xW)0AkiKaqh=p(qsF8=}
z2}mwMRR_r>U@=H80d-Xn=bL~t4T1|<ZVye}x{yr<a2|Z4Ks>1B6K@FK_K{hf59LB_
zF9B7!uv7$@anCFPr?5;^DM$uGUX%jP6qzL`tusg<l)z?*GeIo0KtR<1cLq|U0U8J(
zz2HEA847I)WR}EdmVgU+Nbd&1hx!{D>tH1?AxJrlstjrJ1maO}9K*bXv7`p98R8hw
zux@4vXwxL5-v(tPd<jmkrJ!`<7wYHe?C+}!DZVlxnJlw39y&z^X6faX<|QWQ=R(z#
zLp)m!D&j!pNhXK|Gur|Z|K*^f5#nBO@&GFV)f-^xti*V)0MJSuuK;jD%}NB1(L;nm
zTVcR!8M6}gvNDU2WI($n!0YL<67`BfdnQ1+Ix8_gs{p1bt3VI5O9s6B2P^@y1ZHJc
z0f?7X0G_6Y$b!--XkUhIRslF%;i4eHtO6u+kX({g0CJZ(xZs3n$SnpPxQ3*<AUPY!
zNg%f(aZ3?SFG$P-H;A$l3lc#qnV@DuIJ&8&$tVIK=NE&HBZVnP3WWktD1h#(%1(@T
zchz%u^$&9QboA48bar%c^^F7vb2g-1nVlG)o(isKz%0G=)cm6K%*4FJ<iwQJ+)8lp
zpqUa749;(;>I;go2o^zBM`vfpdq?R7c^ev-K$ah8XUAt(fx|dEC*B=VZ9?*MHl#I^
zofDr98Gr|~U}*|c)1&Ew<VsX^kX#8C17`$q%xCAud&7G9paheh8=np7*<~ZG%mo#?
z*^u%wI}g+-0Tr#;`SIRCpiuV?f&?I>gP)xrpIrowZ7>U@0AdqJ9K_3pwBNGxvk|o_
zsQm^K$jk%RgW35-sfl^uQ~_av^g&EPTbiB?S!b3FUYZV$VT1yQl+?1syhKo?2Z;-i
zB4k0(#1mL2k|1KbC%ZI01TlJR3C`EqrST<2kccYBY?5U|GJkeCtVsrDp+yv`K1h=c
zRUM>BmW`?q8lxbi;RZru6eNZeqm}XAu$f<Qyg`<~Wmm>$r-OqqCkfP*1s6YHKjkFF
z=ahm2C?`EW6lvnt03w|pUkcTj2^u6p(wGSwAj!!@?ZM?_#^*s=csZF_pb8422^7m9
zflNpRl~WS$gEVOY*;JR4S&~tj2p%s5mBTst@ji}vzM(#@K92snko=GXNoYCw@i~xX
zau7wHPQJR%0fvUg#^7=REDdT(f&`#O<s|B5Cgmm<fE9sCXNaQQ(wx+s#C)jfkipoT
zlK31*dkf5hhdE@B71imG0aX-rkT}dKi}yhqW`|5O=0F<mIc4!VW#FU)W}#bvq7!NX
zNC!-v3D}dliRq}B2qcgRS*o3z2yX8}f*#at%}s>d-wcw-gw%bx>G8fuF%B7<%uSEa
zg={0p%_u^wv;@T-NC3LjGB-0GWgP)1t>r>m)47@P(B%YR7R<?zsy#P5-WRbP12RgQ
z3z_}T&5qB_hWHDt2;4D%tYidBfnw9h6w+vb2tZp1rr-h_B81v8fUMKW%|V0`*qx9P
zH8%%VmgVNf`y!9(=H|ucLPIeRDHOp$kO%H7fJ(qzq}^R$V<DY@T=*uh+~Rm&<jD-M
zB1nmqTO6MYnbQEX(88!B-WQQGAju{dk}h*g;&UOhdSDhzA7sKgw=&)rxlx~68K0XA
zZe8ak=7HA#f)fMM?i7%4NjXFST!`l-firzxQhZ)MxU>MXkQ!?cJ~Z4Rbr0IE3rI<Y
zst!_8fyE#t6=;YVbn&tabkz&E*ar!uK(_jTn10aJL~yx0$nxL3)Of!DXy*e|XXT~F
z=M{jHO<qP`yl(_l3KUr&f!qp+TxMy!A9VZ-Vq#`#d>&+zXC6onc_R);Ag>A%B01o)
z5p4|}q&1zF0}FpcQ%Gp##5;yV?FTz8Cq5BUDdgqA3QI5xIYdD+aC2amAuk4lhA4_U
zNShd97A!W9+Qg7Wec<Q@moX59pf)BX{6Xzbuo##NiSry#p$$scc_0?53z2*ZGY?4!
z?ige-u*tAcfyE_~W(>#V<v_H63hTT))SWz_oRbG>f#l`E(<X?8>`pKr78;O{L^TH*
zk|^q+X%i%dWPd&u`|}~LuSAgow^H)*9r7yk@{5Wg1zBD`+=(C-vJ=64R41ZZ1$82d
zI!O5jHWi*w96-C75_5_{jUF@^s8gUWi_gmk`wQIX&dV<<PX)DSA*BM02R9Ys!y?QL
z#(9vkEw2c+!5GX!=mTvF%qz}E(P#?Zw4Ya;56N%E`5?WZjx<Oi@^U9gMuRj|@+#qB
z2Vx<I9hi?AcBpXy4LcNd(C7t;L4pC)|AU1PD5>Qqg9a^7yU_W`;4G1!3>q;9H59-s
zgl|EfK+^}Y8&w^|Zm<~GZg6hMN7{xBDkJjY`>*qJ<Gs<Rr1Nv*vmuMC^U-RXd`OJs
zgKHa5w#_d_RMudFi$U8WKr#i1sP$g~q_0zu2&?}J65|8Bk;<)t#P|Y8O<a&z5bp@9
z8bL)WNB}yzTaW@;--H@+1u5VpRFHx^x&>LuP>=!|+yaFrn1vdeXc{1)iK-3~nqV<-
zXo91tAO*Dc3u-9RqCRl$M{^+DP$YG5LraUnhC*DQ0h;?n^H>JNz6{vP#{v)w;R#Su
zD#!utS%K+;49yil+8PBppxrBAcY;_jeUNd#f_(4-I<OHX@d1dcA94%@=qS9>^wQMg
zRPbmyf(tVR(y}TjiFZPDSPa3Z>mk&}Clw`DWkSje3{h|{gZMAMII{v=auk4Ax}_y)
zkjd}@a5{kb4boOFD1hiGh);wp94Y{@5Uv8Jz2bOBH{_&M9G{p5&hQ10Za@L5k0CW{
z0n+{rh#e*INs!sV0uT%AU`R_4!bd3<&_V(l?_hl}b<lVRiGkxCW=R2LwyK~cz5scQ
z3c`nJh9nZO5||LA3Pe?gR3Ae;iKveu3Q?;-uo&1eVDpRe<AV^B=#a!z1nK$|<;NF6
zCegtxSb#%@nTzssA^j&%=oghD$^=jyS_EnEK!m}kS_FYdbBjvBCs;s=l%i5l!2xQb
zLDV6&!@*Lpb~q@#LR7$#1!T}3q6iu?kcJUN2(gbC!bfkbL#+&Tgls_$1xHFzX?!VU
z-*ZtZXp<VMYf2Mgu7P^DG!g8RQgD|5tQUQ|GI&s_s1y=P-~|murNzat8MmVH_#ouP
zwBS&KwBd@%<BK3`YQZd6utWM7#Ykl=sPruc7p@>56(^P;ieFF>3KD?saxP9rbdSNh
zl40|u#VH6)AU71JfU9~WVWd$D@W5Ab3X%vo=!#Q71w5#-0<(~$!J&gL2pRhTg=29F
zYJE_g0;&(dGO3`}4>%!1tVjh_*Pz<JxF|jdx~Lf1p#Y7>6{i*@<-@iMg0nqzCs}b(
zyfb1(zzE`?jQAw@B0nRCr2OK%Ovon0;tbSHh~TiwfK9d(gIKWWfNU--&WJCDlupGN
z@s*HNUz|}48r6k39vl%F#h|fVu)i|nePA^pIJhBQ+2YLj97si2oSA|+J_W2fGX*r?
z2x?9gXXa%j=0IJV9UqM7-$Jr2v{_i39bXKY{R6Y$4hCoU;+*(k#PT7iKFBn9aSlpQ
zLBc&J9=gY}I48asvZxZwf}09%bQS01mnCL{6FG>Png_Xt0m6nQ`Qm)cBWjBCVMo*y
z=Og?L4)%Q5c`?QLnC+F~d{BD@R5BFj#|I<IFGv%hI6uA^(uzine#kHYEW!%nD@!3x
zE`aPj1gBsK8|FPj@XCZ@h#=^C`OG|UlNLn;TuVSgw=mujF|G;?-9ku67RDz+##M_!
zESLpG;Ko{UA!xJ$l48J~F9Z!yfD;TNxkHjQq;@JUa!9T$%FM~hOa>RM#YK?J03JAo
zcp7XPR1}<gz)B$dHjq?699IO}KwAuAAsh#qHb)f#nFy(cQN$sYA4CXT-{d5gK!#Sq
zVh~+W5Bb7+<6y5A#pgmMY>SKHiy-Tt!7PxLOt=w6#UMVUYgSwY&vZrbOb5>A&_WwD
z;#v%nf)?6{umZJ=ATrQ;!w5X_h$3WKEDpLQ2CN^d$`oM&=mJTIa<pm%p#;?Hg(v}q
z1h_GU;3Aa4-GUGTC+K37-VG$yA)`6P#h|VYSRaT5izZ0BthfY=KFDZJaS2=>h=r!F
zEIt^yI{+@0%D@fVVpJ(en+attF4)0kC@T^n391aV@DS`$5DQ@=IFF%ffF>Ojb&z&W
zF{&7((E?6HU=zS89Fp(A3PGU_Q3H+vkQkT?b5Sv*hf`b@Uz`fgvyhe@gb$5rXjp=k
zz=R-;IIuFXd5|ny4l0$vPJozS4l0qrjw_E3fsOKjQ+RoNNfo4^DNjv-ZDA>fun{2x
zuEVRqO?!x`;L^Ve)Qkt$yCvY7KLj*gu4@2J6(x}VRSCEW0J0g((klVYo`VOYkoX2*
zN0%fbsvnTkN)kc!4p=MF;sa0$D1qe36425Eh*|0JAzqLM6Xb-l63A&VCF$`ckVD46
zEO4tR8Jv1bGU7v!c6347@+FY|O-V+431q7`m<107$S^EKXNYI8nUMj+a*%R8$a!qY
z0-42TMh4*1+)6SMGa+8gM6BfjdodGqa0u9onW!~PNhYX<0R?+WW;#L>DA+*)&;!y+
zvg1R1kvbM7+3_Wi6$~ZdrK_+uDb#zAZdgeUtosIL!Mz6wmpqh=3aOMzAVphA9w?{s
zGcYiKS#XVzJW^7GI#&daD9A)nNfGjvR7-G@EGdF*Ni8V?O(=n~BbWs<))Jg~N>B@&
zpeB&*;GhE)GT`#D1jK^rf@G1B5>S&r#4*G%NY^<MGB;NODQ-$iU=4eSB5()584^1n
zDQFr2I|s}!Nd(=OU0DP!Dj|BnS->H)up~7nGYyjdK}umF;OtaVT9ggTPEa<?jh0~B
zO4C7SRe+5G2S{l;=x`rUjF)DE+W26Hg@W@EbZ1~`Hmnx_Q30(`pjr^U08k7;RKVgN
z(kB7yhdBb$CxHlo`XrFf0)&rNd4Oj!A)60NOVYq8x->7d3_O?yVx$%oC+2{I2hIaG
zqa8|<iy?C~rFpraVG@XEL1`EyPzsp|E-eDJv%!9W9E?{AX+?n6QNjjYKoJgFMhQuW
zrA45YIM~}D7Nj0E1Gk>RQfQqWGe~e(#fQQQK2Xvug`7rFS`}XknRYG(D}aR<r1S;L
z!a~dt;zf`Ki1*-)98h8bD@9b6pgdic3d&0mPlK#1gA`k3si15Gss+k2<HP*)LY%|=
zz|mX=X>XTh#+N~w7GRcMNpcyaO@rW?nj1on2!WUo242twE_)zq%D{`az!?Zxz|atq
zJ<1b7vzTzNf-NtHl-K2npfP%ohrld^-$8XFnm$OrM^y)@8_~od6%)wEU<n8p6o2K3
zsi37dkRSr33y=VGH-C9z4x&he$mM{_L{P|<=cDdGD9;D&KmeutiVRSgqk63ZQmj{G
zfWjT*H82a|HIPdxGeHRyoC+ajUL_<lDl<W2Yfu%X#gMcH8H)x>p`|rQuByyOU5izj
z4_b=_Hl#E)-UHUh0(q*kG&MdW8yo{wkW&mGXV|1C85tWwx^Yz*pn?GudXNKbk}}gF
zl|EQP56lHEZi8?^YeGPsPM9%<76!%!;4%s#pPmE}0l5Yy0<sF6$zhtZVZ7u#z4Ro=
zmer~Zkjp`~Wn>pa`(0HT@fnbXEC^Zfz!_Kq;xwp58QEZN2HY@&Kr*BtsLF^BcGq)v
z0=WiUB35O@7pKEq0+#ZI@ru(y?t-Z*DTi5FQVzBSrmUnKzG|W>BObylfvk?KD#c7F
zRgl$9Ri&_m0%pMz3fQ_t(8;5jW-JV#n_U?gib0*KOc@Xt6rJhC<?(JonJpkbsL)CT
z4RmM5!MR28!H$`XNL<grOhyi<S&2pQuI`zPJP58&WG15kg6k5M$tZ&0`Z{JZN+7r)
zewmCi2(G_xCZhs^8|j+KsDj`IM`ki=Ah=%snT$FJu8&hDqXB~J9iGW(g5Wy3W-?kJ
zxK19Kj5Y{vpkpSZ1C$G1N13S&_b+H+N~SNI3p!UeQ-_6tAyWqy21$wWL7|zsFeRy=
zT~L|2FfRC%!%Ss37qmVn(-qDI9q*PYrNF?DDFq8A@L_eCb#Nu1V*@jpU|jGKUzyAx
zE-3au$=@Rw9L?aYmdOH=0mUOo#xIiv=1OpC&t!qc6gcH(vcO`hDkI+4Ka&OI1h}ao
znJl17X+dTs=Yx_+Gt6l4*;1KONL(k!OevUI;De<ySz)r^(~vURKwOZ~=}A@bj&7Mf
zFn&rV=!BBYR1hCz6?n!rQy7Ws<eDiA^98s{&*X&3rh*Qa$mB$lbqvkqg!wTwFW%WP
zlN07H(BTSEnVcX$f-C|b-jK-&OO2p?`i_~Lu+*5E7w_em$q7r1AfuczIbo?0bZAFZ
zCMPU4rsl<mgk*BUQX|Ny@JvovYD~?G5Aew3gr!E1y?&XTu=JLi7w;RH$?3wtkjd!*
zO@rWrR5Ddzz69^D%CrD+K_Lj*(iPy5nF8X2JObW|mdOq0g0@a&@*r`YTr+uKK?FYS
zFOvrrL?Et5CJ!u#(m?xVGI?M@lvWh)>zv603nK82kIW>P$>4?bnPD(4czIo>IgATF
z-6xYBiR<i<$qsV{`1qzwc9=6#QsaF>GudIz0C7Dt*<sEApYf8(0W%7`Xf87!#!UyU
zzt41salvcbGc({^(1P|%UN{%DEF{ws&IK*X&g6q}!7GI``Qcp9BIZm*I2W|IG&2^I
z_hVuHNC$0o$+UrS!E0JG1>ibBi*7RoV6xz~pqYX&S@2T5Om8?Bw7f9W9?s2(_x8vP
z25~`=URYWZ?;eub2I7Mv9X#Hh*$(1@q(Q6jJpD4mL41%jc$HtK5S$BIU6$zp<APUS
zWro1HpjAtmYH%)SfmfzFhzl}01-#@vQxE0~@ItiAJdiZVCh)?bOno>Pw00)b4vFjJ
zmuUyn3trKa=>wN7iT4f3w1RU%Ym+h?L0pi<iA8zw&OVt{AU@b8&`fHkABYQ*&dtvN
zW$zjgA1n=843rsw#C7(|41n332U>lSnFx~wFMi1sfpbCY4KhVwiotWlnN2WR@Dy&Q
z2aH<)ni|VYhH=4rP%|}QT<~OKrYM{Xn%&D3L*fR6WQxHo0?+Vfx`AXtUMeiDig)tQ
z%tq$BI%j5sl*8l$Tr;y_*#<n<lqmsH4hn&y+<0e?OmR3DG>Mcc3F3k@7w6{1yLo0>
zgUT=nKP%qPKhqkN>0ta|*Gy|zt}6yj8Dv_6w1W&UPK^i2f}8^7f(!$>1fsbZY&fXA
zgzyu=hJ%U@7$2k^R=k3zT{8XQh8M*L2V_ctOamKU6c4IUWI(kd2Z#U}1C{^{_h&}K
zwB><%+L<{pZV6~0AkzrOEd~wgXG+7lppp7a6&N=abX-Fw7ZTSuB9jYb8yCzOsl}iy
z#{~)?kmaex@y<b+T(Ix~ZQ^&#<bpX3e4a%n7tDjH#qnXTnOvaofa&$m<N}2~lpElh
z$px=JKu3dQa>475;&@l*OfGo+Q4GokT=4p%I6gEelgk2DSAfnE$mD{xW>P_ihGcTV
zYnS5q;IK?C7ldLDzf3N8JyRU-=b6dngOCjf%H#?_a6^MLxk8}aV$c9xrXwuCz+;)2
zvPfJv&rDfR@&LzoWl?-^WM&jhx&$=Zm8k*Zf}~4wtKwavGUGwYLE!-&i_7!`NrSnd
zv5-s`I2SaQmgxoOg2urz<zU>T{CKC3%s`k?NuUFWGXr6=;31w&c{mp|`jqJe<AMh?
zG8^Dr&?rWx5{L_OWjW|<EZ0mu5Fg|$aJN5G0g3DBm#F}=7~C1pbOu!q&M+}>UpG?=
zrUQHoWo8hJ3+@tTcEGsceqg2vhzqj4I57j%u51PILAGaR#yk6ER=~KGpblGR7K{t-
z8)TZYFfb&8Zg&A009rf>zGvkSBLhPw14AtX=*GAdMurwf=#{3;3=E7l3=Anu47MrE
z4DKE&EDR~E3?l9xkQ-}am>6oocb%rNF}T+-F%)=#E`N6SNa0{`uVH2=h=g!GQaF+I
zR)m18$pYV&>JsY)z7Cg#p_Y}QhK0dBg^R)619a^dD?>9QSPEhRH^hR~5ED~)AQtR`
za6Jmk8NxkMc#&->VP*iio)XI>7*p6mMnWx9hj2X#pD=`j?x0}-^_EijK)0$ghUbZa
zZk|cu2dNhT5rPcv9(m~u5gsW*ATBK6C~?mUhy!4r-wxq=6qYcCrwB6yYk*Fg1fM;v
z5RwYI4YM>axg;|`PY-;782ok}(0R<kp!pWiZNwE;pxbep85m&Ep$QIiMo_$hZYO4B
zP)K0{-ykRex~8@UeD#`5p#Vdn07G~R0|VsJK)*~-QUb3E^Kp&`-@*hQFHFzLPfE;z
zOr>O&q~;cbudxB29R<BoD>Jnid`nC=m@EU|U;`#-d5sO^j{3|z&@QONlGOBk&@Hy7
z*%=s$LAio~QHD`~5qzg!u?YhMgHL{PVh-q<%(TSPoRVVDUA3s!d0}4PWfe3BbS<_A
zD3n2C96r$dysZ?#!*&{_dC=QQHNky+*SzHXl+3(zD}`cdgoV)i7C~3DDHN9^7L}A1
zSQUf9Sx-+7JocfWpnzmBXnaILK>^7u9V})grj?`?!7d<EC`yIjA*i8g1-_XGeCD>F
ze~7D9u_eg)sU?tm&@>?T5kfA^P03G%T(1kgmJobf7xbbs=nZ_uY77hvklW>;*US0`
zgKk{~-O!144Ha@I!#$1aP=qs)oMGjs0g5kBX~_^&%gn$K1PYxX(CsEcp!rvD6hf5L
zfn*z*85qC=y`T%0z=<_AFBvQVy2=}TPa-(!feD(XKTur77ZhdYl|U~vJqAjAVW4uE
zg^iJig`JU|iItI)ksk~h!E8xJPDUXxpOuM`5hTmbh%5%Whl!by6(j?dN63P=82UKJ
z`?>}PJG#3DgICJL$LA(y=EcW@r%0fQJTWITu^5yR!E^3@rMXF|MW7q-auZ8RK*FH<
z8InsN@c^C*huydtv<8%5K*0~X@)mS+wuUQcW&;!#@$o77$?@?)TR@jl_Jc%0OG{u^
zCl>30Elw>4j~N!F2Bm;ha56A3q=Cw?{QMlq4X>qnnV>yqL7;#FkJS4m=B9%0y96(a
z$WO{jO)deKJn`{~IXUt1kh|bEfh+}`IR{P=L7-w1a_d$bC|Q6O+6I9ppo2iO*g>Fc
z=E2u-1%d2`TqX<hK@cb-2Z07^gUmtZS%91fs&>nZ5(|oh>_K9n+i`<@L99TKEJz#Z
zs^rX^)F6<XgFu71L7-?30*yQe*??4n!XXGWo(LYINz2JkEC~Xok08*XZcsZ&3Fv~w
zAUBYSAp43E^U_m;7JwvXfC%tKjG&ut5w`#$WrVFDZ6K$Ei;!Z_ebL~1*Mg3K^iBp5
z3qiy-5YY+>4;K&%bSWG-A0P;t<_J)#vB}L(Da}c>0|iF07#9Nr8x!c#TPS8?X5?bz
zWtQUPVdRHo1SV!CJ|<okHbyka#3{kU!O6zU&c?#VB*Diiz$4Ge&Ckrw%P+yBB&5s9
z!o$nS!YRN8)+x-)DZm-RDaR?mW6C4MBgn%g#Kh0W%*esW%Ot?cBhSpt&IpIdY=kHt
z7FQ`V9$C1#qiRM&U^E0qLtr!nMnhmU1ZW-tTmlr=%1onmHxVH~b|`T%b6SDhV2mtG
Tyi7cdtc;9|?2Mpp4<jQ0DM4}7

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/no-global-site-packages.txt b/tests/python/assert_test01/venv/lib/python2.7/no-global-site-packages.txt
new file mode 100644
index 0000000..e69de29
diff --git a/tests/python/assert_test01/venv/lib/python2.7/ntpath.py b/tests/python/assert_test01/venv/lib/python2.7/ntpath.py
new file mode 120000
index 0000000..af0bbe7
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/ntpath.py
@@ -0,0 +1 @@
+/System/Library/Frameworks/Python.framework/Versions/2.7/lib/python2.7/ntpath.py
\ No newline at end of file
diff --git a/tests/python/assert_test01/venv/lib/python2.7/ntpath.pyc b/tests/python/assert_test01/venv/lib/python2.7/ntpath.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..d2e6dabaa309547169adb8199e3aeafa8d4f8ea6
GIT binary patch
literal 14384
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

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/orig-prefix.txt b/tests/python/assert_test01/venv/lib/python2.7/orig-prefix.txt
new file mode 100644
index 0000000..2a45120
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/orig-prefix.txt
@@ -0,0 +1 @@
+/System/Library/Frameworks/Python.framework/Versions/2.7
\ No newline at end of file
diff --git a/tests/python/assert_test01/venv/lib/python2.7/os.py b/tests/python/assert_test01/venv/lib/python2.7/os.py
new file mode 120000
index 0000000..04db928
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/os.py
@@ -0,0 +1 @@
+/System/Library/Frameworks/Python.framework/Versions/2.7/lib/python2.7/os.py
\ No newline at end of file
diff --git a/tests/python/assert_test01/venv/lib/python2.7/os.pyc b/tests/python/assert_test01/venv/lib/python2.7/os.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..ea60e97602e76ee5ce3c0383be65547517b4dfcf
GIT binary patch
literal 28720
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
az=R-$nRvkKC7Bt;K_LKTgO)4tG6DeM2Y{jg

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/posixpath.py b/tests/python/assert_test01/venv/lib/python2.7/posixpath.py
new file mode 120000
index 0000000..cc89aa2
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/posixpath.py
@@ -0,0 +1 @@
+/System/Library/Frameworks/Python.framework/Versions/2.7/lib/python2.7/posixpath.py
\ No newline at end of file
diff --git a/tests/python/assert_test01/venv/lib/python2.7/posixpath.pyc b/tests/python/assert_test01/venv/lib/python2.7/posixpath.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..e8bb932a25c17c68d063f558681c082fbb486574
GIT binary patch
literal 12731
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
TpaOwYk5iVDkCTH_i=PPqk6faT

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/re.py b/tests/python/assert_test01/venv/lib/python2.7/re.py
new file mode 120000
index 0000000..b1a8e65
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/re.py
@@ -0,0 +1 @@
+/System/Library/Frameworks/Python.framework/Versions/2.7/lib/python2.7/re.py
\ No newline at end of file
diff --git a/tests/python/assert_test01/venv/lib/python2.7/re.pyc b/tests/python/assert_test01/venv/lib/python2.7/re.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..e2536eaa70dbb61dba12b6e54fdbb117a05d6754
GIT binary patch
literal 14610
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
VOl(Y?N}T+hteiYNOq|TZtN@fA=34*&

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/assertpy-0.14.dist-info/INSTALLER b/tests/python/assert_test01/venv/lib/python2.7/site-packages/assertpy-0.14.dist-info/INSTALLER
new file mode 100644
index 0000000..a1b589e
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/assertpy-0.14.dist-info/INSTALLER
@@ -0,0 +1 @@
+pip
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/assertpy-0.14.dist-info/LICENSE b/tests/python/assert_test01/venv/lib/python2.7/site-packages/assertpy-0.14.dist-info/LICENSE
new file mode 100644
index 0000000..d219296
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/assertpy-0.14.dist-info/LICENSE
@@ -0,0 +1,27 @@
+Copyright (c) 2015-2018, Activision Publishing, Inc.
+All rights reserved.
+
+Redistribution and use in source and binary forms, with or without modification,
+are permitted provided that the following conditions are met:
+
+1. Redistributions of source code must retain the above copyright notice, this
+   list of conditions and the following disclaimer.
+
+2. Redistributions in binary form must reproduce the above copyright notice,
+   this list of conditions and the following disclaimer in the documentation
+   and/or other materials provided with the distribution.
+
+3. Neither the name of the copyright holder nor the names of its contributors
+   may be used to endorse or promote products derived from this software without
+  specific prior written permission.
+
+THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
+ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
+WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
+DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR
+ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
+(INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
+LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON
+ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
+(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
+SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/assertpy-0.14.dist-info/METADATA b/tests/python/assert_test01/venv/lib/python2.7/site-packages/assertpy-0.14.dist-info/METADATA
new file mode 100644
index 0000000..f62fda6
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/assertpy-0.14.dist-info/METADATA
@@ -0,0 +1,48 @@
+Metadata-Version: 2.1
+Name: assertpy
+Version: 0.14
+Summary: Assertion library for python unit testing with a fluent API
+Home-page: https://github.com/ActivisionGameScience/assertpy
+Author: Justin Shacklette
+Author-email: justin@saturnboy.com
+License: BSD
+Download-URL: https://codeload.github.com/ActivisionGameScience/assertpy/tar.gz/0.14
+Keywords: test,testing,assert,assertion,assertthat,assert_that,nose,nosetests,pytest,unittest
+Platform: UNKNOWN
+Classifier: Development Status :: 5 - Production/Stable
+Classifier: Intended Audience :: Developers
+Classifier: License :: OSI Approved :: BSD License
+Classifier: Natural Language :: English
+Classifier: Operating System :: OS Independent
+Classifier: Programming Language :: Python
+Classifier: Programming Language :: Python :: 2
+Classifier: Programming Language :: Python :: 2.7
+Classifier: Programming Language :: Python :: 3
+Classifier: Programming Language :: Python :: 3.4
+Classifier: Programming Language :: Python :: 3.5
+Classifier: Programming Language :: Python :: 3.6
+Classifier: Topic :: Software Development
+Classifier: Topic :: Software Development :: Testing
+
+assertpy
+========
+
+Dead simple assertion library for python unit testing with a fluent API
+that supports Python 2 and 3.
+
+Usage
+'''''
+
+Just import the ``assert_that`` function, and away you go::
+
+    from assertpy import assert_that
+
+    def test_something():
+        assert_that(1 + 2).is_equal_to(3)
+        assert_that('foobar').is_length(6).starts_with('foo').ends_with('bar')
+        assert_that(['a', 'b', 'c']).contains('a').does_not_contain('x')
+
+Of course, ``assertpy`` works best with a python test runner
+like `pytest <http://pytest.org/latest/contents.html>`_ (our favorite)
+or `Nose <http://nose.readthedocs.org/>`_.
+
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/assertpy-0.14.dist-info/RECORD b/tests/python/assert_test01/venv/lib/python2.7/site-packages/assertpy-0.14.dist-info/RECORD
new file mode 100644
index 0000000..1707217
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/assertpy-0.14.dist-info/RECORD
@@ -0,0 +1,10 @@
+assertpy-0.14.dist-info/INSTALLER,sha256=zuuue4knoyJ-UwPPXg8fezS7VCrXJQrAP7zeNuwvFQg,4
+assertpy-0.14.dist-info/LICENSE,sha256=A5e_Ox6QhAy0Rav1APb1K-8drhBEHcDXILlNKMwymco,1517
+assertpy-0.14.dist-info/METADATA,sha256=iLto6XTsj5ZQqCNSKhOLNdXtFDV0BOMIvPz2KQlYEi8,1756
+assertpy-0.14.dist-info/RECORD,,
+assertpy-0.14.dist-info/WHEEL,sha256=wy6I0RkXf1SHQI9WgMGMZtkrPqc-c49UWrTH1_nKFnQ,93
+assertpy-0.14.dist-info/top_level.txt,sha256=UjINadP2D2SPePrtkYj1Fb45xKse9cFMpUWW2F7fWTQ,9
+assertpy/__init__.py,sha256=0JJbj_CiDS3zthpc2MKmm9Uxp-WLJMkGD-naZuAWhM8,146
+assertpy/__init__.pyc,,
+assertpy/assertpy.py,sha256=2z4fdAi3m0B0mU9uFzzlFETyKAlw9oP1FL5mdxfFvZ0,61429
+assertpy/assertpy.pyc,,
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/assertpy-0.14.dist-info/WHEEL b/tests/python/assert_test01/venv/lib/python2.7/site-packages/assertpy-0.14.dist-info/WHEEL
new file mode 100644
index 0000000..5d26497
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/assertpy-0.14.dist-info/WHEEL
@@ -0,0 +1,5 @@
+Wheel-Version: 1.0
+Generator: bdist_wheel (0.33.1)
+Root-Is-Purelib: true
+Tag: cp27-none-any
+
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/assertpy-0.14.dist-info/top_level.txt b/tests/python/assert_test01/venv/lib/python2.7/site-packages/assertpy-0.14.dist-info/top_level.txt
new file mode 100644
index 0000000..8593653
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/assertpy-0.14.dist-info/top_level.txt
@@ -0,0 +1 @@
+assertpy
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/assertpy/__init__.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/assertpy/__init__.py
new file mode 100644
index 0000000..f9cf769
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/assertpy/__init__.py
@@ -0,0 +1,2 @@
+from __future__ import absolute_import
+from .assertpy import assert_that, assert_warn, soft_assertions, contents_of, fail, soft_fail, __version__
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/assertpy/__init__.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/assertpy/__init__.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..0c65a65ed3027dbb92a7a9a2ac07e415cac37fcc
GIT binary patch
literal 476
zcmZSn%**BKcQPiK0ScHH7#JKJ7#NB@7#J8*7#LC*8FCmHav2$-7#SE-m>5!+8FH8y
za+w*Tm>F_e7@}Aha#<OoSQ&EJ7^2u1a@iT8*coy;7@{~Bayc2II2jmISQvseSQ!`?
zGC?+IFfuSOl<+e!FeD}w=jW7`q{e6F7UUO|WP&6#*g>+~Alc&L)S{C3l8nTX5+r_k
zVo@GgcX57NNqiz$QD%N#F<4D<eqKpxUP*C$ep(3&0|P@^VrEVWCj$cmSTUFfGAcg4
zEVZaOGe0jr-cN%IWFd%%k54NtDJ@Ekj}HR5vxEcgh=R%>klTVlArr*Rz`zg$GCT<6
zr64vC7vyLSkR}9CoWa1rpkGjwS(aFms$Z5^q@R|blag9gte=#kU!Ihdmus3^Y-E^Z
zo?ex1VQNvHlT~GA00QZG`XTxSmB|^2MY*~KiOJcC>6v-y`VgNMR3aGh@tJv<CGqik
Y1(jg8+T`Y^l;)(`ft*?la;g9$00ZD|`v3p{

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/assertpy/assertpy.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/assertpy/assertpy.py
new file mode 100644
index 0000000..c761762
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/assertpy/assertpy.py
@@ -0,0 +1,1373 @@
+# Copyright (c) 2015-2018, Activision Publishing, Inc.
+# All rights reserved.
+#
+# Redistribution and use in source and binary forms, with or without modification,
+# are permitted provided that the following conditions are met:
+#
+# 1. Redistributions of source code must retain the above copyright notice, this
+# list of conditions and the following disclaimer.
+#
+# 2. Redistributions in binary form must reproduce the above copyright notice,
+# this list of conditions and the following disclaimer in the documentation
+# and/or other materials provided with the distribution.
+#
+# 3. Neither the name of the copyright holder nor the names of its contributors
+# may be used to endorse or promote products derived from this software without
+# specific prior written permission.
+#
+# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
+# ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
+# WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
+# DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR
+# ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
+# (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
+# LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON
+# ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
+# (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
+# SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+
+"""Assertion library for python unit testing with a fluent API"""
+
+from __future__ import division, print_function
+import re
+import os
+import sys
+import datetime
+import numbers
+import collections
+import inspect
+import math
+import contextlib
+import json
+
+__version__ = '0.14'
+
+__tracebackhide__ = True # clean tracebacks via py.test integration
+contextlib.__tracebackhide__ = True # monkey patch contextlib with clean py.test tracebacks
+
+if sys.version_info[0] == 3:
+    str_types = (str,)
+    xrange = range
+    unicode = str
+else:
+    str_types = (basestring,)
+    xrange = xrange
+    unicode = unicode
+
+
+### soft assertions ###
+_soft_ctx = False
+_soft_err = []
+
+@contextlib.contextmanager
+def soft_assertions():
+    global _soft_ctx
+    global _soft_err
+
+    # init ctx
+    _soft_ctx = True
+    _soft_err = []
+
+    try:
+        yield
+    finally:
+        # reset ctx
+        _soft_ctx = False
+
+    if _soft_err:
+        out = 'soft assertion failures:'
+        for i,msg in enumerate(_soft_err):
+            out += '\n%d. %s' % (i+1, msg)
+        # reset msg, then raise
+        _soft_err = []
+        raise AssertionError(out)
+
+
+### factory methods ###
+def assert_that(val, description=''):
+    """Factory method for the assertion builder with value to be tested and optional description."""
+    global _soft_ctx
+    if _soft_ctx:
+        return AssertionBuilder(val, description, 'soft')
+    return AssertionBuilder(val, description)
+
+def assert_warn(val, description=''):
+    """Factory method for the assertion builder with value to be tested, optional description, and
+       just warn on assertion failures instead of raisings exceptions."""
+    return AssertionBuilder(val, description, 'warn')
+
+def contents_of(f, encoding='utf-8'):
+    """Helper to read the contents of the given file or path into a string with the given encoding.
+    Encoding defaults to 'utf-8', other useful encodings are 'ascii' and 'latin-1'."""
+
+    try:
+        contents = f.read()
+    except AttributeError:
+        try:
+            with open(f, 'r') as fp:
+                contents = fp.read()
+        except TypeError:
+            raise ValueError('val must be file or path, but was type <%s>' % type(f).__name__)
+        except OSError:
+            if not isinstance(f, str_types):
+                raise ValueError('val must be file or path, but was type <%s>' % type(f).__name__)
+            raise
+
+    if sys.version_info[0] == 3 and type(contents) is bytes:
+        # in PY3 force decoding of bytes to target encoding
+        return contents.decode(encoding, 'replace')
+    elif sys.version_info[0] == 2 and encoding == 'ascii':
+        # in PY2 force encoding back to ascii
+        return contents.encode('ascii', 'replace')
+    else:
+        # in all other cases, try to decode to target encoding
+        try:
+            return contents.decode(encoding, 'replace')
+        except AttributeError:
+            pass
+    # if all else fails, just return the contents "as is"
+    return contents
+
+def fail(msg=''):
+    """Force test failure with the given message."""
+    raise AssertionError('Fail: %s!' % msg if msg else 'Fail!')
+
+def soft_fail(msg=''):
+    """Adds error message to soft errors list if within soft assertions context.
+       Either just force test failure with the given message."""
+    global _soft_ctx
+    if _soft_ctx:
+        global _soft_err
+        _soft_err.append('Fail: %s!' % msg if msg else 'Fail!')
+        return
+    fail(msg)
+
+
+class AssertionBuilder(object):
+    """Assertion builder."""
+
+    def __init__(self, val, description='', kind=None, expected=None):
+        """Construct the assertion builder."""
+        self.val = val
+        self.description = description
+        self.kind = kind
+        self.expected = expected
+
+    def described_as(self, description):
+        """Describes the assertion.  On failure, the description is included in the error message."""
+        self.description = str(description)
+        return self
+
+    def is_equal_to(self, other, **kwargs):
+        """Asserts that val is equal to other."""
+        if self._check_dict_like(self.val, check_values=False, return_as_bool=True) and self._check_dict_like(other, check_values=False, return_as_bool=True):
+            if self._dict_not_equal(self.val, other, ignore=kwargs.get('ignore'), include=kwargs.get('include')):
+                self._dict_err(self.val, other, ignore=kwargs.get('ignore'), include=kwargs.get('include'))
+        else:
+            if self.val != other:
+                self._err('Expected <%s> to be equal to <%s>, but was not.' % (self.val, other))
+        return self
+
+    def is_not_equal_to(self, other):
+        """Asserts that val is not equal to other."""
+        if self.val == other:
+            self._err('Expected <%s> to be not equal to <%s>, but was.' % (self.val, other))
+        return self
+
+    def is_same_as(self, other):
+        """Asserts that the val is identical to other, via 'is' compare."""
+        if self.val is not other:
+            self._err('Expected <%s> to be identical to <%s>, but was not.' % (self.val, other))
+        return self
+
+    def is_not_same_as(self, other):
+        """Asserts that the val is not identical to other, via 'is' compare."""
+        if self.val is other:
+            self._err('Expected <%s> to be not identical to <%s>, but was.' % (self.val, other))
+        return self
+
+    def is_true(self):
+        """Asserts that val is true."""
+        if not self.val:
+            self._err('Expected <True>, but was not.')
+        return self
+
+    def is_false(self):
+        """Asserts that val is false."""
+        if self.val:
+            self._err('Expected <False>, but was not.')
+        return self
+
+    def is_none(self):
+        """Asserts that val is none."""
+        if self.val is not None:
+            self._err('Expected <%s> to be <None>, but was not.' % self.val)
+        return self
+
+    def is_not_none(self):
+        """Asserts that val is not none."""
+        if self.val is None:
+            self._err('Expected not <None>, but was.')
+        return self
+
+    def is_type_of(self, some_type):
+        """Asserts that val is of the given type."""
+        if type(some_type) is not type and\
+                not issubclass(type(some_type), type):
+            raise TypeError('given arg must be a type')
+        if type(self.val) is not some_type:
+            if hasattr(self.val, '__name__'):
+                t = self.val.__name__
+            elif hasattr(self.val, '__class__'):
+                t = self.val.__class__.__name__
+            else:
+                t = 'unknown'
+            self._err('Expected <%s:%s> to be of type <%s>, but was not.' % (self.val, t, some_type.__name__))
+        return self
+
+    def is_instance_of(self, some_class):
+        """Asserts that val is an instance of the given class."""
+        try:
+            if not isinstance(self.val, some_class):
+                if hasattr(self.val, '__name__'):
+                    t = self.val.__name__
+                elif hasattr(self.val, '__class__'):
+                    t = self.val.__class__.__name__
+                else:
+                    t = 'unknown'
+                self._err('Expected <%s:%s> to be instance of class <%s>, but was not.' % (self.val, t, some_class.__name__))
+        except TypeError:
+            raise TypeError('given arg must be a class')
+        return self
+
+    def is_length(self, length):
+        """Asserts that val is the given length."""
+        if type(length) is not int:
+            raise TypeError('given arg must be an int')
+        if length < 0:
+            raise ValueError('given arg must be a positive int')
+        if len(self.val) != length:
+            self._err('Expected <%s> to be of length <%d>, but was <%d>.' % (self.val, length, len(self.val)))
+        return self
+
+    def contains(self, *items):
+        """Asserts that val contains the given item or items."""
+        if len(items) == 0:
+            raise ValueError('one or more args must be given')
+        elif len(items) == 1:
+            if items[0] not in self.val:
+                if self._check_dict_like(self.val, return_as_bool=True):
+                    self._err('Expected <%s> to contain key <%s>, but did not.' % (self.val, items[0]))
+                else:
+                    self._err('Expected <%s> to contain item <%s>, but did not.' % (self.val, items[0]))
+        else:
+            missing = []
+            for i in items:
+                if i not in self.val:
+                    missing.append(i)
+            if missing:
+                if self._check_dict_like(self.val, return_as_bool=True):
+                    self._err('Expected <%s> to contain keys %s, but did not contain key%s %s.' % (self.val, self._fmt_items(items), '' if len(missing) == 0 else 's', self._fmt_items(missing)))
+                else:
+                    self._err('Expected <%s> to contain items %s, but did not contain %s.' % (self.val, self._fmt_items(items), self._fmt_items(missing)))
+        return self
+
+    def does_not_contain(self, *items):
+        """Asserts that val does not contain the given item or items."""
+        if len(items) == 0:
+            raise ValueError('one or more args must be given')
+        elif len(items) == 1:
+            if items[0] in self.val:
+                self._err('Expected <%s> to not contain item <%s>, but did.' % (self.val, items[0]))
+        else:
+            found = []
+            for i in items:
+                if i in self.val:
+                    found.append(i)
+            if found:
+                self._err('Expected <%s> to not contain items %s, but did contain %s.' % (self.val, self._fmt_items(items), self._fmt_items(found)))
+        return self
+
+    def contains_only(self, *items):
+        """Asserts that val contains only the given item or items."""
+        if len(items) == 0:
+            raise ValueError('one or more args must be given')
+        else:
+            extra = []
+            for i in self.val:
+                if i not in items:
+                    extra.append(i)
+            if extra:
+                self._err('Expected <%s> to contain only %s, but did contain %s.' % (self.val, self._fmt_items(items), self._fmt_items(extra)))
+
+            missing = []
+            for i in items:
+                if i not in self.val:
+                    missing.append(i)
+            if missing:
+                self._err('Expected <%s> to contain only %s, but did not contain %s.' % (self.val, self._fmt_items(items), self._fmt_items(missing)))
+        return self
+
+    def contains_sequence(self, *items):
+        """Asserts that val contains the given sequence of items in order."""
+        if len(items) == 0:
+            raise ValueError('one or more args must be given')
+        else:
+            try:
+                for i in xrange(len(self.val) - len(items) + 1):
+                    for j in xrange(len(items)):
+                        if self.val[i+j] != items[j]:
+                            break
+                    else:
+                        return self
+            except TypeError:
+                raise TypeError('val is not iterable')
+        self._err('Expected <%s> to contain sequence %s, but did not.' % (self.val, self._fmt_items(items)))
+
+    def contains_duplicates(self):
+        """Asserts that val is iterable and contains duplicate items."""
+        try:
+            if len(self.val) != len(set(self.val)):
+                return self
+        except TypeError:
+            raise TypeError('val is not iterable')
+        self._err('Expected <%s> to contain duplicates, but did not.' % self.val)
+
+    def does_not_contain_duplicates(self):
+        """Asserts that val is iterable and does not contain any duplicate items."""
+        try:
+            if len(self.val) == len(set(self.val)):
+                return self
+        except TypeError:
+            raise TypeError('val is not iterable')
+        self._err('Expected <%s> to not contain duplicates, but did.' % self.val)
+
+    def is_empty(self):
+        """Asserts that val is empty."""
+        if len(self.val) != 0:
+            if isinstance(self.val, str_types):
+                self._err('Expected <%s> to be empty string, but was not.' % self.val)
+            else:
+                self._err('Expected <%s> to be empty, but was not.' % self.val)
+        return self
+
+    def is_not_empty(self):
+        """Asserts that val is not empty."""
+        if len(self.val) == 0:
+            if isinstance(self.val, str_types):
+                self._err('Expected not empty string, but was empty.')
+            else:
+                self._err('Expected not empty, but was empty.')
+        return self
+
+    def is_in(self, *items):
+        """Asserts that val is equal to one of the given items."""
+        if len(items) == 0:
+            raise ValueError('one or more args must be given')
+        else:
+            for i in items:
+                if self.val == i:
+                    return self
+        self._err('Expected <%s> to be in %s, but was not.' % (self.val, self._fmt_items(items)))
+
+    def is_not_in(self, *items):
+        """Asserts that val is not equal to one of the given items."""
+        if len(items) == 0:
+            raise ValueError('one or more args must be given')
+        else:
+            for i in items:
+                if self.val == i:
+                    self._err('Expected <%s> to not be in %s, but was.' % (self.val, self._fmt_items(items)))
+        return self
+
+### numeric assertions ###
+
+    COMPAREABLE_TYPES = set([datetime.datetime, datetime.timedelta, datetime.date, datetime.time])
+    NON_COMPAREABLE_TYPES = set([complex])
+
+    def _validate_compareable(self, other):
+        self_type = type(self.val)
+        other_type = type(other)
+
+        if self_type in self.NON_COMPAREABLE_TYPES:
+            raise TypeError('ordering is not defined for type <%s>' % self_type.__name__)
+        if self_type in self.COMPAREABLE_TYPES:
+            if other_type is not self_type:
+                raise TypeError('given arg must be <%s>, but was <%s>' % (self_type.__name__, other_type.__name__))
+            return
+        if isinstance(self.val, numbers.Number):
+            if not isinstance(other, numbers.Number):
+                raise TypeError('given arg must be a number, but was <%s>' % other_type.__name__)
+            return
+        raise TypeError('ordering is not defined for type <%s>' % self_type.__name__)
+
+    def _validate_number(self):
+        """Raise TypeError if val is not numeric."""
+        if isinstance(self.val, numbers.Number) is False:
+            raise TypeError('val is not numeric')
+
+    def _validate_real(self):
+        """Raise TypeError if val is not real number."""
+        if isinstance(self.val, numbers.Real) is False:
+            raise TypeError('val is not real number')
+
+    def is_zero(self):
+        """Asserts that val is numeric and equal to zero."""
+        self._validate_number()
+        return self.is_equal_to(0)
+
+    def is_not_zero(self):
+        """Asserts that val is numeric and not equal to zero."""
+        self._validate_number()
+        return self.is_not_equal_to(0)
+
+    def is_nan(self):
+        """Asserts that val is real number and NaN (not a number)."""
+        self._validate_number()
+        self._validate_real()
+        if not math.isnan(self.val):
+            self._err('Expected <%s> to be <NaN>, but was not.' % self.val)
+        return self
+
+    def is_not_nan(self):
+        """Asserts that val is real number and not NaN (not a number)."""
+        self._validate_number()
+        self._validate_real()
+        if math.isnan(self.val):
+            self._err('Expected not <NaN>, but was.')
+        return self
+
+    def is_inf(self):
+        """Asserts that val is real number and Inf (infinity)."""
+        self._validate_number()
+        self._validate_real()
+        if not math.isinf(self.val):
+            self._err('Expected <%s> to be <Inf>, but was not.' % self.val)
+        return self
+
+    def is_not_inf(self):
+        """Asserts that val is real number and not Inf (infinity)."""
+        self._validate_number()
+        self._validate_real()
+        if math.isinf(self.val):
+            self._err('Expected not <Inf>, but was.')
+        return self
+
+    def is_greater_than(self, other):
+        """Asserts that val is numeric and is greater than other."""
+        self._validate_compareable(other)
+        if self.val <= other:
+            if type(self.val) is datetime.datetime:
+                self._err('Expected <%s> to be greater than <%s>, but was not.' % (self.val.strftime('%Y-%m-%d %H:%M:%S'), other.strftime('%Y-%m-%d %H:%M:%S')))
+            else:
+                self._err('Expected <%s> to be greater than <%s>, but was not.' % (self.val, other))
+        return self
+
+    def is_greater_than_or_equal_to(self, other):
+        """Asserts that val is numeric and is greater than or equal to other."""
+        self._validate_compareable(other)
+        if self.val < other:
+            if type(self.val) is datetime.datetime:
+                self._err('Expected <%s> to be greater than or equal to <%s>, but was not.' % (self.val.strftime('%Y-%m-%d %H:%M:%S'), other.strftime('%Y-%m-%d %H:%M:%S')))
+            else:
+                self._err('Expected <%s> to be greater than or equal to <%s>, but was not.' % (self.val, other))
+        return self
+
+    def is_less_than(self, other):
+        """Asserts that val is numeric and is less than other."""
+        self._validate_compareable(other)
+        if self.val >= other:
+            if type(self.val) is datetime.datetime:
+                self._err('Expected <%s> to be less than <%s>, but was not.' % (self.val.strftime('%Y-%m-%d %H:%M:%S'), other.strftime('%Y-%m-%d %H:%M:%S')))
+            else:
+                self._err('Expected <%s> to be less than <%s>, but was not.' % (self.val, other))
+        return self
+
+    def is_less_than_or_equal_to(self, other):
+        """Asserts that val is numeric and is less than or equal to other."""
+        self._validate_compareable(other)
+        if self.val > other:
+            if type(self.val) is datetime.datetime:
+                self._err('Expected <%s> to be less than or equal to <%s>, but was not.' % (self.val.strftime('%Y-%m-%d %H:%M:%S'), other.strftime('%Y-%m-%d %H:%M:%S')))
+            else:
+                self._err('Expected <%s> to be less than or equal to <%s>, but was not.' % (self.val, other))
+        return self
+
+    def is_positive(self):
+        """Asserts that val is numeric and greater than zero."""
+        return self.is_greater_than(0)
+
+    def is_negative(self):
+        """Asserts that val is numeric and less than zero."""
+        return self.is_less_than(0)
+
+    def is_between(self, low, high):
+        """Asserts that val is numeric and is between low and high."""
+        val_type = type(self.val)
+        self._validate_between_args(val_type, low, high)
+
+        if self.val < low or self.val > high:
+            if val_type is datetime.datetime:
+                self._err('Expected <%s> to be between <%s> and <%s>, but was not.' % (self.val.strftime('%Y-%m-%d %H:%M:%S'), low.strftime('%Y-%m-%d %H:%M:%S'), high.strftime('%Y-%m-%d %H:%M:%S')))
+            else:
+                self._err('Expected <%s> to be between <%s> and <%s>, but was not.' % (self.val, low, high))
+        return self
+
+    def is_not_between(self, low, high):
+        """Asserts that val is numeric and is between low and high."""
+        val_type = type(self.val)
+        self._validate_between_args(val_type, low, high)
+
+        if self.val >= low and self.val <= high:
+            if val_type is datetime.datetime:
+                self._err('Expected <%s> to not be between <%s> and <%s>, but was.' % (self.val.strftime('%Y-%m-%d %H:%M:%S'), low.strftime('%Y-%m-%d %H:%M:%S'), high.strftime('%Y-%m-%d %H:%M:%S')))
+            else:
+                self._err('Expected <%s> to not be between <%s> and <%s>, but was.' % (self.val, low, high))
+        return self
+
+    def is_close_to(self, other, tolerance):
+        """Asserts that val is numeric and is close to other within tolerance."""
+        self._validate_close_to_args(self.val, other, tolerance)
+
+        if self.val < (other-tolerance) or self.val > (other+tolerance):
+            if type(self.val) is datetime.datetime:
+                tolerance_seconds = tolerance.days * 86400 + tolerance.seconds + tolerance.microseconds / 1000000
+                h, rem = divmod(tolerance_seconds, 3600)
+                m, s = divmod(rem, 60)
+                self._err('Expected <%s> to be close to <%s> within tolerance <%d:%02d:%02d>, but was not.' % (self.val.strftime('%Y-%m-%d %H:%M:%S'), other.strftime('%Y-%m-%d %H:%M:%S'), h, m, s))
+            else:
+                self._err('Expected <%s> to be close to <%s> within tolerance <%s>, but was not.' % (self.val, other, tolerance))
+        return self
+
+    def is_not_close_to(self, other, tolerance):
+        """Asserts that val is numeric and is not close to other within tolerance."""
+        self._validate_close_to_args(self.val, other, tolerance)
+
+        if self.val >= (other-tolerance) and self.val <= (other+tolerance):
+            if type(self.val) is datetime.datetime:
+                tolerance_seconds = tolerance.days * 86400 + tolerance.seconds + tolerance.microseconds / 1000000
+                h, rem = divmod(tolerance_seconds, 3600)
+                m, s = divmod(rem, 60)
+                self._err('Expected <%s> to not be close to <%s> within tolerance <%d:%02d:%02d>, but was.' % (self.val.strftime('%Y-%m-%d %H:%M:%S'), other.strftime('%Y-%m-%d %H:%M:%S'), h, m, s))
+            else:
+                self._err('Expected <%s> to not be close to <%s> within tolerance <%s>, but was.' % (self.val, other, tolerance))
+        return self
+
+### string assertions ###
+    def is_equal_to_ignoring_case(self, other):
+        """Asserts that val is case-insensitive equal to other."""
+        if not isinstance(self.val, str_types):
+            raise TypeError('val is not a string')
+        if not isinstance(other, str_types):
+            raise TypeError('given arg must be a string')
+        if self.val.lower() != other.lower():
+            self._err('Expected <%s> to be case-insensitive equal to <%s>, but was not.' % (self.val, other))
+        return self
+
+    def contains_ignoring_case(self, *items):
+        """Asserts that val is string and contains the given item or items."""
+        if len(items) == 0:
+            raise ValueError('one or more args must be given')
+        if isinstance(self.val, str_types):
+            if len(items) == 1:
+                if not isinstance(items[0], str_types):
+                    raise TypeError('given arg must be a string')
+                if items[0].lower() not in self.val.lower():
+                    self._err('Expected <%s> to case-insensitive contain item <%s>, but did not.' % (self.val, items[0]))
+            else:
+                missing = []
+                for i in items:
+                    if not isinstance(i, str_types):
+                        raise TypeError('given args must all be strings')
+                    if i.lower() not in self.val.lower():
+                        missing.append(i)
+                if missing:
+                    self._err('Expected <%s> to case-insensitive contain items %s, but did not contain %s.' % (self.val, self._fmt_items(items), self._fmt_items(missing)))
+        elif isinstance(self.val, collections.Iterable):
+            missing = []
+            for i in items:
+                if not isinstance(i, str_types):
+                    raise TypeError('given args must all be strings')
+                found = False
+                for v in self.val:
+                    if not isinstance(v, str_types):
+                        raise TypeError('val items must all be strings')
+                    if i.lower() == v.lower():
+                        found = True
+                        break
+                if not found:
+                    missing.append(i)
+            if missing:
+                self._err('Expected <%s> to case-insensitive contain items %s, but did not contain %s.' % (self.val, self._fmt_items(items), self._fmt_items(missing)))
+        else:
+            raise TypeError('val is not a string or iterable')
+        return self
+
+    def starts_with(self, prefix):
+        """Asserts that val is string or iterable and starts with prefix."""
+        if prefix is None:
+            raise TypeError('given prefix arg must not be none')
+        if isinstance(self.val, str_types):
+            if not isinstance(prefix, str_types):
+                raise TypeError('given prefix arg must be a string')
+            if len(prefix) == 0:
+                raise ValueError('given prefix arg must not be empty')
+            if not self.val.startswith(prefix):
+                self._err('Expected <%s> to start with <%s>, but did not.' % (self.val, prefix))
+        elif isinstance(self.val, collections.Iterable):
+            if len(self.val) == 0:
+                raise ValueError('val must not be empty')
+            first = next(iter(self.val))
+            if first != prefix:
+                self._err('Expected %s to start with <%s>, but did not.' % (self.val, prefix))
+        else:
+            raise TypeError('val is not a string or iterable')
+        return self
+
+    def ends_with(self, suffix):
+        """Asserts that val is string or iterable and ends with suffix."""
+        if suffix is None:
+            raise TypeError('given suffix arg must not be none')
+        if isinstance(self.val, str_types):
+            if not isinstance(suffix, str_types):
+                raise TypeError('given suffix arg must be a string')
+            if len(suffix) == 0:
+                raise ValueError('given suffix arg must not be empty')
+            if not self.val.endswith(suffix):
+                self._err('Expected <%s> to end with <%s>, but did not.' % (self.val, suffix))
+        elif isinstance(self.val, collections.Iterable):
+            if len(self.val) == 0:
+                raise ValueError('val must not be empty')
+            last = None
+            for last in self.val:
+                pass
+            if last != suffix:
+                self._err('Expected %s to end with <%s>, but did not.' % (self.val, suffix))
+        else:
+            raise TypeError('val is not a string or iterable')
+        return self
+
+    def matches(self, pattern):
+        """Asserts that val is string and matches regex pattern."""
+        if not isinstance(self.val, str_types):
+            raise TypeError('val is not a string')
+        if not isinstance(pattern, str_types):
+            raise TypeError('given pattern arg must be a string')
+        if len(pattern) == 0:
+            raise ValueError('given pattern arg must not be empty')
+        if re.search(pattern, self.val) is None:
+            self._err('Expected <%s> to match pattern <%s>, but did not.' % (self.val, pattern))
+        return self
+
+    def does_not_match(self, pattern):
+        """Asserts that val is string and does not match regex pattern."""
+        if not isinstance(self.val, str_types):
+            raise TypeError('val is not a string')
+        if not isinstance(pattern, str_types):
+            raise TypeError('given pattern arg must be a string')
+        if len(pattern) == 0:
+            raise ValueError('given pattern arg must not be empty')
+        if re.search(pattern, self.val) is not None:
+            self._err('Expected <%s> to not match pattern <%s>, but did.' % (self.val, pattern))
+        return self
+
+    def is_alpha(self):
+        """Asserts that val is non-empty string and all characters are alphabetic."""
+        if not isinstance(self.val, str_types):
+            raise TypeError('val is not a string')
+        if len(self.val) == 0:
+            raise ValueError('val is empty')
+        if not self.val.isalpha():
+            self._err('Expected <%s> to contain only alphabetic chars, but did not.' % self.val)
+        return self
+
+    def is_digit(self):
+        """Asserts that val is non-empty string and all characters are digits."""
+        if not isinstance(self.val, str_types):
+            raise TypeError('val is not a string')
+        if len(self.val) == 0:
+            raise ValueError('val is empty')
+        if not self.val.isdigit():
+            self._err('Expected <%s> to contain only digits, but did not.' % self.val)
+        return self
+
+    def is_lower(self):
+        """Asserts that val is non-empty string and all characters are lowercase."""
+        if not isinstance(self.val, str_types):
+            raise TypeError('val is not a string')
+        if len(self.val) == 0:
+            raise ValueError('val is empty')
+        if self.val != self.val.lower():
+            self._err('Expected <%s> to contain only lowercase chars, but did not.' % self.val)
+        return self
+
+    def is_upper(self):
+        """Asserts that val is non-empty string and all characters are uppercase."""
+        if not isinstance(self.val, str_types):
+            raise TypeError('val is not a string')
+        if len(self.val) == 0:
+            raise ValueError('val is empty')
+        if self.val != self.val.upper():
+            self._err('Expected <%s> to contain only uppercase chars, but did not.' % self.val)
+        return self
+
+    def is_unicode(self):
+        """Asserts that val is a unicode string."""
+        if type(self.val) is not unicode:
+            self._err('Expected <%s> to be unicode, but was <%s>.' % (self.val, type(self.val).__name__))
+        return self
+
+### collection assertions ###
+    def is_iterable(self):
+        """Asserts that val is iterable collection."""
+        if not isinstance(self.val, collections.Iterable):
+            self._err('Expected iterable, but was not.')
+        return self
+
+    def is_not_iterable(self):
+        """Asserts that val is not iterable collection."""
+        if isinstance(self.val, collections.Iterable):
+            self._err('Expected not iterable, but was.')
+        return self
+
+    def is_subset_of(self, *supersets):
+        """Asserts that val is iterable and a subset of the given superset or flattened superset if multiple supersets are given."""
+        if not isinstance(self.val, collections.Iterable):
+            raise TypeError('val is not iterable')
+        if len(supersets) == 0:
+            raise ValueError('one or more superset args must be given')
+
+        missing = []
+        if hasattr(self.val, 'keys') and callable(getattr(self.val, 'keys')) and hasattr(self.val, '__getitem__'):
+            # flatten superset dicts
+            superdict = {}
+            for l,j in enumerate(supersets):
+                self._check_dict_like(j, check_values=False, name='arg #%d' % (l+1))
+                for k in j.keys():
+                    superdict.update({k: j[k]})
+
+            for i in self.val.keys():
+                if i not in superdict:
+                    missing.append({i: self.val[i]}) # bad key
+                elif self.val[i] != superdict[i]:
+                    missing.append({i: self.val[i]}) # bad val
+            if missing:
+                self._err('Expected <%s> to be subset of %s, but %s %s missing.' % (self.val, self._fmt_items(superdict), self._fmt_items(missing), 'was' if len(missing) == 1 else 'were'))
+        else:
+            # flatten supersets
+            superset = set()
+            for j in supersets:
+                try:
+                    for k in j:
+                        superset.add(k)
+                except Exception:
+                    superset.add(j)
+
+            for i in self.val:
+                if i not in superset:
+                    missing.append(i)
+            if missing:
+                self._err('Expected <%s> to be subset of %s, but %s %s missing.' % (self.val, self._fmt_items(superset), self._fmt_items(missing), 'was' if len(missing) == 1 else 'were'))
+
+        return self
+
+### dict assertions ###
+    def contains_key(self, *keys):
+        """Asserts the val is a dict and contains the given key or keys.  Alias for contains()."""
+        self._check_dict_like(self.val, check_values=False, check_getitem=False)
+        return self.contains(*keys)
+
+    def does_not_contain_key(self, *keys):
+        """Asserts the val is a dict and does not contain the given key or keys.  Alias for does_not_contain()."""
+        self._check_dict_like(self.val, check_values=False, check_getitem=False)
+        return self.does_not_contain(*keys)
+
+    def contains_value(self, *values):
+        """Asserts that val is a dict and contains the given value or values."""
+        self._check_dict_like(self.val, check_getitem=False)
+        if len(values) == 0:
+            raise ValueError('one or more value args must be given')
+        missing = []
+        for v in values:
+            if v not in self.val.values():
+                missing.append(v)
+        if missing:
+            self._err('Expected <%s> to contain values %s, but did not contain %s.' % (self.val, self._fmt_items(values), self._fmt_items(missing)))
+        return self
+
+    def does_not_contain_value(self, *values):
+        """Asserts that val is a dict and does not contain the given value or values."""
+        self._check_dict_like(self.val, check_getitem=False)
+        if len(values) == 0:
+            raise ValueError('one or more value args must be given')
+        else:
+            found = []
+            for v in values:
+                if v in self.val.values():
+                    found.append(v)
+            if found:
+                self._err('Expected <%s> to not contain values %s, but did contain %s.' % (self.val, self._fmt_items(values), self._fmt_items(found)))
+        return self
+
+    def contains_entry(self, *entries):
+        """Asserts that val is a dict and contains the given entry or entries."""
+        self._check_dict_like(self.val, check_values=False)
+        if len(entries) == 0:
+            raise ValueError('one or more entry args must be given')
+        missing = []
+        for e in entries:
+            if type(e) is not dict:
+                raise TypeError('given entry arg must be a dict')
+            if len(e) != 1:
+                raise ValueError('given entry args must contain exactly one key-value pair')
+            k = next(iter(e))
+            if k not in self.val:
+                missing.append(e) # bad key
+            elif self.val[k] != e[k]:
+                missing.append(e) # bad val
+        if missing:
+            self._err('Expected <%s> to contain entries %s, but did not contain %s.' % (self.val, self._fmt_items(entries), self._fmt_items(missing)))
+        return self
+
+    def does_not_contain_entry(self, *entries):
+        """Asserts that val is a dict and does not contain the given entry or entries."""
+        self._check_dict_like(self.val, check_values=False)
+        if len(entries) == 0:
+            raise ValueError('one or more entry args must be given')
+        found = []
+        for e in entries:
+            if type(e) is not dict:
+                raise TypeError('given entry arg must be a dict')
+            if len(e) != 1:
+                raise ValueError('given entry args must contain exactly one key-value pair')
+            k = next(iter(e))
+            if k in self.val and e[k] == self.val[k]:
+                found.append(e)
+        if found:
+            self._err('Expected <%s> to not contain entries %s, but did contain %s.' % (self.val, self._fmt_items(entries), self._fmt_items(found)))
+        return self
+
+### datetime assertions ###
+    def is_before(self, other):
+        """Asserts that val is a date and is before other date."""
+        if type(self.val) is not datetime.datetime:
+            raise TypeError('val must be datetime, but was type <%s>' % type(self.val).__name__)
+        if type(other) is not datetime.datetime:
+            raise TypeError('given arg must be datetime, but was type <%s>' % type(other).__name__)
+        if self.val >= other:
+            self._err('Expected <%s> to be before <%s>, but was not.' % (self.val.strftime('%Y-%m-%d %H:%M:%S'), other.strftime('%Y-%m-%d %H:%M:%S')))
+        return self
+
+    def is_after(self, other):
+        """Asserts that val is a date and is after other date."""
+        if type(self.val) is not datetime.datetime:
+            raise TypeError('val must be datetime, but was type <%s>' % type(self.val).__name__)
+        if type(other) is not datetime.datetime:
+            raise TypeError('given arg must be datetime, but was type <%s>' % type(other).__name__)
+        if self.val <= other:
+            self._err('Expected <%s> to be after <%s>, but was not.' % (self.val.strftime('%Y-%m-%d %H:%M:%S'), other.strftime('%Y-%m-%d %H:%M:%S')))
+        return self
+
+    def is_equal_to_ignoring_milliseconds(self, other):
+        if type(self.val) is not datetime.datetime:
+            raise TypeError('val must be datetime, but was type <%s>' % type(self.val).__name__)
+        if type(other) is not datetime.datetime:
+            raise TypeError('given arg must be datetime, but was type <%s>' % type(other).__name__)
+        if self.val.date() != other.date() or self.val.hour != other.hour or self.val.minute != other.minute or self.val.second != other.second:
+            self._err('Expected <%s> to be equal to <%s>, but was not.' % (self.val.strftime('%Y-%m-%d %H:%M:%S'), other.strftime('%Y-%m-%d %H:%M:%S')))
+        return self
+
+    def is_equal_to_ignoring_seconds(self, other):
+        if type(self.val) is not datetime.datetime:
+            raise TypeError('val must be datetime, but was type <%s>' % type(self.val).__name__)
+        if type(other) is not datetime.datetime:
+            raise TypeError('given arg must be datetime, but was type <%s>' % type(other).__name__)
+        if self.val.date() != other.date() or self.val.hour != other.hour or self.val.minute != other.minute:
+            self._err('Expected <%s> to be equal to <%s>, but was not.' % (self.val.strftime('%Y-%m-%d %H:%M'), other.strftime('%Y-%m-%d %H:%M')))
+        return self
+
+    def is_equal_to_ignoring_time(self, other):
+        if type(self.val) is not datetime.datetime:
+            raise TypeError('val must be datetime, but was type <%s>' % type(self.val).__name__)
+        if type(other) is not datetime.datetime:
+            raise TypeError('given arg must be datetime, but was type <%s>' % type(other).__name__)
+        if self.val.date() != other.date():
+            self._err('Expected <%s> to be equal to <%s>, but was not.' % (self.val.strftime('%Y-%m-%d'), other.strftime('%Y-%m-%d')))
+        return self
+
+### file assertions ###
+    def exists(self):
+        """Asserts that val is a path and that it exists."""
+        if not isinstance(self.val, str_types):
+            raise TypeError('val is not a path')
+        if not os.path.exists(self.val):
+            self._err('Expected <%s> to exist, but was not found.' % self.val)
+        return self
+
+    def does_not_exist(self):
+        """Asserts that val is a path and that it does not exist."""
+        if not isinstance(self.val, str_types):
+            raise TypeError('val is not a path')
+        if os.path.exists(self.val):
+            self._err('Expected <%s> to not exist, but was found.' % self.val)
+        return self
+
+    def is_file(self):
+        """Asserts that val is an existing path to a file."""
+        self.exists()
+        if not os.path.isfile(self.val):
+            self._err('Expected <%s> to be a file, but was not.' % self.val)
+        return self
+
+    def is_directory(self):
+        """Asserts that val is an existing path to a directory."""
+        self.exists()
+        if not os.path.isdir(self.val):
+            self._err('Expected <%s> to be a directory, but was not.' % self.val)
+        return self
+
+    def is_named(self, filename):
+        """Asserts that val is an existing path to a file and that file is named filename."""
+        self.is_file()
+        if not isinstance(filename, str_types):
+            raise TypeError('given filename arg must be a path')
+        val_filename = os.path.basename(os.path.abspath(self.val))
+        if val_filename != filename:
+            self._err('Expected filename <%s> to be equal to <%s>, but was not.' % (val_filename, filename))
+        return self
+
+    def is_child_of(self, parent):
+        """Asserts that val is an existing path to a file and that file is a child of parent."""
+        self.is_file()
+        if not isinstance(parent, str_types):
+            raise TypeError('given parent directory arg must be a path')
+        val_abspath = os.path.abspath(self.val)
+        parent_abspath = os.path.abspath(parent)
+        if not val_abspath.startswith(parent_abspath):
+            self._err('Expected file <%s> to be a child of <%s>, but was not.' % (val_abspath, parent_abspath))
+        return self
+
+### collection of objects assertions ###
+    def extracting(self, *names, **kwargs):
+        """Asserts that val is collection, then extracts the named properties or named zero-arg methods into a list (or list of tuples if multiple names are given)."""
+        if not isinstance(self.val, collections.Iterable):
+            raise TypeError('val is not iterable')
+        if isinstance(self.val, str_types):
+            raise TypeError('val must not be string')
+        if len(names) == 0:
+            raise ValueError('one or more name args must be given')
+
+        def _extract(x, name):
+            if self._check_dict_like(x, check_values=False, return_as_bool=True):
+                if name in x:
+                    return x[name]
+                else:
+                    raise ValueError('item keys %s did not contain key <%s>' % (list(x.keys()), name))
+            elif hasattr(x, name):
+                attr = getattr(x, name)
+                if callable(attr):
+                    try:
+                        return attr()
+                    except TypeError:
+                        raise ValueError('val method <%s()> exists, but is not zero-arg method' % name)
+                else:
+                    return attr
+            else:
+                raise ValueError('val does not have property or zero-arg method <%s>' % name)
+
+        def _filter(x):
+            if 'filter' in kwargs:
+                if isinstance(kwargs['filter'], str_types):
+                    return bool(_extract(x, kwargs['filter']))
+                elif self._check_dict_like(kwargs['filter'], check_values=False, return_as_bool=True):
+                    for k in kwargs['filter']:
+                        if isinstance(k, str_types):
+                            if _extract(x, k) != kwargs['filter'][k]:
+                                return False
+                    return True
+                elif callable(kwargs['filter']):
+                    return kwargs['filter'](x)
+                return False
+            return True
+
+        def _sort(x):
+            if 'sort' in kwargs:
+                if isinstance(kwargs['sort'], str_types):
+                    return _extract(x, kwargs['sort'])
+                elif isinstance(kwargs['sort'], collections.Iterable):
+                    items = []
+                    for k in kwargs['sort']:
+                        if isinstance(k, str_types):
+                            items.append(_extract(x, k))
+                    return tuple(items)
+                elif callable(kwargs['sort']):
+                    return kwargs['sort'](x)
+            return 0
+
+        extracted = []
+        for i in sorted(self.val, key=lambda x: _sort(x)):
+            if _filter(i):
+                items = [_extract(i, name) for name in names]
+                extracted.append(tuple(items) if len(items) > 1 else items[0])
+        return AssertionBuilder(extracted, self.description, self.kind)
+
+### dynamic assertions ###
+    def __getattr__(self, attr):
+        """Asserts that val has attribute attr and that attribute's value is equal to other via a dynamic assertion of the form: has_<attr>()."""
+        if not attr.startswith('has_'):
+            raise AttributeError('assertpy has no assertion <%s()>' % attr)
+
+        attr_name = attr[4:]
+        err_msg = False
+        is_dict = isinstance(self.val, collections.Iterable) and hasattr(self.val, '__getitem__')
+
+        if not hasattr(self.val, attr_name):
+            if is_dict:
+                if attr_name not in self.val:
+                    err_msg = 'Expected key <%s>, but val has no key <%s>.' % (attr_name, attr_name)
+            else:
+                err_msg = 'Expected attribute <%s>, but val has no attribute <%s>.' % (attr_name, attr_name)
+
+        def _wrapper(*args, **kwargs):
+            if err_msg:
+                self._err(err_msg) # ok to raise AssertionError now that we are inside wrapper
+            else:
+                if len(args) != 1:
+                    raise TypeError('assertion <%s()> takes exactly 1 argument (%d given)' % (attr, len(args)))
+
+                try:
+                    val_attr = getattr(self.val, attr_name)
+                except AttributeError:
+                    val_attr = self.val[attr_name]
+
+                if callable(val_attr):
+                    try:
+                        actual = val_attr()
+                    except TypeError:
+                        raise TypeError('val does not have zero-arg method <%s()>' % attr_name)
+                else:
+                    actual = val_attr
+
+                expected = args[0]
+                if actual != expected:
+                    self._err('Expected <%s> to be equal to <%s> on %s <%s>, but was not.' % (actual, expected, 'key' if is_dict else 'attribute', attr_name))
+            return self
+
+        return _wrapper
+
+### expected exceptions ###
+    def raises(self, ex):
+        """Asserts that val is callable and that when called raises the given error."""
+        if not callable(self.val):
+            raise TypeError('val must be callable')
+        if not issubclass(ex, BaseException):
+            raise TypeError('given arg must be exception')
+        return AssertionBuilder(self.val, self.description, self.kind, ex)
+
+    def when_called_with(self, *some_args, **some_kwargs):
+        """Asserts the val callable when invoked with the given args and kwargs raises the expected exception."""
+        if not self.expected:
+            raise TypeError('expected exception not set, raises() must be called first')
+        try:
+            self.val(*some_args, **some_kwargs)
+        except BaseException as e:
+            if issubclass(type(e), self.expected):
+                # chain on with exception message as val
+                return AssertionBuilder(str(e), self.description, self.kind)
+            else:
+                # got exception, but wrong type, so raise
+                self._err('Expected <%s> to raise <%s> when called with (%s), but raised <%s>.' % (
+                    self.val.__name__,
+                    self.expected.__name__,
+                    self._fmt_args_kwargs(*some_args, **some_kwargs),
+                    type(e).__name__))
+
+        # didn't fail as expected, so raise
+        self._err('Expected <%s> to raise <%s> when called with (%s).' % (
+            self.val.__name__,
+            self.expected.__name__,
+            self._fmt_args_kwargs(*some_args, **some_kwargs)))
+
+### helpers ###
+    def _err(self, msg):
+        """Helper to raise an AssertionError, and optionally prepend custom description."""
+        out = '%s%s' % ('[%s] ' % self.description if len(self.description) > 0 else '', msg)
+        if self.kind == 'warn':
+            print(out)
+            return self
+        elif self.kind == 'soft':
+            global _soft_err
+            _soft_err.append(out)
+            return self
+        else:
+            raise AssertionError(out)
+
+    def _fmt_items(self, i):
+        if len(i) == 0:
+            return '<>'
+        elif len(i) == 1:
+            return '<%s>' % i[0]
+        else:
+            return '<%s>' % str(i).lstrip('([').rstrip(',])')
+
+    def _fmt_args_kwargs(self, *some_args, **some_kwargs):
+        """Helper to convert the given args and kwargs into a string."""
+        if some_args:
+            out_args = str(some_args).lstrip('(').rstrip(',)')
+        if some_kwargs:
+            out_kwargs = ', '.join([str(i).lstrip('(').rstrip(')').replace(', ',': ') for i in [
+                    (k,some_kwargs[k]) for k in sorted(some_kwargs.keys())]])
+
+        if some_args and some_kwargs:
+            return out_args + ', ' + out_kwargs
+        elif some_args:
+            return out_args
+        elif some_kwargs:
+            return out_kwargs
+        else:
+            return ''
+
+    def _validate_between_args(self, val_type, low, high):
+        low_type = type(low)
+        high_type = type(high)
+
+        if val_type in self.NON_COMPAREABLE_TYPES:
+            raise TypeError('ordering is not defined for type <%s>' % val_type.__name__)
+
+        if val_type in self.COMPAREABLE_TYPES:
+            if low_type is not val_type:
+                raise TypeError('given low arg must be <%s>, but was <%s>' % (val_type.__name__, low_type.__name__))
+            if high_type is not val_type:
+                raise TypeError('given high arg must be <%s>, but was <%s>' % (val_type.__name__, low_type.__name__))
+        elif isinstance(self.val, numbers.Number):
+            if isinstance(low, numbers.Number) is False:
+                raise TypeError('given low arg must be numeric, but was <%s>' % low_type.__name__)
+            if isinstance(high, numbers.Number) is False:
+                raise TypeError('given high arg must be numeric, but was <%s>' % high_type.__name__)
+        else:
+            raise TypeError('ordering is not defined for type <%s>' % val_type.__name__)
+
+        if low > high:
+            raise ValueError('given low arg must be less than given high arg')
+
+    def _validate_close_to_args(self, val, other, tolerance):
+        if type(val) is complex or type(other) is complex or type(tolerance) is complex:
+            raise TypeError('ordering is not defined for complex numbers')
+
+        if isinstance(val, numbers.Number) is False and type(val) is not datetime.datetime:
+            raise TypeError('val is not numeric or datetime')
+
+        if type(val) is datetime.datetime:
+            if type(other) is not datetime.datetime:
+                raise TypeError('given arg must be datetime, but was <%s>' % type(other).__name__)
+            if type(tolerance) is not datetime.timedelta:
+                raise TypeError('given tolerance arg must be timedelta, but was <%s>' % type(tolerance).__name__)
+        else:
+            if isinstance(other, numbers.Number) is False:
+                raise TypeError('given arg must be numeric')
+            if isinstance(tolerance, numbers.Number) is False:
+                raise TypeError('given tolerance arg must be numeric')
+            if tolerance < 0:
+                raise ValueError('given tolerance arg must be positive')
+
+    def _check_dict_like(self, d, check_keys=True, check_values=True, check_getitem=True, name='val', return_as_bool=False):
+        if not isinstance(d, collections.Iterable):
+            if return_as_bool:
+                return False
+            else:
+                raise TypeError('%s <%s> is not dict-like: not iterable' % (name, type(d).__name__))
+        if check_keys:
+            if not hasattr(d, 'keys') or not callable(getattr(d, 'keys')):
+                if return_as_bool:
+                    return False
+                else:
+                    raise TypeError('%s <%s> is not dict-like: missing keys()' % (name, type(d).__name__))
+        if check_values:
+            if not hasattr(d, 'values') or not callable(getattr(d, 'values')):
+                if return_as_bool:
+                    return False
+                else:
+                    raise TypeError('%s <%s> is not dict-like: missing values()' % (name, type(d).__name__))
+        if check_getitem:
+            if not hasattr(d, '__getitem__'):
+                if return_as_bool:
+                    return False
+                else:
+                    raise TypeError('%s <%s> is not dict-like: missing [] accessor' % (name, type(d).__name__))
+        if return_as_bool:
+            return True
+
+    def _dict_not_equal(self, val, other, ignore=None, include=None):
+        if ignore or include:
+            ignores = self._dict_ignore(ignore)
+            includes = self._dict_include(include)
+
+            # guarantee include keys are in val
+            if include:
+                missing = []
+                for i in includes:
+                    if i not in val:
+                        missing.append(i)
+                if missing:
+                    self._err('Expected <%s> to include key%s %s, but did not include key%s %s.' % (
+                        val,
+                        '' if len(includes) == 1 else 's',
+                        self._fmt_items(['.'.join([str(s) for s in i]) if type(i) is tuple else i for i in includes]),
+                        '' if len(missing) == 1 else 's',
+                        self._fmt_items(missing)))
+
+            if ignore and include:
+                k1 = set([k for k in val if k not in ignores and k in includes])
+            elif ignore:
+                k1 = set([k for k in val if k not in ignores])
+            else: # include
+                k1 = set([k for k in val if k in includes])
+
+            if ignore and include:
+                k2 = set([k for k in other if k not in ignores and k in includes])
+            elif ignore:
+                k2 = set([k for k in other if k not in ignores])
+            else: # include
+                k2 = set([k for k in other if k in includes])
+
+            if k1 != k2:
+                return True
+            else:
+                for k in k1:
+                    if self._check_dict_like(val[k], check_values=False, return_as_bool=True) and self._check_dict_like(other[k], check_values=False, return_as_bool=True):
+                        return self._dict_not_equal(val[k], other[k],
+                            ignore=[i[1:] for i in ignores if type(i) is tuple and i[0] == k] if ignore else None,
+                            include=[i[1:] for i in self._dict_ignore(include) if type(i) is tuple and i[0] == k] if include else None)
+                    elif val[k] != other[k]:
+                        return True
+            return False
+        else:
+            return val != other
+
+    def _dict_ignore(self, ignore):
+        return [i[0] if type(i) is tuple and len(i) == 1 else i \
+            for i in (ignore if type(ignore) is list else [ignore])]
+
+    def _dict_include(self, include):
+        return [i[0] if type(i) is tuple else i \
+            for i in (include if type(include) is list else [include])]
+
+    def _dict_err(self, val, other, ignore=None, include=None):
+        def _dict_repr(d, other):
+            out = ''
+            ellip = False
+            for k,v in d.items():
+                if k not in other:
+                    out += '%s%s: %s' % (', ' if len(out) > 0 else '', repr(k), repr(v))
+                elif v != other[k]:
+                    out += '%s%s: %s' % (', ' if len(out) > 0 else '', repr(k),
+                        _dict_repr(v, other[k]) if self._check_dict_like(v, check_values=False, return_as_bool=True) and self._check_dict_like(other[k], check_values=False, return_as_bool=True) else repr(v)
+                    )
+                else:
+                    ellip = True
+            return '{%s%s}' % ('..' if ellip and len(out) == 0 else '.., ' if ellip else '', out)
+
+        if ignore:
+            ignores = self._dict_ignore(ignore)
+            ignore_err = ' ignoring keys %s' % self._fmt_items(['.'.join([str(s) for s in i]) if type(i) is tuple else i for i in ignores])
+        if include:
+            includes = self._dict_ignore(include)
+            include_err = ' including keys %s' % self._fmt_items(['.'.join([str(s) for s in i]) if type(i) is tuple else i for i in includes])
+
+        self._err('Expected <%s> to be equal to <%s>%s%s, but was not.' % (
+            _dict_repr(val, other),
+            _dict_repr(other, val),
+            ignore_err if ignore else '',
+            include_err if include else ''
+        ))
+
+### snapshot testing ###
+    def snapshot(self, id=None, path='__snapshots'):
+        if sys.version_info[0] < 3:
+            raise NotImplementedError('snapshot testing requires Python 3')
+
+        class _Encoder(json.JSONEncoder):
+            def default(self, o):
+                if isinstance(o, set):
+                    return {'__type__': 'set', '__data__': list(o)}
+                elif isinstance(o, complex):
+                    return {'__type__': 'complex', '__data__': [o.real, o.imag]}
+                elif isinstance(o, datetime.datetime):
+                    return {'__type__': 'datetime', '__data__': o.strftime('%Y-%m-%d %H:%M:%S')}
+                elif '__dict__' in dir(o) and type(o) is not type:
+                    return {
+                        '__type__': 'instance',
+                        '__class__': o.__class__.__name__,
+                        '__module__': o.__class__.__module__,
+                        '__data__': o.__dict__
+                    }
+                return json.JSONEncoder.default(self, o)
+
+        class _Decoder(json.JSONDecoder):
+            def __init__(self):
+                json.JSONDecoder.__init__(self, object_hook=self.object_hook)
+
+            def object_hook(self, d):
+                if '__type__' in d and '__data__' in d:
+                    if d['__type__'] == 'set':
+                        return set(d['__data__'])
+                    elif d['__type__'] == 'complex':
+                        return complex(d['__data__'][0], d['__data__'][1])
+                    elif d['__type__'] == 'datetime':
+                        return datetime.datetime.strptime(d['__data__'], '%Y-%m-%d %H:%M:%S')
+                    elif d['__type__'] == 'instance':
+                        mod = __import__(d['__module__'], fromlist=[d['__class__']])
+                        klass = getattr(mod, d['__class__'])
+                        inst = klass.__new__(klass)
+                        inst.__dict__ = d['__data__']
+                        return inst
+                return d
+
+        def _save(name, val):
+            with open(name, 'w') as fp:
+                json.dump(val, fp, indent=2, separators=(',', ': '), sort_keys=True, cls=_Encoder)
+
+        def _load(name):
+            with open(name, 'r') as fp:
+                return json.load(fp, cls=_Decoder)
+
+        def _name(path, name):
+            try:
+                return os.path.join(path, 'snap-%s.json' % name.replace(' ','_').lower())
+            except Exception:
+                raise ValueError('failed to create snapshot filename, either bad path or bad name')
+
+        if id:
+            # custom id
+            snapname = _name(path, id)
+        else:
+            # make id from filename and line number
+            f = inspect.currentframe()
+            fpath = os.path.basename(f.f_back.f_code.co_filename)
+            fname = os.path.splitext(fpath)[0]
+            lineno = str(f.f_back.f_lineno)
+            snapname = _name(path, fname)
+
+        if not os.path.exists(path):
+            os.makedirs(path)
+
+        if os.path.isfile(snapname):
+            # snap exists, so load
+            snap = _load(snapname)
+
+            if id:
+                # custom id, so test
+                return self.is_equal_to(snap)
+            else:
+                if lineno in snap:
+                    # found sub-snap, so test
+                    return self.is_equal_to(snap[lineno])
+                else:
+                    # lineno not in snap, so create sub-snap and pass
+                    snap[lineno] = self.val
+                    _save(snapname, snap)
+        else:
+            # no snap, so create and pass
+            _save(snapname, self.val if id else {lineno: self.val})
+
+        return self
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/assertpy/assertpy.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/assertpy/assertpy.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..1a647ce5b5dc4d68ba67ab47d376bac2d21a0433
GIT binary patch
literal 63355
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

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/easy_install.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/easy_install.py
new file mode 100644
index 0000000..d87e984
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/easy_install.py
@@ -0,0 +1,5 @@
+"""Run the EasyInstall command"""
+
+if __name__ == '__main__':
+    from setuptools.command.easy_install import main
+    main()
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/easy_install.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/easy_install.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..0746cc4f92ac6f5995c85fe66357bf239b2f38ad
GIT binary patch
literal 369
zcmZSn%**AGdLky70ScHH7#JKF7#NBT7#J8*7#N}$7*ZJ-QWzPsnHY+67*d!RQkWTX
zm>6=I8KRgO7*m-Uni&`v^B5RXSQvseSV20a85kIXO7j#-GEx;>6N@W7^NLFnb8-}t
z^K)|(^HNGU7#JAh<8u=;^Wx((|NsC0UxSf>fuV$jfq?-e=%)c<m9T?VrQ|2a$3u1G
zCFZ8a$Ct>1>_{ysEhx#)&neb}nyQzYSX>#O39%{&WS|DfM+l-gje&tdzo00yEU_e2
zzbvsxKP^8eCAFwnKPg4OJSizJ*EF}-$S}z~y(-<p)S^5mtIEs(1k&^LL-Y$W3v{7|
u>$;VBcp3-j7sK74k8HPIK_%F|Ho5sJr8%i~Ag2_wF)%Q&G4U`8FaiKWa$e^E

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip-19.1.dist-info/INSTALLER b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip-19.1.dist-info/INSTALLER
new file mode 100644
index 0000000..a1b589e
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip-19.1.dist-info/INSTALLER
@@ -0,0 +1 @@
+pip
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip-19.1.dist-info/LICENSE.txt b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip-19.1.dist-info/LICENSE.txt
new file mode 100644
index 0000000..737fec5
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip-19.1.dist-info/LICENSE.txt
@@ -0,0 +1,20 @@
+Copyright (c) 2008-2019 The pip developers (see AUTHORS.txt file)
+
+Permission is hereby granted, free of charge, to any person obtaining
+a copy of this software and associated documentation files (the
+"Software"), to deal in the Software without restriction, including
+without limitation the rights to use, copy, modify, merge, publish,
+distribute, sublicense, and/or sell copies of the Software, and to
+permit persons to whom the Software is furnished to do so, subject to
+the following conditions:
+
+The above copyright notice and this permission notice shall be
+included in all copies or substantial portions of the Software.
+
+THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
+EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
+MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
+NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
+LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
+OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
+WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip-19.1.dist-info/METADATA b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip-19.1.dist-info/METADATA
new file mode 100644
index 0000000..5f48a62
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip-19.1.dist-info/METADATA
@@ -0,0 +1,75 @@
+Metadata-Version: 2.1
+Name: pip
+Version: 19.1
+Summary: The PyPA recommended tool for installing Python packages.
+Home-page: https://pip.pypa.io/
+Author: The pip developers
+Author-email: pypa-dev@groups.google.com
+License: MIT
+Keywords: distutils easy_install egg setuptools wheel virtualenv
+Platform: UNKNOWN
+Classifier: Development Status :: 5 - Production/Stable
+Classifier: Intended Audience :: Developers
+Classifier: License :: OSI Approved :: MIT License
+Classifier: Topic :: Software Development :: Build Tools
+Classifier: Programming Language :: Python
+Classifier: Programming Language :: Python :: 2
+Classifier: Programming Language :: Python :: 2.7
+Classifier: Programming Language :: Python :: 3
+Classifier: Programming Language :: Python :: 3.4
+Classifier: Programming Language :: Python :: 3.5
+Classifier: Programming Language :: Python :: 3.6
+Classifier: Programming Language :: Python :: 3.7
+Classifier: Programming Language :: Python :: Implementation :: CPython
+Classifier: Programming Language :: Python :: Implementation :: PyPy
+Requires-Python: >=2.7,!=3.0.*,!=3.1.*,!=3.2.*,!=3.3.*
+
+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`_
+* `Release notes`_
+
+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 and feel free to jump on the developer mailing lists and chat rooms:
+
+* `GitHub page`_
+* `Dev mailing list`_
+* `Dev IRC`_
+
+Code of Conduct
+---------------
+
+Everyone interacting in the pip project's codebases, issue trackers, chat
+rooms, and mailing lists is expected to follow the `PyPA Code of Conduct`_.
+
+.. _package installer: https://packaging.python.org/en/latest/current/
+.. _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
+.. _GitHub page: https://github.com/pypa/pip
+.. _Issue tracking: https://github.com/pypa/pip/issues
+.. _Discourse channel: https://discuss.python.org/c/packaging
+.. _Dev mailing list: https://groups.google.com/forum/#!forum/pypa-dev
+.. _User IRC: https://webchat.freenode.net/?channels=%23pypa
+.. _Dev IRC: https://webchat.freenode.net/?channels=%23pypa-dev
+.. _PyPA Code of Conduct: https://www.pypa.io/en/latest/code-of-conduct/
+
+
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip-19.1.dist-info/RECORD b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip-19.1.dist-info/RECORD
new file mode 100644
index 0000000..8b51f6f
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip-19.1.dist-info/RECORD
@@ -0,0 +1,618 @@
+../../../bin/pip,sha256=bIoROJz0KisyAO97slLnRSlZuGfjzipmeKQHbDZYX_c,273
+../../../bin/pip2,sha256=bIoROJz0KisyAO97slLnRSlZuGfjzipmeKQHbDZYX_c,273
+../../../bin/pip2.7,sha256=bIoROJz0KisyAO97slLnRSlZuGfjzipmeKQHbDZYX_c,273
+pip-19.1.dist-info/INSTALLER,sha256=zuuue4knoyJ-UwPPXg8fezS7VCrXJQrAP7zeNuwvFQg,4
+pip-19.1.dist-info/LICENSE.txt,sha256=W6Ifuwlk-TatfRU2LR7W1JMcyMj5_y1NkRkOEJvnRDE,1090
+pip-19.1.dist-info/METADATA,sha256=beBgNX95MIue6GG4pjR72SBngkDbdZydSE1mLZJQngw,2890
+pip-19.1.dist-info/RECORD,,
+pip-19.1.dist-info/WHEEL,sha256=HX-v9-noUkyUoxyZ1PMSuS7auUxDAR4VBdoYLqD0xws,110
+pip-19.1.dist-info/entry_points.txt,sha256=S_zfxY25QtQDVY1BiLAmOKSkkI5llzCKPLiYOSEupsY,98
+pip-19.1.dist-info/top_level.txt,sha256=zuuue4knoyJ-UwPPXg8fezS7VCrXJQrAP7zeNuwvFQg,4
+pip/__init__.py,sha256=FmpL3q9nmKqFLOCMcYN8LoGCA7mrESG-HiX5Ksm8Kls,21
+pip/__init__.pyc,,
+pip/__main__.py,sha256=L3IHqBeasELUHvwy5CT_izVEMhM12tve289qut49DvU,623
+pip/__main__.pyc,,
+pip/_internal/__init__.py,sha256=Di4rpoQhA2Kx0Dm0THczf61CDOXcPokR2FIpyKkRm1Y,2870
+pip/_internal/__init__.pyc,,
+pip/_internal/build_env.py,sha256=ZUpR-00pxQc-Mw750jyBVA-oWb4WHtpK63pfiTHd8qU,7392
+pip/_internal/build_env.pyc,,
+pip/_internal/cache.py,sha256=PQesJm1JrjgAya3VyV6qkbnfACG23c1wQ7PaSw_0F-Y,7656
+pip/_internal/cache.pyc,,
+pip/_internal/cli/__init__.py,sha256=FkHBgpxxb-_gd6r1FjnNhfMOzAUYyXoXKJ6abijfcFU,132
+pip/_internal/cli/__init__.pyc,,
+pip/_internal/cli/autocompletion.py,sha256=ptvsMdGjq42pzoY4skABVF43u2xAtLJlXAulPi-A10Y,6083
+pip/_internal/cli/autocompletion.pyc,,
+pip/_internal/cli/base_command.py,sha256=2SbVZ2o3KmVdeJlK4l1lP6y_ZMFZ8VkDp9ns1ByZ-xM,12629
+pip/_internal/cli/base_command.pyc,,
+pip/_internal/cli/cmdoptions.py,sha256=IA1XAgTJ1oWXp1oF3CkE8mpUx8vqIysyd7hlEZk7wWE,23813
+pip/_internal/cli/cmdoptions.pyc,,
+pip/_internal/cli/main_parser.py,sha256=YH_w_hApq2pyS_G5tZlbIe7g_HUIcKE820jhnv0piVA,3002
+pip/_internal/cli/main_parser.pyc,,
+pip/_internal/cli/parser.py,sha256=VZKUKJPbU6I2cHPLDOikin-aCx7OvLcZ3fzYp3xytd8,9378
+pip/_internal/cli/parser.pyc,,
+pip/_internal/cli/status_codes.py,sha256=F6uDG6Gj7RNKQJUDnd87QKqI16Us-t-B0wPF_4QMpWc,156
+pip/_internal/cli/status_codes.pyc,,
+pip/_internal/commands/__init__.py,sha256=7fscm9bUGJInZwWY7VjH2pPC7HUWQWyjYMEIB33L9CY,2223
+pip/_internal/commands/__init__.pyc,,
+pip/_internal/commands/check.py,sha256=liigNVif0iz2mBfhvsajrLZT5zM5KIvgmKvhAW91EzA,1430
+pip/_internal/commands/check.pyc,,
+pip/_internal/commands/completion.py,sha256=hqvCvoxsIHjysiD7olHKTqK2lzE1_lS6LWn69kN5qyI,2929
+pip/_internal/commands/completion.pyc,,
+pip/_internal/commands/configuration.py,sha256=Il76e-ERfEHtW2GbV1aTR6o-xurh-LVv2NCea7erP4s,8020
+pip/_internal/commands/configuration.pyc,,
+pip/_internal/commands/download.py,sha256=XPe3Kuj9iZfXwOiJq70mYVYNZD5lJCLnGT_C61cOsKw,6623
+pip/_internal/commands/download.pyc,,
+pip/_internal/commands/freeze.py,sha256=VvS3G0wrm_9BH3B7Ex5msLL_1UQTtCq5G8dDI63Iemo,3259
+pip/_internal/commands/freeze.pyc,,
+pip/_internal/commands/hash.py,sha256=K1JycsD-rpjqrRcL_ijacY9UKmI82pQcLYq4kCM4Pv0,1681
+pip/_internal/commands/hash.pyc,,
+pip/_internal/commands/help.py,sha256=MwBhPJpW1Dt3GfJV3V8V6kgAy_pXT0jGrZJB1wCTW-E,1090
+pip/_internal/commands/help.pyc,,
+pip/_internal/commands/install.py,sha256=vSb8TfUHwz3HJ5cA-JnPP3X84ONQ0wkCztw0pHFbmsc,22841
+pip/_internal/commands/install.pyc,,
+pip/_internal/commands/list.py,sha256=EtKEUotPbLCzzcWrZqEiEXi4ic00dgUOKUeNU0y7Pfg,10166
+pip/_internal/commands/list.pyc,,
+pip/_internal/commands/search.py,sha256=sLZ9icKMEEGekHvzRRZMiTd1zCFIZeDptyyU1mQCYzk,4728
+pip/_internal/commands/search.pyc,,
+pip/_internal/commands/show.py,sha256=bE-ucu8fAjTTENpRRKhwD3QSWR8Rss7YgKAbMJoxock,6273
+pip/_internal/commands/show.pyc,,
+pip/_internal/commands/uninstall.py,sha256=h0gfPF5jylDESx_IHgF6bZME7QAEOHzQHdn65GP-jrE,2963
+pip/_internal/commands/uninstall.pyc,,
+pip/_internal/commands/wheel.py,sha256=7MNPZqK9WWxZC3TgzvMBH-RPRlOFLpwq927lkzUiUjI,7167
+pip/_internal/commands/wheel.pyc,,
+pip/_internal/configuration.py,sha256=xit1f8ZdnHz-AHzWAKTUa_gZzlIIM-5AgK30glB71ik,13115
+pip/_internal/configuration.pyc,,
+pip/_internal/download.py,sha256=0_8jUtL4SLZe4qo8Fe66qkbO69gUG-IPbp932WOHyFs,35147
+pip/_internal/download.pyc,,
+pip/_internal/exceptions.py,sha256=ryXWmEJpSHr3yXXk1efWHSzQwAjBdBJiKR5kCQvjgPA,9117
+pip/_internal/exceptions.pyc,,
+pip/_internal/index.py,sha256=jVzHqVuP2CJh9YCyp2Zbx1NSmE_VBxhc26fYKF8aer8,42130
+pip/_internal/index.pyc,,
+pip/_internal/locations.py,sha256=-N3f1I24gcPTdW52onPnySDoQUIn_TtPYV99WwsjxRE,6932
+pip/_internal/locations.pyc,,
+pip/_internal/models/__init__.py,sha256=3DHUd_qxpPozfzouoqa9g9ts1Czr5qaHfFxbnxriepM,63
+pip/_internal/models/__init__.pyc,,
+pip/_internal/models/candidate.py,sha256=_IzS-yw0h2UHfZALsZ2mxkeGNSNuNGspjSn2JfZ-ZHM,1045
+pip/_internal/models/candidate.pyc,,
+pip/_internal/models/format_control.py,sha256=ap8Swa26ocSXBxIuCvaDBRZjxdKUFuwC-bfqXQHWtKw,2250
+pip/_internal/models/format_control.pyc,,
+pip/_internal/models/index.py,sha256=K59A8-hVhBM20Xkahr4dTwP7OjkJyEqXH11UwHFVgqM,1060
+pip/_internal/models/index.pyc,,
+pip/_internal/models/link.py,sha256=Hqu72UgH266njr2z2kTnIG-sQiPtjENDbPqXFzT-84s,4783
+pip/_internal/models/link.pyc,,
+pip/_internal/operations/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
+pip/_internal/operations/__init__.pyc,,
+pip/_internal/operations/check.py,sha256=CZHaksHKUMo58wGHGhhKlPrpcRMHObouzzyd9pMRFt8,5109
+pip/_internal/operations/check.pyc,,
+pip/_internal/operations/freeze.py,sha256=_Ffl2HpoWLLHaiB1XyTjKIA3QWC8H-E1ib6xJgX_mRE,9279
+pip/_internal/operations/freeze.pyc,,
+pip/_internal/operations/prepare.py,sha256=hqzdPNAJLZVEpJQATn_0aSMJqy8xPvW36j9mjFKw54s,17102
+pip/_internal/operations/prepare.pyc,,
+pip/_internal/pep425tags.py,sha256=jyBorYxepVJeHNo69TE-3UxJXsGO2XvGxveSWQDi_Wo,13128
+pip/_internal/pep425tags.pyc,,
+pip/_internal/pyproject.py,sha256=I1S69bAIy0kwKZSkP3Mz5cdbXXlBSfuQHmdCCm9bwJ4,10788
+pip/_internal/pyproject.pyc,,
+pip/_internal/req/__init__.py,sha256=Y2SjAuMFsSt3dkiK8kkiQAfv8sHrjl0PAT63FKFT0tM,2364
+pip/_internal/req/__init__.pyc,,
+pip/_internal/req/constructors.py,sha256=4KlO_-G89XYZW1VnzHwV34oCvR6ilmxFqSSGLgv4PEw,11399
+pip/_internal/req/constructors.pyc,,
+pip/_internal/req/req_file.py,sha256=mZoQvhHZJwgljrXDH8CLXaNoUK4sM8_bRfK9Po2fM80,13714
+pip/_internal/req/req_file.pyc,,
+pip/_internal/req/req_install.py,sha256=sLu2Z3CKEtnKUI0j0QsDuPidlU2PJihxm7K_O-5Jm3A,40068
+pip/_internal/req/req_install.pyc,,
+pip/_internal/req/req_set.py,sha256=PaDc5EswLQhxBMFbuKbJ0frZbMNKocmA8OGqIWT-9EY,7860
+pip/_internal/req/req_set.pyc,,
+pip/_internal/req/req_tracker.py,sha256=wBpDzSDSYwpUfW4K43NrEOCCp1r6stuubfLc65Y95EM,3129
+pip/_internal/req/req_tracker.pyc,,
+pip/_internal/req/req_uninstall.py,sha256=rVOk8BRM_L9rsUUr9lmkV6Lm9N1Os7TEIDir6tT1Q7U,23105
+pip/_internal/req/req_uninstall.pyc,,
+pip/_internal/resolve.py,sha256=rZDMkyhUIbaytY9KsYQVez8nl21xLXgaDt8xuHvyGMI,15128
+pip/_internal/resolve.pyc,,
+pip/_internal/utils/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
+pip/_internal/utils/__init__.pyc,,
+pip/_internal/utils/appdirs.py,sha256=r9i0BZLK9KcvrzI5tqlw8ehRTtSehWGERFLy7YppG3g,9398
+pip/_internal/utils/appdirs.pyc,,
+pip/_internal/utils/compat.py,sha256=Q0cmYGBaKB4tV5E0CG11339YLxuCaqdUCSJd9vinMc8,8551
+pip/_internal/utils/compat.pyc,,
+pip/_internal/utils/deprecation.py,sha256=HYUvfCZUxwLIFlYHeZM3VmuFhXTdlw0rk4-cC14bKw4,3080
+pip/_internal/utils/deprecation.pyc,,
+pip/_internal/utils/encoding.py,sha256=tudXCoAPe9fZvNK4cmWQs2frREZ-QuGCwF_SlTyz6cI,1218
+pip/_internal/utils/encoding.pyc,,
+pip/_internal/utils/filesystem.py,sha256=ojaIDvOFOtkpKme5se6X2N8ARmQxu8cxvaaI-NFqVtk,990
+pip/_internal/utils/filesystem.pyc,,
+pip/_internal/utils/glibc.py,sha256=9_1wY9Lmca4xzOQDF1A6ITW_N80j_BXwN7Sx7vBqP4k,3282
+pip/_internal/utils/glibc.pyc,,
+pip/_internal/utils/hashes.py,sha256=_6l8M_nqmLZjs-o2lP2rB7ZleAT05WOuqgwBa8uFYR8,3527
+pip/_internal/utils/hashes.pyc,,
+pip/_internal/utils/logging.py,sha256=qSYK7Wf_oiCr1VR4qvAq_TtpY3SIKSlVDgnAeQqSjHc,11671
+pip/_internal/utils/logging.pyc,,
+pip/_internal/utils/misc.py,sha256=QsYl2j5rU5Mh_CEsSf1W8GB6HvPOfioj30Emqz7mg7s,32434
+pip/_internal/utils/misc.pyc,,
+pip/_internal/utils/models.py,sha256=DQYZSRhjvSdDTAaJLLCpDtxAn1S_-v_8nlNjv4T2jwY,1042
+pip/_internal/utils/models.pyc,,
+pip/_internal/utils/outdated.py,sha256=sEe1l902jiOl3tArf6omqVd44s4BT9DOk3a3CXtJNNI,5868
+pip/_internal/utils/outdated.pyc,,
+pip/_internal/utils/packaging.py,sha256=frr5M-ORe30rRKbH6pwqp_jkX1T8rx-UGDlj8vG5HII,2743
+pip/_internal/utils/packaging.pyc,,
+pip/_internal/utils/setuptools_build.py,sha256=0blfscmNJW_iZ5DcswJeDB_PbtTEjfK9RL1R1WEDW2E,278
+pip/_internal/utils/setuptools_build.pyc,,
+pip/_internal/utils/temp_dir.py,sha256=0Xq5ZlOd2OOeHwKM6hGy66gnMGAbyhio7DtjLHd7DFg,5339
+pip/_internal/utils/temp_dir.pyc,,
+pip/_internal/utils/typing.py,sha256=bF73ImJzIaxLLEVwfEaSJzFGqV9LaxkQBvDULIyr1jI,1125
+pip/_internal/utils/typing.pyc,,
+pip/_internal/utils/ui.py,sha256=yRqmi2V4OeTYP9SnXhuXKlyRx8xJ79AjLRgvLCZ4E1E,13812
+pip/_internal/utils/ui.pyc,,
+pip/_internal/vcs/__init__.py,sha256=kgwOhkt6ddbKosZytktLydMUb_e-JpXMstJF9YpSOwM,19205
+pip/_internal/vcs/__init__.pyc,,
+pip/_internal/vcs/bazaar.py,sha256=3lA6CKyrYpoJuxjTa8oTozszNcqdYILqEhKLJ41RMug,3231
+pip/_internal/vcs/bazaar.pyc,,
+pip/_internal/vcs/git.py,sha256=x0PQDgzWho544gfqtE9CXoUkN34zE4YkpgrbTcWEte4,12960
+pip/_internal/vcs/git.pyc,,
+pip/_internal/vcs/mercurial.py,sha256=AbH4IWdLCsjUxFnIHRvijV-7SNhfjDZJJFzQ1e_b48Q,3355
+pip/_internal/vcs/mercurial.pyc,,
+pip/_internal/vcs/subversion.py,sha256=cMH4MEobSj68gaSiBD53KXVJnEbhtuUJjL8U1Kk_v70,8167
+pip/_internal/vcs/subversion.pyc,,
+pip/_internal/wheel.py,sha256=-MijhN1BIuaQkb3909smA63wkbvdRrdtr1CUDxnQTqA,41189
+pip/_internal/wheel.pyc,,
+pip/_vendor/__init__.py,sha256=iip2nWwH_riYqnDnM0q4BJFrWE-XWjYfxCejJKct0WM,4654
+pip/_vendor/__init__.pyc,,
+pip/_vendor/appdirs.py,sha256=BENKsvcA08IpccD9345-rMrg3aXWFA1q6BFEglnHg6I,24547
+pip/_vendor/appdirs.pyc,,
+pip/_vendor/cachecontrol/__init__.py,sha256=6cRPchVqkAkeUtYTSW8qCetjSqJo-GxP-n4VMVDbvmc,302
+pip/_vendor/cachecontrol/__init__.pyc,,
+pip/_vendor/cachecontrol/_cmd.py,sha256=URGE0KrA87QekCG3SGPatlSPT571dZTDjNa-ZXX3pDc,1295
+pip/_vendor/cachecontrol/_cmd.pyc,,
+pip/_vendor/cachecontrol/adapter.py,sha256=eBGAtVNRZgtl_Kj5JV54miqL9YND-D0JZPahwY8kFtY,4863
+pip/_vendor/cachecontrol/adapter.pyc,,
+pip/_vendor/cachecontrol/cache.py,sha256=1fc4wJP8HYt1ycnJXeEw5pCpeBL2Cqxx6g9Fb0AYDWQ,805
+pip/_vendor/cachecontrol/cache.pyc,,
+pip/_vendor/cachecontrol/caches/__init__.py,sha256=-gHNKYvaeD0kOk5M74eOrsSgIKUtC6i6GfbmugGweEo,86
+pip/_vendor/cachecontrol/caches/__init__.pyc,,
+pip/_vendor/cachecontrol/caches/file_cache.py,sha256=8vrSzzGcdfEfICago1uSFbkumNJMGLbCdEkXsmUIExw,4177
+pip/_vendor/cachecontrol/caches/file_cache.pyc,,
+pip/_vendor/cachecontrol/caches/redis_cache.py,sha256=HxelMpNCo-dYr2fiJDwM3hhhRmxUYtB5tXm1GpAAT4Y,856
+pip/_vendor/cachecontrol/caches/redis_cache.pyc,,
+pip/_vendor/cachecontrol/compat.py,sha256=kHNvMRdt6s_Xwqq_9qJmr9ou3wYMOMUMxPPcwNxT8Mc,695
+pip/_vendor/cachecontrol/compat.pyc,,
+pip/_vendor/cachecontrol/controller.py,sha256=U7g-YwizQ2O5NRgK_MZreF1ntM4E49C3PuF3od-Vwz4,13698
+pip/_vendor/cachecontrol/controller.pyc,,
+pip/_vendor/cachecontrol/filewrapper.py,sha256=vACKO8Llzu_ZWyjV1Fxn1MA4TGU60N5N3GSrAFdAY2Q,2533
+pip/_vendor/cachecontrol/filewrapper.pyc,,
+pip/_vendor/cachecontrol/heuristics.py,sha256=BFGHJ3yQcxvZizfo90LLZ04T_Z5XSCXvFotrp7Us0sc,4070
+pip/_vendor/cachecontrol/heuristics.pyc,,
+pip/_vendor/cachecontrol/serialize.py,sha256=GebE34fgToyWwAsRPguh8hEPN6CqoG-5hRMXRsjVABQ,6954
+pip/_vendor/cachecontrol/serialize.pyc,,
+pip/_vendor/cachecontrol/wrapper.py,sha256=sfr9YHWx-5TwNz1H5rT6QOo8ggII6v3vbEDjQFwR6wc,671
+pip/_vendor/cachecontrol/wrapper.pyc,,
+pip/_vendor/certifi/__init__.py,sha256=-M1moep9D6jZnOAT0qnM1dpoEHMPage7Osv5xLRLyFg,52
+pip/_vendor/certifi/__init__.pyc,,
+pip/_vendor/certifi/__main__.py,sha256=NaCn6WtWME-zzVWQ2j4zFyl8cY4knDa9CwtHNIeFPhM,53
+pip/_vendor/certifi/__main__.pyc,,
+pip/_vendor/certifi/cacert.pem,sha256=OXuDPlrPiaJwm5ZEAamspo0ktiNJtyu-OGhOWGqgeic,284518
+pip/_vendor/certifi/core.py,sha256=EuFc2BsToG5O1-qsx4BSjQ1r1-7WRtH87b1WflZOWhI,218
+pip/_vendor/certifi/core.pyc,,
+pip/_vendor/chardet/__init__.py,sha256=YsP5wQlsHJ2auF1RZJfypiSrCA7_bQiRm3ES_NI76-Y,1559
+pip/_vendor/chardet/__init__.pyc,,
+pip/_vendor/chardet/big5freq.py,sha256=D_zK5GyzoVsRes0HkLJziltFQX0bKCLOrFe9_xDvO_8,31254
+pip/_vendor/chardet/big5freq.pyc,,
+pip/_vendor/chardet/big5prober.py,sha256=kBxHbdetBpPe7xrlb-e990iot64g_eGSLd32lB7_h3M,1757
+pip/_vendor/chardet/big5prober.pyc,,
+pip/_vendor/chardet/chardistribution.py,sha256=3woWS62KrGooKyqz4zQSnjFbJpa6V7g02daAibTwcl8,9411
+pip/_vendor/chardet/chardistribution.pyc,,
+pip/_vendor/chardet/charsetgroupprober.py,sha256=6bDu8YIiRuScX4ca9Igb0U69TA2PGXXDej6Cc4_9kO4,3787
+pip/_vendor/chardet/charsetgroupprober.pyc,,
+pip/_vendor/chardet/charsetprober.py,sha256=KSmwJErjypyj0bRZmC5F5eM7c8YQgLYIjZXintZNstg,5110
+pip/_vendor/chardet/charsetprober.pyc,,
+pip/_vendor/chardet/cli/__init__.py,sha256=AbpHGcgLb-kRsJGnwFEktk7uzpZOCcBY74-YBdrKVGs,1
+pip/_vendor/chardet/cli/__init__.pyc,,
+pip/_vendor/chardet/cli/chardetect.py,sha256=DI8dlV3FBD0c0XA_y3sQ78z754DUv1J8n34RtDjOXNw,2774
+pip/_vendor/chardet/cli/chardetect.pyc,,
+pip/_vendor/chardet/codingstatemachine.py,sha256=VYp_6cyyki5sHgXDSZnXW4q1oelHc3cu9AyQTX7uug8,3590
+pip/_vendor/chardet/codingstatemachine.pyc,,
+pip/_vendor/chardet/compat.py,sha256=PKTzHkSbtbHDqS9PyujMbX74q1a8mMpeQTDVsQhZMRw,1134
+pip/_vendor/chardet/compat.pyc,,
+pip/_vendor/chardet/cp949prober.py,sha256=TZ434QX8zzBsnUvL_8wm4AQVTZ2ZkqEEQL_lNw9f9ow,1855
+pip/_vendor/chardet/cp949prober.pyc,,
+pip/_vendor/chardet/enums.py,sha256=Aimwdb9as1dJKZaFNUH2OhWIVBVd6ZkJJ_WK5sNY8cU,1661
+pip/_vendor/chardet/enums.pyc,,
+pip/_vendor/chardet/escprober.py,sha256=kkyqVg1Yw3DIOAMJ2bdlyQgUFQhuHAW8dUGskToNWSc,3950
+pip/_vendor/chardet/escprober.pyc,,
+pip/_vendor/chardet/escsm.py,sha256=RuXlgNvTIDarndvllNCk5WZBIpdCxQ0kcd9EAuxUh84,10510
+pip/_vendor/chardet/escsm.pyc,,
+pip/_vendor/chardet/eucjpprober.py,sha256=iD8Jdp0ISRjgjiVN7f0e8xGeQJ5GM2oeZ1dA8nbSeUw,3749
+pip/_vendor/chardet/eucjpprober.pyc,,
+pip/_vendor/chardet/euckrfreq.py,sha256=-7GdmvgWez4-eO4SuXpa7tBiDi5vRXQ8WvdFAzVaSfo,13546
+pip/_vendor/chardet/euckrfreq.pyc,,
+pip/_vendor/chardet/euckrprober.py,sha256=MqFMTQXxW4HbzIpZ9lKDHB3GN8SP4yiHenTmf8g_PxY,1748
+pip/_vendor/chardet/euckrprober.pyc,,
+pip/_vendor/chardet/euctwfreq.py,sha256=No1WyduFOgB5VITUA7PLyC5oJRNzRyMbBxaKI1l16MA,31621
+pip/_vendor/chardet/euctwfreq.pyc,,
+pip/_vendor/chardet/euctwprober.py,sha256=13p6EP4yRaxqnP4iHtxHOJ6R2zxHq1_m8hTRjzVZ95c,1747
+pip/_vendor/chardet/euctwprober.pyc,,
+pip/_vendor/chardet/gb2312freq.py,sha256=JX8lsweKLmnCwmk8UHEQsLgkr_rP_kEbvivC4qPOrlc,20715
+pip/_vendor/chardet/gb2312freq.pyc,,
+pip/_vendor/chardet/gb2312prober.py,sha256=gGvIWi9WhDjE-xQXHvNIyrnLvEbMAYgyUSZ65HUfylw,1754
+pip/_vendor/chardet/gb2312prober.pyc,,
+pip/_vendor/chardet/hebrewprober.py,sha256=c3SZ-K7hvyzGY6JRAZxJgwJ_sUS9k0WYkvMY00YBYFo,13838
+pip/_vendor/chardet/hebrewprober.pyc,,
+pip/_vendor/chardet/jisfreq.py,sha256=vpmJv2Bu0J8gnMVRPHMFefTRvo_ha1mryLig8CBwgOg,25777
+pip/_vendor/chardet/jisfreq.pyc,,
+pip/_vendor/chardet/jpcntx.py,sha256=PYlNqRUQT8LM3cT5FmHGP0iiscFlTWED92MALvBungo,19643
+pip/_vendor/chardet/jpcntx.pyc,,
+pip/_vendor/chardet/langbulgarianmodel.py,sha256=1HqQS9Pbtnj1xQgxitJMvw8X6kKr5OockNCZWfEQrPE,12839
+pip/_vendor/chardet/langbulgarianmodel.pyc,,
+pip/_vendor/chardet/langcyrillicmodel.py,sha256=LODajvsetH87yYDDQKA2CULXUH87tI223dhfjh9Zx9c,17948
+pip/_vendor/chardet/langcyrillicmodel.pyc,,
+pip/_vendor/chardet/langgreekmodel.py,sha256=8YAW7bU8YwSJap0kIJSbPMw1BEqzGjWzqcqf0WgUKAA,12688
+pip/_vendor/chardet/langgreekmodel.pyc,,
+pip/_vendor/chardet/langhebrewmodel.py,sha256=JSnqmE5E62tDLTPTvLpQsg5gOMO4PbdWRvV7Avkc0HA,11345
+pip/_vendor/chardet/langhebrewmodel.pyc,,
+pip/_vendor/chardet/langhungarianmodel.py,sha256=RhapYSG5l0ZaO-VV4Fan5sW0WRGQqhwBM61yx3yxyOA,12592
+pip/_vendor/chardet/langhungarianmodel.pyc,,
+pip/_vendor/chardet/langthaimodel.py,sha256=8l0173Gu_W6G8mxmQOTEF4ls2YdE7FxWf3QkSxEGXJQ,11290
+pip/_vendor/chardet/langthaimodel.pyc,,
+pip/_vendor/chardet/langturkishmodel.py,sha256=W22eRNJsqI6uWAfwXSKVWWnCerYqrI8dZQTm_M0lRFk,11102
+pip/_vendor/chardet/langturkishmodel.pyc,,
+pip/_vendor/chardet/latin1prober.py,sha256=S2IoORhFk39FEFOlSFWtgVybRiP6h7BlLldHVclNkU8,5370
+pip/_vendor/chardet/latin1prober.pyc,,
+pip/_vendor/chardet/mbcharsetprober.py,sha256=AR95eFH9vuqSfvLQZN-L5ijea25NOBCoXqw8s5O9xLQ,3413
+pip/_vendor/chardet/mbcharsetprober.pyc,,
+pip/_vendor/chardet/mbcsgroupprober.py,sha256=h6TRnnYq2OxG1WdD5JOyxcdVpn7dG0q-vB8nWr5mbh4,2012
+pip/_vendor/chardet/mbcsgroupprober.pyc,,
+pip/_vendor/chardet/mbcssm.py,sha256=SY32wVIF3HzcjY3BaEspy9metbNSKxIIB0RKPn7tjpI,25481
+pip/_vendor/chardet/mbcssm.pyc,,
+pip/_vendor/chardet/sbcharsetprober.py,sha256=LDSpCldDCFlYwUkGkwD2oFxLlPWIWXT09akH_2PiY74,5657
+pip/_vendor/chardet/sbcharsetprober.pyc,,
+pip/_vendor/chardet/sbcsgroupprober.py,sha256=1IprcCB_k1qfmnxGC6MBbxELlKqD3scW6S8YIwdeyXA,3546
+pip/_vendor/chardet/sbcsgroupprober.pyc,,
+pip/_vendor/chardet/sjisprober.py,sha256=IIt-lZj0WJqK4rmUZzKZP4GJlE8KUEtFYVuY96ek5MQ,3774
+pip/_vendor/chardet/sjisprober.pyc,,
+pip/_vendor/chardet/universaldetector.py,sha256=qL0174lSZE442eB21nnktT9_VcAye07laFWUeUrjttY,12485
+pip/_vendor/chardet/universaldetector.pyc,,
+pip/_vendor/chardet/utf8prober.py,sha256=IdD8v3zWOsB8OLiyPi-y_fqwipRFxV9Nc1eKBLSuIEw,2766
+pip/_vendor/chardet/utf8prober.pyc,,
+pip/_vendor/chardet/version.py,sha256=sp3B08mrDXB-pf3K9fqJ_zeDHOCLC8RrngQyDFap_7g,242
+pip/_vendor/chardet/version.pyc,,
+pip/_vendor/colorama/__init__.py,sha256=lJdY6COz9uM_pXwuk9oLr0fp8H8q2RrUqN16GKabvq4,239
+pip/_vendor/colorama/__init__.pyc,,
+pip/_vendor/colorama/ansi.py,sha256=Fi0un-QLqRm-v7o_nKiOqyC8PapBJK7DLV_q9LKtTO0,2524
+pip/_vendor/colorama/ansi.pyc,,
+pip/_vendor/colorama/ansitowin32.py,sha256=u8QaqdqS_xYSfNkPM1eRJLHz6JMWPodaJaP0mxgHCDc,10462
+pip/_vendor/colorama/ansitowin32.pyc,,
+pip/_vendor/colorama/initialise.py,sha256=PprovDNxMTrvoNHFcL2NZjpH2XzDc8BLxLxiErfUl4k,1915
+pip/_vendor/colorama/initialise.pyc,,
+pip/_vendor/colorama/win32.py,sha256=bJ8Il9jwaBN5BJ8bmN6FoYZ1QYuMKv2j8fGrXh7TJjw,5404
+pip/_vendor/colorama/win32.pyc,,
+pip/_vendor/colorama/winterm.py,sha256=2y_2b7Zsv34feAsP67mLOVc-Bgq51mdYGo571VprlrM,6438
+pip/_vendor/colorama/winterm.pyc,,
+pip/_vendor/distlib/__init__.py,sha256=7uthK6m96pTekk8hjlT-MybcwYmmxwP8gEOxXVg1f2s,581
+pip/_vendor/distlib/__init__.pyc,,
+pip/_vendor/distlib/_backport/__init__.py,sha256=bqS_dTOH6uW9iGgd0uzfpPjo6vZ4xpPZ7kyfZJ2vNaw,274
+pip/_vendor/distlib/_backport/__init__.pyc,,
+pip/_vendor/distlib/_backport/misc.py,sha256=KWecINdbFNOxSOP1fGF680CJnaC6S4fBRgEtaYTw0ig,971
+pip/_vendor/distlib/_backport/misc.pyc,,
+pip/_vendor/distlib/_backport/shutil.py,sha256=VW1t3uYqUjWZH7jV-6QiimLhnldoV5uIpH4EuiT1jfw,25647
+pip/_vendor/distlib/_backport/shutil.pyc,,
+pip/_vendor/distlib/_backport/sysconfig.cfg,sha256=swZKxq9RY5e9r3PXCrlvQPMsvOdiWZBTHLEbqS8LJLU,2617
+pip/_vendor/distlib/_backport/sysconfig.py,sha256=JdJ9ztRy4Hc-b5-VS74x3nUtdEIVr_OBvMsIb8O2sjc,26964
+pip/_vendor/distlib/_backport/sysconfig.pyc,,
+pip/_vendor/distlib/_backport/tarfile.py,sha256=Ihp7rXRcjbIKw8COm9wSePV9ARGXbSF9gGXAMn2Q-KU,92628
+pip/_vendor/distlib/_backport/tarfile.pyc,,
+pip/_vendor/distlib/compat.py,sha256=xdNZmqFN5HwF30HjRn5M415pcC2kgXRBXn767xS8v-M,41404
+pip/_vendor/distlib/compat.pyc,,
+pip/_vendor/distlib/database.py,sha256=-KJH63AJ7hqjLtGCwOTrionhKr2Vsytdwkjyo8UdEco,51029
+pip/_vendor/distlib/database.pyc,,
+pip/_vendor/distlib/index.py,sha256=Dd1kIV06XIdynNpKxHMMRRIKsXuoUsG7QIzntfVtZCI,21073
+pip/_vendor/distlib/index.pyc,,
+pip/_vendor/distlib/locators.py,sha256=S9G2IsZp0RnMMbXGrT-gu7892pNpy1XMlUEuUHX3OI8,51828
+pip/_vendor/distlib/locators.pyc,,
+pip/_vendor/distlib/manifest.py,sha256=nQEhYmgoreaBZzyFzwYsXxJARu3fo4EkunU163U16iE,14811
+pip/_vendor/distlib/manifest.pyc,,
+pip/_vendor/distlib/markers.py,sha256=6Ac3cCfFBERexiESWIOXmg-apIP8l2esafNSX3KMy-8,4387
+pip/_vendor/distlib/markers.pyc,,
+pip/_vendor/distlib/metadata.py,sha256=BNCnpRfFVslyZcosr4vnE_YbkRb3TNxXtk7TrDszJdc,40172
+pip/_vendor/distlib/metadata.pyc,,
+pip/_vendor/distlib/resources.py,sha256=2FGv0ZHF14KXjLIlL0R991lyQQGcewOS4mJ-5n-JVnc,10766
+pip/_vendor/distlib/resources.pyc,,
+pip/_vendor/distlib/scripts.py,sha256=NYqRJ2uuEuJwr_NNLzWH0m_s_YsobDFQb6HqxuQ2Sew,16638
+pip/_vendor/distlib/scripts.pyc,,
+pip/_vendor/distlib/t32.exe,sha256=ftub1bsSPUCOnBn-eCtcarKTk0N0CBEP53BumkIxWJE,92672
+pip/_vendor/distlib/t64.exe,sha256=iChOG627LWTHY8-jzSwlo9SYU5a-0JHwQu4AqDz8I68,102400
+pip/_vendor/distlib/util.py,sha256=gwKL5geJKmtR4GeIUnoMAWjsPPG3tVP_mFxw_Sx-isc,59681
+pip/_vendor/distlib/util.pyc,,
+pip/_vendor/distlib/version.py,sha256=_n7F6juvQGAcn769E_SHa7fOcf5ERlEVymJ_EjPRwGw,23391
+pip/_vendor/distlib/version.pyc,,
+pip/_vendor/distlib/w32.exe,sha256=NPYPpt7PIjVqABEu1CzabbDyHHkJpuw-_qZq_48H0j0,89088
+pip/_vendor/distlib/w64.exe,sha256=Yb-qr1OQEzL8KRGTk-XHUZDwMSljfQeZnVoTk-K4e7E,99328
+pip/_vendor/distlib/wheel.py,sha256=gV53KDG7BgbxsdeKjnATbP47gTEJRNylcIeE1TFin1o,39880
+pip/_vendor/distlib/wheel.pyc,,
+pip/_vendor/distro.py,sha256=X2So5kjrRKyMbQJ90Xgy93HU5eFtujCzKaYNeoy1k1c,43251
+pip/_vendor/distro.pyc,,
+pip/_vendor/html5lib/__init__.py,sha256=Ztrn7UvF-wIFAgRBBa0ML-Gu5AffH3BPX_INJx4SaBI,1162
+pip/_vendor/html5lib/__init__.pyc,,
+pip/_vendor/html5lib/_ihatexml.py,sha256=3LBtJMlzgwM8vpQiU1TvGmEEmNH72sV0yD8yS53y07A,16705
+pip/_vendor/html5lib/_ihatexml.pyc,,
+pip/_vendor/html5lib/_inputstream.py,sha256=bPUWcAfJScK4xkjQQaG_HsI2BvEVbFvI0AsodDYPQj0,32552
+pip/_vendor/html5lib/_inputstream.pyc,,
+pip/_vendor/html5lib/_tokenizer.py,sha256=YAaOEBD6qc5ISq9Xt9Nif1OFgcybTTfMdwqBkZhpAq4,76580
+pip/_vendor/html5lib/_tokenizer.pyc,,
+pip/_vendor/html5lib/_trie/__init__.py,sha256=8VR1bcgD2OpeS2XExpu5yBhP_Q1K-lwKbBKICBPf1kU,289
+pip/_vendor/html5lib/_trie/__init__.pyc,,
+pip/_vendor/html5lib/_trie/_base.py,sha256=uJHVhzif9S0MJXgy9F98iEev5evi_rgUk5BmEbUSp8c,930
+pip/_vendor/html5lib/_trie/_base.pyc,,
+pip/_vendor/html5lib/_trie/datrie.py,sha256=EQpqSfkZRuTbE-DuhW7xMdVDxdZNZ0CfmnYfHA_3zxM,1178
+pip/_vendor/html5lib/_trie/datrie.pyc,,
+pip/_vendor/html5lib/_trie/py.py,sha256=wXmQLrZRf4MyWNyg0m3h81m9InhLR7GJ002mIIZh-8o,1775
+pip/_vendor/html5lib/_trie/py.pyc,,
+pip/_vendor/html5lib/_utils.py,sha256=ismpASeqa2jqEPQjHUj8vReAf7yIoKnvLN5fuOw6nv0,4015
+pip/_vendor/html5lib/_utils.pyc,,
+pip/_vendor/html5lib/constants.py,sha256=4lmZWLtEPRLnl8NzftOoYTJdo6jpeMtP6dqQC0g_bWQ,83518
+pip/_vendor/html5lib/constants.pyc,,
+pip/_vendor/html5lib/filters/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
+pip/_vendor/html5lib/filters/__init__.pyc,,
+pip/_vendor/html5lib/filters/alphabeticalattributes.py,sha256=lViZc2JMCclXi_5gduvmdzrRxtO5Xo9ONnbHBVCsykU,919
+pip/_vendor/html5lib/filters/alphabeticalattributes.pyc,,
+pip/_vendor/html5lib/filters/base.py,sha256=z-IU9ZAYjpsVsqmVt7kuWC63jR11hDMr6CVrvuao8W0,286
+pip/_vendor/html5lib/filters/base.pyc,,
+pip/_vendor/html5lib/filters/inject_meta_charset.py,sha256=egDXUEHXmAG9504xz0K6ALDgYkvUrC2q15YUVeNlVQg,2945
+pip/_vendor/html5lib/filters/inject_meta_charset.pyc,,
+pip/_vendor/html5lib/filters/lint.py,sha256=jk6q56xY0ojiYfvpdP-OZSm9eTqcAdRqhCoPItemPYA,3643
+pip/_vendor/html5lib/filters/lint.pyc,,
+pip/_vendor/html5lib/filters/optionaltags.py,sha256=8lWT75J0aBOHmPgfmqTHSfPpPMp01T84NKu0CRedxcE,10588
+pip/_vendor/html5lib/filters/optionaltags.pyc,,
+pip/_vendor/html5lib/filters/sanitizer.py,sha256=4ON02KNjuqda1lCw5_JCUZxb0BzWR5M7ON84dtJ7dm0,26248
+pip/_vendor/html5lib/filters/sanitizer.pyc,,
+pip/_vendor/html5lib/filters/whitespace.py,sha256=8eWqZxd4UC4zlFGW6iyY6f-2uuT8pOCSALc3IZt7_t4,1214
+pip/_vendor/html5lib/filters/whitespace.pyc,,
+pip/_vendor/html5lib/html5parser.py,sha256=g5g2ezkusHxhi7b23vK_-d6K6BfIJRbqIQmvQ9z4EgI,118963
+pip/_vendor/html5lib/html5parser.pyc,,
+pip/_vendor/html5lib/serializer.py,sha256=yfcfBHse2wDs6ojxn-kieJjLT5s1ipilQJ0gL3-rJis,15758
+pip/_vendor/html5lib/serializer.pyc,,
+pip/_vendor/html5lib/treeadapters/__init__.py,sha256=A0rY5gXIe4bJOiSGRO_j_tFhngRBO8QZPzPtPw5dFzo,679
+pip/_vendor/html5lib/treeadapters/__init__.pyc,,
+pip/_vendor/html5lib/treeadapters/genshi.py,sha256=CH27pAsDKmu4ZGkAUrwty7u0KauGLCZRLPMzaO3M5vo,1715
+pip/_vendor/html5lib/treeadapters/genshi.pyc,,
+pip/_vendor/html5lib/treeadapters/sax.py,sha256=BKS8woQTnKiqeffHsxChUqL4q2ZR_wb5fc9MJ3zQC8s,1776
+pip/_vendor/html5lib/treeadapters/sax.pyc,,
+pip/_vendor/html5lib/treebuilders/__init__.py,sha256=AysSJyvPfikCMMsTVvaxwkgDieELD5dfR8FJIAuq7hY,3592
+pip/_vendor/html5lib/treebuilders/__init__.pyc,,
+pip/_vendor/html5lib/treebuilders/base.py,sha256=wQGp5yy22TNG8tJ6aREe4UUeTR7A99dEz0BXVaedWb4,14579
+pip/_vendor/html5lib/treebuilders/base.pyc,,
+pip/_vendor/html5lib/treebuilders/dom.py,sha256=SY3MsijXyzdNPc8aK5IQsupBoM8J67y56DgNtGvsb9g,8835
+pip/_vendor/html5lib/treebuilders/dom.pyc,,
+pip/_vendor/html5lib/treebuilders/etree.py,sha256=aqIBOGj_dFYqBURIcTegGNBhAIJOw5iFDHb4jrkYH-8,12764
+pip/_vendor/html5lib/treebuilders/etree.pyc,,
+pip/_vendor/html5lib/treebuilders/etree_lxml.py,sha256=9V0dXxbJYYq-Skgb5-_OL2NkVYpjioEb4CHajo0e9yI,14122
+pip/_vendor/html5lib/treebuilders/etree_lxml.pyc,,
+pip/_vendor/html5lib/treewalkers/__init__.py,sha256=yhXxHpjlSqfQyUag3v8-vWjMPriFBU8YRAPNpDgBTn8,5714
+pip/_vendor/html5lib/treewalkers/__init__.pyc,,
+pip/_vendor/html5lib/treewalkers/base.py,sha256=ouiOsuSzvI0KgzdWP8PlxIaSNs9falhbiinAEc_UIJY,7476
+pip/_vendor/html5lib/treewalkers/base.pyc,,
+pip/_vendor/html5lib/treewalkers/dom.py,sha256=EHyFR8D8lYNnyDU9lx_IKigVJRyecUGua0mOi7HBukc,1413
+pip/_vendor/html5lib/treewalkers/dom.pyc,,
+pip/_vendor/html5lib/treewalkers/etree.py,sha256=sz1o6mmE93NQ53qJFDO7HKyDtuwgK-Ay3qSFZPC6u00,4550
+pip/_vendor/html5lib/treewalkers/etree.pyc,,
+pip/_vendor/html5lib/treewalkers/etree_lxml.py,sha256=sY6wfRshWTllu6n48TPWpKsQRPp-0CQrT0hj_AdzHSU,6309
+pip/_vendor/html5lib/treewalkers/etree_lxml.pyc,,
+pip/_vendor/html5lib/treewalkers/genshi.py,sha256=4D2PECZ5n3ZN3qu3jMl9yY7B81jnQApBQSVlfaIuYbA,2309
+pip/_vendor/html5lib/treewalkers/genshi.pyc,,
+pip/_vendor/idna/__init__.py,sha256=9Nt7xpyet3DmOrPUGooDdAwmHZZu1qUAy2EaJ93kGiQ,58
+pip/_vendor/idna/__init__.pyc,,
+pip/_vendor/idna/codec.py,sha256=lvYb7yu7PhAqFaAIAdWcwgaWI2UmgseUua-1c0AsG0A,3299
+pip/_vendor/idna/codec.pyc,,
+pip/_vendor/idna/compat.py,sha256=R-h29D-6mrnJzbXxymrWUW7iZUvy-26TQwZ0ij57i4U,232
+pip/_vendor/idna/compat.pyc,,
+pip/_vendor/idna/core.py,sha256=JDCZZ_PLESqIgEbU8mPyoEufWwoOiIqygA17-QZIe3s,11733
+pip/_vendor/idna/core.pyc,,
+pip/_vendor/idna/idnadata.py,sha256=HXaPFw6_YAJ0qppACPu0YLAULtRs3QovRM_CCZHGdY0,40899
+pip/_vendor/idna/idnadata.pyc,,
+pip/_vendor/idna/intranges.py,sha256=TY1lpxZIQWEP6tNqjZkFA5hgoMWOj1OBmnUG8ihT87E,1749
+pip/_vendor/idna/intranges.pyc,,
+pip/_vendor/idna/package_data.py,sha256=kIzeKKXEouXLR4srqwf9Q3zv-NffKSOz5aSDOJARPB0,21
+pip/_vendor/idna/package_data.pyc,,
+pip/_vendor/idna/uts46data.py,sha256=oLyNZ1pBaiBlj9zFzLFRd_P7J8MkRcgDisjExZR_4MY,198292
+pip/_vendor/idna/uts46data.pyc,,
+pip/_vendor/ipaddress.py,sha256=2OgbkeAD2rLkcXqbcvof3J5R7lRwjNLoBySyTkBtKnc,79852
+pip/_vendor/ipaddress.pyc,,
+pip/_vendor/lockfile/__init__.py,sha256=Tqpz90DwKYfhPsfzVOJl84TL87pdFE5ePNHdXAxs4Tk,9371
+pip/_vendor/lockfile/__init__.pyc,,
+pip/_vendor/lockfile/linklockfile.py,sha256=C7OH3H4GdK68u4FQgp8fkP2kO4fyUTSyj3X6blgfobc,2652
+pip/_vendor/lockfile/linklockfile.pyc,,
+pip/_vendor/lockfile/mkdirlockfile.py,sha256=e3qgIL-etZMLsS-3ft19iW_8IQ360HNkGOqE3yBKsUw,3096
+pip/_vendor/lockfile/mkdirlockfile.pyc,,
+pip/_vendor/lockfile/pidlockfile.py,sha256=ukH9uk6NFuxyVmG5QiWw4iKq3fT7MjqUguX95avYPIY,6090
+pip/_vendor/lockfile/pidlockfile.pyc,,
+pip/_vendor/lockfile/sqlitelockfile.py,sha256=o2TMkMRY0iwn-iL1XMRRIFStMUkS4i3ajceeYNntKFg,5506
+pip/_vendor/lockfile/sqlitelockfile.pyc,,
+pip/_vendor/lockfile/symlinklockfile.py,sha256=ABwXXmvTHvCl5viPblShL3PG-gGsLiT1roAMfDRwhi8,2616
+pip/_vendor/lockfile/symlinklockfile.pyc,,
+pip/_vendor/msgpack/__init__.py,sha256=y0bk2YbzK6J2e0J_dyreN6nD7yM2IezT6m_tU2h-Mdg,1677
+pip/_vendor/msgpack/__init__.pyc,,
+pip/_vendor/msgpack/_version.py,sha256=dN7wVIjbyuQIJ35B2o6gymQNDLPlj_7-uTfgCv7KErM,20
+pip/_vendor/msgpack/_version.pyc,,
+pip/_vendor/msgpack/exceptions.py,sha256=lPkAi_u12NlFajDz4FELSHEdfU8hrR3zeTvKX8aQuz4,1056
+pip/_vendor/msgpack/exceptions.pyc,,
+pip/_vendor/msgpack/fallback.py,sha256=h0ll8xnq12mI9PuQ9Qd_Ihtt08Sp8L0JqhG9KY8Vyjk,36411
+pip/_vendor/msgpack/fallback.pyc,,
+pip/_vendor/packaging/__about__.py,sha256=Wg0-hNgTU2_lBZcGBh5pm1R9yroQ3rv-X0rig8KjA6o,744
+pip/_vendor/packaging/__about__.pyc,,
+pip/_vendor/packaging/__init__.py,sha256=6enbp5XgRfjBjsI9-bn00HjHf5TH21PDMOKkJW8xw-w,562
+pip/_vendor/packaging/__init__.pyc,,
+pip/_vendor/packaging/_compat.py,sha256=Ugdm-qcneSchW25JrtMIKgUxfEEBcCAz6WrEeXeqz9o,865
+pip/_vendor/packaging/_compat.pyc,,
+pip/_vendor/packaging/_structures.py,sha256=pVd90XcXRGwpZRB_qdFuVEibhCHpX_bL5zYr9-N0mc8,1416
+pip/_vendor/packaging/_structures.pyc,,
+pip/_vendor/packaging/markers.py,sha256=-QjvJkhSJBxBogO9J_EpPQudHaaLV3rgVYsBDqn-ZLc,8234
+pip/_vendor/packaging/markers.pyc,,
+pip/_vendor/packaging/requirements.py,sha256=grcnFU8x7KD230JaFLXtWl3VClLuOmsOy4c-m55tOWs,4700
+pip/_vendor/packaging/requirements.pyc,,
+pip/_vendor/packaging/specifiers.py,sha256=0ZzQpcUnvrQ6LjR-mQRLzMr8G6hdRv-mY0VSf_amFtI,27778
+pip/_vendor/packaging/specifiers.pyc,,
+pip/_vendor/packaging/utils.py,sha256=VaTC0Ei7zO2xl9ARiWmz2YFLFt89PuuhLbAlXMyAGms,1520
+pip/_vendor/packaging/utils.pyc,,
+pip/_vendor/packaging/version.py,sha256=Npdwnb8OHedj_2L86yiUqscujb7w_i5gmSK1PhOAFzg,11978
+pip/_vendor/packaging/version.pyc,,
+pip/_vendor/pep517/__init__.py,sha256=nOY747zTld3oTdEetBG6DWxEcZXTeOQk0aHvbR-sa5w,84
+pip/_vendor/pep517/__init__.pyc,,
+pip/_vendor/pep517/_in_process.py,sha256=xMY2kLutkjCti5WqTmKOLRRL3o8Ds_k-fObFyuMv1tk,6061
+pip/_vendor/pep517/_in_process.pyc,,
+pip/_vendor/pep517/build.py,sha256=-n8PT-ugS1TdqoTUY1vatDQjrLtx48K_-Quu2MuQBiA,2699
+pip/_vendor/pep517/build.pyc,,
+pip/_vendor/pep517/check.py,sha256=Lu7nMdYu1JVV58fE3hv-d_avTy5h0yO9LsIzAt82Clk,5885
+pip/_vendor/pep517/check.pyc,,
+pip/_vendor/pep517/colorlog.py,sha256=Tk9AuYm_cLF3BKTBoSTJt9bRryn0aFojIQOwbfVUTxQ,4098
+pip/_vendor/pep517/colorlog.pyc,,
+pip/_vendor/pep517/compat.py,sha256=4SFG4QN-cNj8ebSa0wV0HUtEEQWwmbok2a0uk1gYEOM,631
+pip/_vendor/pep517/compat.pyc,,
+pip/_vendor/pep517/envbuild.py,sha256=9-u4KffexPMEm52rTaIjEOxsCAd2DMByxzv5H566QLw,5763
+pip/_vendor/pep517/envbuild.pyc,,
+pip/_vendor/pep517/wrappers.py,sha256=9dZn-q7F5KyQKUJMie2uKwur2FG0CLXz_kLZzkJOhZc,5912
+pip/_vendor/pep517/wrappers.pyc,,
+pip/_vendor/pkg_resources/__init__.py,sha256=ZVHzk7ZiFIIgE2RTJj8F7wwjdMGrAngMWtQo-rGNsm4,107910
+pip/_vendor/pkg_resources/__init__.pyc,,
+pip/_vendor/pkg_resources/py31compat.py,sha256=CRk8fkiPRDLsbi5pZcKsHI__Pbmh_94L8mr9Qy9Ab2U,562
+pip/_vendor/pkg_resources/py31compat.pyc,,
+pip/_vendor/progress/__init__.py,sha256=fcbQQXo5np2CoQyhSH5XprkicwLZNLePR3uIahznSO0,4857
+pip/_vendor/progress/__init__.pyc,,
+pip/_vendor/progress/bar.py,sha256=QuDuVNcmXgpxtNtxO0Fq72xKigxABaVmxYGBw4J3Z_E,2854
+pip/_vendor/progress/bar.pyc,,
+pip/_vendor/progress/counter.py,sha256=MznyBrvPWrOlGe4MZAlGUb9q3aODe6_aNYeAE_VNoYA,1372
+pip/_vendor/progress/counter.pyc,,
+pip/_vendor/progress/spinner.py,sha256=k8JbDW94T0-WXuXfxZIFhdoNPYp3jfnpXqBnfRv5fGs,1380
+pip/_vendor/progress/spinner.pyc,,
+pip/_vendor/pyparsing.py,sha256=sxGUe_YcWBB5ZoHec0m1iJtgcj4iKv_SGfdA_zVCYII,245385
+pip/_vendor/pyparsing.pyc,,
+pip/_vendor/pytoml/__init__.py,sha256=W_SKx36Hsew-Fty36BOpreLm4uF4V_Tgkm_z9rIoOE8,127
+pip/_vendor/pytoml/__init__.pyc,,
+pip/_vendor/pytoml/core.py,sha256=9CrLLTs1PdWjEwRnYzt_i4dhHcZvGxs_GsMlYAX3iY4,509
+pip/_vendor/pytoml/core.pyc,,
+pip/_vendor/pytoml/parser.py,sha256=2tDXkldqPQJhyadXzL2rGhVbjUyBNeXXhaEfncHl2iQ,10326
+pip/_vendor/pytoml/parser.pyc,,
+pip/_vendor/pytoml/test.py,sha256=2nQs4aX3XQEaaQCx6x_OJTS2Hb0_IiTZRqNOeDmLCzo,1021
+pip/_vendor/pytoml/test.pyc,,
+pip/_vendor/pytoml/utils.py,sha256=JCLHx77Hu1R3F-bRgiROIiKyCzLwyebnp5P35cRJxWs,1665
+pip/_vendor/pytoml/utils.pyc,,
+pip/_vendor/pytoml/writer.py,sha256=WbNNQg3sh_V-s3kt88LkNNbxEq6pPDdhRE-daJzArcI,3198
+pip/_vendor/pytoml/writer.pyc,,
+pip/_vendor/requests/__init__.py,sha256=ZI8kbaEzLAxsqex3MmMPr-v24d1RfZbNAOY8fUxg2Xw,4074
+pip/_vendor/requests/__init__.pyc,,
+pip/_vendor/requests/__version__.py,sha256=8KG3anaNCi-PEclPPOHJ_cv1udY_L1_njVr84gRZ9HM,436
+pip/_vendor/requests/__version__.pyc,,
+pip/_vendor/requests/_internal_utils.py,sha256=Zx3PnEUccyfsB-ie11nZVAW8qClJy0gx1qNME7rgT18,1096
+pip/_vendor/requests/_internal_utils.pyc,,
+pip/_vendor/requests/adapters.py,sha256=e-bmKEApNVqFdylxuMJJfiaHdlmS_zhWhIMEzlHvGuc,21548
+pip/_vendor/requests/adapters.pyc,,
+pip/_vendor/requests/api.py,sha256=hWZgfD7OriCZFOnpeq0bv2pbXDl8YXfxDwAcU036qDs,6253
+pip/_vendor/requests/api.pyc,,
+pip/_vendor/requests/auth.py,sha256=QB2-cSUj1jrvWZfPXttsZpyAacQgtKLVk14vQW9TpSE,10206
+pip/_vendor/requests/auth.pyc,,
+pip/_vendor/requests/certs.py,sha256=nXRVq9DtGmv_1AYbwjTu9UrgAcdJv05ZvkNeaoLOZxY,465
+pip/_vendor/requests/certs.pyc,,
+pip/_vendor/requests/compat.py,sha256=FZX4Q_EMKiMnhZpZ3g_gOsT-j2ca9ij2gehDx1cwYeo,1941
+pip/_vendor/requests/compat.pyc,,
+pip/_vendor/requests/cookies.py,sha256=Y-bKX6TvW3FnYlE6Au0SXtVVWcaNdFvuAwQxw-G0iTI,18430
+pip/_vendor/requests/cookies.pyc,,
+pip/_vendor/requests/exceptions.py,sha256=-mLam3TAx80V09EaH3H-ZxR61eAVuLRZ8zgBBSLjK44,3197
+pip/_vendor/requests/exceptions.pyc,,
+pip/_vendor/requests/help.py,sha256=SJPVcoXeo7KfK4AxJN5eFVQCjr0im87tU2n7ubLsksU,3578
+pip/_vendor/requests/help.pyc,,
+pip/_vendor/requests/hooks.py,sha256=QReGyy0bRcr5rkwCuObNakbYsc7EkiKeBwG4qHekr2Q,757
+pip/_vendor/requests/hooks.pyc,,
+pip/_vendor/requests/models.py,sha256=6s-37iAqXVptq8z7U_LoH_pbIPrCQUm_Z8QuIGE29Q0,34275
+pip/_vendor/requests/models.pyc,,
+pip/_vendor/requests/packages.py,sha256=njJmVifY4aSctuW3PP5EFRCxjEwMRDO6J_feG2dKWsI,695
+pip/_vendor/requests/packages.pyc,,
+pip/_vendor/requests/sessions.py,sha256=DjbCotDW6xSAaBsjbW-L8l4N0UcwmrxVNgSrZgIjGWM,29332
+pip/_vendor/requests/sessions.pyc,,
+pip/_vendor/requests/status_codes.py,sha256=XWlcpBjbCtq9sSqpH9_KKxgnLTf9Z__wCWolq21ySlg,4129
+pip/_vendor/requests/status_codes.pyc,,
+pip/_vendor/requests/structures.py,sha256=zoP8qly2Jak5e89HwpqjN1z2diztI-_gaqts1raJJBc,2981
+pip/_vendor/requests/structures.pyc,,
+pip/_vendor/requests/utils.py,sha256=LtPJ1db6mJff2TJSJWKi7rBpzjPS3mSOrjC9zRhoD3A,30049
+pip/_vendor/requests/utils.pyc,,
+pip/_vendor/retrying.py,sha256=k3fflf5_Mm0XcIJYhB7Tj34bqCCPhUDkYbx1NvW2FPE,9972
+pip/_vendor/retrying.pyc,,
+pip/_vendor/six.py,sha256=h9jch2pS86y4R36pKRS3LOYUCVFNIJMRwjZ4fJDtJ44,32452
+pip/_vendor/six.pyc,,
+pip/_vendor/urllib3/__init__.py,sha256=EZviRQA_iuL_94EeJHY4JAArRXbRCkAzA0HH9iXZ15s,2722
+pip/_vendor/urllib3/__init__.pyc,,
+pip/_vendor/urllib3/_collections.py,sha256=-CAKsDE-WdubAjlBSZLx7b0e7WKenaNGwWvGLDEF1TM,10746
+pip/_vendor/urllib3/_collections.pyc,,
+pip/_vendor/urllib3/connection.py,sha256=KLFvknLgllcMkgJ-zUsFjCzOt9P03fDoIpTPz_vqXCw,13839
+pip/_vendor/urllib3/connection.pyc,,
+pip/_vendor/urllib3/connectionpool.py,sha256=rgc_3D0VsD5VDxr4KzzA8Plee0Rmerm5WKb71FcxWu8,35097
+pip/_vendor/urllib3/connectionpool.pyc,,
+pip/_vendor/urllib3/contrib/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
+pip/_vendor/urllib3/contrib/__init__.pyc,,
+pip/_vendor/urllib3/contrib/_appengine_environ.py,sha256=lhYXvB5_oGKSeurX7za3XhcGyERvNjXRQ3eJp2GmQ3M,717
+pip/_vendor/urllib3/contrib/_appengine_environ.pyc,,
+pip/_vendor/urllib3/contrib/_securetransport/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
+pip/_vendor/urllib3/contrib/_securetransport/__init__.pyc,,
+pip/_vendor/urllib3/contrib/_securetransport/bindings.py,sha256=x2kLSh-ASZKsun0FxtraBuLVe3oHuth4YW6yZ5Vof-w,17560
+pip/_vendor/urllib3/contrib/_securetransport/bindings.pyc,,
+pip/_vendor/urllib3/contrib/_securetransport/low_level.py,sha256=Umy5u-3Z957GirdapnicXVOpHaM4xdOZABJuJxfaeJA,12162
+pip/_vendor/urllib3/contrib/_securetransport/low_level.pyc,,
+pip/_vendor/urllib3/contrib/appengine.py,sha256=VvDpkc5gf9dTXNxXmyG1mPdON_3DrYG_eW4uOqN98oQ,10938
+pip/_vendor/urllib3/contrib/appengine.pyc,,
+pip/_vendor/urllib3/contrib/ntlmpool.py,sha256=5ZpMF7N9B6NEjVU-r-xjDOV_-hkNvsDoNc84J2yqauI,4459
+pip/_vendor/urllib3/contrib/ntlmpool.pyc,,
+pip/_vendor/urllib3/contrib/pyopenssl.py,sha256=-kI_9y99Iwybv6Wy8IF8PugVl61BeMBEEqGwrDYNCuc,15823
+pip/_vendor/urllib3/contrib/pyopenssl.pyc,,
+pip/_vendor/urllib3/contrib/securetransport.py,sha256=BqXSlChN9_hjCWgyN6JdcgvBUdc37QCCX4u3_8zE_9o,30309
+pip/_vendor/urllib3/contrib/securetransport.pyc,,
+pip/_vendor/urllib3/contrib/socks.py,sha256=Iom0snbHkCuZbZ7Sle2Kueha1W0jYAJ0SyCOtePLaio,6391
+pip/_vendor/urllib3/contrib/socks.pyc,,
+pip/_vendor/urllib3/exceptions.py,sha256=rFeIfBNKC8KJ61ux-MtJyJlEC9G9ggkmCeF751JwVR4,6604
+pip/_vendor/urllib3/exceptions.pyc,,
+pip/_vendor/urllib3/fields.py,sha256=D_TE_SK15YatdbhWDMN0OE3X6UCJn1RTkANINCYOobE,5943
+pip/_vendor/urllib3/fields.pyc,,
+pip/_vendor/urllib3/filepost.py,sha256=40CROlpRKVBpFUkD0R6wJf_PpvbcRQRFUu0OOQlFkKM,2436
+pip/_vendor/urllib3/filepost.pyc,,
+pip/_vendor/urllib3/packages/__init__.py,sha256=nlChrGzkjCkmhCX9HrF_qHPUgosfsPQkVIJxiiLhk9g,109
+pip/_vendor/urllib3/packages/__init__.pyc,,
+pip/_vendor/urllib3/packages/backports/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
+pip/_vendor/urllib3/packages/backports/__init__.pyc,,
+pip/_vendor/urllib3/packages/backports/makefile.py,sha256=so2z9BiNM8kh38Ve5tomQP_mp2_ubEqzdlCpLZKzzCI,1456
+pip/_vendor/urllib3/packages/backports/makefile.pyc,,
+pip/_vendor/urllib3/packages/six.py,sha256=A6hdJZVjI3t_geebZ9BzUvwRrIXo0lfwzQlM2LcKyas,30098
+pip/_vendor/urllib3/packages/six.pyc,,
+pip/_vendor/urllib3/packages/ssl_match_hostname/__init__.py,sha256=WBVbxQBojNAxfZwNavkox3BgJiMA9BJmm-_fwd0jD_o,688
+pip/_vendor/urllib3/packages/ssl_match_hostname/__init__.pyc,,
+pip/_vendor/urllib3/packages/ssl_match_hostname/_implementation.py,sha256=E-9J-kAaUn76WMZ4PpzKUxM4C3yjY7mopOpbPIy3Dso,5700
+pip/_vendor/urllib3/packages/ssl_match_hostname/_implementation.pyc,,
+pip/_vendor/urllib3/poolmanager.py,sha256=csE6Bh6L0FJ3iNOHk2z8KhMT8Eiq976b6pk8I6vrOC8,16853
+pip/_vendor/urllib3/poolmanager.pyc,,
+pip/_vendor/urllib3/request.py,sha256=OfelFYzPnxGlU3amEz9uBLjCBOriwgJh4QC_aW9SF3U,5991
+pip/_vendor/urllib3/request.pyc,,
+pip/_vendor/urllib3/response.py,sha256=ta1jp4B5PGBWzoAV1s48WLuHCRICQnK7F9m_kyK4Z8g,25609
+pip/_vendor/urllib3/response.pyc,,
+pip/_vendor/urllib3/util/__init__.py,sha256=6Ran4oAVIy40Cu_oEPWnNV9bwF5rXx6G1DUZ7oehjPY,1044
+pip/_vendor/urllib3/util/__init__.pyc,,
+pip/_vendor/urllib3/util/connection.py,sha256=-AyqcRTuNUHuo5ndtsU0Og_nMyCGATC-kYqOUdBHwIQ,4639
+pip/_vendor/urllib3/util/connection.pyc,,
+pip/_vendor/urllib3/util/queue.py,sha256=myTX3JDHntglKQNBf3b6dasHH-uF-W59vzGSQiFdAfI,497
+pip/_vendor/urllib3/util/queue.pyc,,
+pip/_vendor/urllib3/util/request.py,sha256=H5_lrHvtwl2U2BbT1UYN9HpruNc1gsNFlz2njQmhPrQ,3705
+pip/_vendor/urllib3/util/request.pyc,,
+pip/_vendor/urllib3/util/response.py,sha256=028PNXDZhwBtnm2uXvnAHi_l9_AAGrAMH2Igh2AbgWg,2586
+pip/_vendor/urllib3/util/response.pyc,,
+pip/_vendor/urllib3/util/retry.py,sha256=kFQTesNiwPp6ZeQo9VHeUO7b8qA-_l3BnErCAOEPo4Q,15105
+pip/_vendor/urllib3/util/retry.pyc,,
+pip/_vendor/urllib3/util/ssl_.py,sha256=4qqBDM82bufhqqEd0b-99sObz95XmEVEXDVi5iAyCeE,13172
+pip/_vendor/urllib3/util/ssl_.pyc,,
+pip/_vendor/urllib3/util/timeout.py,sha256=7lHNrgL5YH2cI1j-yZnzV_J8jBlRVdmFhQaNyM1_2b8,9757
+pip/_vendor/urllib3/util/timeout.pyc,,
+pip/_vendor/urllib3/util/url.py,sha256=qCY_HHUXvo05wAsEERALgExtlgxLnAHSQ7ce1b-g3SM,6487
+pip/_vendor/urllib3/util/url.pyc,,
+pip/_vendor/urllib3/util/wait.py,sha256=p4BZo_Ukp5JF0Dn6jro7cUfqIjnU6WFtuoA6poaV5Jk,5403
+pip/_vendor/urllib3/util/wait.pyc,,
+pip/_vendor/webencodings/__init__.py,sha256=qOBJIuPy_4ByYH6W_bNgJF-qYQ2DoU-dKsDu5yRWCXg,10579
+pip/_vendor/webencodings/__init__.pyc,,
+pip/_vendor/webencodings/labels.py,sha256=4AO_KxTddqGtrL9ns7kAPjb0CcN6xsCIxbK37HY9r3E,8979
+pip/_vendor/webencodings/labels.pyc,,
+pip/_vendor/webencodings/mklabels.py,sha256=GYIeywnpaLnP0GSic8LFWgd0UVvO_l1Nc6YoF-87R_4,1305
+pip/_vendor/webencodings/mklabels.pyc,,
+pip/_vendor/webencodings/tests.py,sha256=OtGLyjhNY1fvkW1GvLJ_FV9ZoqC9Anyjr7q3kxTbzNs,6563
+pip/_vendor/webencodings/tests.pyc,,
+pip/_vendor/webencodings/x_user_defined.py,sha256=yOqWSdmpytGfUgh_Z6JYgDNhoc-BAHyyeeT15Fr42tM,4307
+pip/_vendor/webencodings/x_user_defined.pyc,,
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip-19.1.dist-info/WHEEL b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip-19.1.dist-info/WHEEL
new file mode 100644
index 0000000..c8240f0
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip-19.1.dist-info/WHEEL
@@ -0,0 +1,6 @@
+Wheel-Version: 1.0
+Generator: bdist_wheel (0.33.1)
+Root-Is-Purelib: true
+Tag: py2-none-any
+Tag: py3-none-any
+
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip-19.1.dist-info/entry_points.txt b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip-19.1.dist-info/entry_points.txt
new file mode 100644
index 0000000..f5809cb
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip-19.1.dist-info/entry_points.txt
@@ -0,0 +1,5 @@
+[console_scripts]
+pip = pip._internal:main
+pip3 = pip._internal:main
+pip3.7 = pip._internal:main
+
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip-19.1.dist-info/top_level.txt b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip-19.1.dist-info/top_level.txt
new file mode 100644
index 0000000..a1b589e
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip-19.1.dist-info/top_level.txt
@@ -0,0 +1 @@
+pip
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/__init__.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/__init__.py
new file mode 100644
index 0000000..75cd896
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/__init__.py
@@ -0,0 +1 @@
+__version__ = "19.1"
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/__init__.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/__init__.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..1633fcdd9524076890bcc30e59c934dd4ceb8d1c
GIT binary patch
literal 213
zcmZSn%**AGdLky70SXuy7#JKF7#NDV7#J8*7#N}$7*ZG+f;E^xVk`^{42G6^hJG3#
zWhLAU3=Hw{WvNBQnfZC~@fsi_5JYi20|SG8K~ZK|Vo9ogSz?iXT7FJSYEiL%Qi^_g
zQc_;7X>PHRVUl@zRl0?#MR`tEm6-tur03~}=oe%b=w{{>mn7!o=(?48cp3+QgupmH
gJ~J<~BtBlRpt6L6fq}s$H$SB`C)Ez*recsA05!NW&Hw-a

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/__main__.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/__main__.py
new file mode 100644
index 0000000..0c223f8
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/__main__.py
@@ -0,0 +1,19 @@
+from __future__ import absolute_import
+
+import os
+import sys
+
+# If we are running from a wheel, add the wheel to sys.path
+# This allows the usage python pip-*.whl/pip install pip-*.whl
+if __package__ == '':
+    # __file__ is pip-*.whl/pip/__main__.py
+    # first dirname call strips of '/__main__.py', second strips off '/pip'
+    # Resulting path is the name of the wheel itself
+    # Add that to sys.path so we can import pip
+    path = os.path.dirname(os.path.dirname(__file__))
+    sys.path.insert(0, path)
+
+from pip._internal import main as _main  # isort:skip # noqa
+
+if __name__ == '__main__':
+    sys.exit(_main())
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/__main__.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/__main__.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..1ba9e3e7b61c03af3289b4dba1d685bc3b6ffe30
GIT binary patch
literal 562
zcmZSn%**AGdLky70ScHI7#JKJ7#NCYGcYiuFfgPrGUPBY<T5fuF)}cM_)H8rObk&>
zU^ym+9A<_nW`<N2h7@LoY$k@H42D!DhAdWwEH)$tJ3})g2t~0nq%wnLIY8P|Ss9v{
z7#Q;)_OLMIa5Cg_F+_1QFsAY_q_Bd`n-12&%aF>=(98fb1FW2hAy|Wrfq@|t<Y)~>
z1_p)_eg+1H#H8Z<oYIoi_{`jb{Gt-S5`;7h0|P^DVrE_m2Ll5`d_0I5AFsg&(#ZuD
zNh>WWElQ1#4+7~aVParl$S*Dd1x9gYaS1nANkL+Ac4B&Je0&MWw1UKvj1qQGAY~Ti
zCFZ6=O-{?q0jU7HF0VMXsHB9Kfq|hQvp_FCGp{7IC@(Q52xNK*E67ZcJD?gtW<ZTj
zt;j6V0J#G}6vs0#Fz6Q)WtJtDr0SO?7U`$u=cJ?-73(LZ=$9uY<>i{@78@BRnWtB!
zTbNpu=VVox8Gt}~o_>gaL1uw&W?pegVor{(TbYNaaR5jNjA3D+S5OIdh)r&ON@-52
a9Vk$X1sE6@1ekajd02Q@<ru}7Kx_cXk9a@;

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/__init__.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/__init__.py
new file mode 100644
index 0000000..9c1637c
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/__init__.py
@@ -0,0 +1,78 @@
+#!/usr/bin/env python
+from __future__ import absolute_import
+
+import locale
+import logging
+import os
+import warnings
+
+import sys
+
+# 2016-06-17 barry@debian.org: urllib3 1.14 added optional support for socks,
+# but if invoked (i.e. imported), it will issue a warning to stderr if socks
+# isn't available.  requests unconditionally imports urllib3's socks contrib
+# module, triggering this warning.  The warning breaks DEP-8 tests (because of
+# the stderr output) and is just plain annoying in normal usage.  I don't want
+# to add socks as yet another dependency for pip, nor do I want to allow-stderr
+# in the DEP-8 tests, so just suppress the warning.  pdb tells me this has to
+# be done before the import of pip.vcs.
+from pip._vendor.urllib3.exceptions import DependencyWarning
+warnings.filterwarnings("ignore", category=DependencyWarning)  # noqa
+
+# We want to inject the use of SecureTransport as early as possible so that any
+# references or sessions or what have you are ensured to have it, however we
+# only want to do this in the case that we're running on macOS and the linked
+# OpenSSL is too old to handle TLSv1.2
+try:
+    import ssl
+except ImportError:
+    pass
+else:
+    # Checks for OpenSSL 1.0.1 on MacOS
+    if sys.platform == "darwin" and ssl.OPENSSL_VERSION_NUMBER < 0x1000100f:
+        try:
+            from pip._vendor.urllib3.contrib import securetransport
+        except (ImportError, OSError):
+            pass
+        else:
+            securetransport.inject_into_urllib3()
+
+from pip._internal.cli.autocompletion import autocomplete
+from pip._internal.cli.main_parser import parse_command
+from pip._internal.commands import commands_dict
+from pip._internal.exceptions import PipError
+from pip._internal.utils import deprecation
+from pip._internal.vcs import git, mercurial, subversion, bazaar  # noqa
+from pip._vendor.urllib3.exceptions import InsecureRequestWarning
+
+logger = logging.getLogger(__name__)
+
+# Hide the InsecureRequestWarning from urllib3
+warnings.filterwarnings("ignore", category=InsecureRequestWarning)
+
+
+def main(args=None):
+    if args is None:
+        args = sys.argv[1:]
+
+    # Configure our deprecation warnings to be sent through loggers
+    deprecation.install_warning_logger()
+
+    autocomplete()
+
+    try:
+        cmd_name, cmd_args = parse_command(args)
+    except PipError as exc:
+        sys.stderr.write("ERROR: %s" % exc)
+        sys.stderr.write(os.linesep)
+        sys.exit(1)
+
+    # Needed for locale.getpreferredencoding(False) to work
+    # in pip._internal.utils.encoding.auto_decode
+    try:
+        locale.setlocale(locale.LC_ALL, '')
+    except locale.Error as e:
+        # setlocale can apparently crash if locale are uninitialized
+        logger.debug("Ignoring error %s when setting locale", e)
+    command = commands_dict[cmd_name](isolated=("--isolated" in cmd_args))
+    return command.main(cmd_args)
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/__init__.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/__init__.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..e6d831bdd1728fe77b723b4adec7a2fa1cf5ccdb
GIT binary patch
literal 2298
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
bFv~GAgA+3g6EBkhBMd4r3NZ0A3o`=%lmZ0t

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/build_env.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/build_env.py
new file mode 100644
index 0000000..89830e7
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/build_env.py
@@ -0,0 +1,215 @@
+"""Build Environment used for isolation during sdist building
+"""
+
+import logging
+import os
+import sys
+import textwrap
+from collections import OrderedDict
+from distutils.sysconfig import get_python_lib
+from sysconfig import get_paths
+
+from pip._vendor.pkg_resources import Requirement, VersionConflict, WorkingSet
+
+from pip import __file__ as pip_location
+from pip._internal.utils.misc import call_subprocess
+from pip._internal.utils.temp_dir import TempDirectory
+from pip._internal.utils.typing import MYPY_CHECK_RUNNING
+from pip._internal.utils.ui import open_spinner
+
+if MYPY_CHECK_RUNNING:
+    from typing import Tuple, Set, Iterable, Optional, List
+    from pip._internal.index import PackageFinder
+
+logger = logging.getLogger(__name__)
+
+
+class _Prefix:
+
+    def __init__(self, path):
+        # type: (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']
+        # Note: prefer distutils' sysconfig to get the
+        # library paths so PyPy is correctly supported.
+        purelib = get_python_lib(plat_specific=False, prefix=path)
+        platlib = get_python_lib(plat_specific=True, prefix=path)
+        if purelib == platlib:
+            self.lib_dirs = [purelib]
+        else:
+            self.lib_dirs = [purelib, platlib]
+
+
+class BuildEnvironment(object):
+    """Creates and manages an isolated environment to install build deps
+    """
+
+    def __init__(self):
+        # type: () -> None
+        self._temp_dir = TempDirectory(kind="build-env")
+        self._temp_dir.create()
+
+        self._prefixes = OrderedDict((
+            (name, _Prefix(os.path.join(self._temp_dir.path, name)))
+            for name in ('normal', 'overlay')
+        ))
+
+        self._bin_dirs = []  # type: List[str]
+        self._lib_dirs = []  # type: List[str]
+        for prefix in reversed(list(self._prefixes.values())):
+            self._bin_dirs.append(prefix.bin_dir)
+            self._lib_dirs.extend(prefix.lib_dirs)
+
+        # Customize site to:
+        # - ensure .pth files are honored
+        # - prevent access to system site packages
+        system_sites = {
+            os.path.normcase(site) for site in (
+                get_python_lib(plat_specific=False),
+                get_python_lib(plat_specific=True),
+            )
+        }
+        self._site_dir = os.path.join(self._temp_dir.path, 'site')
+        if not os.path.exists(self._site_dir):
+            os.mkdir(self._site_dir)
+        with open(os.path.join(self._site_dir, 'sitecustomize.py'), 'w') as fp:
+            fp.write(textwrap.dedent(
+                '''
+                import os, site, sys
+
+                # First, drop system-sites related paths.
+                original_sys_path = sys.path[:]
+                known_paths = set()
+                for path in {system_sites!r}:
+                    site.addsitedir(path, known_paths=known_paths)
+                system_paths = set(
+                    os.path.normcase(path)
+                    for path in sys.path[len(original_sys_path):]
+                )
+                original_sys_path = [
+                    path for path in original_sys_path
+                    if os.path.normcase(path) not in system_paths
+                ]
+                sys.path = original_sys_path
+
+                # Second, add lib directories.
+                # ensuring .pth file are processed.
+                for path in {lib_dirs!r}:
+                    assert not path in sys.path
+                    site.addsitedir(path)
+                '''
+            ).format(system_sites=system_sites, lib_dirs=self._lib_dirs))
+
+    def __enter__(self):
+        self._save_env = {
+            name: os.environ.get(name, None)
+            for name in ('PATH', 'PYTHONNOUSERSITE', 'PYTHONPATH')
+        }
+
+        path = self._bin_dirs[:]
+        old_path = self._save_env['PATH']
+        if old_path:
+            path.extend(old_path.split(os.pathsep))
+
+        pythonpath = [self._site_dir]
+
+        os.environ.update({
+            'PATH': os.pathsep.join(path),
+            'PYTHONNOUSERSITE': '1',
+            'PYTHONPATH': os.pathsep.join(pythonpath),
+        })
+
+    def __exit__(self, exc_type, exc_val, exc_tb):
+        for varname, old_value in self._save_env.items():
+            if old_value is None:
+                os.environ.pop(varname, None)
+            else:
+                os.environ[varname] = old_value
+
+    def cleanup(self):
+        # type: () -> None
+        self._temp_dir.cleanup()
+
+    def check_requirements(self, reqs):
+        # type: (Iterable[str]) -> Tuple[Set[Tuple[str, str]], Set[str]]
+        """Return 2 sets:
+            - conflicting requirements: set of (installed, wanted) reqs tuples
+            - missing requirements: set of reqs
+        """
+        missing = set()
+        conflicting = set()
+        if reqs:
+            ws = WorkingSet(self._lib_dirs)
+            for req in reqs:
+                try:
+                    if ws.find(Requirement.parse(req)) is None:
+                        missing.add(req)
+                except VersionConflict as e:
+                    conflicting.add((str(e.args[0].as_requirement()),
+                                     str(e.args[1])))
+        return conflicting, missing
+
+    def install_requirements(
+        self,
+        finder,  # type: PackageFinder
+        requirements,  # type: Iterable[str]
+        prefix_as_string,  # type: str
+        message  # type: Optional[str]
+    ):
+        # type: (...) -> None
+        prefix = self._prefixes[prefix_as_string]
+        assert not prefix.setup
+        prefix.setup = True
+        if not requirements:
+            return
+        args = [
+            sys.executable, os.path.dirname(pip_location), 'install',
+            '--ignore-installed', '--no-user', '--prefix', prefix.path,
+            '--no-warn-script-location',
+        ]  # type: List[str]
+        if logger.getEffectiveLevel() <= logging.DEBUG:
+            args.append('-v')
+        for format_control in ('no_binary', 'only_binary'):
+            formats = getattr(finder.format_control, format_control)
+            args.extend(('--' + format_control.replace('_', '-'),
+                         ','.join(sorted(formats or {':none:'}))))
+        if finder.index_urls:
+            args.extend(['-i', finder.index_urls[0]])
+            for extra_index in finder.index_urls[1:]:
+                args.extend(['--extra-index-url', extra_index])
+        else:
+            args.append('--no-index')
+        for link in finder.find_links:
+            args.extend(['--find-links', link])
+        for _, host, _ in finder.secure_origins:
+            args.extend(['--trusted-host', host])
+        if finder.allow_all_prereleases:
+            args.append('--pre')
+        args.append('--')
+        args.extend(requirements)
+        with open_spinner(message) as spinner:
+            call_subprocess(args, spinner=spinner)
+
+
+class NoOpBuildEnvironment(BuildEnvironment):
+    """A no-op drop-in replacement for BuildEnvironment
+    """
+
+    def __init__(self):
+        pass
+
+    def __enter__(self):
+        pass
+
+    def __exit__(self, exc_type, exc_val, exc_tb):
+        pass
+
+    def cleanup(self):
+        pass
+
+    def install_requirements(self, finder, requirements, prefix, message):
+        raise NotImplementedError()
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/build_env.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/build_env.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..8ed3612027c2f8164821fab9b2f26293847dd64f
GIT binary patch
literal 10101
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
F0{{ry0ObGx

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/cache.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/cache.py
new file mode 100644
index 0000000..9379343
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/cache.py
@@ -0,0 +1,224 @@
+"""Cache Management
+"""
+
+import errno
+import hashlib
+import logging
+import os
+
+from pip._vendor.packaging.utils import canonicalize_name
+
+from pip._internal.download import path_to_url
+from pip._internal.models.link import Link
+from pip._internal.utils.compat import expanduser
+from pip._internal.utils.temp_dir import TempDirectory
+from pip._internal.utils.typing import MYPY_CHECK_RUNNING
+from pip._internal.wheel import InvalidWheelFilename, Wheel
+
+if MYPY_CHECK_RUNNING:
+    from typing import Optional, Set, List, Any
+    from pip._internal.index import FormatControl
+
+logger = logging.getLogger(__name__)
+
+
+class Cache(object):
+    """An abstract class - provides cache directories for data from links
+
+
+        :param cache_dir: The root of the cache.
+        :param format_control: An object of FormatControl class to limit
+            binaries being read from the cache.
+        :param allowed_formats: which formats of files the cache should store.
+            ('binary' and 'source' are the only allowed values)
+    """
+
+    def __init__(self, cache_dir, format_control, allowed_formats):
+        # type: (str, FormatControl, Set[str]) -> None
+        super(Cache, self).__init__()
+        self.cache_dir = expanduser(cache_dir) if cache_dir else 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
+        """
+
+        # We want to generate an url to use as our cache key, we don't want to
+        # just re-use the URL because it might have other items in the fragment
+        # and we don't care about those.
+        key_parts = [link.url_without_fragment]
+        if link.hash_name is not None and link.hash is not None:
+            key_parts.append("=".join([link.hash_name, link.hash]))
+        key_url = "#".join(key_parts)
+
+        # Encode our key url with sha224, we'll use this because it has similar
+        # security properties to sha256, but with a shorter total output (and
+        # thus less secure). However the differences don't make a lot of
+        # difference for our use case here.
+        hashed = hashlib.sha224(key_url.encode()).hexdigest()
+
+        # We want to nest the directories some to prevent having a ton of top
+        # level directories where we might run out of sub directories on some
+        # FS.
+        parts = [hashed[:2], hashed[2:4], hashed[4:6], hashed[6:]]
+
+        return parts
+
+    def _get_candidates(self, link, package_name):
+        # type: (Link, Optional[str]) -> List[Any]
+        can_not_cache = (
+            not self.cache_dir or
+            not package_name or
+            not link
+        )
+        if can_not_cache:
+            return []
+
+        canonical_name = canonicalize_name(package_name)
+        formats = self.format_control.get_allowed_formats(
+            canonical_name
+        )
+        if not self.allowed_formats.intersection(formats):
+            return []
+
+        root = self.get_path_for_link(link)
+        try:
+            return os.listdir(root)
+        except OSError as err:
+            if err.errno in {errno.ENOENT, errno.ENOTDIR}:
+                return []
+            raise
+
+    def get_path_for_link(self, link):
+        # type: (Link) -> str
+        """Return a directory to store cached items in for link.
+        """
+        raise NotImplementedError()
+
+    def get(self, link, package_name):
+        # type: (Link, Optional[str]) -> Link
+        """Returns a link to a cached item if it exists, otherwise returns the
+        passed link.
+        """
+        raise NotImplementedError()
+
+    def _link_for_candidate(self, link, candidate):
+        # type: (Link, str) -> Link
+        root = self.get_path_for_link(link)
+        path = os.path.join(root, candidate)
+
+        return Link(path_to_url(path))
+
+    def cleanup(self):
+        # type: () -> None
+        pass
+
+
+class SimpleWheelCache(Cache):
+    """A cache of wheels for future installs.
+    """
+
+    def __init__(self, cache_dir, format_control):
+        # type: (str, FormatControl) -> None
+        super(SimpleWheelCache, self).__init__(
+            cache_dir, format_control, {"binary"}
+        )
+
+    def get_path_for_link(self, link):
+        # type: (Link) -> str
+        """Return a directory to store cached wheels for link
+
+        Because there are M wheels for any one sdist, we provide a directory
+        to cache them in, and then consult that directory when looking up
+        cache hits.
+
+        We only insert things into the cache if they have plausible version
+        numbers, so that we don't contaminate the cache with things that were
+        not unique. E.g. ./package might have dozens of installs done for it
+        and build a version of 0.0...and if we built and cached a wheel, we'd
+        end up using the same wheel even if the source has been edited.
+
+        :param link: The link of the sdist for which this will cache wheels.
+        """
+        parts = self._get_cache_path_parts(link)
+
+        # Store wheels within the root cache_dir
+        return os.path.join(self.cache_dir, "wheels", *parts)
+
+    def get(self, link, package_name):
+        # type: (Link, Optional[str]) -> Link
+        candidates = []
+
+        for wheel_name in self._get_candidates(link, package_name):
+            try:
+                wheel = Wheel(wheel_name)
+            except InvalidWheelFilename:
+                continue
+            if not wheel.supported():
+                # Built for a different python/arch/etc
+                continue
+            candidates.append((wheel.support_index_min(), wheel_name))
+
+        if not candidates:
+            return link
+
+        return self._link_for_candidate(link, min(candidates)[1])
+
+
+class EphemWheelCache(SimpleWheelCache):
+    """A SimpleWheelCache that creates it's own temporary cache directory
+    """
+
+    def __init__(self, format_control):
+        # type: (FormatControl) -> None
+        self._temp_dir = TempDirectory(kind="ephem-wheel-cache")
+        self._temp_dir.create()
+
+        super(EphemWheelCache, self).__init__(
+            self._temp_dir.path, format_control
+        )
+
+    def cleanup(self):
+        # type: () -> None
+        self._temp_dir.cleanup()
+
+
+class WheelCache(Cache):
+    """Wraps EphemWheelCache and SimpleWheelCache into a single Cache
+
+    This Cache allows for gracefully degradation, using the ephem wheel cache
+    when a certain link is not found in the simple wheel cache first.
+    """
+
+    def __init__(self, cache_dir, format_control):
+        # type: (str, FormatControl) -> None
+        super(WheelCache, self).__init__(
+            cache_dir, format_control, {'binary'}
+        )
+        self._wheel_cache = SimpleWheelCache(cache_dir, format_control)
+        self._ephem_cache = EphemWheelCache(format_control)
+
+    def get_path_for_link(self, link):
+        # type: (Link) -> str
+        return self._wheel_cache.get_path_for_link(link)
+
+    def get_ephem_path_for_link(self, link):
+        # type: (Link) -> str
+        return self._ephem_cache.get_path_for_link(link)
+
+    def get(self, link, package_name):
+        # type: (Link, Optional[str]) -> Link
+        retval = self._wheel_cache.get(link, package_name)
+        if retval is link:
+            retval = self._ephem_cache.get(link, package_name)
+        return retval
+
+    def cleanup(self):
+        # type: () -> None
+        self._wheel_cache.cleanup()
+        self._ephem_cache.cleanup()
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/cache.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/cache.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..be43085daeb21959a7b30430ba6975c4a911c8be
GIT binary patch
literal 9463
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
Ku|zRrF(ClyWV*`$

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/cli/__init__.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/cli/__init__.py
new file mode 100644
index 0000000..e589bb9
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/cli/__init__.py
@@ -0,0 +1,4 @@
+"""Subpackage containing all of pip's command line interface related code
+"""
+
+# This file intentionally does not import submodules
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/cli/__init__.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/cli/__init__.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..2d6698542edab46186c906b81e345c0abca51dae
GIT binary patch
literal 290
zcmZSn%**AGdLky70SXuy7#JKF7#NDV7#J8*7#N}$7*ZG+f;E^xV(ttK48f&I1&PVo
ziRq~d$@zIDiJ5tsdFcv?IXMdXX$l3I1?t5L$@#gtiFqjsIhlE>3YmE&sYPjt$*BrO
zsX2)ysVNG{`6;Pfei|T~O4u0~7~<no@{{A^H9#&v5XHF+3=H}OMVV!ZC8_#liADNp
z`8g@6MaB9_Df;C}NqM=Zxy43?N#^NQ=@zCI<vCeZW(FXTo~Iw8Uyxa#o0(T!l9-dD
z>sIFBX&e9&0^@kFi}Dh4^pkTk_2c6+^D;}~<Mj$EOE?%97;JL$Q%ZAE?ZEy8xd;GE
C%umDs

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/cli/autocompletion.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/cli/autocompletion.py
new file mode 100644
index 0000000..0a04199
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/cli/autocompletion.py
@@ -0,0 +1,152 @@
+"""Logic that powers autocompletion installed by ``pip completion``.
+"""
+
+import optparse
+import os
+import sys
+
+from pip._internal.cli.main_parser import create_main_parser
+from pip._internal.commands import commands_dict, get_summaries
+from pip._internal.utils.misc import get_installed_distributions
+
+
+def autocomplete():
+    """Entry Point for completion of main and subcommand options.
+    """
+    # Don't complete if user hasn't sourced bash_completion file.
+    if 'PIP_AUTO_COMPLETE' not in os.environ:
+        return
+    cwords = os.environ['COMP_WORDS'].split()[1:]
+    cword = int(os.environ['COMP_CWORD'])
+    try:
+        current = cwords[cword - 1]
+    except IndexError:
+        current = ''
+
+    subcommands = [cmd for cmd, summary in get_summaries()]
+    options = []
+    # subcommand
+    try:
+        subcommand_name = [w for w in cwords if w in subcommands][0]
+    except IndexError:
+        subcommand_name = None
+
+    parser = create_main_parser()
+    # subcommand options
+    if subcommand_name:
+        # special case: 'help' subcommand has no options
+        if subcommand_name == 'help':
+            sys.exit(1)
+        # special case: list locally installed dists for show and uninstall
+        should_list_installed = (
+            subcommand_name in ['show', 'uninstall'] and
+            not current.startswith('-')
+        )
+        if should_list_installed:
+            installed = []
+            lc = current.lower()
+            for dist in get_installed_distributions(local_only=True):
+                if dist.key.startswith(lc) and dist.key not in cwords[1:]:
+                    installed.append(dist.key)
+            # if there are no dists installed, fall back to option completion
+            if installed:
+                for dist in installed:
+                    print(dist)
+                sys.exit(1)
+
+        subcommand = commands_dict[subcommand_name]()
+
+        for opt in subcommand.parser.option_list_all:
+            if opt.help != optparse.SUPPRESS_HELP:
+                for opt_str in opt._long_opts + opt._short_opts:
+                    options.append((opt_str, opt.nargs))
+
+        # filter out previously specified options from available options
+        prev_opts = [x.split('=')[0] for x in cwords[1:cword - 1]]
+        options = [(x, v) for (x, v) in options if x not in prev_opts]
+        # filter options by current input
+        options = [(k, v) for k, v in options if k.startswith(current)]
+        # get completion type given cwords and available subcommand options
+        completion_type = get_path_completion_type(
+            cwords, cword, subcommand.parser.option_list_all,
+        )
+        # get completion files and directories if ``completion_type`` is
+        # ``<file>``, ``<dir>`` or ``<path>``
+        if completion_type:
+            options = auto_complete_paths(current, completion_type)
+            options = ((opt, 0) for opt in options)
+        for option in options:
+            opt_label = option[0]
+            # append '=' to options which require args
+            if option[1] and option[0][:2] == "--":
+                opt_label += '='
+            print(opt_label)
+    else:
+        # show main parser options only when necessary
+
+        opts = [i.option_list for i in parser.option_groups]
+        opts.append(parser.option_list)
+        opts = (o for it in opts for o in it)
+        if current.startswith('-'):
+            for opt in opts:
+                if opt.help != optparse.SUPPRESS_HELP:
+                    subcommands += opt._long_opts + opt._short_opts
+        else:
+            # get completion type given cwords and all available options
+            completion_type = get_path_completion_type(cwords, cword, opts)
+            if completion_type:
+                subcommands = auto_complete_paths(current, completion_type)
+
+        print(' '.join([x for x in subcommands if x.startswith(current)]))
+    sys.exit(1)
+
+
+def get_path_completion_type(cwords, cword, opts):
+    """Get the type of path completion (``file``, ``dir``, ``path`` or None)
+
+    :param cwords: same as the environmental variable ``COMP_WORDS``
+    :param cword: same as the environmental variable ``COMP_CWORD``
+    :param opts: The available options to check
+    :return: path completion type (``file``, ``dir``, ``path`` or None)
+    """
+    if cword < 2 or not cwords[cword - 2].startswith('-'):
+        return
+    for opt in opts:
+        if opt.help == optparse.SUPPRESS_HELP:
+            continue
+        for o in str(opt).split('/'):
+            if cwords[cword - 2].split('=')[0] == o:
+                if not opt.metavar or any(
+                        x in ('path', 'file', 'dir')
+                        for x in opt.metavar.split('/')):
+                    return opt.metavar
+
+
+def auto_complete_paths(current, completion_type):
+    """If ``completion_type`` is ``file`` or ``path``, list all regular files
+    and directories starting with ``current``; otherwise only list directories
+    starting with ``current``.
+
+    :param current: The word to be completed
+    :param completion_type: path completion type(`file`, `path` or `dir`)i
+    :return: A generator of regular files and/or directories
+    """
+    directory, filename = os.path.split(current)
+    current_path = os.path.abspath(directory)
+    # Don't complete paths if they can't be accessed
+    if not os.access(current_path, os.R_OK):
+        return
+    filename = os.path.normcase(filename)
+    # list all files that start with ``filename``
+    file_list = (x for x in os.listdir(current_path)
+                 if os.path.normcase(x).startswith(filename))
+    for f in file_list:
+        opt = os.path.join(current_path, f)
+        comp_file = os.path.normcase(os.path.join(directory, f))
+        # complete regular files when there is not ``<dir>`` after option
+        # complete directories when there is ``<file>``, ``<path>`` or
+        # ``<dir>``after option
+        if completion_type != 'dir' and os.path.isfile(opt):
+            yield comp_file
+        elif os.path.isdir(opt):
+            yield os.path.join(comp_file, '')
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/cli/autocompletion.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/cli/autocompletion.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..7c5ccff140f7a8fd38d8a7afc1328bfef32fec4f
GIT binary patch
literal 5912
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
P2{4K=3NUj<bBY20(u{Al

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/cli/base_command.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/cli/base_command.py
new file mode 100644
index 0000000..f6108c9
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/cli/base_command.py
@@ -0,0 +1,340 @@
+"""Base Command class, and related routines"""
+from __future__ import absolute_import, print_function
+
+import logging
+import logging.config
+import optparse
+import os
+import platform
+import sys
+import traceback
+
+from pip._internal.cli import cmdoptions
+from pip._internal.cli.parser import (
+    ConfigOptionParser, UpdatingDefaultsHelpFormatter,
+)
+from pip._internal.cli.status_codes import (
+    ERROR, PREVIOUS_BUILD_DIR_ERROR, SUCCESS, UNKNOWN_ERROR,
+    VIRTUALENV_NOT_FOUND,
+)
+from pip._internal.download import PipSession
+from pip._internal.exceptions import (
+    BadCommand, CommandError, InstallationError, PreviousBuildDirError,
+    UninstallationError,
+)
+from pip._internal.index import PackageFinder
+from pip._internal.locations import running_under_virtualenv
+from pip._internal.req.constructors import (
+    install_req_from_editable, install_req_from_line,
+)
+from pip._internal.req.req_file import parse_requirements
+from pip._internal.utils.deprecation import deprecated
+from pip._internal.utils.logging import BrokenStdoutLoggingError, setup_logging
+from pip._internal.utils.misc import (
+    get_prog, normalize_path, redact_password_from_url,
+)
+from pip._internal.utils.outdated import pip_version_check
+from pip._internal.utils.typing import MYPY_CHECK_RUNNING
+
+if MYPY_CHECK_RUNNING:
+    from typing import Optional, List, Tuple, Any
+    from optparse import Values
+    from pip._internal.cache import WheelCache
+    from pip._internal.req.req_set import RequirementSet
+
+__all__ = ['Command']
+
+logger = logging.getLogger(__name__)
+
+
+class Command(object):
+    name = None  # type: Optional[str]
+    usage = None  # type: Optional[str]
+    ignore_require_venv = False  # type: bool
+
+    def __init__(self, isolated=False):
+        # type: (bool) -> None
+        parser_kw = {
+            'usage': self.usage,
+            'prog': '%s %s' % (get_prog(), self.name),
+            'formatter': UpdatingDefaultsHelpFormatter(),
+            'add_help_option': False,
+            'name': self.name,
+            'description': self.__doc__,
+            'isolated': isolated,
+        }
+
+        self.parser = ConfigOptionParser(**parser_kw)
+
+        # Commands should add options to this option group
+        optgroup_name = '%s Options' % self.name.capitalize()
+        self.cmd_opts = optparse.OptionGroup(self.parser, optgroup_name)
+
+        # Add the general options
+        gen_opts = cmdoptions.make_option_group(
+            cmdoptions.general_group,
+            self.parser,
+        )
+        self.parser.add_option_group(gen_opts)
+
+    def run(self, options, args):
+        # type: (Values, List[Any]) -> Any
+        raise NotImplementedError
+
+    def _build_session(self, options, retries=None, timeout=None):
+        # type: (Values, Optional[int], Optional[int]) -> PipSession
+        session = PipSession(
+            cache=(
+                normalize_path(os.path.join(options.cache_dir, "http"))
+                if options.cache_dir else None
+            ),
+            retries=retries if retries is not None else options.retries,
+            insecure_hosts=options.trusted_hosts,
+        )
+
+        # Handle custom ca-bundles from the user
+        if options.cert:
+            session.verify = options.cert
+
+        # Handle SSL client certificate
+        if options.client_cert:
+            session.cert = options.client_cert
+
+        # Handle timeouts
+        if options.timeout or timeout:
+            session.timeout = (
+                timeout if timeout is not None else options.timeout
+            )
+
+        # Handle configured proxies
+        if options.proxy:
+            session.proxies = {
+                "http": options.proxy,
+                "https": options.proxy,
+            }
+
+        # Determine if we can prompt the user for authentication or not
+        session.auth.prompting = not options.no_input
+
+        return session
+
+    def parse_args(self, args):
+        # type: (List[str]) -> Tuple
+        # factored out for testability
+        return self.parser.parse_args(args)
+
+    def main(self, args):
+        # type: (List[str]) -> int
+        options, args = self.parse_args(args)
+
+        # Set verbosity so that it can be used elsewhere.
+        self.verbosity = options.verbose - options.quiet
+
+        level_number = setup_logging(
+            verbosity=self.verbosity,
+            no_color=options.no_color,
+            user_log_file=options.log,
+        )
+
+        if sys.version_info[:2] == (3, 4):
+            deprecated(
+                "Python 3.4 support has been deprecated. pip 19.1 will be the "
+                "last one supporting it. Please upgrade your Python as Python "
+                "3.4 won't be maintained after March 2019 (cf PEP 429).",
+                replacement=None,
+                gone_in='19.2',
+            )
+        elif sys.version_info[:2] == (2, 7):
+            message = (
+                "A future version of pip will drop support for Python 2.7."
+            )
+            if platform.python_implementation() == "CPython":
+                message = (
+                    "Python 2.7 will reach the end of its life on January "
+                    "1st, 2020. Please upgrade your Python as Python 2.7 "
+                    "won't be maintained after that date. "
+                ) + message
+            deprecated(message, replacement=None, gone_in=None)
+
+        # TODO: Try to get these passing down from the command?
+        #       without resorting to os.environ to hold these.
+        #       This also affects isolated builds and it should.
+
+        if options.no_input:
+            os.environ['PIP_NO_INPUT'] = '1'
+
+        if options.exists_action:
+            os.environ['PIP_EXISTS_ACTION'] = ' '.join(options.exists_action)
+
+        if options.require_venv and not self.ignore_require_venv:
+            # If a venv is required check if it can really be found
+            if not running_under_virtualenv():
+                logger.critical(
+                    'Could not find an activated virtualenv (required).'
+                )
+                sys.exit(VIRTUALENV_NOT_FOUND)
+
+        try:
+            status = self.run(options, args)
+            # FIXME: all commands should return an exit status
+            # and when it is done, isinstance is not needed anymore
+            if isinstance(status, int):
+                return status
+        except PreviousBuildDirError as exc:
+            logger.critical(str(exc))
+            logger.debug('Exception information:', exc_info=True)
+
+            return PREVIOUS_BUILD_DIR_ERROR
+        except (InstallationError, UninstallationError, BadCommand) as exc:
+            logger.critical(str(exc))
+            logger.debug('Exception information:', exc_info=True)
+
+            return ERROR
+        except CommandError as exc:
+            logger.critical('%s', exc)
+            logger.debug('Exception information:', exc_info=True)
+
+            return ERROR
+        except BrokenStdoutLoggingError:
+            # Bypass our logger and write any remaining messages to stderr
+            # because stdout no longer works.
+            print('ERROR: Pipe to stdout was broken', file=sys.stderr)
+            if level_number <= logging.DEBUG:
+                traceback.print_exc(file=sys.stderr)
+
+            return ERROR
+        except KeyboardInterrupt:
+            logger.critical('Operation cancelled by user')
+            logger.debug('Exception information:', exc_info=True)
+
+            return ERROR
+        except BaseException:
+            logger.critical('Exception:', exc_info=True)
+
+            return UNKNOWN_ERROR
+        finally:
+            allow_version_check = (
+                # Does this command have the index_group options?
+                hasattr(options, "no_index") and
+                # Is this command allowed to perform this check?
+                not (options.disable_pip_version_check or options.no_index)
+            )
+            # Check if we're using the latest version of pip available
+            if allow_version_check:
+                session = self._build_session(
+                    options,
+                    retries=0,
+                    timeout=min(5, options.timeout)
+                )
+                with session:
+                    pip_version_check(session, options)
+
+            # Shutdown the logging module
+            logging.shutdown()
+
+        return SUCCESS
+
+
+class RequirementCommand(Command):
+
+    @staticmethod
+    def populate_requirement_set(requirement_set,  # type: RequirementSet
+                                 args,             # type: List[str]
+                                 options,          # type: Values
+                                 finder,           # type: PackageFinder
+                                 session,          # type: PipSession
+                                 name,             # type: str
+                                 wheel_cache       # type: Optional[WheelCache]
+                                 ):
+        # type: (...) -> None
+        """
+        Marshal cmd line args into a requirement set.
+        """
+        # NOTE: As a side-effect, options.require_hashes and
+        #       requirement_set.require_hashes may be updated
+
+        for filename in options.constraints:
+            for req_to_add in parse_requirements(
+                    filename,
+                    constraint=True, finder=finder, options=options,
+                    session=session, wheel_cache=wheel_cache):
+                req_to_add.is_direct = True
+                requirement_set.add_requirement(req_to_add)
+
+        for req in args:
+            req_to_add = install_req_from_line(
+                req, None, isolated=options.isolated_mode,
+                use_pep517=options.use_pep517,
+                wheel_cache=wheel_cache
+            )
+            req_to_add.is_direct = True
+            requirement_set.add_requirement(req_to_add)
+
+        for req in options.editables:
+            req_to_add = install_req_from_editable(
+                req,
+                isolated=options.isolated_mode,
+                use_pep517=options.use_pep517,
+                wheel_cache=wheel_cache
+            )
+            req_to_add.is_direct = True
+            requirement_set.add_requirement(req_to_add)
+
+        for filename in options.requirements:
+            for req_to_add in parse_requirements(
+                    filename,
+                    finder=finder, options=options, session=session,
+                    wheel_cache=wheel_cache,
+                    use_pep517=options.use_pep517):
+                req_to_add.is_direct = True
+                requirement_set.add_requirement(req_to_add)
+        # If --require-hashes was a line in a requirements file, tell
+        # RequirementSet about it:
+        requirement_set.require_hashes = options.require_hashes
+
+        if not (args or options.editables or options.requirements):
+            opts = {'name': name}
+            if options.find_links:
+                raise CommandError(
+                    'You must give at least one requirement to %(name)s '
+                    '(maybe you meant "pip %(name)s %(links)s"?)' %
+                    dict(opts, links=' '.join(options.find_links)))
+            else:
+                raise CommandError(
+                    'You must give at least one requirement to %(name)s '
+                    '(see "pip help %(name)s")' % opts)
+
+    def _build_package_finder(
+        self,
+        options,               # type: Values
+        session,               # type: PipSession
+        platform=None,         # type: Optional[str]
+        python_versions=None,  # type: Optional[List[str]]
+        abi=None,              # type: Optional[str]
+        implementation=None    # type: Optional[str]
+    ):
+        # type: (...) -> PackageFinder
+        """
+        Create a package finder appropriate to this requirement command.
+        """
+        index_urls = [options.index_url] + options.extra_index_urls
+        if options.no_index:
+            logger.debug(
+                'Ignoring indexes: %s',
+                ','.join(redact_password_from_url(url) for url in index_urls),
+            )
+            index_urls = []
+
+        return PackageFinder(
+            find_links=options.find_links,
+            format_control=options.format_control,
+            index_urls=index_urls,
+            trusted_hosts=options.trusted_hosts,
+            allow_all_prereleases=options.pre,
+            session=session,
+            platform=platform,
+            versions=python_versions,
+            abi=abi,
+            implementation=implementation,
+            prefer_binary=options.prefer_binary,
+        )
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/cli/base_command.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/cli/base_command.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..6d38b587006ede2a8d4467fb6d561056cbb7aaf7
GIT binary patch
literal 10137
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
Ng_$^+_?gA_004xxJ}dwL

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/cli/cmdoptions.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/cli/cmdoptions.py
new file mode 100644
index 0000000..a09e38f
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/cli/cmdoptions.py
@@ -0,0 +1,809 @@
+"""
+shared options and groups
+
+The principle here is to define options once, but *not* instantiate them
+globally. One reason being that options with action='append' can carry state
+between parses. pip parses general options twice internally, and shouldn't
+pass on state. To be consistent, all options will follow this design.
+
+"""
+from __future__ import absolute_import
+
+import textwrap
+import warnings
+from distutils.util import strtobool
+from functools import partial
+from optparse import SUPPRESS_HELP, Option, OptionGroup
+
+from pip._internal.exceptions import CommandError
+from pip._internal.locations import USER_CACHE_DIR, src_prefix
+from pip._internal.models.format_control import FormatControl
+from pip._internal.models.index import PyPI
+from pip._internal.utils.hashes import STRONG_HASHES
+from pip._internal.utils.typing import MYPY_CHECK_RUNNING
+from pip._internal.utils.ui import BAR_TYPES
+
+if MYPY_CHECK_RUNNING:
+    from typing import Any, Callable, Dict, Optional
+    from optparse import OptionParser, Values
+    from pip._internal.cli.parser import ConfigOptionParser
+
+
+def raise_option_error(parser, option, msg):
+    """
+    Raise an option parsing error using parser.error().
+
+    Args:
+      parser: an OptionParser instance.
+      option: an Option instance.
+      msg: the error text.
+    """
+    msg = '{} error: {}'.format(option, msg)
+    msg = textwrap.fill(' '.join(msg.split()))
+    parser.error(msg)
+
+
+def make_option_group(group, parser):
+    # type: (Dict[str, Any], ConfigOptionParser) -> OptionGroup
+    """
+    Return an OptionGroup object
+    group  -- assumed to be dict with 'name' and 'options' keys
+    parser -- an optparse Parser
+    """
+    option_group = OptionGroup(parser, group['name'])
+    for option in group['options']:
+        option_group.add_option(option())
+    return option_group
+
+
+def check_install_build_global(options, check_options=None):
+    # type: (Values, Optional[Values]) -> None
+    """Disable wheels if per-setup.py call options are set.
+
+    :param options: The OptionParser options to update.
+    :param check_options: The options to check, if not supplied defaults to
+        options.
+    """
+    if check_options is None:
+        check_options = options
+
+    def getname(n):
+        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-options '
+            '/ --global-options / --install-options.', stacklevel=2,
+        )
+
+
+def check_dist_restriction(options, check_target=False):
+    # type: (Values, bool) -> None
+    """Function for determining if custom platform options are allowed.
+
+    :param options: The OptionParser options.
+    :param check_target: Whether or not to check if --target is being used.
+    """
+    dist_restriction_set = any([
+        options.python_version,
+        options.platform,
+        options.abi,
+        options.implementation,
+    ])
+
+    binary_only = FormatControl(set(), {':all:'})
+    sdist_dependencies_allowed = (
+        options.format_control != binary_only and
+        not options.ignore_dependencies
+    )
+
+    # Installations or downloads using dist restrictions must not combine
+    # source distributions and dist-specific wheels, as they are not
+    # guaranteed to be locally compatible.
+    if dist_restriction_set and sdist_dependencies_allowed:
+        raise CommandError(
+            "When restricting platform and interpreter constraints using "
+            "--python-version, --platform, --abi, or --implementation, "
+            "either --no-deps must be set, or --only-binary=:all: must be "
+            "set and --no-binary must not be set (or must be set to "
+            ":none:)."
+        )
+
+    if check_target:
+        if dist_restriction_set and not options.target_dir:
+            raise CommandError(
+                "Can not use any platform or abi specific options unless "
+                "installing via '--target'"
+            )
+
+
+###########
+# options #
+###########
+
+help_ = partial(
+    Option,
+    '-h', '--help',
+    dest='help',
+    action='help',
+    help='Show help.',
+)  # type: Callable[..., Option]
+
+isolated_mode = partial(
+    Option,
+    "--isolated",
+    dest="isolated_mode",
+    action="store_true",
+    default=False,
+    help=(
+        "Run pip in an isolated mode, ignoring environment variables and user "
+        "configuration."
+    ),
+)  # type: Callable[..., Option]
+
+require_virtualenv = partial(
+    Option,
+    # Run only if inside a virtualenv, bail if not.
+    '--require-virtualenv', '--require-venv',
+    dest='require_venv',
+    action='store_true',
+    default=False,
+    help=SUPPRESS_HELP
+)  # type: Callable[..., Option]
+
+verbose = partial(
+    Option,
+    '-v', '--verbose',
+    dest='verbose',
+    action='count',
+    default=0,
+    help='Give more output. Option is additive, and can be used up to 3 times.'
+)  # type: Callable[..., Option]
+
+no_color = partial(
+    Option,
+    '--no-color',
+    dest='no_color',
+    action='store_true',
+    default=False,
+    help="Suppress colored output",
+)  # type: Callable[..., Option]
+
+version = partial(
+    Option,
+    '-V', '--version',
+    dest='version',
+    action='store_true',
+    help='Show version and exit.',
+)  # type: Callable[..., Option]
+
+quiet = partial(
+    Option,
+    '-q', '--quiet',
+    dest='quiet',
+    action='count',
+    default=0,
+    help=(
+        'Give less output. Option is additive, and can be used up to 3'
+        ' times (corresponding to WARNING, ERROR, and CRITICAL logging'
+        ' levels).'
+    ),
+)  # type: Callable[..., Option]
+
+progress_bar = partial(
+    Option,
+    '--progress-bar',
+    dest='progress_bar',
+    type='choice',
+    choices=list(BAR_TYPES.keys()),
+    default='on',
+    help=(
+        'Specify type of progress to be displayed [' +
+        '|'.join(BAR_TYPES.keys()) + '] (default: %default)'
+    ),
+)  # type: Callable[..., Option]
+
+log = partial(
+    Option,
+    "--log", "--log-file", "--local-log",
+    dest="log",
+    metavar="path",
+    help="Path to a verbose appending log."
+)  # type: Callable[..., Option]
+
+no_input = partial(
+    Option,
+    # Don't ask for input
+    '--no-input',
+    dest='no_input',
+    action='store_true',
+    default=False,
+    help=SUPPRESS_HELP
+)  # type: Callable[..., Option]
+
+proxy = partial(
+    Option,
+    '--proxy',
+    dest='proxy',
+    type='str',
+    default='',
+    help="Specify a proxy in the form [user:passwd@]proxy.server:port."
+)  # type: Callable[..., Option]
+
+retries = partial(
+    Option,
+    '--retries',
+    dest='retries',
+    type='int',
+    default=5,
+    help="Maximum number of retries each connection should attempt "
+         "(default %default times).",
+)  # type: Callable[..., Option]
+
+timeout = partial(
+    Option,
+    '--timeout', '--default-timeout',
+    metavar='sec',
+    dest='timeout',
+    type='float',
+    default=15,
+    help='Set the socket timeout (default %default seconds).',
+)  # type: Callable[..., Option]
+
+skip_requirements_regex = partial(
+    Option,
+    # A regex to be used to skip requirements
+    '--skip-requirements-regex',
+    dest='skip_requirements_regex',
+    type='str',
+    default='',
+    help=SUPPRESS_HELP,
+)  # type: Callable[..., Option]
+
+
+def exists_action():
+    # type: () -> Option
+    return Option(
+        # Option when path already exist
+        '--exists-action',
+        dest='exists_action',
+        type='choice',
+        choices=['s', 'i', 'w', 'b', 'a'],
+        default=[],
+        action='append',
+        metavar='action',
+        help="Default action when a path already exists: "
+             "(s)witch, (i)gnore, (w)ipe, (b)ackup, (a)bort.",
+    )
+
+
+cert = partial(
+    Option,
+    '--cert',
+    dest='cert',
+    type='str',
+    metavar='path',
+    help="Path to alternate CA bundle.",
+)  # type: Callable[..., Option]
+
+client_cert = partial(
+    Option,
+    '--client-cert',
+    dest='client_cert',
+    type='str',
+    default=None,
+    metavar='path',
+    help="Path to SSL client certificate, a single file containing the "
+         "private key and the certificate in PEM format.",
+)  # type: Callable[..., Option]
+
+index_url = partial(
+    Option,
+    '-i', '--index-url', '--pypi-url',
+    dest='index_url',
+    metavar='URL',
+    default=PyPI.simple_url,
+    help="Base URL of Python Package Index (default %default). "
+         "This should point to a repository compliant with PEP 503 "
+         "(the simple repository API) or a local directory laid out "
+         "in the same format.",
+)  # type: Callable[..., Option]
+
+
+def extra_index_url():
+    return Option(
+        '--extra-index-url',
+        dest='extra_index_urls',
+        metavar='URL',
+        action='append',
+        default=[],
+        help="Extra URLs of package indexes to use in addition to "
+             "--index-url. Should follow the same rules as "
+             "--index-url.",
+    )
+
+
+no_index = partial(
+    Option,
+    '--no-index',
+    dest='no_index',
+    action='store_true',
+    default=False,
+    help='Ignore package index (only looking at --find-links URLs instead).',
+)  # type: Callable[..., Option]
+
+
+def find_links():
+    # type: () -> Option
+    return Option(
+        '-f', '--find-links',
+        dest='find_links',
+        action='append',
+        default=[],
+        metavar='url',
+        help="If a url or path to an html file, then parse for links to "
+             "archives. If a local path or file:// url that's a directory, "
+             "then look for archives in the directory listing.",
+    )
+
+
+def trusted_host():
+    # type: () -> Option
+    return Option(
+        "--trusted-host",
+        dest="trusted_hosts",
+        action="append",
+        metavar="HOSTNAME",
+        default=[],
+        help="Mark this host as trusted, even though it does not have valid "
+             "or any HTTPS.",
+    )
+
+
+def constraints():
+    # type: () -> Option
+    return Option(
+        '-c', '--constraint',
+        dest='constraints',
+        action='append',
+        default=[],
+        metavar='file',
+        help='Constrain versions using the given constraints file. '
+        'This option can be used multiple times.'
+    )
+
+
+def requirements():
+    # type: () -> Option
+    return Option(
+        '-r', '--requirement',
+        dest='requirements',
+        action='append',
+        default=[],
+        metavar='file',
+        help='Install from the given requirements file. '
+        'This option can be used multiple times.'
+    )
+
+
+def editable():
+    # type: () -> Option
+    return Option(
+        '-e', '--editable',
+        dest='editables',
+        action='append',
+        default=[],
+        metavar='path/url',
+        help=('Install a project in editable mode (i.e. setuptools '
+              '"develop mode") from a local project path or a VCS url.'),
+    )
+
+
+src = partial(
+    Option,
+    '--src', '--source', '--source-dir', '--source-directory',
+    dest='src_dir',
+    metavar='dir',
+    default=src_prefix,
+    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
+    """Get a format_control object."""
+    return getattr(values, option.dest)
+
+
+def _handle_no_binary(option, opt_str, value, parser):
+    # type: (Option, str, str, OptionParser) -> None
+    existing = _get_format_control(parser.values, option)
+    FormatControl.handle_mutual_excludes(
+        value, existing.no_binary, existing.only_binary,
+    )
+
+
+def _handle_only_binary(option, opt_str, value, parser):
+    # type: (Option, str, str, OptionParser) -> None
+    existing = _get_format_control(parser.values, option)
+    FormatControl.handle_mutual_excludes(
+        value, existing.only_binary, existing.no_binary,
+    )
+
+
+def no_binary():
+    # type: () -> Option
+    format_control = FormatControl(set(), set())
+    return Option(
+        "--no-binary", dest="format_control", action="callback",
+        callback=_handle_no_binary, type="str",
+        default=format_control,
+        help="Do not use binary packages. Can be supplied multiple times, and "
+             "each time adds to the existing value. Accepts either :all: to "
+             "disable all binary packages, :none: to empty the set, or one or "
+             "more package names with commas between them. Note that some "
+             "packages are tricky to compile and may fail to install when "
+             "this option is used on them.",
+    )
+
+
+def only_binary():
+    # type: () -> Option
+    format_control = FormatControl(set(), set())
+    return Option(
+        "--only-binary", dest="format_control", action="callback",
+        callback=_handle_only_binary, type="str",
+        default=format_control,
+        help="Do not use source packages. Can be supplied multiple times, and "
+             "each time adds to the existing value. Accepts either :all: to "
+             "disable all source packages, :none: to empty the set, or one or "
+             "more package names with commas between them. Packages without "
+             "binary distributions will fail to install when this option is "
+             "used on them.",
+    )
+
+
+platform = partial(
+    Option,
+    '--platform',
+    dest='platform',
+    metavar='platform',
+    default=None,
+    help=("Only use wheels compatible with <platform>. "
+          "Defaults to the platform of the running system."),
+)  # type: Callable[..., Option]
+
+
+python_version = partial(
+    Option,
+    '--python-version',
+    dest='python_version',
+    metavar='python_version',
+    default=None,
+    help=("Only use wheels compatible with Python "
+          "interpreter version <version>. If not specified, then the "
+          "current system interpreter minor version is used. A major "
+          "version (e.g. '2') can be specified to match all "
+          "minor revs of that major version.  A minor version "
+          "(e.g. '34') can also be specified."),
+)  # type: Callable[..., Option]
+
+
+implementation = partial(
+    Option,
+    '--implementation',
+    dest='implementation',
+    metavar='implementation',
+    default=None,
+    help=("Only use wheels compatible with Python "
+          "implementation <implementation>, e.g. 'pp', 'jy', 'cp', "
+          " or 'ip'. If not specified, then the current "
+          "interpreter implementation is used.  Use 'py' to force "
+          "implementation-agnostic wheels."),
+)  # type: Callable[..., Option]
+
+
+abi = partial(
+    Option,
+    '--abi',
+    dest='abi',
+    metavar='abi',
+    default=None,
+    help=("Only use wheels compatible with Python "
+          "abi <abi>, e.g. 'pypy_41'.  If not specified, then the "
+          "current interpreter abi tag is used.  Generally "
+          "you will need to specify --implementation, "
+          "--platform, and --python-version when using "
+          "this option."),
+)  # type: Callable[..., Option]
+
+
+def prefer_binary():
+    # type: () -> Option
+    return Option(
+        "--prefer-binary",
+        dest="prefer_binary",
+        action="store_true",
+        default=False,
+        help="Prefer older binary packages over newer source packages."
+    )
+
+
+cache_dir = partial(
+    Option,
+    "--cache-dir",
+    dest="cache_dir",
+    default=USER_CACHE_DIR,
+    metavar="dir",
+    help="Store the cache data in <dir>."
+)  # type: Callable[..., Option]
+
+
+def no_cache_dir_callback(option, opt, value, parser):
+    """
+    Process a value provided for the --no-cache-dir option.
+
+    This is an optparse.Option callback for the --no-cache-dir option.
+    """
+    # The value argument will be None if --no-cache-dir is passed via the
+    # command-line, since the option doesn't accept arguments.  However,
+    # the value can be non-None if the option is triggered e.g. by an
+    # environment variable, like PIP_NO_CACHE_DIR=true.
+    if value is not None:
+        # Then parse the string value to get argument error-checking.
+        try:
+            strtobool(value)
+        except ValueError as exc:
+            raise_option_error(parser, option=option, msg=str(exc))
+
+    # Originally, setting PIP_NO_CACHE_DIR to a value that strtobool()
+    # converted to 0 (like "false" or "no") caused cache_dir to be disabled
+    # rather than enabled (logic would say the latter).  Thus, we disable
+    # the cache directory not just on values that parse to True, but (for
+    # backwards compatibility reasons) also on values that parse to False.
+    # In other words, always set it to False if the option is provided in
+    # some (valid) form.
+    parser.values.cache_dir = False
+
+
+no_cache = partial(
+    Option,
+    "--no-cache-dir",
+    dest="cache_dir",
+    action="callback",
+    callback=no_cache_dir_callback,
+    help="Disable the cache.",
+)  # type: Callable[..., Option]
+
+no_deps = partial(
+    Option,
+    '--no-deps', '--no-dependencies',
+    dest='ignore_dependencies',
+    action='store_true',
+    default=False,
+    help="Don't install package dependencies.",
+)  # type: Callable[..., Option]
+
+build_dir = partial(
+    Option,
+    '-b', '--build', '--build-dir', '--build-directory',
+    dest='build_dir',
+    metavar='dir',
+    help='Directory to unpack packages into and build in. Note that '
+         'an initial build still takes place in a temporary directory. '
+         'The location of temporary directories can be controlled by setting '
+         'the TMPDIR environment variable (TEMP on Windows) appropriately. '
+         'When passed, build directories are not cleaned in case of failures.'
+)  # type: Callable[..., Option]
+
+ignore_requires_python = partial(
+    Option,
+    '--ignore-requires-python',
+    dest='ignore_requires_python',
+    action='store_true',
+    help='Ignore the Requires-Python information.'
+)  # type: Callable[..., Option]
+
+no_build_isolation = partial(
+    Option,
+    '--no-build-isolation',
+    dest='build_isolation',
+    action='store_false',
+    default=True,
+    help='Disable isolation when building a modern source distribution. '
+         'Build dependencies specified by PEP 518 must be already installed '
+         'if this option is used.'
+)  # type: Callable[..., Option]
+
+
+def no_use_pep517_callback(option, opt, value, parser):
+    """
+    Process a value provided for the --no-use-pep517 option.
+
+    This is an optparse.Option callback for the no_use_pep517 option.
+    """
+    # Since --no-use-pep517 doesn't accept arguments, the value argument
+    # will be None if --no-use-pep517 is passed via the command-line.
+    # However, the value can be non-None if the option is triggered e.g.
+    # by an environment variable, for example "PIP_NO_USE_PEP517=true".
+    if value is not None:
+        msg = """A value was passed for --no-use-pep517,
+        probably using either the PIP_NO_USE_PEP517 environment variable
+        or the "no-use-pep517" config file option. Use an appropriate value
+        of the PIP_USE_PEP517 environment variable or the "use-pep517"
+        config file option instead.
+        """
+        raise_option_error(parser, option=option, msg=msg)
+
+    # Otherwise, --no-use-pep517 was passed via the command-line.
+    parser.values.use_pep517 = False
+
+
+use_pep517 = partial(
+    Option,
+    '--use-pep517',
+    dest='use_pep517',
+    action='store_true',
+    default=None,
+    help='Use PEP 517 for building source distributions '
+         '(use --no-use-pep517 to force legacy behaviour).'
+)  # type: Any
+
+no_use_pep517 = partial(
+    Option,
+    '--no-use-pep517',
+    dest='use_pep517',
+    action='callback',
+    callback=no_use_pep517_callback,
+    default=None,
+    help=SUPPRESS_HELP
+)  # type: Any
+
+install_options = partial(
+    Option,
+    '--install-option',
+    dest='install_options',
+    action='append',
+    metavar='options',
+    help="Extra arguments to be supplied to the setup.py install "
+         "command (use like --install-option=\"--install-scripts=/usr/local/"
+         "bin\"). Use multiple --install-option options to pass multiple "
+         "options to setup.py install. If you are using an option with a "
+         "directory path, be sure to use absolute path.",
+)  # type: Callable[..., Option]
+
+global_options = partial(
+    Option,
+    '--global-option',
+    dest='global_options',
+    action='append',
+    metavar='options',
+    help="Extra global options to be supplied to the setup.py "
+         "call before the install command.",
+)  # type: Callable[..., Option]
+
+no_clean = partial(
+    Option,
+    '--no-clean',
+    action='store_true',
+    default=False,
+    help="Don't clean up build directories."
+)  # type: Callable[..., Option]
+
+pre = partial(
+    Option,
+    '--pre',
+    action='store_true',
+    default=False,
+    help="Include pre-release and development versions. By default, "
+         "pip only finds stable versions.",
+)  # type: Callable[..., Option]
+
+disable_pip_version_check = partial(
+    Option,
+    "--disable-pip-version-check",
+    dest="disable_pip_version_check",
+    action="store_true",
+    default=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]
+
+
+# Deprecated, Remove later
+always_unzip = partial(
+    Option,
+    '-Z', '--always-unzip',
+    dest='always_unzip',
+    action='store_true',
+    help=SUPPRESS_HELP,
+)  # type: Callable[..., Option]
+
+
+def _merge_hash(option, opt_str, value, parser):
+    # type: (Option, str, str, OptionParser) -> None
+    """Given a value spelled "algo:digest", append the digest to a list
+    pointed to in a dict by the algo name."""
+    if not parser.values.hashes:
+        parser.values.hashes = {}
+    try:
+        algo, digest = value.split(':', 1)
+    except ValueError:
+        parser.error('Arguments to %s must be a hash name '
+                     'followed by a value, like --hash=sha256:abcde...' %
+                     opt_str)
+    if algo not in STRONG_HASHES:
+        parser.error('Allowed hash algorithms for %s are %s.' %
+                     (opt_str, ', '.join(STRONG_HASHES)))
+    parser.values.hashes.setdefault(algo, []).append(digest)
+
+
+hash = partial(
+    Option,
+    '--hash',
+    # Hash values eventually end up in InstallRequirement.hashes due to
+    # __dict__ copying in process_line().
+    dest='hashes',
+    action='callback',
+    callback=_merge_hash,
+    type='string',
+    help="Verify that the package's archive matches this "
+         'hash before installing. Example: --hash=sha256:abcdef...',
+)  # type: Callable[..., Option]
+
+
+require_hashes = partial(
+    Option,
+    '--require-hashes',
+    dest='require_hashes',
+    action='store_true',
+    default=False,
+    help='Require a hash to check each requirement against, for '
+         'repeatable installs. This option is implied when any package in a '
+         'requirements file has a --hash option.',
+)  # type: Callable[..., Option]
+
+
+##########
+# groups #
+##########
+
+general_group = {
+    'name': 'General Options',
+    'options': [
+        help_,
+        isolated_mode,
+        require_virtualenv,
+        verbose,
+        version,
+        quiet,
+        log,
+        no_input,
+        proxy,
+        retries,
+        timeout,
+        skip_requirements_regex,
+        exists_action,
+        trusted_host,
+        cert,
+        client_cert,
+        cache_dir,
+        no_cache,
+        disable_pip_version_check,
+        no_color,
+    ]
+}  # type: Dict[str, Any]
+
+index_group = {
+    'name': 'Package Index Options',
+    'options': [
+        index_url,
+        extra_index_url,
+        no_index,
+        find_links,
+    ]
+}  # type: Dict[str, Any]
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/cli/cmdoptions.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/cli/cmdoptions.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..55ca08cf3870407ab58e0a6ac862ab269b1ade9a
GIT binary patch
literal 21201
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
FEdZfc)gJ%=

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/cli/main_parser.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/cli/main_parser.py
new file mode 100644
index 0000000..767f35d
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/cli/main_parser.py
@@ -0,0 +1,104 @@
+"""A single place for constructing and exposing the main parser
+"""
+
+import os
+import sys
+
+from pip import __version__
+from pip._internal.cli import cmdoptions
+from pip._internal.cli.parser import (
+    ConfigOptionParser, UpdatingDefaultsHelpFormatter,
+)
+from pip._internal.commands import (
+    commands_dict, get_similar_commands, get_summaries,
+)
+from pip._internal.exceptions import CommandError
+from pip._internal.utils.misc import get_prog
+from pip._internal.utils.typing import MYPY_CHECK_RUNNING
+
+if MYPY_CHECK_RUNNING:
+    from typing import Tuple, List
+
+
+__all__ = ["create_main_parser", "parse_command"]
+
+
+def create_main_parser():
+    # type: () -> ConfigOptionParser
+    """Creates and returns the main parser for pip's CLI
+    """
+
+    parser_kw = {
+        'usage': '\n%prog <command> [options]',
+        'add_help_option': False,
+        'formatter': UpdatingDefaultsHelpFormatter(),
+        'name': 'global',
+        'prog': get_prog(),
+    }
+
+    parser = ConfigOptionParser(**parser_kw)
+    parser.disable_interspersed_args()
+
+    pip_pkg_dir = os.path.abspath(os.path.join(
+        os.path.dirname(__file__), "..", "..",
+    ))
+    parser.version = 'pip %s from %s (python %s)' % (
+        __version__, pip_pkg_dir, sys.version[:3],
+    )
+
+    # add the general options
+    gen_opts = cmdoptions.make_option_group(cmdoptions.general_group, parser)
+    parser.add_option_group(gen_opts)
+
+    # so the help formatter knows
+    parser.main = True  # type: ignore
+
+    # create command listing for description
+    command_summaries = get_summaries()
+    description = [''] + ['%-27s %s' % (i, j) for i, j in command_summaries]
+    parser.description = '\n'.join(description)
+
+    return parser
+
+
+def parse_command(args):
+    # type: (List[str]) -> Tuple[str, List[str]]
+    parser = create_main_parser()
+
+    # Note: parser calls disable_interspersed_args(), so the result of this
+    # call is to split the initial args into the general options before the
+    # subcommand and everything else.
+    # For example:
+    #  args: ['--timeout=5', 'install', '--user', 'INITools']
+    #  general_options: ['--timeout==5']
+    #  args_else: ['install', '--user', 'INITools']
+    general_options, args_else = parser.parse_args(args)
+
+    # --version
+    if general_options.version:
+        sys.stdout.write(parser.version)  # type: ignore
+        sys.stdout.write(os.linesep)
+        sys.exit()
+
+    # pip || pip help -> print_help()
+    if not args_else or (args_else[0] == 'help' and len(args_else) == 1):
+        parser.print_help()
+        sys.exit()
+
+    # the subcommand name
+    cmd_name = args_else[0]
+
+    if cmd_name not in commands_dict:
+        guess = get_similar_commands(cmd_name)
+
+        msg = ['unknown command "%s"' % cmd_name]
+        if guess:
+            msg.append('maybe you meant "%s"' % guess)
+
+        raise CommandError(' - '.join(msg))
+
+    # all the args without the subcommand
+    cmd_args = args[:]
+    cmd_args.remove(cmd_name)
+
+    return cmd_name, cmd_args
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/cli/main_parser.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/cli/main_parser.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..38df7e0b94b6e019d1f138674294809f13a790d1
GIT binary patch
literal 2974
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

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/cli/parser.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/cli/parser.py
new file mode 100644
index 0000000..e1eaac4
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/cli/parser.py
@@ -0,0 +1,261 @@
+"""Base option parser setup"""
+from __future__ import absolute_import
+
+import logging
+import optparse
+import sys
+import textwrap
+from distutils.util import strtobool
+
+from pip._vendor.six import string_types
+
+from pip._internal.cli.status_codes import UNKNOWN_ERROR
+from pip._internal.configuration import Configuration, ConfigurationError
+from pip._internal.utils.compat import get_terminal_size
+
+logger = logging.getLogger(__name__)
+
+
+class PrettyHelpFormatter(optparse.IndentedHelpFormatter):
+    """A prettier/less verbose help formatter for optparse."""
+
+    def __init__(self, *args, **kwargs):
+        # help position must be aligned with __init__.parseopts.description
+        kwargs['max_help_position'] = 30
+        kwargs['indent_increment'] = 1
+        kwargs['width'] = get_terminal_size()[0] - 2
+        optparse.IndentedHelpFormatter.__init__(self, *args, **kwargs)
+
+    def format_option_strings(self, option):
+        return self._format_option_strings(option, ' <%s>', ', ')
+
+    def _format_option_strings(self, option, mvarfmt=' <%s>', optsep=', '):
+        """
+        Return a comma-separated list of option strings and metavars.
+
+        :param option:  tuple of (short opt, long opt), e.g: ('-f', '--format')
+        :param mvarfmt: metavar format string - evaluated as mvarfmt % metavar
+        :param optsep:  separator
+        """
+        opts = []
+
+        if option._short_opts:
+            opts.append(option._short_opts[0])
+        if option._long_opts:
+            opts.append(option._long_opts[0])
+        if len(opts) > 1:
+            opts.insert(1, optsep)
+
+        if option.takes_value():
+            metavar = option.metavar or option.dest.lower()
+            opts.append(mvarfmt % metavar.lower())
+
+        return ''.join(opts)
+
+    def format_heading(self, heading):
+        if heading == 'Options':
+            return ''
+        return heading + ':\n'
+
+    def format_usage(self, usage):
+        """
+        Ensure there is only one newline between usage and the first heading
+        if there is no description.
+        """
+        msg = '\nUsage: %s\n' % self.indent_lines(textwrap.dedent(usage), "  ")
+        return msg
+
+    def format_description(self, description):
+        # leave full control over description to us
+        if description:
+            if hasattr(self.parser, 'main'):
+                label = 'Commands'
+            else:
+                label = 'Description'
+            # some doc strings have initial newlines, some don't
+            description = description.lstrip('\n')
+            # some doc strings have final newlines and spaces, some don't
+            description = description.rstrip()
+            # dedent, then reindent
+            description = self.indent_lines(textwrap.dedent(description), "  ")
+            description = '%s:\n%s\n' % (label, description)
+            return description
+        else:
+            return ''
+
+    def format_epilog(self, epilog):
+        # leave full control over epilog to us
+        if epilog:
+            return epilog
+        else:
+            return ''
+
+    def indent_lines(self, text, indent):
+        new_lines = [indent + line for line in text.split('\n')]
+        return "\n".join(new_lines)
+
+
+class UpdatingDefaultsHelpFormatter(PrettyHelpFormatter):
+    """Custom help formatter for use in ConfigOptionParser.
+
+    This is updates the defaults before expanding them, allowing
+    them to show up correctly in the help listing.
+    """
+
+    def expand_default(self, option):
+        if self.parser is not None:
+            self.parser._update_defaults(self.parser.defaults)
+        return optparse.IndentedHelpFormatter.expand_default(self, option)
+
+
+class CustomOptionParser(optparse.OptionParser):
+
+    def insert_option_group(self, idx, *args, **kwargs):
+        """Insert an OptionGroup at a given position."""
+        group = self.add_option_group(*args, **kwargs)
+
+        self.option_groups.pop()
+        self.option_groups.insert(idx, group)
+
+        return group
+
+    @property
+    def option_list_all(self):
+        """Get a list of all options, including those in option groups."""
+        res = self.option_list[:]
+        for i in self.option_groups:
+            res.extend(i.option_list)
+
+        return res
+
+
+class ConfigOptionParser(CustomOptionParser):
+    """Custom option parser which updates its defaults by checking the
+    configuration files and environmental variables"""
+
+    def __init__(self, *args, **kwargs):
+        self.name = kwargs.pop('name')
+
+        isolated = kwargs.pop("isolated", False)
+        self.config = Configuration(isolated)
+
+        assert self.name
+        optparse.OptionParser.__init__(self, *args, **kwargs)
+
+    def check_default(self, option, key, val):
+        try:
+            return option.check_value(key, val)
+        except optparse.OptionValueError as exc:
+            print("An error occurred during configuration: %s" % exc)
+            sys.exit(3)
+
+    def _get_ordered_configuration_items(self):
+        # Configuration gives keys in an unordered manner. Order them.
+        override_order = ["global", self.name, ":env:"]
+
+        # Pool the options into different groups
+        section_items = {name: [] for name in override_order}
+        for section_key, val in self.config.items():
+            # ignore empty values
+            if not val:
+                logger.debug(
+                    "Ignoring configuration key '%s' as it's value is empty.",
+                    section_key
+                )
+                continue
+
+            section, key = section_key.split(".", 1)
+            if section in override_order:
+                section_items[section].append((key, val))
+
+        # Yield each group in their override order
+        for section in override_order:
+            for key, val in section_items[section]:
+                yield key, val
+
+    def _update_defaults(self, defaults):
+        """Updates the given defaults with values from the config files and
+        the environ. Does a little special handling for certain types of
+        options (lists)."""
+
+        # Accumulate complex default state.
+        self.values = optparse.Values(self.defaults)
+        late_eval = set()
+        # Then set the options with those values
+        for key, val in self._get_ordered_configuration_items():
+            # '--' because configuration supports only long names
+            option = self.get_option('--' + key)
+
+            # Ignore options not present in this parser. E.g. non-globals put
+            # in [global] by users that want them to apply to all applicable
+            # commands.
+            if option is None:
+                continue
+
+            if option.action in ('store_true', 'store_false', 'count'):
+                try:
+                    val = strtobool(val)
+                except ValueError:
+                    error_msg = invalid_config_error_message(
+                        option.action, key, val
+                    )
+                    self.error(error_msg)
+
+            elif option.action == 'append':
+                val = val.split()
+                val = [self.check_default(option, key, v) for v in val]
+            elif option.action == 'callback':
+                late_eval.add(option.dest)
+                opt_str = option.get_opt_string()
+                val = option.convert_value(opt_str, val)
+                # From take_action
+                args = option.callback_args or ()
+                kwargs = option.callback_kwargs or {}
+                option.callback(option, opt_str, val, self, *args, **kwargs)
+            else:
+                val = self.check_default(option, key, val)
+
+            defaults[option.dest] = val
+
+        for key in late_eval:
+            defaults[key] = getattr(self.values, key)
+        self.values = None
+        return defaults
+
+    def get_default_values(self):
+        """Overriding to make updating the defaults after instantiation of
+        the option parser possible, _update_defaults() does the dirty work."""
+        if not self.process_default_values:
+            # Old, pre-Optik 1.5 behaviour.
+            return optparse.Values(self.defaults)
+
+        # Load the configuration, or error out in case of an error
+        try:
+            self.config.load()
+        except ConfigurationError as err:
+            self.exit(UNKNOWN_ERROR, str(err))
+
+        defaults = self._update_defaults(self.defaults.copy())  # ours
+        for option in self._get_all_options():
+            default = defaults.get(option.dest)
+            if isinstance(default, string_types):
+                opt_str = option.get_opt_string()
+                defaults[option.dest] = option.check_value(opt_str, default)
+        return optparse.Values(defaults)
+
+    def error(self, msg):
+        self.print_usage(sys.stderr)
+        self.exit(UNKNOWN_ERROR, "%s\n" % msg)
+
+
+def invalid_config_error_message(action, key, val):
+    """Returns a better error message when invalid configuration option
+    is provided."""
+    if action in ('store_true', 'store_false'):
+        return ("{0} is not a valid value for {1} option, "
+                "please specify a boolean value like yes/no, "
+                "true/false or 1/0 instead.").format(val, key)
+
+    return ("{0} is not a valid value for {1} option, "
+            "please specify a numerical value like 1/0 "
+            "instead.").format(val, key)
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/cli/parser.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/cli/parser.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..369206cff4354e56c1bf949ec155f01885a4fbee
GIT binary patch
literal 11559
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
C!NLCk

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/cli/status_codes.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/cli/status_codes.py
new file mode 100644
index 0000000..275360a
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/cli/status_codes.py
@@ -0,0 +1,8 @@
+from __future__ import absolute_import
+
+SUCCESS = 0
+ERROR = 1
+UNKNOWN_ERROR = 2
+VIRTUALENV_NOT_FOUND = 3
+PREVIOUS_BUILD_DIR_ERROR = 4
+NO_MATCHES_FOUND = 23
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/cli/status_codes.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/cli/status_codes.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..c2f68705ea2b9b09943380986b9e0b4c2c1a1252
GIT binary patch
literal 454
zcmZSn%**AGdLky70ScHH7#JKJ7#NBz7#J8*7#LC*8FCmHav2$-7#SE-7#O0M7*d!R
zqL>*{m>Hs27*bdmqF5PHSQ(<&7*g06qSzTy*cpN~I2afhGC?M4FfuSOl<+e!FeD}w
z=jW7`q{e6F7UUO|WP&6zLAGTwgA}uX2yq4m20yUo5-tV?hWPlj(vs4m)cE)ykXa?{
z3=9mxq0Y{(!NDc03=9meK|%gOCA<s_455DBe*WQp@emOa1_p*O&!CV{M;}+euy{ZJ
zka#!$P(POv2?hp+fFRc}Pyf*1c&AWLAD4I+&mgES0g&bX@xG2B&K|D85FHvIdl5u&
zAp--0enC-YSz<}5epzCXep-G`N@`KDeo~5lc~Vkdu4!(ukztZ~dR4lGsYQ8CR+X6n
z2&Cufhv*k%7U*W?6_+ID<mkGUd3YKJfP}y}J~OW*wJ0w!M?X0yQ@^+*v81#(J~=-n
hwOFs9vIG>GHo5sJr8%i~pkOQJVPIeoU}9s0K>#u#W={YB

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/commands/__init__.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/commands/__init__.py
new file mode 100644
index 0000000..2e90db3
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/commands/__init__.py
@@ -0,0 +1,79 @@
+"""
+Package containing all pip commands
+"""
+from __future__ import absolute_import
+
+from pip._internal.commands.completion import CompletionCommand
+from pip._internal.commands.configuration import ConfigurationCommand
+from pip._internal.commands.download import DownloadCommand
+from pip._internal.commands.freeze import FreezeCommand
+from pip._internal.commands.hash import HashCommand
+from pip._internal.commands.help import HelpCommand
+from pip._internal.commands.list import ListCommand
+from pip._internal.commands.check import CheckCommand
+from pip._internal.commands.search import SearchCommand
+from pip._internal.commands.show import ShowCommand
+from pip._internal.commands.install import InstallCommand
+from pip._internal.commands.uninstall import UninstallCommand
+from pip._internal.commands.wheel import WheelCommand
+
+from pip._internal.utils.typing import MYPY_CHECK_RUNNING
+
+if MYPY_CHECK_RUNNING:
+    from typing import List, Type
+    from pip._internal.cli.base_command import Command
+
+commands_order = [
+    InstallCommand,
+    DownloadCommand,
+    UninstallCommand,
+    FreezeCommand,
+    ListCommand,
+    ShowCommand,
+    CheckCommand,
+    ConfigurationCommand,
+    SearchCommand,
+    WheelCommand,
+    HashCommand,
+    CompletionCommand,
+    HelpCommand,
+]  # type: List[Type[Command]]
+
+commands_dict = {c.name: c for c in commands_order}
+
+
+def get_summaries(ordered=True):
+    """Yields sorted (command name, command summary) tuples."""
+
+    if ordered:
+        cmditems = _sort_commands(commands_dict, commands_order)
+    else:
+        cmditems = commands_dict.items()
+
+    for name, command_class in cmditems:
+        yield (name, command_class.summary)
+
+
+def get_similar_commands(name):
+    """Command name auto-correct."""
+    from difflib import get_close_matches
+
+    name = name.lower()
+
+    close_commands = get_close_matches(name, commands_dict.keys())
+
+    if close_commands:
+        return close_commands[0]
+    else:
+        return False
+
+
+def _sort_commands(cmddict, order):
+    def keyfn(key):
+        try:
+            return order.index(key[1])
+        except ValueError:
+            # unordered items should come last
+            return 0xff
+
+    return sorted(cmddict.items(), key=keyfn)
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/commands/__init__.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/commands/__init__.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..b91a99bcddee35385b14a2c87d0e51cef8e97bbf
GIT binary patch
literal 3475
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
BMI8VD

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/commands/check.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/commands/check.py
new file mode 100644
index 0000000..801cecc
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/commands/check.py
@@ -0,0 +1,41 @@
+import logging
+
+from pip._internal.cli.base_command import Command
+from pip._internal.operations.check import (
+    check_package_set, create_package_set_from_installed,
+)
+
+logger = logging.getLogger(__name__)
+
+
+class CheckCommand(Command):
+    """Verify installed packages have compatible dependencies."""
+    name = 'check'
+    usage = """
+      %prog [options]"""
+    summary = 'Verify installed packages have compatible dependencies.'
+
+    def run(self, options, args):
+        package_set, parsing_probs = create_package_set_from_installed()
+        missing, conflicting = check_package_set(package_set)
+
+        for project_name in missing:
+            version = package_set[project_name].version
+            for dependency in missing[project_name]:
+                logger.info(
+                    "%s %s requires %s, which is not installed.",
+                    project_name, version, dependency[0],
+                )
+
+        for project_name in conflicting:
+            version = package_set[project_name].version
+            for dep_name, dep_version, req in conflicting[project_name]:
+                logger.info(
+                    "%s %s has requirement %s, but you have %s %s.",
+                    project_name, version, req, dep_name, dep_version,
+                )
+
+        if missing or conflicting or parsing_probs:
+            return 1
+        else:
+            logger.info("No broken requirements found.")
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/commands/check.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/commands/check.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..8a3731993346aec849d1ef31b2629e19bb37fc07
GIT binary patch
literal 1725
zcmZSn%**AGdLky70ScHI7#JKF7#ND985kH+7#LC*8FCmHq9AN0h8#wQTqcGnCI&{3
z95X`>Gea&5Llg@`E-OP6D+6OH149-YLn=E%Gb2M32SW-ALn;$P8Y4prD?<wdLo)+I
zWE3aJ%wP>R1_p-A|NsC0_tRixU|=X=XJBA(&d<$F%uCT=0tpB*Ffb%%q$X#_7bGTU
zC#I*y7pIn#D1t<bQWHy3k%i;ait=;gGxLf|5_57=Q%ZP1hJo}#O@w<7WR(-hdzuUk
z45<tZQH&r@Mlpfh6vfPt!UXb53IoV5Da;@zN3k&k1#7T?w3st6FodNRWu{dsz->~1
zx~*6tBe5)1Avr&{Ah9GfDJNASCAA<mFC{fEIWx6buY?ukY><PB#TXbExD>!ZwV)_J
zT_HNZpd>RtuQ)at6!yFf3=Etg*Mn?)3knBtu*EPj)G{;FvM`h|GSo1GLKh^$%23P3
zP~pW;!^+?i>%>sY4w9>3XOPTdVyNX{sL%n)fcP%43JkTJ3?<AASu7y0*03|wa4^(x
zf;=qQ%)-D}=*AFUsKF3k5z0`*#^4g`i)olSNCsk<HbV?ELoF9WEjL3g56o0%2B@h#
z3^iN~HQWr%Yz&NrlNrJbOBupzSQ(0MfD8bUEDS|=KuIGQ>K;~*e?SQek}CX)wHO!}
zRErf<ixrAe3rjPLQbBATh4PHd<P3$(Vuif?5=0c}WrC7!u`XOsMj~8aZfahMf@-mj
zLQ-joLS=p_B$mKN>t%w{La{6Z1A||_LQ+wFc4{8XI*_(vg|z(Ayc9hRP}Bv1Qe+TF
z12~<Qr4|)u=I51w(r`|GdU|S62`GhR=B4FpfFcmgD^ATx1FMF{FIX_KD80CZn}LA=
znr^^p8l<Hlv8XsRFFn4XC_kwftSvXQ7$gE#ot&SSmXn!Wl9`tdPTK`V`B|ySCGmNQ
zxv4=Q2bOSwvMVgfRhDo-xL^ff6H-zO;$hAPrL&^cLJd&3fr;XL1_lQGf}+f_#FA9~
zvcw|&wEUcu)S_bjq!j(~q@=uD)7)Ys!zA<cs&orei}IYTDl-ERNYB#`(J#m>(1m6Q
zUAHn1PvZcP5E#d2=9Q!t<t66mCquG!u|7CU>lIX%fL&3VCj?69N+72&@-qrC@iOu<
z3No@WGBZjtgV<7FwluR4BMXxTsEh!6EgtN#_;|3l<KuJlQ%ZAE<Kw~M79XFIpBx_#
z4sKBRfb(8yabkKZSh~10H#f1UGDw7hfdTA!1Thf75CjSaP=Y81#UL9a8zUPN2y1}2
zU<ZQ|7%1N5K&d9PKo1_KddWGNdP#}JsqxUj4FZK?38uRIg4Ci!a2cZq4t;P!1}Etf
zP*IbfTH*sv#6hAA3=Bb_L=AQoB4EI*fe0ONWZOWZ*AA5Zia`mRhe?1@jD?>W0OVw*
A#sB~S

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/commands/completion.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/commands/completion.py
new file mode 100644
index 0000000..2fcdd39
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/commands/completion.py
@@ -0,0 +1,94 @@
+from __future__ import absolute_import
+
+import sys
+import textwrap
+
+from pip._internal.cli.base_command import Command
+from pip._internal.utils.misc import get_prog
+
+BASE_COMPLETION = """
+# pip %(shell)s completion start%(script)s# pip %(shell)s completion end
+"""
+
+COMPLETION_SCRIPTS = {
+    'bash': """
+        _pip_completion()
+        {
+            COMPREPLY=( $( COMP_WORDS="${COMP_WORDS[*]}" \\
+                           COMP_CWORD=$COMP_CWORD \\
+                           PIP_AUTO_COMPLETE=1 $1 ) )
+        }
+        complete -o default -F _pip_completion %(prog)s
+    """,
+    'zsh': """
+        function _pip_completion {
+          local words cword
+          read -Ac words
+          read -cn cword
+          reply=( $( COMP_WORDS="$words[*]" \\
+                     COMP_CWORD=$(( cword-1 )) \\
+                     PIP_AUTO_COMPLETE=1 $words[1] ) )
+        }
+        compctl -K _pip_completion %(prog)s
+    """,
+    'fish': """
+        function __fish_complete_pip
+            set -lx COMP_WORDS (commandline -o) ""
+            set -lx COMP_CWORD ( \\
+                math (contains -i -- (commandline -t) $COMP_WORDS)-1 \\
+            )
+            set -lx PIP_AUTO_COMPLETE 1
+            string split \\  -- (eval $COMP_WORDS[1])
+        end
+        complete -fa "(__fish_complete_pip)" -c %(prog)s
+    """,
+}
+
+
+class CompletionCommand(Command):
+    """A helper command to be used for command completion."""
+    name = 'completion'
+    summary = 'A helper command used for command completion.'
+    ignore_require_venv = True
+
+    def __init__(self, *args, **kw):
+        super(CompletionCommand, self).__init__(*args, **kw)
+
+        cmd_opts = self.cmd_opts
+
+        cmd_opts.add_option(
+            '--bash', '-b',
+            action='store_const',
+            const='bash',
+            dest='shell',
+            help='Emit completion code for bash')
+        cmd_opts.add_option(
+            '--zsh', '-z',
+            action='store_const',
+            const='zsh',
+            dest='shell',
+            help='Emit completion code for zsh')
+        cmd_opts.add_option(
+            '--fish', '-f',
+            action='store_const',
+            const='fish',
+            dest='shell',
+            help='Emit completion code for fish')
+
+        self.parser.insert_option_group(0, cmd_opts)
+
+    def run(self, options, args):
+        """Prints the completion code of the given shell"""
+        shells = COMPLETION_SCRIPTS.keys()
+        shell_options = ['--' + shell for shell in sorted(shells)]
+        if options.shell in shells:
+            script = textwrap.dedent(
+                COMPLETION_SCRIPTS.get(options.shell, '') % {
+                    'prog': get_prog(),
+                }
+            )
+            print(BASE_COMPLETION % {'script': script, 'shell': options.shell})
+        else:
+            sys.stderr.write(
+                'ERROR: You must pass %s\n' % ' or '.join(shell_options)
+            )
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/commands/completion.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/commands/completion.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..72eb9f933787bbfca367c897bcf8983199ee8507
GIT binary patch
literal 3577
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

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/commands/configuration.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/commands/configuration.py
new file mode 100644
index 0000000..950e205
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/commands/configuration.py
@@ -0,0 +1,253 @@
+import logging
+import os
+import subprocess
+
+from pip._internal.cli.base_command import Command
+from pip._internal.cli.status_codes import ERROR, SUCCESS
+from pip._internal.configuration import Configuration, kinds
+from pip._internal.exceptions import PipError
+from pip._internal.locations import running_under_virtualenv, site_config_file
+from pip._internal.utils.deprecation import deprecated
+from pip._internal.utils.misc import get_prog
+
+logger = logging.getLogger(__name__)
+
+
+class ConfigurationCommand(Command):
+    """Manage local and global configuration.
+
+        Subcommands:
+
+        list: List the active configuration (or from the file specified)
+        edit: Edit the configuration file in an editor
+        get: Get the value associated with name
+        set: Set the name=value
+        unset: Unset the value associated with name
+
+        If none of --user, --global and --site are passed, a virtual
+        environment configuration file is used if one is active and the file
+        exists. Otherwise, all modifications happen on the to the user file by
+        default.
+    """
+
+    name = 'config'
+    usage = """
+        %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
+    """
+
+    summary = "Manage local and global configuration."
+
+    def __init__(self, *args, **kwargs):
+        super(ConfigurationCommand, self).__init__(*args, **kwargs)
+
+        self.configuration = None
+
+        self.cmd_opts.add_option(
+            '--editor',
+            dest='editor',
+            action='store',
+            default=None,
+            help=(
+                'Editor to use to edit the file. Uses VISUAL or EDITOR '
+                'environment variables if not provided.'
+            )
+        )
+
+        self.cmd_opts.add_option(
+            '--global',
+            dest='global_file',
+            action='store_true',
+            default=False,
+            help='Use the system-wide configuration file only'
+        )
+
+        self.cmd_opts.add_option(
+            '--user',
+            dest='user_file',
+            action='store_true',
+            default=False,
+            help='Use the user configuration file only'
+        )
+
+        self.cmd_opts.add_option(
+            '--site',
+            dest='site_file',
+            action='store_true',
+            default=False,
+            help='Use the current environment configuration file only'
+        )
+
+        self.cmd_opts.add_option(
+            '--venv',
+            dest='venv_file',
+            action='store_true',
+            default=False,
+            help=(
+                '[Deprecated] Use the current environment configuration '
+                'file in a virtual environment only'
+            )
+        )
+
+        self.parser.insert_option_group(0, self.cmd_opts)
+
+    def run(self, options, args):
+        handlers = {
+            "list": self.list_values,
+            "edit": self.open_in_editor,
+            "get": self.get_name,
+            "set": self.set_name_value,
+            "unset": self.unset_name
+        }
+
+        # Determine action
+        if not args or args[0] not in handlers:
+            logger.error("Need an action ({}) to perform.".format(
+                ", ".join(sorted(handlers)))
+            )
+            return ERROR
+
+        action = args[0]
+
+        # Determine which configuration files are to be loaded
+        #    Depends on whether the command is modifying.
+        try:
+            load_only = self._determine_file(
+                options, need_value=(action in ["get", "set", "unset", "edit"])
+            )
+        except PipError as e:
+            logger.error(e.args[0])
+            return ERROR
+
+        # Load a new configuration
+        self.configuration = Configuration(
+            isolated=options.isolated_mode, load_only=load_only
+        )
+        self.configuration.load()
+
+        # Error handling happens here, not in the action-handlers.
+        try:
+            handlers[action](options, args[1:])
+        except PipError as e:
+            logger.error(e.args[0])
+            return ERROR
+
+        return SUCCESS
+
+    def _determine_file(self, options, need_value):
+        # Convert legacy venv_file option to site_file or error
+        if options.venv_file and not options.site_file:
+            if running_under_virtualenv():
+                options.site_file = True
+                deprecated(
+                    "The --venv option has been deprecated.",
+                    replacement="--site",
+                    gone_in="19.3",
+                )
+            else:
+                raise PipError(
+                    "Legacy --venv option requires a virtual environment. "
+                    "Use --site instead."
+                )
+
+        file_options = [key for key, value in (
+            (kinds.USER, options.user_file),
+            (kinds.GLOBAL, options.global_file),
+            (kinds.SITE, options.site_file),
+        ) if value]
+
+        if not file_options:
+            if not need_value:
+                return None
+            # Default to user, unless there's a site file.
+            elif os.path.exists(site_config_file):
+                return kinds.SITE
+            else:
+                return kinds.USER
+        elif len(file_options) == 1:
+            return file_options[0]
+
+        raise PipError(
+            "Need exactly one file to operate upon "
+            "(--user, --site, --global) to perform."
+        )
+
+    def list_values(self, options, args):
+        self._get_n_args(args, "list", n=0)
+
+        for key, value in sorted(self.configuration.items()):
+            logger.info("%s=%r", key, value)
+
+    def get_name(self, options, args):
+        key = self._get_n_args(args, "get [name]", n=1)
+        value = self.configuration.get_value(key)
+
+        logger.info("%s", value)
+
+    def set_name_value(self, options, args):
+        key, value = self._get_n_args(args, "set [name] [value]", n=2)
+        self.configuration.set_value(key, value)
+
+        self._save_configuration()
+
+    def unset_name(self, options, args):
+        key = self._get_n_args(args, "unset [name]", n=1)
+        self.configuration.unset_value(key)
+
+        self._save_configuration()
+
+    def open_in_editor(self, options, args):
+        editor = self._determine_editor(options)
+
+        fname = self.configuration.get_file_to_edit()
+        if fname is None:
+            raise PipError("Could not determine appropriate file.")
+
+        try:
+            subprocess.check_call([editor, fname])
+        except subprocess.CalledProcessError as e:
+            raise PipError(
+                "Editor Subprocess exited with exit code {}"
+                .format(e.returncode)
+            )
+
+    def _get_n_args(self, args, example, n):
+        """Helper to make sure the command got the right number of arguments
+        """
+        if len(args) != n:
+            msg = (
+                'Got unexpected number of arguments, expected {}. '
+                '(example: "{} config {}")'
+            ).format(n, get_prog(), example)
+            raise PipError(msg)
+
+        if n == 1:
+            return args[0]
+        else:
+            return args
+
+    def _save_configuration(self):
+        # We successfully ran a modifying command. Need to save the
+        # configuration.
+        try:
+            self.configuration.save()
+        except Exception:
+            logger.error(
+                "Unable to save configuration. Please report this as a bug.",
+                exc_info=1
+            )
+            raise PipError("Internal Error.")
+
+    def _determine_editor(self, options):
+        if options.editor is not None:
+            return options.editor
+        elif "VISUAL" in os.environ:
+            return os.environ["VISUAL"]
+        elif "EDITOR" in os.environ:
+            return os.environ["EDITOR"]
+        else:
+            raise PipError("Could not determine editor to use.")
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/commands/configuration.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/commands/configuration.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..6330c861a85f94bf57ae2329245b0692c3c26320
GIT binary patch
literal 8747
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
HnE06i8ek@=

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/commands/download.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/commands/download.py
new file mode 100644
index 0000000..a57e4bc
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/commands/download.py
@@ -0,0 +1,176 @@
+from __future__ import absolute_import
+
+import logging
+import os
+
+from pip._internal.cli import cmdoptions
+from pip._internal.cli.base_command import RequirementCommand
+from pip._internal.operations.prepare import RequirementPreparer
+from pip._internal.req import RequirementSet
+from pip._internal.req.req_tracker import RequirementTracker
+from pip._internal.resolve import Resolver
+from pip._internal.utils.filesystem import check_path_owner
+from pip._internal.utils.misc import ensure_dir, normalize_path
+from pip._internal.utils.temp_dir import TempDirectory
+
+logger = logging.getLogger(__name__)
+
+
+class DownloadCommand(RequirementCommand):
+    """
+    Download packages from:
+
+    - PyPI (and other indexes) using requirement specifiers.
+    - VCS project urls.
+    - Local project directories.
+    - Local or remote source archives.
+
+    pip also supports downloading from "requirements files", which provide
+    an easy way to specify a whole environment to be downloaded.
+    """
+    name = 'download'
+
+    usage = """
+      %prog [options] <requirement specifier> [package-index-options] ...
+      %prog [options] -r <requirements file> [package-index-options] ...
+      %prog [options] <vcs project url> ...
+      %prog [options] <local project path> ...
+      %prog [options] <archive url/path> ..."""
+
+    summary = 'Download packages.'
+
+    def __init__(self, *args, **kw):
+        super(DownloadCommand, self).__init__(*args, **kw)
+
+        cmd_opts = self.cmd_opts
+
+        cmd_opts.add_option(cmdoptions.constraints())
+        cmd_opts.add_option(cmdoptions.requirements())
+        cmd_opts.add_option(cmdoptions.build_dir())
+        cmd_opts.add_option(cmdoptions.no_deps())
+        cmd_opts.add_option(cmdoptions.global_options())
+        cmd_opts.add_option(cmdoptions.no_binary())
+        cmd_opts.add_option(cmdoptions.only_binary())
+        cmd_opts.add_option(cmdoptions.prefer_binary())
+        cmd_opts.add_option(cmdoptions.src())
+        cmd_opts.add_option(cmdoptions.pre())
+        cmd_opts.add_option(cmdoptions.no_clean())
+        cmd_opts.add_option(cmdoptions.require_hashes())
+        cmd_opts.add_option(cmdoptions.progress_bar())
+        cmd_opts.add_option(cmdoptions.no_build_isolation())
+        cmd_opts.add_option(cmdoptions.use_pep517())
+        cmd_opts.add_option(cmdoptions.no_use_pep517())
+
+        cmd_opts.add_option(
+            '-d', '--dest', '--destination-dir', '--destination-directory',
+            dest='download_dir',
+            metavar='dir',
+            default=os.curdir,
+            help=("Download packages into <dir>."),
+        )
+
+        cmd_opts.add_option(cmdoptions.platform())
+        cmd_opts.add_option(cmdoptions.python_version())
+        cmd_opts.add_option(cmdoptions.implementation())
+        cmd_opts.add_option(cmdoptions.abi())
+
+        index_opts = cmdoptions.make_option_group(
+            cmdoptions.index_group,
+            self.parser,
+        )
+
+        self.parser.insert_option_group(0, index_opts)
+        self.parser.insert_option_group(0, cmd_opts)
+
+    def run(self, options, args):
+        options.ignore_installed = True
+        # editable doesn't really make sense for `pip download`, but the bowels
+        # of the RequirementSet code require that property.
+        options.editables = []
+
+        if options.python_version:
+            python_versions = [options.python_version]
+        else:
+            python_versions = None
+
+        cmdoptions.check_dist_restriction(options)
+
+        options.src_dir = os.path.abspath(options.src_dir)
+        options.download_dir = normalize_path(options.download_dir)
+
+        ensure_dir(options.download_dir)
+
+        with self._build_session(options) as session:
+            finder = self._build_package_finder(
+                options=options,
+                session=session,
+                platform=options.platform,
+                python_versions=python_versions,
+                abi=options.abi,
+                implementation=options.implementation,
+            )
+            build_delete = (not (options.no_clean or options.build_dir))
+            if options.cache_dir and not check_path_owner(options.cache_dir):
+                logger.warning(
+                    "The directory '%s' or its parent directory is not owned "
+                    "by the current user and caching wheels has been "
+                    "disabled. check the permissions and owner of that "
+                    "directory. If executing pip with sudo, you may want "
+                    "sudo's -H flag.",
+                    options.cache_dir,
+                )
+                options.cache_dir = None
+
+            with RequirementTracker() as req_tracker, TempDirectory(
+                options.build_dir, delete=build_delete, kind="download"
+            ) as directory:
+
+                requirement_set = RequirementSet(
+                    require_hashes=options.require_hashes,
+                )
+                self.populate_requirement_set(
+                    requirement_set,
+                    args,
+                    options,
+                    finder,
+                    session,
+                    self.name,
+                    None
+                )
+
+                preparer = RequirementPreparer(
+                    build_dir=directory.path,
+                    src_dir=options.src_dir,
+                    download_dir=options.download_dir,
+                    wheel_download_dir=None,
+                    progress_bar=options.progress_bar,
+                    build_isolation=options.build_isolation,
+                    req_tracker=req_tracker,
+                )
+
+                resolver = Resolver(
+                    preparer=preparer,
+                    finder=finder,
+                    session=session,
+                    wheel_cache=None,
+                    use_user_site=False,
+                    upgrade_strategy="to-satisfy-only",
+                    force_reinstall=False,
+                    ignore_dependencies=options.ignore_dependencies,
+                    ignore_requires_python=False,
+                    ignore_installed=True,
+                    isolated=options.isolated_mode,
+                )
+                resolver.resolve(requirement_set)
+
+                downloaded = ' '.join([
+                    req.name for req in requirement_set.successfully_downloaded
+                ])
+                if downloaded:
+                    logger.info('Successfully downloaded %s', downloaded)
+
+                # Clean up
+                if not options.no_clean:
+                    requirement_set.cleanup_files()
+
+        return requirement_set
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/commands/download.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/commands/download.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..5ef46e13610ca012a0ee47441aac9f48c7980730
GIT binary patch
literal 5692
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
C^=(W5

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/commands/freeze.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/commands/freeze.py
new file mode 100644
index 0000000..dc9c53a
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/commands/freeze.py
@@ -0,0 +1,96 @@
+from __future__ import absolute_import
+
+import sys
+
+from pip._internal.cache import WheelCache
+from pip._internal.cli.base_command import Command
+from pip._internal.models.format_control import FormatControl
+from pip._internal.operations.freeze import freeze
+from pip._internal.utils.compat import stdlib_pkgs
+
+DEV_PKGS = {'pip', 'setuptools', 'distribute', 'wheel'}
+
+
+class FreezeCommand(Command):
+    """
+    Output installed packages in requirements format.
+
+    packages are listed in a case-insensitive sorted order.
+    """
+    name = 'freeze'
+    usage = """
+      %prog [options]"""
+    summary = 'Output installed packages in requirements format.'
+    log_streams = ("ext://sys.stderr", "ext://sys.stderr")
+
+    def __init__(self, *args, **kw):
+        super(FreezeCommand, self).__init__(*args, **kw)
+
+        self.cmd_opts.add_option(
+            '-r', '--requirement',
+            dest='requirements',
+            action='append',
+            default=[],
+            metavar='file',
+            help="Use the order in the given requirements file and its "
+                 "comments when generating output. This option can be "
+                 "used multiple times.")
+        self.cmd_opts.add_option(
+            '-f', '--find-links',
+            dest='find_links',
+            action='append',
+            default=[],
+            metavar='URL',
+            help='URL for finding packages, which will be added to the '
+                 'output.')
+        self.cmd_opts.add_option(
+            '-l', '--local',
+            dest='local',
+            action='store_true',
+            default=False,
+            help='If in a virtualenv that has global access, do not output '
+                 'globally-installed packages.')
+        self.cmd_opts.add_option(
+            '--user',
+            dest='user',
+            action='store_true',
+            default=False,
+            help='Only output packages installed in user-site.')
+        self.cmd_opts.add_option(
+            '--all',
+            dest='freeze_all',
+            action='store_true',
+            help='Do not skip these packages in the output:'
+                 ' %s' % ', '.join(DEV_PKGS))
+        self.cmd_opts.add_option(
+            '--exclude-editable',
+            dest='exclude_editable',
+            action='store_true',
+            help='Exclude editable package from output.')
+
+        self.parser.insert_option_group(0, self.cmd_opts)
+
+    def run(self, options, args):
+        format_control = FormatControl(set(), set())
+        wheel_cache = WheelCache(options.cache_dir, format_control)
+        skip = set(stdlib_pkgs)
+        if not options.freeze_all:
+            skip.update(DEV_PKGS)
+
+        freeze_kwargs = dict(
+            requirement=options.requirements,
+            find_links=options.find_links,
+            local_only=options.local,
+            user_only=options.user,
+            skip_regex=options.skip_requirements_regex,
+            isolated=options.isolated_mode,
+            wheel_cache=wheel_cache,
+            skip=skip,
+            exclude_editable=options.exclude_editable,
+        )
+
+        try:
+            for line in freeze(**freeze_kwargs):
+                sys.stdout.write(line + '\n')
+        finally:
+            wheel_cache.cleanup()
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/commands/freeze.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/commands/freeze.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..aa7acb8c68a9ff4474727e99444161fe310e66aa
GIT binary patch
literal 3677
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
On0S~37@?3!h#3H&Fn@&r

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/commands/hash.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/commands/hash.py
new file mode 100644
index 0000000..423440e
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/commands/hash.py
@@ -0,0 +1,57 @@
+from __future__ import absolute_import
+
+import hashlib
+import logging
+import sys
+
+from pip._internal.cli.base_command import Command
+from pip._internal.cli.status_codes import ERROR
+from pip._internal.utils.hashes import FAVORITE_HASH, STRONG_HASHES
+from pip._internal.utils.misc import read_chunks
+
+logger = logging.getLogger(__name__)
+
+
+class HashCommand(Command):
+    """
+    Compute a hash of a local package archive.
+
+    These can be used with --hash in a requirements file to do repeatable
+    installs.
+
+    """
+    name = 'hash'
+    usage = '%prog [options] <file> ...'
+    summary = 'Compute hashes of package archives.'
+    ignore_require_venv = True
+
+    def __init__(self, *args, **kw):
+        super(HashCommand, self).__init__(*args, **kw)
+        self.cmd_opts.add_option(
+            '-a', '--algorithm',
+            dest='algorithm',
+            choices=STRONG_HASHES,
+            action='store',
+            default=FAVORITE_HASH,
+            help='The hash algorithm to use: one of %s' %
+                 ', '.join(STRONG_HASHES))
+        self.parser.insert_option_group(0, self.cmd_opts)
+
+    def run(self, options, args):
+        if not args:
+            self.parser.print_usage(sys.stderr)
+            return ERROR
+
+        algorithm = options.algorithm
+        for path in args:
+            logger.info('%s:\n--hash=%s:%s',
+                        path, algorithm, _hash_of_file(path, algorithm))
+
+
+def _hash_of_file(path, algorithm):
+    """Return the hash digest of a file."""
+    with open(path, 'rb') as archive:
+        hash = hashlib.new(algorithm)
+        for chunk in read_chunks(archive):
+            hash.update(chunk)
+    return hash.hexdigest()
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/commands/hash.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/commands/hash.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..34f88f89c841039c4d9a97736014c761123bc982
GIT binary patch
literal 2783
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

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/commands/help.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/commands/help.py
new file mode 100644
index 0000000..49a81cb
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/commands/help.py
@@ -0,0 +1,37 @@
+from __future__ import absolute_import
+
+from pip._internal.cli.base_command import Command
+from pip._internal.cli.status_codes import SUCCESS
+from pip._internal.exceptions import CommandError
+
+
+class HelpCommand(Command):
+    """Show help for commands"""
+    name = 'help'
+    usage = """
+      %prog <command>"""
+    summary = 'Show help for commands.'
+    ignore_require_venv = True
+
+    def run(self, options, args):
+        from pip._internal.commands import commands_dict, get_similar_commands
+
+        try:
+            # 'pip help' with no args is handled by pip.__init__.parseopt()
+            cmd_name = args[0]  # the command we need help for
+        except IndexError:
+            return SUCCESS
+
+        if cmd_name not in commands_dict:
+            guess = get_similar_commands(cmd_name)
+
+            msg = ['unknown command "%s"' % cmd_name]
+            if guess:
+                msg.append('maybe you meant "%s"' % guess)
+
+            raise CommandError(' - '.join(msg))
+
+        command = commands_dict[cmd_name]()
+        command.parser.print_help()
+
+        return SUCCESS
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/commands/help.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/commands/help.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..347580b95266971a6c2ab99ad322e0d3b9009405
GIT binary patch
literal 1651
zcmZSn%**AGdLky70ScHI7#JKJ7#ND97#J8*7#LC*8FCmHav2$-7#SErd?tn*CWc&Q
zhA3tTpP3<tg&~)fA&M2kXJN=;W5{J^h+=18Okrh6WoAfYWJqCSXklPzW?+bn;$TQ&
zX9(8dU|?X#1lg&<$iTo*!q33KkeF1QpHo_r8lRb4kY7{+kzi+FU~taQ%}vZpK?nqg
zIy<`t2SWsS5Gq`Yit>v}xEUB2JW_KCpxWSG16kw*@|r#a14AkU$VVv*3{gxVKSnV#
zq%bi=u`r}CgM5<826BH23&_<`91KCh8mtTq48>v$3=F{;`Q-{3sW}A-Y57G8$q=U%
zm#{D}Fn~nCYPb}@K((MKKV88Fs>ZHZ9H(}@WKg(sGB7ZJ>~RJ;avdoA89}asgnunF
zLoO3TEeiu<B_Bf#*wK=;tPJ6KLJTY=%naFF3`G_UjEsyWEDXUBHLMIZ%naG=3`G+d
zYFHR*SQ(lb8EV-;zN=wn5KCudsAXrUVPhz&V5nhd$YNzkVF7W)ni&}w^B5RP*ceh+
z8M4?xlFf`Dy-kb^c?=*kYgid1n;95tIT&g<7_vARvN%D}3bs{)je&u|4-%<Nph)Fq
zU|@iHzBoQ5Gr6Qhgn@w}J+&mhI5RghC$T6VCR+@WD9y{x%P-G^g{gv)YOxYnA~&%z
zDOI5|zf>VNH8HOQA^{381ziOVE|5*2h$+Y{(2LK^D@iTNOU%)OnH&UiR1hc?m4H-w
z=B1=ofRjlO*oh$7#Dap<yp$l2f#7J&%FoOz0Z9}j78R!!f%O#>W#*N{gCbZ16iZ-r
z#i==IB_NaY3raHc^B`#;u_(P5$xcu*PtHw=&r8frEdj-CdTDBLaS6z-+~RbwZm3H&
zz?lI=6z4H8Fz6Q)WtJtDr0SO?7U`$u=cJ?-73(LZ=$9uY<>i{@78@BRnWtB!TbNpu
z=VVox8Gt}~o_>gaL1uw&W?pegVor{(TbYNaaR5jNjNzf954E#cALJvwf=aN1ic0eY
zK&e~?<OoJFCT1o+MqWl%CLTr}CSFE1MiC|nCSFEfCP)Z?d=?M(SA0A;h~ndO^HWN5
zQsd*n-inV;$xn`t2Zt2g_oc;&>8W7p;?msQ#G*>DbVyNYYKbtYKuFKaFG`IsN-ZqS
zEJ}?pOU)|_5@lduK!gpLH2?t=1j^qaFBgM~8#YEZMm8o0=?4i8P~wV@Pb)1cElQ1#
z4*~^Yi5vq116r!g$<#|qEKY?b{2)-7ghO3%Nn%N9aeQ)qN@_7Au}WZ=ms*jW3Q2t6
k<O_BsIEWC$00dSED4=X0slg89!(xzt0FwZt0HXji02U~NTmS$7

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/commands/install.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/commands/install.py
new file mode 100644
index 0000000..c13da44
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/commands/install.py
@@ -0,0 +1,587 @@
+from __future__ import absolute_import
+
+import errno
+import logging
+import operator
+import os
+import shutil
+from optparse import SUPPRESS_HELP
+
+from pip._vendor import pkg_resources
+
+from pip._internal.cache import WheelCache
+from pip._internal.cli import cmdoptions
+from pip._internal.cli.base_command import RequirementCommand
+from pip._internal.cli.status_codes import ERROR
+from pip._internal.exceptions import (
+    CommandError, InstallationError, PreviousBuildDirError,
+)
+from pip._internal.locations import distutils_scheme, virtualenv_no_global
+from pip._internal.operations.check import check_install_conflicts
+from pip._internal.operations.prepare import RequirementPreparer
+from pip._internal.req import RequirementSet, install_given_reqs
+from pip._internal.req.req_tracker import RequirementTracker
+from pip._internal.resolve import Resolver
+from pip._internal.utils.filesystem import check_path_owner
+from pip._internal.utils.misc import (
+    ensure_dir, get_installed_version,
+    protect_pip_from_modification_on_windows,
+)
+from pip._internal.utils.temp_dir import TempDirectory
+from pip._internal.wheel import WheelBuilder
+
+logger = logging.getLogger(__name__)
+
+
+def is_wheel_installed():
+    """
+    Return whether the wheel package is installed.
+    """
+    try:
+        import wheel  # noqa: F401
+    except ImportError:
+        return False
+
+    return True
+
+
+def build_wheels(builder, pep517_requirements, legacy_requirements, session):
+    """
+    Build wheels for requirements, depending on whether wheel is installed.
+    """
+    # We don't build wheels for legacy requirements if wheel is not installed.
+    should_build_legacy = is_wheel_installed()
+
+    # Always build PEP 517 requirements
+    build_failures = builder.build(
+        pep517_requirements,
+        session=session, autobuilding=True
+    )
+
+    if should_build_legacy:
+        # We don't care about failures building legacy
+        # requirements, as we'll fall through to a direct
+        # install for those.
+        builder.build(
+            legacy_requirements,
+            session=session, autobuilding=True
+        )
+
+    return build_failures
+
+
+class InstallCommand(RequirementCommand):
+    """
+    Install packages from:
+
+    - PyPI (and other indexes) using requirement specifiers.
+    - VCS project urls.
+    - Local project directories.
+    - Local or remote source archives.
+
+    pip also supports installing from "requirements files", which provide
+    an easy way to specify a whole environment to be installed.
+    """
+    name = 'install'
+
+    usage = """
+      %prog [options] <requirement specifier> [package-index-options] ...
+      %prog [options] -r <requirements file> [package-index-options] ...
+      %prog [options] [-e] <vcs project url> ...
+      %prog [options] [-e] <local project path> ...
+      %prog [options] <archive url/path> ..."""
+
+    summary = 'Install packages.'
+
+    def __init__(self, *args, **kw):
+        super(InstallCommand, self).__init__(*args, **kw)
+
+        cmd_opts = self.cmd_opts
+
+        cmd_opts.add_option(cmdoptions.requirements())
+        cmd_opts.add_option(cmdoptions.constraints())
+        cmd_opts.add_option(cmdoptions.no_deps())
+        cmd_opts.add_option(cmdoptions.pre())
+
+        cmd_opts.add_option(cmdoptions.editable())
+        cmd_opts.add_option(
+            '-t', '--target',
+            dest='target_dir',
+            metavar='dir',
+            default=None,
+            help='Install packages into <dir>. '
+                 'By default this will not replace existing files/folders in '
+                 '<dir>. Use --upgrade to replace existing packages in <dir> '
+                 'with new versions.'
+        )
+        cmd_opts.add_option(cmdoptions.platform())
+        cmd_opts.add_option(cmdoptions.python_version())
+        cmd_opts.add_option(cmdoptions.implementation())
+        cmd_opts.add_option(cmdoptions.abi())
+
+        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.)")
+        cmd_opts.add_option(
+            '--no-user',
+            dest='use_user_site',
+            action='store_false',
+            help=SUPPRESS_HELP)
+        cmd_opts.add_option(
+            '--root',
+            dest='root_path',
+            metavar='dir',
+            default=None,
+            help="Install everything relative to this alternate root "
+                 "directory.")
+        cmd_opts.add_option(
+            '--prefix',
+            dest='prefix_path',
+            metavar='dir',
+            default=None,
+            help="Installation prefix where lib, bin and other top-level "
+                 "folders are placed")
+
+        cmd_opts.add_option(cmdoptions.build_dir())
+
+        cmd_opts.add_option(cmdoptions.src())
+
+        cmd_opts.add_option(
+            '-U', '--upgrade',
+            dest='upgrade',
+            action='store_true',
+            help='Upgrade all specified packages to the newest available '
+                 'version. The handling of dependencies depends on the '
+                 'upgrade-strategy used.'
+        )
+
+        cmd_opts.add_option(
+            '--upgrade-strategy',
+            dest='upgrade_strategy',
+            default='only-if-needed',
+            choices=['only-if-needed', 'eager'],
+            help='Determines how dependency upgrading should be handled '
+                 '[default: %default]. '
+                 '"eager" - dependencies are upgraded regardless of '
+                 'whether the currently installed version satisfies the '
+                 'requirements of the upgraded package(s). '
+                 '"only-if-needed" -  are upgraded only when they do not '
+                 'satisfy the requirements of the upgraded package(s).'
+        )
+
+        cmd_opts.add_option(
+            '--force-reinstall',
+            dest='force_reinstall',
+            action='store_true',
+            help='Reinstall all packages even if they are already '
+                 'up-to-date.')
+
+        cmd_opts.add_option(
+            '-I', '--ignore-installed',
+            dest='ignore_installed',
+            action='store_true',
+            help='Ignore the installed packages (reinstalling instead).')
+
+        cmd_opts.add_option(cmdoptions.ignore_requires_python())
+        cmd_opts.add_option(cmdoptions.no_build_isolation())
+        cmd_opts.add_option(cmdoptions.use_pep517())
+        cmd_opts.add_option(cmdoptions.no_use_pep517())
+
+        cmd_opts.add_option(cmdoptions.install_options())
+        cmd_opts.add_option(cmdoptions.global_options())
+
+        cmd_opts.add_option(
+            "--compile",
+            action="store_true",
+            dest="compile",
+            default=True,
+            help="Compile Python source files to bytecode",
+        )
+
+        cmd_opts.add_option(
+            "--no-compile",
+            action="store_false",
+            dest="compile",
+            help="Do not compile Python source files to bytecode",
+        )
+
+        cmd_opts.add_option(
+            "--no-warn-script-location",
+            action="store_false",
+            dest="warn_script_location",
+            default=True,
+            help="Do not warn when installing scripts outside PATH",
+        )
+        cmd_opts.add_option(
+            "--no-warn-conflicts",
+            action="store_false",
+            dest="warn_about_conflicts",
+            default=True,
+            help="Do not warn about broken dependencies",
+        )
+
+        cmd_opts.add_option(cmdoptions.no_binary())
+        cmd_opts.add_option(cmdoptions.only_binary())
+        cmd_opts.add_option(cmdoptions.prefer_binary())
+        cmd_opts.add_option(cmdoptions.no_clean())
+        cmd_opts.add_option(cmdoptions.require_hashes())
+        cmd_opts.add_option(cmdoptions.progress_bar())
+
+        index_opts = cmdoptions.make_option_group(
+            cmdoptions.index_group,
+            self.parser,
+        )
+
+        self.parser.insert_option_group(0, index_opts)
+        self.parser.insert_option_group(0, cmd_opts)
+
+    def run(self, options, args):
+        cmdoptions.check_install_build_global(options)
+        upgrade_strategy = "to-satisfy-only"
+        if options.upgrade:
+            upgrade_strategy = options.upgrade_strategy
+
+        if options.build_dir:
+            options.build_dir = os.path.abspath(options.build_dir)
+
+        cmdoptions.check_dist_restriction(options, check_target=True)
+
+        if options.python_version:
+            python_versions = [options.python_version]
+        else:
+            python_versions = None
+
+        options.src_dir = os.path.abspath(options.src_dir)
+        install_options = options.install_options or []
+        if options.use_user_site:
+            if options.prefix_path:
+                raise CommandError(
+                    "Can not combine '--user' and '--prefix' as they imply "
+                    "different installation locations"
+                )
+            if virtualenv_no_global():
+                raise InstallationError(
+                    "Can not perform a '--user' install. User site-packages "
+                    "are not visible in this virtualenv."
+                )
+            install_options.append('--user')
+            install_options.append('--prefix=')
+
+        target_temp_dir = TempDirectory(kind="target")
+        if options.target_dir:
+            options.ignore_installed = True
+            options.target_dir = os.path.abspath(options.target_dir)
+            if (os.path.exists(options.target_dir) and not
+                    os.path.isdir(options.target_dir)):
+                raise CommandError(
+                    "Target path exists but is not a directory, will not "
+                    "continue."
+                )
+
+            # Create a target directory for using with the target option
+            target_temp_dir.create()
+            install_options.append('--home=' + target_temp_dir.path)
+
+        global_options = options.global_options or []
+
+        with self._build_session(options) as session:
+            finder = self._build_package_finder(
+                options=options,
+                session=session,
+                platform=options.platform,
+                python_versions=python_versions,
+                abi=options.abi,
+                implementation=options.implementation,
+            )
+            build_delete = (not (options.no_clean or options.build_dir))
+            wheel_cache = WheelCache(options.cache_dir, options.format_control)
+
+            if options.cache_dir and not check_path_owner(options.cache_dir):
+                logger.warning(
+                    "The directory '%s' or its parent directory is not owned "
+                    "by the current user and caching wheels has been "
+                    "disabled. check the permissions and owner of that "
+                    "directory. If executing pip with sudo, you may want "
+                    "sudo's -H flag.",
+                    options.cache_dir,
+                )
+                options.cache_dir = None
+
+            with RequirementTracker() as req_tracker, TempDirectory(
+                options.build_dir, delete=build_delete, kind="install"
+            ) as directory:
+                requirement_set = RequirementSet(
+                    require_hashes=options.require_hashes,
+                    check_supported_wheels=not options.target_dir,
+                )
+
+                try:
+                    self.populate_requirement_set(
+                        requirement_set, args, options, finder, session,
+                        self.name, wheel_cache
+                    )
+                    preparer = RequirementPreparer(
+                        build_dir=directory.path,
+                        src_dir=options.src_dir,
+                        download_dir=None,
+                        wheel_download_dir=None,
+                        progress_bar=options.progress_bar,
+                        build_isolation=options.build_isolation,
+                        req_tracker=req_tracker,
+                    )
+
+                    resolver = Resolver(
+                        preparer=preparer,
+                        finder=finder,
+                        session=session,
+                        wheel_cache=wheel_cache,
+                        use_user_site=options.use_user_site,
+                        upgrade_strategy=upgrade_strategy,
+                        force_reinstall=options.force_reinstall,
+                        ignore_dependencies=options.ignore_dependencies,
+                        ignore_requires_python=options.ignore_requires_python,
+                        ignore_installed=options.ignore_installed,
+                        isolated=options.isolated_mode,
+                        use_pep517=options.use_pep517
+                    )
+                    resolver.resolve(requirement_set)
+
+                    protect_pip_from_modification_on_windows(
+                        modifying_pip=requirement_set.has_requirement("pip")
+                    )
+
+                    # Consider legacy and PEP517-using requirements separately
+                    legacy_requirements = []
+                    pep517_requirements = []
+                    for req in requirement_set.requirements.values():
+                        if req.use_pep517:
+                            pep517_requirements.append(req)
+                        else:
+                            legacy_requirements.append(req)
+
+                    wheel_builder = WheelBuilder(
+                        finder, preparer, wheel_cache,
+                        build_options=[], global_options=[],
+                    )
+
+                    build_failures = build_wheels(
+                        builder=wheel_builder,
+                        pep517_requirements=pep517_requirements,
+                        legacy_requirements=legacy_requirements,
+                        session=session,
+                    )
+
+                    # If we're using PEP 517, we cannot do a direct install
+                    # so we fail here.
+                    if build_failures:
+                        raise InstallationError(
+                            "Could not build wheels for {} which use"
+                            " PEP 517 and cannot be installed directly".format(
+                                ", ".join(r.name for r in build_failures)))
+
+                    to_install = resolver.get_installation_order(
+                        requirement_set
+                    )
+
+                    # Consistency Checking of the package set we're installing.
+                    should_warn_about_conflicts = (
+                        not options.ignore_dependencies and
+                        options.warn_about_conflicts
+                    )
+                    if should_warn_about_conflicts:
+                        self._warn_about_conflicts(to_install)
+
+                    # Don't warn about script install locations if
+                    # --target has been specified
+                    warn_script_location = options.warn_script_location
+                    if options.target_dir:
+                        warn_script_location = False
+
+                    installed = install_given_reqs(
+                        to_install,
+                        install_options,
+                        global_options,
+                        root=options.root_path,
+                        home=target_temp_dir.path,
+                        prefix=options.prefix_path,
+                        pycompile=options.compile,
+                        warn_script_location=warn_script_location,
+                        use_user_site=options.use_user_site,
+                    )
+
+                    lib_locations = get_lib_location_guesses(
+                        user=options.use_user_site,
+                        home=target_temp_dir.path,
+                        root=options.root_path,
+                        prefix=options.prefix_path,
+                        isolated=options.isolated_mode,
+                    )
+                    working_set = pkg_resources.WorkingSet(lib_locations)
+
+                    reqs = sorted(installed, key=operator.attrgetter('name'))
+                    items = []
+                    for req in reqs:
+                        item = req.name
+                        try:
+                            installed_version = get_installed_version(
+                                req.name, working_set=working_set
+                            )
+                            if installed_version:
+                                item += '-' + installed_version
+                        except Exception:
+                            pass
+                        items.append(item)
+                    installed = ' '.join(items)
+                    if installed:
+                        logger.info('Successfully installed %s', installed)
+                except EnvironmentError as error:
+                    show_traceback = (self.verbosity >= 1)
+
+                    message = create_env_error_message(
+                        error, show_traceback, options.use_user_site,
+                    )
+                    logger.error(message, exc_info=show_traceback)
+
+                    return ERROR
+                except PreviousBuildDirError:
+                    options.no_clean = True
+                    raise
+                finally:
+                    # Clean up
+                    if not options.no_clean:
+                        requirement_set.cleanup_files()
+                        wheel_cache.cleanup()
+
+        if options.target_dir:
+            self._handle_target_dir(
+                options.target_dir, target_temp_dir, options.upgrade
+            )
+        return requirement_set
+
+    def _handle_target_dir(self, target_dir, target_temp_dir, upgrade):
+        ensure_dir(target_dir)
+
+        # Checking both purelib and platlib directories for installed
+        # packages to be moved to target directory
+        lib_dir_list = []
+
+        with target_temp_dir:
+            # Checking both purelib and platlib directories for installed
+            # packages to be moved to target directory
+            scheme = distutils_scheme('', home=target_temp_dir.path)
+            purelib_dir = scheme['purelib']
+            platlib_dir = scheme['platlib']
+            data_dir = scheme['data']
+
+            if os.path.exists(purelib_dir):
+                lib_dir_list.append(purelib_dir)
+            if os.path.exists(platlib_dir) and platlib_dir != purelib_dir:
+                lib_dir_list.append(platlib_dir)
+            if os.path.exists(data_dir):
+                lib_dir_list.append(data_dir)
+
+            for lib_dir in lib_dir_list:
+                for item in os.listdir(lib_dir):
+                    if lib_dir == data_dir:
+                        ddir = os.path.join(data_dir, item)
+                        if any(s.startswith(ddir) for s in lib_dir_list[:-1]):
+                            continue
+                    target_item_dir = os.path.join(target_dir, item)
+                    if os.path.exists(target_item_dir):
+                        if not upgrade:
+                            logger.warning(
+                                'Target directory %s already exists. Specify '
+                                '--upgrade to force replacement.',
+                                target_item_dir
+                            )
+                            continue
+                        if os.path.islink(target_item_dir):
+                            logger.warning(
+                                'Target directory %s already exists and is '
+                                'a link. Pip will not automatically replace '
+                                'links, please remove if replacement is '
+                                'desired.',
+                                target_item_dir
+                            )
+                            continue
+                        if os.path.isdir(target_item_dir):
+                            shutil.rmtree(target_item_dir)
+                        else:
+                            os.remove(target_item_dir)
+
+                    shutil.move(
+                        os.path.join(lib_dir, item),
+                        target_item_dir
+                    )
+
+    def _warn_about_conflicts(self, to_install):
+        try:
+            package_set, _dep_info = check_install_conflicts(to_install)
+        except Exception:
+            logger.error("Error checking for conflicts.", exc_info=True)
+            return
+        missing, conflicting = _dep_info
+
+        # NOTE: There is some duplication here from pip check
+        for project_name in missing:
+            version = package_set[project_name][0]
+            for dependency in missing[project_name]:
+                logger.critical(
+                    "%s %s requires %s, which is not installed.",
+                    project_name, version, dependency[1],
+                )
+
+        for project_name in conflicting:
+            version = package_set[project_name][0]
+            for dep_name, dep_version, req in conflicting[project_name]:
+                logger.critical(
+                    "%s %s has requirement %s, but you'll have %s %s which is "
+                    "incompatible.",
+                    project_name, version, req, dep_name, dep_version,
+                )
+
+
+def get_lib_location_guesses(*args, **kwargs):
+    scheme = distutils_scheme('', *args, **kwargs)
+    return [scheme['purelib'], scheme['platlib']]
+
+
+def create_env_error_message(error, show_traceback, using_user_site):
+    """Format an error message for an EnvironmentError
+
+    It may occur anytime during the execution of the install command.
+    """
+    parts = []
+
+    # Mention the error if we are not going to show a traceback
+    parts.append("Could not install packages due to an EnvironmentError")
+    if not show_traceback:
+        parts.append(": ")
+        parts.append(str(error))
+    else:
+        parts.append(".")
+
+    # Spilt the error indication from a helper message (if any)
+    parts[-1] += "\n"
+
+    # Suggest useful actions to the user:
+    #  (1) using user site-packages or (2) verifying the permissions
+    if error.errno == errno.EACCES:
+        user_option_part = "Consider using the `--user` option"
+        permissions_part = "Check the permissions"
+
+        if not using_user_site:
+            parts.extend([
+                user_option_part, " or ",
+                permissions_part.lower(),
+            ])
+        else:
+            parts.append(permissions_part)
+        parts.append(".\n")
+
+    return "".join(parts).strip() + "\n"
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/commands/install.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/commands/install.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..4de612faa65f247fbe24fbf178899c348138ad84
GIT binary patch
literal 16064
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
P=H%g&6#LI`my;C$<aKwy

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/commands/list.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/commands/list.py
new file mode 100644
index 0000000..d70782d
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/commands/list.py
@@ -0,0 +1,302 @@
+from __future__ import absolute_import
+
+import json
+import logging
+
+from pip._vendor import six
+from pip._vendor.six.moves import zip_longest
+
+from pip._internal.cli import cmdoptions
+from pip._internal.cli.base_command import Command
+from pip._internal.exceptions import CommandError
+from pip._internal.index import PackageFinder
+from pip._internal.utils.misc import (
+    dist_is_editable, get_installed_distributions,
+)
+from pip._internal.utils.packaging import get_installer
+
+logger = logging.getLogger(__name__)
+
+
+class ListCommand(Command):
+    """
+    List installed packages, including editables.
+
+    Packages are listed in a case-insensitive sorted order.
+    """
+    name = 'list'
+    usage = """
+      %prog [options]"""
+    summary = 'List installed packages.'
+
+    def __init__(self, *args, **kw):
+        super(ListCommand, self).__init__(*args, **kw)
+
+        cmd_opts = self.cmd_opts
+
+        cmd_opts.add_option(
+            '-o', '--outdated',
+            action='store_true',
+            default=False,
+            help='List outdated packages')
+        cmd_opts.add_option(
+            '-u', '--uptodate',
+            action='store_true',
+            default=False,
+            help='List uptodate packages')
+        cmd_opts.add_option(
+            '-e', '--editable',
+            action='store_true',
+            default=False,
+            help='List editable projects.')
+        cmd_opts.add_option(
+            '-l', '--local',
+            action='store_true',
+            default=False,
+            help=('If in a virtualenv that has global access, do not list '
+                  'globally-installed packages.'),
+        )
+        self.cmd_opts.add_option(
+            '--user',
+            dest='user',
+            action='store_true',
+            default=False,
+            help='Only output packages installed in user-site.')
+
+        cmd_opts.add_option(
+            '--pre',
+            action='store_true',
+            default=False,
+            help=("Include pre-release and development versions. By default, "
+                  "pip only finds stable versions."),
+        )
+
+        cmd_opts.add_option(
+            '--format',
+            action='store',
+            dest='list_format',
+            default="columns",
+            choices=('columns', 'freeze', 'json'),
+            help="Select the output format among: columns (default), freeze, "
+                 "or json",
+        )
+
+        cmd_opts.add_option(
+            '--not-required',
+            action='store_true',
+            dest='not_required',
+            help="List packages that are not dependencies of "
+                 "installed packages.",
+        )
+
+        cmd_opts.add_option(
+            '--exclude-editable',
+            action='store_false',
+            dest='include_editable',
+            help='Exclude editable package from output.',
+        )
+        cmd_opts.add_option(
+            '--include-editable',
+            action='store_true',
+            dest='include_editable',
+            help='Include editable package from output.',
+            default=True,
+        )
+        index_opts = cmdoptions.make_option_group(
+            cmdoptions.index_group, self.parser
+        )
+
+        self.parser.insert_option_group(0, index_opts)
+        self.parser.insert_option_group(0, cmd_opts)
+
+    def _build_package_finder(self, options, index_urls, session):
+        """
+        Create a package finder appropriate to this list command.
+        """
+        return PackageFinder(
+            find_links=options.find_links,
+            index_urls=index_urls,
+            allow_all_prereleases=options.pre,
+            trusted_hosts=options.trusted_hosts,
+            session=session,
+        )
+
+    def run(self, options, args):
+        if options.outdated and options.uptodate:
+            raise CommandError(
+                "Options --outdated and --uptodate cannot be combined.")
+
+        packages = get_installed_distributions(
+            local_only=options.local,
+            user_only=options.user,
+            editables_only=options.editable,
+            include_editables=options.include_editable,
+        )
+
+        # get_not_required must be called firstly in order to find and
+        # filter out all dependencies correctly. Otherwise a package
+        # can't be identified as requirement because some parent packages
+        # could be filtered out before.
+        if options.not_required:
+            packages = self.get_not_required(packages, options)
+
+        if options.outdated:
+            packages = self.get_outdated(packages, options)
+        elif options.uptodate:
+            packages = self.get_uptodate(packages, options)
+
+        self.output_package_listing(packages, options)
+
+    def get_outdated(self, packages, options):
+        return [
+            dist for dist in self.iter_packages_latest_infos(packages, options)
+            if dist.latest_version > dist.parsed_version
+        ]
+
+    def get_uptodate(self, packages, options):
+        return [
+            dist for dist in self.iter_packages_latest_infos(packages, options)
+            if dist.latest_version == dist.parsed_version
+        ]
+
+    def get_not_required(self, packages, options):
+        dep_keys = set()
+        for dist in packages:
+            dep_keys.update(requirement.key for requirement in dist.requires())
+        return {pkg for pkg in packages if pkg.key not in dep_keys}
+
+    def iter_packages_latest_infos(self, packages, options):
+        index_urls = [options.index_url] + options.extra_index_urls
+        if options.no_index:
+            logger.debug('Ignoring indexes: %s', ','.join(index_urls))
+            index_urls = []
+
+        with self._build_session(options) as session:
+            finder = self._build_package_finder(options, index_urls, session)
+
+            for dist in packages:
+                typ = 'unknown'
+                all_candidates = finder.find_all_candidates(dist.key)
+                if not options.pre:
+                    # Remove prereleases
+                    all_candidates = [candidate for candidate in all_candidates
+                                      if not candidate.version.is_prerelease]
+
+                evaluator = finder.candidate_evaluator
+                best_candidate = evaluator.get_best_candidate(all_candidates)
+                if best_candidate is None:
+                    continue
+
+                remote_version = best_candidate.version
+                if best_candidate.location.is_wheel:
+                    typ = 'wheel'
+                else:
+                    typ = 'sdist'
+                # This is dirty but makes the rest of the code much cleaner
+                dist.latest_version = remote_version
+                dist.latest_filetype = typ
+                yield dist
+
+    def output_package_listing(self, packages, options):
+        packages = sorted(
+            packages,
+            key=lambda dist: dist.project_name.lower(),
+        )
+        if options.list_format == 'columns' and packages:
+            data, header = format_for_columns(packages, options)
+            self.output_package_listing_columns(data, header)
+        elif options.list_format == 'freeze':
+            for dist in packages:
+                if options.verbose >= 1:
+                    logger.info("%s==%s (%s)", dist.project_name,
+                                dist.version, dist.location)
+                else:
+                    logger.info("%s==%s", dist.project_name, dist.version)
+        elif options.list_format == 'json':
+            logger.info(format_for_json(packages, options))
+
+    def output_package_listing_columns(self, data, header):
+        # insert the header first: we need to know the size of column names
+        if len(data) > 0:
+            data.insert(0, header)
+
+        pkg_strings, sizes = tabulate(data)
+
+        # Create and add a separator.
+        if len(data) > 0:
+            pkg_strings.insert(1, " ".join(map(lambda x: '-' * x, sizes)))
+
+        for val in pkg_strings:
+            logger.info(val)
+
+
+def tabulate(vals):
+    # From pfmoore on GitHub:
+    # https://github.com/pypa/pip/issues/3651#issuecomment-216932564
+    assert len(vals) > 0
+
+    sizes = [0] * max(len(x) for x in vals)
+    for row in vals:
+        sizes = [max(s, len(str(c))) for s, c in zip_longest(sizes, row)]
+
+    result = []
+    for row in vals:
+        display = " ".join([str(c).ljust(s) if c is not None else ''
+                            for s, c in zip_longest(sizes, row)])
+        result.append(display)
+
+    return result, sizes
+
+
+def format_for_columns(pkgs, options):
+    """
+    Convert the package data into something usable
+    by output_package_listing_columns.
+    """
+    running_outdated = options.outdated
+    # Adjust the header for the `pip list --outdated` case.
+    if running_outdated:
+        header = ["Package", "Version", "Latest", "Type"]
+    else:
+        header = ["Package", "Version"]
+
+    data = []
+    if options.verbose >= 1 or any(dist_is_editable(x) for x in pkgs):
+        header.append("Location")
+    if options.verbose >= 1:
+        header.append("Installer")
+
+    for proj in pkgs:
+        # if we're working on the 'outdated' list, separate out the
+        # latest_version and type
+        row = [proj.project_name, proj.version]
+
+        if running_outdated:
+            row.append(proj.latest_version)
+            row.append(proj.latest_filetype)
+
+        if options.verbose >= 1 or dist_is_editable(proj):
+            row.append(proj.location)
+        if options.verbose >= 1:
+            row.append(get_installer(proj))
+
+        data.append(row)
+
+    return data, header
+
+
+def format_for_json(packages, options):
+    data = []
+    for dist in packages:
+        info = {
+            'name': dist.project_name,
+            'version': six.text_type(dist.version),
+        }
+        if options.verbose >= 1:
+            info['location'] = dist.location
+            info['installer'] = get_installer(dist)
+        if options.outdated:
+            info['latest_version'] = six.text_type(dist.latest_version)
+            info['latest_filetype'] = dist.latest_filetype
+        data.append(info)
+    return json.dumps(data)
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/commands/list.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/commands/list.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..01aaab6fe938aa57f409c1c0fc6f0dbc1eabaf74
GIT binary patch
literal 11121
zcmZSn%**AGdLky70ScHI7#JKJ7#NB_F)%QsFfgPrGUPBY<T5fuF)}cM_)H8rObk&>
zU^ym+9A<_nW-yzXA%}$_mz5!k6{3!XA%~42mz^Ps9l~d2$l+kf<z$HBgz(uIa<~|B
zxf!CkA$)d*93F;TUWO=M2%m!?hmRqbpCO7L!slej5n#v_WQY=E$Q5FU5`u_wG2{p{
z<ccsvi7+sxGBad}GNg(zG&3?pi8G{dGo*4eq%kt2@G!J6Ff=nTL`F$4r0{|`QIZTP
zd|-wYLkd5bA<dA&#1O0@z`($e2?`4hMg|6k5`G2-hQy@e{G8H~)cDNYg8ZTqKZpz{
zpo%jqARKN628OE4g7}>Ly!6!K5{Mud0|P^HZc2VZNoIatF+_}=fq}s}KQ}iqF9jmN
zgAi~nD#|Z{i1IQpFa#tfXD6nox@G32q!wu~fm{P}TuNqfNqlB;d}>N&Nn%n?YKb%h
z14DXhNqlBraY<rMPHIX#NJ&v<QYn(XAOn#V6_tRT?2}ns0(A{M0f4;i1WEvf3=9mZ
z44`;VVE{)sBRHy=7@}AhQkX&UoWcSQIW~qARxpE|A%zXh;9y8$2QxSsQaHd2E`}6N
zFoT;Rg$vB!0Yy*?11P>B5fsJ85EQHda%gc00|Nt>f`Wnq$bkxQk0}&Df}~hSAu}&I
zr!*xqFI@o^4#j$0U@g#KD^^G>N>#|oEG|h+QOL|wNK{BpEKb$U%qvdKE6yy*EK5}=
z&MyK<<`<=;7U_ZYmas4|Fo5(Fi@{u=prBe%l%K8;4UNXwVhIKY1|06vO9q7=D+2=q
zC|dnNp?HvyfuV$fp@fm4hJm4(i6M)Lp@xy6hKZq%fq}7xfgy{Tp_ZAUhM6IY1(erP
zm_T8h!U77?5>`-nrm!<KGchwlRd9g9F@>1{MFkhK3T{w(M_0j%tbz}e<k3|KKvaMo
z1agWXLy8bXiZF(2L>QVGSzxXa#gGPNKDcAW!O{|7lO#btN|9nnk!DEI1p7;lp_!2t
zW|BNuDGOMs0$5s+p_vhGk`h>287!>=mR3cURs%~zbVH=oLDrS9fgM}I&XC2y03ta-
zk&p!nE{0kbC_9UrAw`3sh6NNk;0WPjfC@2#g;E$8f;F@l7#RGDL3vO&zZjISb#?Pg
zOHvX`Qd3IUKt)6{D6f@(WQt4ji&EoDib_*UK$$%yH7&6;rv#j`GE#F2z$puyd|(E^
zQ#Hi=QmFZ*1ts|)3lJJ$B4`>?p&H;BK^&GqVIm3zMfq8&$tA^l5G!(uK`ztP&B;$r
z%qb3LU|{e}gXEF2%%YOg#GKT;GKG?i#1e&!#A1c?ocyH39EHT><kaF~9fg#9g}nR{
zaL$5C<y3;Q6{PHeyG^ec6fU~DrNya5V9%$d7DGY-BvP!yz`)?2ms6>bUs_U7S_0RG
zl-V=$6hKOKi!)17^@>56N>{g_D782e<X&+0PgN)=O4Th&%}GrxPE|<EOHoKkElbVG
zFUU>JD^Vy*Eh+{Tym|^wl?u>k&`~JJEKtY?S)7)cmr|@y3@$?vYKu7-7#MVQ)AEaQ
z6H7`!mV)CGTv~z(hIpt9C;*f5b4qjbiowyGoROcIoLUS{3~5EFsa2_9PiGb9=M_6K
zFfatC=A<T<D3oNR!h8%dNFgydKQG-%0cw_l2GpUNItmbDbQJQ76u`#tfnAoDU!q%-
zT3DJ{l$uh)!@$6hmtPVO6DYQWMLn#fghV5#C<H}XN@_uBUP@|Sa%O6=LOv+Yp;ZPv
z{Pl{3z}BQzfXdfYU04zV2LL!I;?ojyic?EKRS~2RPK8%R#i|Sp46YEJ@NyYuv_e`@
zelFDWFk7Goz-<8=;0cXenAKPffK<`oIv6P`z-bN=ZpEOY929OEpg@AeWNATaQ4lDP
zmVjb8K0Y%qvm`zq%t_8oiO(-6DF$cZ#1t?mGd~Zk&kgKhka;0RrKv$6OG^Y97#MOB
zvr|EuGV}A|(~I&;3&4Q{s;(=bd{7oBNGt+n0bx+PA`iqu(V_uLV&J4woSKscW+WD+
z7ngvFn(Xo*Sx~JHaxuhIkP9`yjS~=2oX5bxpkGjwS(aFms$Z5^q@R|blag9gte=#k
zU!Ihdmus3^Y-E^Zo?ex1VQNvHlT~GA00QZG`XTxSnFX+HtLs+g;b|NI5(4A+%)FA+
zqP)Z${bWc}rC1-7_Vo%XgJc*O7!(*77>X-EE?|^o;$&iD<YZ)HWMgD!#LHrar~<2G
z0+Arh&H^G~7{Nng!PT-cvNN$U3NZ^aCWGPvgh6c>XHYGx2MQ-}W3`5nA&U{zl&b;P
zq#!O6sI~+#m_e074KqVC18cAbC~k_q5!Jkcf^$)7Vo9n(A|k<oLcK^Kv7n$Rzn~}+
zBw3QLP?C{Z3@QGgp#y0<fSN1d)B`G5;&U?dvLT5HWJX1NX;Dsbi72S1$jQksk5A0W
zi7zNhg%(}KC7@PMNl_`Nu@aw=Ut9tyREkrJK_!?5$g4ph_XcT#{0T~c1x2YrpfVI9
z2g-NgVhGwu2?EtuLAneK3<H{4z#fiID$UGEiH8<Q@u1L2Eh+#dAyCF-V1XnWPDW0~
zWRS-|e&qzUi9yl2hk*gqTFPQzC{hG77(t8@CQwVMnUSH1ks*(Pp@bP6-HhNC6f;;E
zD=fyrO;b?Rvoka^uz(s`jG(qaQ4YBB=LEI8Y8XM)d@VD`D3D49hN3R8EElS*9N1(=
zhN2Z<S#DHW2CyIxLJ-tff+RA(VpC9M2k8YUAQ}$f3QJcPUaKc3=7GxSq*R6E{M@9>
zywnsuaC!pQ((#}=s{|A<pgIx4162sHLb4bl1S*!Gg({*{2Dhofr5vou0p`Fg4gwWH
zL7);5T-t%H3j!GgRt2*lNQ!}hAqdp=1sDCGz65g31Fnidf^aK9u?rG_SyKXPQbTHc
zcwzvRDw%odh(sKu53)rKl*&O4f+m{cflbArWLZ?2R|873a^PZ5h>@9*2VC%h(k%}=
zC!;76C!;7Mh=!+PP)Y_DPN3*dha?bia;{+lr8t*ZIate|5tMAQm>9BI7>a~J>^LTd
zLScqra9_|*17v>*DEKo=Qj1_=R~(;{Sdt3r3g)Hd7ngw20#pFn?g0ydE1#5js1Q;(
z+k(Ow6xiS@2h?F4&@c|NVqjpH1`1$Ms4*}}A_@bL0ExlKgfkd}>_Pr^01=L$(h+2M
z5UBJFf(J+tsJS+<fnm+Sz%U1AU@(J9Mo`670v^=pWMHV!29-@NvC5zX)xiL+02x7@
zY*43>2{iKI(#!}N6=5tCU<hw#01t{VF|>hGBS<P3oW}gXy;o4n1B8n~)`0SR4Ff|g
zA44r8$c`)qhA_rL@PH32b%J`lC7>jlomvSQr2y&HGXOV+pbb+{dwf8Hv=~%!+N7uE
zrB)Oa*)0WyEy$H@3~(=lQi3qZ%b?Vd0nV+l(g<I7Ffe4ZGZe9b0$~ypLm?YOFvLS3
z?*}=9(h|tPAQw>41qzLV>~wJU1s9?zsRi-bsg;m&Yyg^V5bqbKmL%ur7T7I=d7qO3
z9Pi-RD^4u|cV0>hK%GvotD%usjIG!}$|c|sa0i(=0PRsr1_p*jAiF`;1p^}|BQK*O
zr0f7SsX&6sph(qYWB`r1WHB(Lg9l%-7#YMttpV_OOpzU^4FMYT05=@7SV2WFD8n!@
zFs3tr@>Cu;J!G+g%xGq0=)VmcK41rl)G&jG511KhSs5z!fKrG{>=uSvHqf9%EjvRE
zE2zm)!^V)s3Ce@D93VYeTnxp#89=oH2ZKwj1Vb$+Lk%Zr;312Lp?DUE4XOiXG1PK^
z+a;_FS-cFjTnsf_3|V{(H5_1rxEX4=K|`<E91KNI847d2D!D<1)bfC&vIH2i1R08$
z8B<soYS|g`z>Oi0gLoKf*cjr47;4zT3}Fx%##orc5FVbwzz`Ub0vhrFwKx5WML?bH
z^t}8c&`=w=DVthsrJ!0|0*ZAVaGSF<FFP;49MV-P&qz(p0XHLx!F38qJGj*X)(UC`
zgIf=&6(vQ9@o=$XaB|DbhlqfaVNQN}dTJ5aq?FX8(sXb&m6e~F2d>tjZAxhSILH8$
z=|CMUP~#HZwoXpWOUVQ!<YI8%3<CELKpjPBO$csqXBH#1!An5;;o9O;%Mx=+6HD@o
zN<jT#P&+0GRN2B6fZgMlpO*@DI;hPA9smL*xXj{sa4-acsu}PAGPGh&%gjkFsVqnZ
zx5v<H9e9f!?0t|&Qj5Tu44gYlDht3K2lX4^ZYTzaESwAGA>0jW5umvlBvh1|n_rR&
zZxMi+GvI=307@lrWxN8Ec|p;`z$nbf$tcOl$t1)m%EZga#wf(d$;8Vj&BV#b&&b2b
z#>C0U!^p`5qM>~SP!a`UaP#0bC=q~bv=neQ1`YW$GJ>itCUAww%#h8*P!t5po<%_n
zC9q-GW+sLhCQu%S4hVwBVxgmfc~ikzl@ZjN0BPROP|*z1?-CmT%Ih^u;4TL%LpCcz
z(R_vyR)#D#(AXp>!^5*ZD>&P;FfbNoz*IowAS4GvGc#B&JWm5=83)*<&!NgoxIk7y
z+KkPN42*f;X_;URP>tpXPTk--43r;1I2csifyzG6*fO{&&<x7WASpjc^$cp5Lk9%o
z^AdAY!I>;4zdRK(_W(|G;3NSi1|VI4vy@FvVs27OqTOjw`T(WUAW&Hn1nNX&f;>|U
z>ieq}+uEuYD`=<|Yl4S<Ap9WE0H_8?9-NmT!~8*@{0+{`kbyVQKwdm_)U5>6s>j|n
zfh&O)9!dGdsX;-Yqy}m*Wag#i2c>~pli?sD1|$xeF+#EeJOl+wq-Yr)T!5q`mL!7R
zn30;80?qH>PzMtO5cEMd3=9k>KtT=~=wV=FW@KaJVG?B&WfW%QXXIt%XXIxTW>R3}
zht#nke}OPK15O6{9-IN289^O%P;W*Rly*VmG2mLanF*YHA$hNv5s~pq(6kkTYG9By
z@EA@OGeZdrC=a$UfGb)iQ0)gbt3n#2)FoCJlp!HGu!a>R&sbQ&0IJP`!6R&b;PFCm
z!U5M@3h+DwYPEs$45;W%VFY#KMS{T@#Sg4f7aSFkrW`2URY3Tl6gd#_lfl5i@E8<7
zAO~oG5+%5P$Vtrur=v{p2qQQHl_VyWf-0V%5Kz2;nxwgj1>mF`lnZLEg5nL5Ci6jQ
z7c?RRZn76-r^gqUfa?2VaLG`dS(RE0wxldEXJ9>_&A`BL3*>oFMaIA+#3;-p#4N<9
z!Nkj`0m^n@f5(FhwfK1O*hzeRZhlH>PHKESxTz8!pOT*(9}muZ@S?A@I58bES5sV?
zo10h!8RP^vDuO`c>EOO;5U5WU1Zr)9Yb|g-2?DtX5h7sLK%@!K_%LW_u^2Q)z{bkP
z$OalSW#SCr<l&U!WCKG5P9boT2c;NLN(bjyX2{$mXkrqUV~Zs~Q<Y6%ZaO2VnoMB=
z_aqq@Kpn+qMh1~uMurM+P(E>qb!Mn#0ySbwz{75kI?5$h9VufofwCuP{*wiqb-}&R
zW+nzu<2DG?yDGF{2nV&XSs5yFA!eq6%uHcs$YRAb*%)DR4GXyG%gIo56I42YYHUV^
zEOwA}&5R6r;2BboEo(r9K`k4i6%MLH3nwsy*RX=hrZmu;KWG39QbK^k2vj71@(Z{J
z44PdB^?(IIu7#IV*gC;MC7^5t(hTke1{H(2;A{#a1|VTTdVR1??>kV&0lAKiAqX_J
z4{|L7xD^3*IJkM~SPYt=$jr|JFGT=n`rO2dAdoIFr?{jDT$}_&gUS?8u;pZx7DGCY
zi3Om!B}kD3svFA^bBcp1LFzzZS(IN6E>0mGhh%VJRg_u`ni&Np$&}3Ef}F%ka25g+
z0}xz6Wef}qFF~OMYH2VqOEAeY@-jLyu`%*8ax!`{3Nj^w0s`b*kpI9r$N|)^WMs%<
z043TQCWayvP|XLQ#7}1dwJh^^pn~b(h9)Svvw+ebsDcAG9*d*F84bL4q6VJPin2k8
zIg1&zmI9P$L7h;@<OWz1Xq1{6w0s~1+#3Y73oBMavd}_MWe948vVfC4D+9=4aObt?
z5~#12#S9h)&5koLf;y%UK07F@fXo36gENBWO0roQir+GnaDbFIGcpt*s|I&w(N!0z
zLd^rUTEX=&%;hW~r`ABMES$&?Uc&<N9XR`Og2Fr=HWTBVpI4Sz1eq#@j{hov+DQtT
zc_sM@#re6ZB^jX3XlXHM^$U2}MiOiq88$c?4;@&Bwca2zG~g-#x;zBT4ui}PgA=0<
zcr+DUGlWzYq=K6Y6qN>`bOLTi49e1ggOPy&ycmED6uk@#KKaRs;2ta}GCZLxiHg9D
z=pfMebx;m0Cnx4r2DO1&42X6wsG}Pc2NDB$ItbJZ4g#5jC=3d+(~H4l`{3?>QE6UY
zW?p(cY_1>()c6PjHABGR59*u*bqsXr8I;Aq!0;QCG{FTDD`=uqlnFHIugWOE$j>Oi
z#LFzi#KtJVD9j`cZXSy<L5m1b!3ZxRHi4FBfy;-AIgso*1ym?xf@{Vs@SLSt2_tx2
z5I8%78qZ7&W}xmUBe;Lb4DMg1g0c%}XbRjCwkcr)@tYYzwQ340gAKHBU}q?r0;<44
ztBjaI!%k2YYz#J_v0zTHa(0MvCWb675FeC73wasBOSl=bctCy7W=4i!4NxP&FQ^U_
zsi3|MI6r`67Cg)VTar}-9^?SWJ!Dh^oG3u;WU#W5)QXaL(2z$E$P92A0-FI&9guW|
zNIT#}1?swio1H18xdp}GwmZ_$JSd5P`=^j5ET~=uN6tXh7NEgS1yC*mwYnG>LA3-k
zBNw9>6R4jA8p;r36krr&)Bts)pl#8#(vs4m)cAN%|B(UQO9dB0ps}vZymUzGJF`G9
zzAQB_CBG;L9E_lbT>(N+uQ;<pFE_s|wHQ(>gXZbL(y%Fez2uxs$Pxumrxrs>FDbD&
zH6A)~9Ry0GC7>~WRCTEp$*GX(O7PqucxVh&1$gKVJSB}qdud5#PO)BYW^r;5xI6$Q
zr4rCe22?X3${<C2W?nitO@LEPdTNOec=#`<8kGD%p#@&G0j{9I*)j+e_~4jF5Cf0~
t!2JyyNDspf6kElhFc)CrVdP;FU=#phMgc|vMlogqCVpnIE1W`{ssK8;{e%Dj

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/commands/search.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/commands/search.py
new file mode 100644
index 0000000..c157a31
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/commands/search.py
@@ -0,0 +1,135 @@
+from __future__ import absolute_import
+
+import logging
+import sys
+import textwrap
+from collections import OrderedDict
+
+from pip._vendor import pkg_resources
+from pip._vendor.packaging.version import parse as parse_version
+# NOTE: XMLRPC Client is not annotated in typeshed as on 2017-07-17, which is
+#       why we ignore the type on this import
+from pip._vendor.six.moves import xmlrpc_client  # type: ignore
+
+from pip._internal.cli.base_command import Command
+from pip._internal.cli.status_codes import NO_MATCHES_FOUND, SUCCESS
+from pip._internal.download import PipXmlrpcTransport
+from pip._internal.exceptions import CommandError
+from pip._internal.models.index import PyPI
+from pip._internal.utils.compat import get_terminal_size
+from pip._internal.utils.logging import indent_log
+
+logger = logging.getLogger(__name__)
+
+
+class SearchCommand(Command):
+    """Search for PyPI packages whose name or summary contains <query>."""
+    name = 'search'
+    usage = """
+      %prog [options] <query>"""
+    summary = 'Search PyPI for packages.'
+    ignore_require_venv = True
+
+    def __init__(self, *args, **kw):
+        super(SearchCommand, self).__init__(*args, **kw)
+        self.cmd_opts.add_option(
+            '-i', '--index',
+            dest='index',
+            metavar='URL',
+            default=PyPI.pypi_url,
+            help='Base URL of Python Package Index (default %default)')
+
+        self.parser.insert_option_group(0, self.cmd_opts)
+
+    def run(self, options, args):
+        if not args:
+            raise CommandError('Missing required argument (search query).')
+        query = args
+        pypi_hits = self.search(query, options)
+        hits = transform_hits(pypi_hits)
+
+        terminal_width = None
+        if sys.stdout.isatty():
+            terminal_width = get_terminal_size()[0]
+
+        print_results(hits, terminal_width=terminal_width)
+        if pypi_hits:
+            return SUCCESS
+        return NO_MATCHES_FOUND
+
+    def search(self, query, options):
+        index_url = options.index
+        with self._build_session(options) as session:
+            transport = PipXmlrpcTransport(index_url, session)
+            pypi = xmlrpc_client.ServerProxy(index_url, transport)
+            hits = pypi.search({'name': query, 'summary': query}, 'or')
+            return hits
+
+
+def transform_hits(hits):
+    """
+    The list from pypi is really a list of versions. We want a list of
+    packages with the list of versions stored inline. This converts the
+    list from pypi into one we can use.
+    """
+    packages = OrderedDict()
+    for hit in hits:
+        name = hit['name']
+        summary = hit['summary']
+        version = hit['version']
+
+        if name not in packages.keys():
+            packages[name] = {
+                'name': name,
+                'summary': summary,
+                'versions': [version],
+            }
+        else:
+            packages[name]['versions'].append(version)
+
+            # if this is the highest version, replace summary and score
+            if version == highest_version(packages[name]['versions']):
+                packages[name]['summary'] = summary
+
+    return list(packages.values())
+
+
+def print_results(hits, name_column_width=None, terminal_width=None):
+    if not hits:
+        return
+    if name_column_width is None:
+        name_column_width = max([
+            len(hit['name']) + len(highest_version(hit.get('versions', ['-'])))
+            for hit in hits
+        ]) + 4
+
+    installed_packages = [p.project_name for p in pkg_resources.working_set]
+    for hit in hits:
+        name = hit['name']
+        summary = hit['summary'] or ''
+        latest = highest_version(hit.get('versions', ['-']))
+        if terminal_width is not None:
+            target_width = terminal_width - name_column_width - 5
+            if target_width > 10:
+                # wrap and indent summary to fit terminal
+                summary = textwrap.wrap(summary, target_width)
+                summary = ('\n' + ' ' * (name_column_width + 3)).join(summary)
+
+        line = '%-*s - %s' % (name_column_width,
+                              '%s (%s)' % (name, latest), summary)
+        try:
+            logger.info(line)
+            if name in installed_packages:
+                dist = pkg_resources.get_distribution(name)
+                with indent_log():
+                    if dist.version == latest:
+                        logger.info('INSTALLED: %s (latest)', dist.version)
+                    else:
+                        logger.info('INSTALLED: %s', dist.version)
+                        logger.info('LATEST:    %s', latest)
+        except UnicodeEncodeError:
+            pass
+
+
+def highest_version(versions):
+    return max(versions, key=parse_version)
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/commands/search.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/commands/search.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..e9877896c1b5ef63a15cae4153db1058ede7b7d1
GIT binary patch
literal 5521
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

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/commands/show.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/commands/show.py
new file mode 100644
index 0000000..a18a902
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/commands/show.py
@@ -0,0 +1,168 @@
+from __future__ import absolute_import
+
+import logging
+import os
+from email.parser import FeedParser
+
+from pip._vendor import pkg_resources
+from pip._vendor.packaging.utils import canonicalize_name
+
+from pip._internal.cli.base_command import Command
+from pip._internal.cli.status_codes import ERROR, SUCCESS
+
+logger = logging.getLogger(__name__)
+
+
+class ShowCommand(Command):
+    """
+    Show information about one or more installed packages.
+
+    The output is in RFC-compliant mail header format.
+    """
+    name = 'show'
+    usage = """
+      %prog [options] <package> ..."""
+    summary = 'Show information about installed packages.'
+    ignore_require_venv = True
+
+    def __init__(self, *args, **kw):
+        super(ShowCommand, self).__init__(*args, **kw)
+        self.cmd_opts.add_option(
+            '-f', '--files',
+            dest='files',
+            action='store_true',
+            default=False,
+            help='Show the full list of installed files for each package.')
+
+        self.parser.insert_option_group(0, self.cmd_opts)
+
+    def run(self, options, args):
+        if not args:
+            logger.warning('ERROR: Please provide a package name or names.')
+            return ERROR
+        query = args
+
+        results = search_packages_info(query)
+        if not print_results(
+                results, list_files=options.files, verbose=options.verbose):
+            return ERROR
+        return SUCCESS
+
+
+def search_packages_info(query):
+    """
+    Gather details from installed distributions. Print distribution name,
+    version, location, and installed files. Installed files requires a
+    pip generated 'installed-files.txt' in the distributions '.egg-info'
+    directory.
+    """
+    installed = {}
+    for p in pkg_resources.working_set:
+        installed[canonicalize_name(p.project_name)] = p
+
+    query_names = [canonicalize_name(name) for name in query]
+
+    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()],
+        }
+        file_list = None
+        metadata = None
+        if isinstance(dist, pkg_resources.DistInfoDistribution):
+            # RECORDs should be part of .dist-info metadatas
+            if dist.has_metadata('RECORD'):
+                lines = dist.get_metadata_lines('RECORD')
+                paths = [l.split(',')[0] for l in lines]
+                paths = [os.path.join(dist.location, p) for p in paths]
+                file_list = [os.path.relpath(p, dist.location) for p in paths]
+
+            if dist.has_metadata('METADATA'):
+                metadata = dist.get_metadata('METADATA')
+        else:
+            # Otherwise use pip's log for .egg-info's
+            if dist.has_metadata('installed-files.txt'):
+                paths = dist.get_metadata_lines('installed-files.txt')
+                paths = [os.path.join(dist.egg_info, p) for p in paths]
+                file_list = [os.path.relpath(p, dist.location) for p in paths]
+
+            if dist.has_metadata('PKG-INFO'):
+                metadata = dist.get_metadata('PKG-INFO')
+
+        if dist.has_metadata('entry_points.txt'):
+            entry_points = dist.get_metadata_lines('entry_points.txt')
+            package['entry_points'] = entry_points
+
+        if dist.has_metadata('INSTALLER'):
+            for line in dist.get_metadata_lines('INSTALLER'):
+                if line.strip():
+                    package['installer'] = line.strip()
+                    break
+
+        # @todo: Should pkg_resources.Distribution have a
+        # `get_pkg_info` method?
+        feed_parser = FeedParser()
+        feed_parser.feed(metadata)
+        pkg_info_dict = feed_parser.close()
+        for key in ('metadata-version', 'summary',
+                    'home-page', 'author', 'author-email', 'license'):
+            package[key] = pkg_info_dict.get(key)
+
+        # It looks like FeedParser cannot deal with repeated headers
+        classifiers = []
+        for line in metadata.splitlines():
+            if line.startswith('Classifier: '):
+                classifiers.append(line[len('Classifier: '):])
+        package['classifiers'] = classifiers
+
+        if file_list:
+            package['files'] = sorted(file_list)
+        yield package
+
+
+def print_results(distributions, list_files=False, verbose=False):
+    """
+    Print the informations from installed distributions found.
+    """
+    results_printed = False
+    for i, dist in enumerate(distributions):
+        results_printed = True
+        if i > 0:
+            logger.info("---")
+
+        name = dist.get('name', '')
+        required_by = [
+            pkg.project_name for pkg in pkg_resources.working_set
+            if name in [required.name for required in pkg.requires()]
+        ]
+
+        logger.info("Name: %s", name)
+        logger.info("Version: %s", dist.get('version', ''))
+        logger.info("Summary: %s", dist.get('summary', ''))
+        logger.info("Home-page: %s", dist.get('home-page', ''))
+        logger.info("Author: %s", dist.get('author', ''))
+        logger.info("Author-email: %s", dist.get('author-email', ''))
+        logger.info("License: %s", dist.get('license', ''))
+        logger.info("Location: %s", dist.get('location', ''))
+        logger.info("Requires: %s", ', '.join(dist.get('requires', [])))
+        logger.info("Required-by: %s", ', '.join(required_by))
+
+        if verbose:
+            logger.info("Metadata-Version: %s",
+                        dist.get('metadata-version', ''))
+            logger.info("Installer: %s", dist.get('installer', ''))
+            logger.info("Classifiers:")
+            for classifier in dist.get('classifiers', []):
+                logger.info("  %s", classifier)
+            logger.info("Entry-points:")
+            for entry in dist.get('entry_points', []):
+                logger.info("  %s", entry.strip())
+        if list_files:
+            logger.info("Files:")
+            for line in dist.get('files', []):
+                logger.info("  %s", line.strip())
+            if "files" not in dist:
+                logger.info("Cannot locate installed-files.txt")
+    return results_printed
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/commands/show.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/commands/show.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..6462a56d38e6be6a60f429291fbe1aa54cb72eb9
GIT binary patch
literal 6435
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

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/commands/uninstall.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/commands/uninstall.py
new file mode 100644
index 0000000..0cd6f54
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/commands/uninstall.py
@@ -0,0 +1,78 @@
+from __future__ import absolute_import
+
+from pip._vendor.packaging.utils import canonicalize_name
+
+from pip._internal.cli.base_command import Command
+from pip._internal.exceptions import InstallationError
+from pip._internal.req import parse_requirements
+from pip._internal.req.constructors import install_req_from_line
+from pip._internal.utils.misc import protect_pip_from_modification_on_windows
+
+
+class UninstallCommand(Command):
+    """
+    Uninstall packages.
+
+    pip is able to uninstall most installed packages. Known exceptions are:
+
+    - Pure distutils packages installed with ``python setup.py install``, which
+      leave behind no metadata to determine what files were installed.
+    - Script wrappers installed by ``python setup.py develop``.
+    """
+    name = 'uninstall'
+    usage = """
+      %prog [options] <package> ...
+      %prog [options] -r <requirements file> ..."""
+    summary = 'Uninstall packages.'
+
+    def __init__(self, *args, **kw):
+        super(UninstallCommand, self).__init__(*args, **kw)
+        self.cmd_opts.add_option(
+            '-r', '--requirement',
+            dest='requirements',
+            action='append',
+            default=[],
+            metavar='file',
+            help='Uninstall all the packages listed in the given requirements '
+                 'file.  This option can be used multiple times.',
+        )
+        self.cmd_opts.add_option(
+            '-y', '--yes',
+            dest='yes',
+            action='store_true',
+            help="Don't ask for confirmation of uninstall deletions.")
+
+        self.parser.insert_option_group(0, self.cmd_opts)
+
+    def run(self, options, args):
+        with self._build_session(options) as session:
+            reqs_to_uninstall = {}
+            for name in args:
+                req = install_req_from_line(
+                    name, isolated=options.isolated_mode,
+                )
+                if req.name:
+                    reqs_to_uninstall[canonicalize_name(req.name)] = req
+            for filename in options.requirements:
+                for req in parse_requirements(
+                        filename,
+                        options=options,
+                        session=session):
+                    if req.name:
+                        reqs_to_uninstall[canonicalize_name(req.name)] = req
+            if not reqs_to_uninstall:
+                raise InstallationError(
+                    'You must give at least one requirement to %(name)s (see '
+                    '"pip help %(name)s")' % dict(name=self.name)
+                )
+
+            protect_pip_from_modification_on_windows(
+                modifying_pip="pip" in reqs_to_uninstall
+            )
+
+            for req in reqs_to_uninstall.values():
+                uninstall_pathset = req.uninstall(
+                    auto_confirm=options.yes, verbose=self.verbosity > 0,
+                )
+                if uninstall_pathset:
+                    uninstall_pathset.commit()
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/commands/uninstall.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/commands/uninstall.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..87f28e051463acf97bbacf096160ae27c7523bc4
GIT binary patch
literal 3344
zcmZSn%**AGdLky70ScHI7#JKJ7#NDX7#J8*7#LC*8FCmHav2$-7#SErd?tn*CWc&Q
zhA3tTpP3<tg&~)fA&M2kXJN=;W5{J^h+>EESs8LT7;-roqBtRZHijH7hForjC~gR!
zogs&ZA(xjSikE>gg@YlLl_8ChA%&Bng@K`&fgv)Ak0FJNAy|W(fq@|t<VFof1_p)_
zeg+1H#H8Z<oYIoi_{`jb{Gt+wgdhV0LvmtXeqLsBVoqjNYJ6T|ZYo5Ioq>VDIX^cy
zF)sxo08;CjS6q^qlapAInV;ucRFq!?krHBHU?@l|Do%|rN-ZqSEK1Ey%_}K}$cciS
z0?`JNjZZ7e&yCN?%!68^0n%EOUy_<!5?_#60FlnkPsvQnOa@yMpPv_Bo|%`DUtU}y
zz`(!|nwJSN4eB^}T!4J)1d0nI1_p*y22d2FFfc?hfg&Y}nIVOVA&P||g&7p|DJ-A>
zi(+F)VFfeT8G?c}*cccXik%o47`PM^6cpgrC=?_nXD6no7VB|=B?>YN6f%ny5|eUL
z6-x3IN@31X$jvV<QGmKFH3gwf!8<R%JWnCDB004H6mG=|iAAYa5W{p80!oWg6;d*b
zOG-;JbBf`*kPIr%EXhzvNGPZ*$;i)BC{8UYEzm2dgegc!&`~JQ$V|=vJ5E6%CpEDw
zRUs)gBQq~WAunGcH?<@&C9xzC<kpnblGLKy%)C^E@{Gh1g|y6^)MAD5)S^_FVW}y4
zU}JO@f|H9f3rZBqixLY8Qj3Za3KWtmu{b6rwJbF!zaSw2qQ8Wbfq?-YGR2_`&_GpC
zP%S9RPgjV}hlE6|f(<lu?G*I%AbK&?=oTs1Ag3#^!@(Mgg^?2kJn;0AL1_V$H+dNt
z82mwLq7#%27#K<z8EP09nwc1~m>6mp8ETjq`WP4(YZw@^m>IHIKq)1K36w@sSU^c5
zg^eMFogtlpA%z2!$5OZ$Qn(qKnOKoD@GzwCf;I4gHSmM7Uy1-jGZQmd5i3I$8$*g9
z$kHrkkiDQnAy@;HU;K)h7#J9Ii;6*R)YV1uU<nJTFi9;gDdAyYU_g>6E&-*{#AHw^
zf-nmTQu9(uKv^{<H7&6;rv%If#d%p`5!f71B!d|lsW}D3St#L^n3JPWl937zH-((c
z;*!)9h0Hv#aC&B0YMuhJ{os(-Q&0%W$ShWX#GyiRVxB@$szPaTYKlT`X--LI0Vrc+
z=B5_wL3~(Q%nI_TZe?n52`ElLG#4nZmE;$t#+MY8rWS*8tV@2LdWk|}akfHQevv|Q
zeqLH;Q7*UyP{>b1%4R94IjNukDAt1%a3If@fNUr(El4d20&_VS7#QN?GxIV_;^Rv|
zoaEe;`22#B;u4U>i78-CW_}(x5WxjkQ3)t1W#$#97L|ZhX6EO`rx)dy7HEK+3=Y8J
z)SNUhBe5vGxC9h=+2x?pivdg&7c($0=ob`amL-;?>X#)J>8IuAq@)%V>nEk?mnS9V
z<(lRe8yO~<r&pz0m|B$QWL23NfIxbleu#cSW`QoW=+Jd5^YAnd011I{d}dxrYEfQd
zj(#$vG%nVM=PbQ~${-O21_l{WaDoU1MoC6aMovaHC}d}b@z|M?K|bMRU|;}M4$h!V
z;mpVYPMHj#ywJ?Z(67f>%M7YFYFQX6oItt5CDw|emKB_BSV6g?h7pu=ni&~u*%)fr
zK)I$!9>l0&VJKk%F+i!Dk-?@=o}o~lA-p0OWO5cOgG;OjLoGW)g*`(F8$%5{s4%W!
z1m&9=W`<@)CYM-M284-iAcHVWY-1>FV+b!yX9%xhVJN=AP{PiT!opC(0m^rf4BX7X
zDAvr#(8S1)$G}j+$pFc|H7pF-Yz)l|jEoiD3^gnaSzMr+(k0dwW+OK!dxJd21Ipwe
zqj*8NIGcr`nSrU6gQ13lq38#Q%;E#-WGwu_Q22u(JUoSgAuu9^0b1Mofzw%Laehu>
zNh%~uLNZ7(I7=3%78hsc=N0=fFfc^smn!6z7MCc1GMGYQ38>62E>XzOOGVCXpaNS}
z15_Vt7At5Jr=}_>fvO%*HdcU%D`|ogBuG&Ss2Bm)o0XY)>7c3<oY@L83&5pFVrfZ!
zJTy~*9aNTDl$2kb3duvD_CX0BDAOdBX6B^CLtPsL%2r^5Vg8EG%}+@Ul4oFG2m%$c
zL0ljfsJIFOB`&aIQZkcEf<WaIICGUH=9H!u2Z8cn5U2qGt{EV9XO>igm4K3UW{CzU
zWd=!t%##HXQXoPORBD5?6{Qvy$Cu>C!&5%k4PYM@r51vN9#qhQ0|KNTt}ebHu_U87
zwFI0;!NfpiRET3s^YlS^6;$9cFbXlUG4e7pGYT<rGD<NDK=UjwBPXLABO4<#BQv8U
zGaDl>voIqkqcjs6qXsA#!Jdr=H`L<e!R1*zC{{{yQsd*nF&iJBlAjzO4+$Yq43-ur
zrl*3Xic52I6N?~aMvxu@1ElBz2Md@OsIUQ-+Mvp=7(}pfvN5tTvoW$UaSHosfYT-@
zoyEtem6ntirN+kxfm*gD(x8@OW`SOOS!!NNevuxeC6Sqzt_N;PffHy6C<PUO6v0YS
zz2uxsy`;qA)Ob+3OUz3N0+r+?5-`Ky>JaTUNZJM^D^!z;QVWAXX&;LvMX7~)$@zK3
zB}JvlCHY0gkeq~R3D~82xtYbu;4A|U2XIUvh=Ga|a5}Te%}*)KNwouI_F_;0A;2WS
JB)|xT%mDv<QL+F4

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/commands/wheel.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/commands/wheel.py
new file mode 100644
index 0000000..cd72a3d
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/commands/wheel.py
@@ -0,0 +1,186 @@
+# -*- coding: utf-8 -*-
+from __future__ import absolute_import
+
+import logging
+import os
+
+from pip._internal.cache import WheelCache
+from pip._internal.cli import cmdoptions
+from pip._internal.cli.base_command import RequirementCommand
+from pip._internal.exceptions import CommandError, PreviousBuildDirError
+from pip._internal.operations.prepare import RequirementPreparer
+from pip._internal.req import RequirementSet
+from pip._internal.req.req_tracker import RequirementTracker
+from pip._internal.resolve import Resolver
+from pip._internal.utils.temp_dir import TempDirectory
+from pip._internal.wheel import WheelBuilder
+
+logger = logging.getLogger(__name__)
+
+
+class WheelCommand(RequirementCommand):
+    """
+    Build Wheel archives for your requirements and dependencies.
+
+    Wheel is a built-package format, and offers the advantage of not
+    recompiling your software during every install. For more details, see the
+    wheel docs: https://wheel.readthedocs.io/en/latest/
+
+    Requirements: setuptools>=0.8, and wheel.
+
+    'pip wheel' uses the bdist_wheel setuptools extension from the wheel
+    package to build individual wheels.
+
+    """
+
+    name = 'wheel'
+    usage = """
+      %prog [options] <requirement specifier> ...
+      %prog [options] -r <requirements file> ...
+      %prog [options] [-e] <vcs project url> ...
+      %prog [options] [-e] <local project path> ...
+      %prog [options] <archive url/path> ..."""
+
+    summary = 'Build wheels from your requirements.'
+
+    def __init__(self, *args, **kw):
+        super(WheelCommand, self).__init__(*args, **kw)
+
+        cmd_opts = self.cmd_opts
+
+        cmd_opts.add_option(
+            '-w', '--wheel-dir',
+            dest='wheel_dir',
+            metavar='dir',
+            default=os.curdir,
+            help=("Build wheels into <dir>, where the default is the "
+                  "current working directory."),
+        )
+        cmd_opts.add_option(cmdoptions.no_binary())
+        cmd_opts.add_option(cmdoptions.only_binary())
+        cmd_opts.add_option(cmdoptions.prefer_binary())
+        cmd_opts.add_option(
+            '--build-option',
+            dest='build_options',
+            metavar='options',
+            action='append',
+            help="Extra arguments to be supplied to 'setup.py bdist_wheel'.",
+        )
+        cmd_opts.add_option(cmdoptions.no_build_isolation())
+        cmd_opts.add_option(cmdoptions.use_pep517())
+        cmd_opts.add_option(cmdoptions.no_use_pep517())
+        cmd_opts.add_option(cmdoptions.constraints())
+        cmd_opts.add_option(cmdoptions.editable())
+        cmd_opts.add_option(cmdoptions.requirements())
+        cmd_opts.add_option(cmdoptions.src())
+        cmd_opts.add_option(cmdoptions.ignore_requires_python())
+        cmd_opts.add_option(cmdoptions.no_deps())
+        cmd_opts.add_option(cmdoptions.build_dir())
+        cmd_opts.add_option(cmdoptions.progress_bar())
+
+        cmd_opts.add_option(
+            '--global-option',
+            dest='global_options',
+            action='append',
+            metavar='options',
+            help="Extra global options to be supplied to the setup.py "
+            "call before the 'bdist_wheel' command.")
+
+        cmd_opts.add_option(
+            '--pre',
+            action='store_true',
+            default=False,
+            help=("Include pre-release and development versions. By default, "
+                  "pip only finds stable versions."),
+        )
+
+        cmd_opts.add_option(cmdoptions.no_clean())
+        cmd_opts.add_option(cmdoptions.require_hashes())
+
+        index_opts = cmdoptions.make_option_group(
+            cmdoptions.index_group,
+            self.parser,
+        )
+
+        self.parser.insert_option_group(0, index_opts)
+        self.parser.insert_option_group(0, cmd_opts)
+
+    def run(self, options, args):
+        cmdoptions.check_install_build_global(options)
+
+        index_urls = [options.index_url] + options.extra_index_urls
+        if options.no_index:
+            logger.debug('Ignoring indexes: %s', ','.join(index_urls))
+            index_urls = []
+
+        if options.build_dir:
+            options.build_dir = os.path.abspath(options.build_dir)
+
+        options.src_dir = os.path.abspath(options.src_dir)
+
+        with self._build_session(options) as session:
+            finder = self._build_package_finder(options, session)
+            build_delete = (not (options.no_clean or options.build_dir))
+            wheel_cache = WheelCache(options.cache_dir, options.format_control)
+
+            with RequirementTracker() as req_tracker, TempDirectory(
+                options.build_dir, delete=build_delete, kind="wheel"
+            ) as directory:
+
+                requirement_set = RequirementSet(
+                    require_hashes=options.require_hashes,
+                )
+
+                try:
+                    self.populate_requirement_set(
+                        requirement_set, args, options, finder, session,
+                        self.name, wheel_cache
+                    )
+
+                    preparer = RequirementPreparer(
+                        build_dir=directory.path,
+                        src_dir=options.src_dir,
+                        download_dir=None,
+                        wheel_download_dir=options.wheel_dir,
+                        progress_bar=options.progress_bar,
+                        build_isolation=options.build_isolation,
+                        req_tracker=req_tracker,
+                    )
+
+                    resolver = Resolver(
+                        preparer=preparer,
+                        finder=finder,
+                        session=session,
+                        wheel_cache=wheel_cache,
+                        use_user_site=False,
+                        upgrade_strategy="to-satisfy-only",
+                        force_reinstall=False,
+                        ignore_dependencies=options.ignore_dependencies,
+                        ignore_requires_python=options.ignore_requires_python,
+                        ignore_installed=True,
+                        isolated=options.isolated_mode,
+                        use_pep517=options.use_pep517
+                    )
+                    resolver.resolve(requirement_set)
+
+                    # build wheels
+                    wb = WheelBuilder(
+                        finder, preparer, wheel_cache,
+                        build_options=options.build_options or [],
+                        global_options=options.global_options or [],
+                        no_clean=options.no_clean,
+                    )
+                    build_failures = wb.build(
+                        requirement_set.requirements.values(), session=session,
+                    )
+                    if len(build_failures) != 0:
+                        raise CommandError(
+                            "Failed to build one or more wheels"
+                        )
+                except PreviousBuildDirError:
+                    options.no_clean = True
+                    raise
+                finally:
+                    if not options.no_clean:
+                        requirement_set.cleanup_files()
+                        wheel_cache.cleanup()
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/commands/wheel.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/commands/wheel.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..8697da91530615f605e8dae03b3784c4196c0e9b
GIT binary patch
literal 6127
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
Oz$Azzz$n1P&kO(rs@<~y

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/configuration.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/configuration.py
new file mode 100644
index 0000000..b199fa7
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/configuration.py
@@ -0,0 +1,384 @@
+"""Configuration management setup
+
+Some terminology:
+- name
+  As written in config files.
+- value
+  Value associated with a name
+- key
+  Name combined with it's section (section.name)
+- variant
+  A single word describing where the configuration key-value pair came from
+"""
+
+import locale
+import logging
+import os
+
+from pip._vendor.six.moves import configparser
+
+from pip._internal.exceptions import (
+    ConfigurationError, ConfigurationFileCouldNotBeLoaded,
+)
+from pip._internal.locations import (
+    global_config_files, legacy_config_file, new_config_file, site_config_file,
+)
+from pip._internal.utils.misc import ensure_dir, enum
+from pip._internal.utils.typing import MYPY_CHECK_RUNNING
+
+if MYPY_CHECK_RUNNING:
+    from typing import (
+        Any, Dict, Iterable, List, NewType, Optional, Tuple
+    )
+
+    RawConfigParser = configparser.RawConfigParser  # Shorthand
+    Kind = NewType("Kind", str)
+
+logger = logging.getLogger(__name__)
+
+
+# NOTE: Maybe use the optionx attribute to normalize keynames.
+def _normalize_name(name):
+    # type: (str) -> str
+    """Make a name consistent regardless of source (environment or file)
+    """
+    name = name.lower().replace('_', '-')
+    if name.startswith('--'):
+        name = name[2:]  # only prefer long opts
+    return name
+
+
+def _disassemble_key(name):
+    # type: (str) -> List[str]
+    return name.split(".", 1)
+
+
+# The kinds of configurations there are.
+kinds = enum(
+    USER="user",        # User Specific
+    GLOBAL="global",    # System Wide
+    SITE="site",        # [Virtual] Environment Specific
+    ENV="env",          # from PIP_CONFIG_FILE
+    ENV_VAR="env-var",  # from Environment Variables
+)
+
+
+class Configuration(object):
+    """Handles management of configuration.
+
+    Provides an interface to accessing and managing configuration files.
+
+    This class converts provides an API that takes "section.key-name" style
+    keys and stores the value associated with it as "key-name" under the
+    section "section".
+
+    This allows for a clean interface wherein the both the section and the
+    key-name are preserved in an easy to manage form in the configuration files
+    and the data stored is also nice.
+    """
+
+    def __init__(self, isolated, load_only=None):
+        # type: (bool, Kind) -> None
+        super(Configuration, self).__init__()
+
+        _valid_load_only = [kinds.USER, kinds.GLOBAL, kinds.SITE, None]
+        if load_only not in _valid_load_only:
+            raise ConfigurationError(
+                "Got invalid value for load_only - should be one of {}".format(
+                    ", ".join(map(repr, _valid_load_only[:-1]))
+                )
+            )
+        self.isolated = isolated  # type: bool
+        self.load_only = load_only  # type: Optional[Kind]
+
+        # The order here determines the override order.
+        self._override_order = [
+            kinds.GLOBAL, kinds.USER, kinds.SITE, kinds.ENV, kinds.ENV_VAR
+        ]
+
+        self._ignore_env_names = ["version", "help"]
+
+        # Because we keep track of where we got the data from
+        self._parsers = {
+            variant: [] for variant in self._override_order
+        }  # type: Dict[Kind, List[Tuple[str, RawConfigParser]]]
+        self._config = {
+            variant: {} for variant in self._override_order
+        }  # type: Dict[Kind, Dict[str, Any]]
+        self._modified_parsers = []  # type: List[Tuple[str, RawConfigParser]]
+
+    def load(self):
+        # type: () -> None
+        """Loads configuration from configuration files and environment
+        """
+        self._load_config_files()
+        if not self.isolated:
+            self._load_environment_vars()
+
+    def get_file_to_edit(self):
+        # type: () -> Optional[str]
+        """Returns the file with highest priority in configuration
+        """
+        assert self.load_only is not None, \
+            "Need to be specified a file to be editing"
+
+        try:
+            return self._get_parser_to_modify()[0]
+        except IndexError:
+            return None
+
+    def items(self):
+        # type: () -> Iterable[Tuple[str, Any]]
+        """Returns key-value pairs like dict.items() representing the loaded
+        configuration
+        """
+        return self._dictionary.items()
+
+    def get_value(self, key):
+        # type: (str) -> Any
+        """Get a value from the configuration.
+        """
+        try:
+            return self._dictionary[key]
+        except KeyError:
+            raise ConfigurationError("No such key - {}".format(key))
+
+    def set_value(self, key, value):
+        # type: (str, Any) -> None
+        """Modify a value in the configuration.
+        """
+        self._ensure_have_load_only()
+
+        fname, parser = self._get_parser_to_modify()
+
+        if parser is not None:
+            section, name = _disassemble_key(key)
+
+            # Modify the parser and the configuration
+            if not parser.has_section(section):
+                parser.add_section(section)
+            parser.set(section, name, value)
+
+        self._config[self.load_only][key] = value
+        self._mark_as_modified(fname, parser)
+
+    def unset_value(self, key):
+        # type: (str) -> None
+        """Unset a value in the configuration.
+        """
+        self._ensure_have_load_only()
+
+        if key not in self._config[self.load_only]:
+            raise ConfigurationError("No such key - {}".format(key))
+
+        fname, parser = self._get_parser_to_modify()
+
+        if parser is not None:
+            section, name = _disassemble_key(key)
+
+            # Remove the key in the parser
+            modified_something = False
+            if parser.has_section(section):
+                # Returns whether the option was removed or not
+                modified_something = parser.remove_option(section, name)
+
+            if modified_something:
+                # name removed from parser, section may now be empty
+                section_iter = iter(parser.items(section))
+                try:
+                    val = next(section_iter)
+                except StopIteration:
+                    val = None
+
+                if val is None:
+                    parser.remove_section(section)
+
+                self._mark_as_modified(fname, parser)
+            else:
+                raise ConfigurationError(
+                    "Fatal Internal error [id=1]. Please report as a bug."
+                )
+
+        del self._config[self.load_only][key]
+
+    def save(self):
+        # type: () -> None
+        """Save the current in-memory state.
+        """
+        self._ensure_have_load_only()
+
+        for fname, parser in self._modified_parsers:
+            logger.info("Writing to %s", fname)
+
+            # Ensure directory exists.
+            ensure_dir(os.path.dirname(fname))
+
+            with open(fname, "w") as f:
+                parser.write(f)
+
+    #
+    # Private routines
+    #
+
+    def _ensure_have_load_only(self):
+        # type: () -> None
+        if self.load_only is None:
+            raise ConfigurationError("Needed a specific file to be modifying.")
+        logger.debug("Will be working with %s variant only", self.load_only)
+
+    @property
+    def _dictionary(self):
+        # type: () -> Dict[str, Any]
+        """A dictionary representing the loaded configuration.
+        """
+        # NOTE: Dictionaries are not populated if not loaded. So, conditionals
+        #       are not needed here.
+        retval = {}
+
+        for variant in self._override_order:
+            retval.update(self._config[variant])
+
+        return retval
+
+    def _load_config_files(self):
+        # type: () -> None
+        """Loads configuration from configuration files
+        """
+        config_files = dict(self._iter_config_files())
+        if config_files[kinds.ENV][0:1] == [os.devnull]:
+            logger.debug(
+                "Skipping loading configuration files due to "
+                "environment's PIP_CONFIG_FILE being os.devnull"
+            )
+            return
+
+        for variant, files in config_files.items():
+            for fname in files:
+                # If there's specific variant set in `load_only`, load only
+                # that variant, not the others.
+                if self.load_only is not None and variant != self.load_only:
+                    logger.debug(
+                        "Skipping file '%s' (variant: %s)", fname, variant
+                    )
+                    continue
+
+                parser = self._load_file(variant, fname)
+
+                # Keeping track of the parsers used
+                self._parsers[variant].append((fname, parser))
+
+    def _load_file(self, variant, fname):
+        # type: (Kind, str) -> RawConfigParser
+        logger.debug("For variant '%s', will try loading '%s'", variant, fname)
+        parser = self._construct_parser(fname)
+
+        for section in parser.sections():
+            items = parser.items(section)
+            self._config[variant].update(self._normalized_keys(section, items))
+
+        return parser
+
+    def _construct_parser(self, fname):
+        # type: (str) -> RawConfigParser
+        parser = configparser.RawConfigParser()
+        # If there is no such file, don't bother reading it but create the
+        # parser anyway, to hold the data.
+        # Doing this is useful when modifying and saving files, where we don't
+        # need to construct a parser.
+        if os.path.exists(fname):
+            try:
+                parser.read(fname)
+            except UnicodeDecodeError:
+                # See https://github.com/pypa/pip/issues/4963
+                raise ConfigurationFileCouldNotBeLoaded(
+                    reason="contains invalid {} characters".format(
+                        locale.getpreferredencoding(False)
+                    ),
+                    fname=fname,
+                )
+            except configparser.Error as error:
+                # See https://github.com/pypa/pip/issues/4893
+                raise ConfigurationFileCouldNotBeLoaded(error=error)
+        return parser
+
+    def _load_environment_vars(self):
+        # type: () -> None
+        """Loads configuration from environment variables
+        """
+        self._config[kinds.ENV_VAR].update(
+            self._normalized_keys(":env:", self._get_environ_vars())
+        )
+
+    def _normalized_keys(self, section, items):
+        # type: (str, Iterable[Tuple[str, Any]]) -> Dict[str, Any]
+        """Normalizes items to construct a dictionary with normalized keys.
+
+        This routine is where the names become keys and are made the same
+        regardless of source - configuration files or environment.
+        """
+        normalized = {}
+        for name, val in items:
+            key = section + "." + _normalize_name(name)
+            normalized[key] = val
+        return normalized
+
+    def _get_environ_vars(self):
+        # type: () -> Iterable[Tuple[str, str]]
+        """Returns a generator with all environmental vars with prefix PIP_"""
+        for key, val in os.environ.items():
+            should_be_yielded = (
+                key.startswith("PIP_") and
+                key[4:].lower() not in self._ignore_env_names
+            )
+            if should_be_yielded:
+                yield key[4:].lower(), val
+
+    # XXX: This is patched in the tests.
+    def _iter_config_files(self):
+        # type: () -> Iterable[Tuple[Kind, List[str]]]
+        """Yields variant and configuration files associated with it.
+
+        This should be treated like items of a dictionary.
+        """
+        # SMELL: Move the conditions out of this function
+
+        # environment variables have the lowest priority
+        config_file = os.environ.get('PIP_CONFIG_FILE', None)
+        if config_file is not None:
+            yield kinds.ENV, [config_file]
+        else:
+            yield kinds.ENV, []
+
+        # at the base we have any global configuration
+        yield kinds.GLOBAL, list(global_config_files)
+
+        # per-user configuration next
+        should_load_user_config = not self.isolated and not (
+            config_file and os.path.exists(config_file)
+        )
+        if should_load_user_config:
+            # The legacy config file is overridden by the new config file
+            yield kinds.USER, [legacy_config_file, new_config_file]
+
+        # finally virtualenv configuration first trumping others
+        yield kinds.SITE, [site_config_file]
+
+    def _get_parser_to_modify(self):
+        # type: () -> Tuple[str, RawConfigParser]
+        # Determine which parser to modify
+        parsers = self._parsers[self.load_only]
+        if not parsers:
+            # This should not happen if everything works correctly.
+            raise ConfigurationError(
+                "Fatal Internal error [id=2]. Please report as a bug."
+            )
+
+        # Use the highest priority parser.
+        return parsers[-1]
+
+    # XXX: This is patched in the tests.
+    def _mark_as_modified(self, fname, parser):
+        # type: (str, RawConfigParser) -> None
+        file_parser_tuple = (fname, parser)
+        if file_parser_tuple not in self._modified_parsers:
+            self._modified_parsers.append(file_parser_tuple)
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/configuration.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/configuration.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..2356a5e280710d8d8b9a6bb222de931273f1d36c
GIT binary patch
literal 13105
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

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/download.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/download.py
new file mode 100644
index 0000000..2683cf0
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/download.py
@@ -0,0 +1,979 @@
+from __future__ import absolute_import
+
+import cgi
+import email.utils
+import getpass
+import json
+import logging
+import mimetypes
+import os
+import platform
+import re
+import shutil
+import sys
+
+from pip._vendor import requests, six, urllib3
+from pip._vendor.cachecontrol import CacheControlAdapter
+from pip._vendor.cachecontrol.caches import FileCache
+from pip._vendor.lockfile import LockError
+from pip._vendor.requests.adapters import BaseAdapter, HTTPAdapter
+from pip._vendor.requests.auth import AuthBase, HTTPBasicAuth
+from pip._vendor.requests.models import CONTENT_CHUNK_SIZE, Response
+from pip._vendor.requests.structures import CaseInsensitiveDict
+from pip._vendor.requests.utils import get_netrc_auth
+# NOTE: XMLRPC Client is not annotated in typeshed as on 2017-07-17, which is
+#       why we ignore the type on this import
+from pip._vendor.six.moves import xmlrpc_client  # type: ignore
+from pip._vendor.six.moves.urllib import parse as urllib_parse
+from pip._vendor.six.moves.urllib import request as urllib_request
+from pip._vendor.urllib3.util import IS_PYOPENSSL
+
+import pip
+from pip._internal.exceptions import HashMismatch, InstallationError
+from pip._internal.locations import write_delete_marker_file
+from pip._internal.models.index import PyPI
+from pip._internal.utils.encoding import auto_decode
+from pip._internal.utils.filesystem import check_path_owner
+from pip._internal.utils.glibc import libc_ver
+from pip._internal.utils.misc import (
+    ARCHIVE_EXTENSIONS, ask_path_exists, backup_dir, consume, display_path,
+    format_size, get_installed_version, rmtree, split_auth_from_netloc,
+    splitext, unpack_file,
+)
+from pip._internal.utils.temp_dir import TempDirectory
+from pip._internal.utils.typing import MYPY_CHECK_RUNNING
+from pip._internal.utils.ui import DownloadProgressProvider
+from pip._internal.vcs import vcs
+
+if MYPY_CHECK_RUNNING:
+    from typing import (
+        Optional, Tuple, Dict, IO, Text, Union
+    )
+    from pip._internal.models.link import Link
+    from pip._internal.utils.hashes import Hashes
+    from pip._internal.vcs import AuthInfo
+
+try:
+    import ssl  # noqa
+except ImportError:
+    ssl = None
+
+HAS_TLS = (ssl is not None) or IS_PYOPENSSL
+
+__all__ = ['get_file_content',
+           'is_url', 'url_to_path', 'path_to_url',
+           'is_archive_file', 'unpack_vcs_link',
+           'unpack_file_url', 'is_vcs_url', 'is_file_url',
+           'unpack_http_url', 'unpack_url']
+
+
+logger = logging.getLogger(__name__)
+
+
+# These are environment variables present when running under various
+# CI systems.  For each variable, some CI systems that use the variable
+# are indicated.  The collection was chosen so that for each of a number
+# of popular systems, at least one of the environment variables is used.
+# This list is used to provide some indication of and lower bound for
+# CI traffic to PyPI.  Thus, it is okay if the list is not comprehensive.
+# For more background, see: https://github.com/pypa/pip/issues/5499
+CI_ENVIRONMENT_VARIABLES = (
+    # Azure Pipelines
+    'BUILD_BUILDID',
+    # Jenkins
+    'BUILD_ID',
+    # AppVeyor, CircleCI, Codeship, Gitlab CI, Shippable, Travis CI
+    'CI',
+)
+
+
+def looks_like_ci():
+    # type: () -> bool
+    """
+    Return whether it looks like pip is running under CI.
+    """
+    # We don't use the method of checking for a tty (e.g. using isatty())
+    # because some CI systems mimic a tty (e.g. Travis CI).  Thus that
+    # method doesn't provide definitive information in either direction.
+    return any(name in os.environ for name in CI_ENVIRONMENT_VARIABLES)
+
+
+def user_agent():
+    """
+    Return a string representing the user agent.
+    """
+    data = {
+        "installer": {"name": "pip", "version": pip.__version__},
+        "python": platform.python_version(),
+        "implementation": {
+            "name": platform.python_implementation(),
+        },
+    }
+
+    if data["implementation"]["name"] == 'CPython':
+        data["implementation"]["version"] = platform.python_version()
+    elif data["implementation"]["name"] == 'PyPy':
+        if sys.pypy_version_info.releaselevel == 'final':
+            pypy_version_info = sys.pypy_version_info[:3]
+        else:
+            pypy_version_info = sys.pypy_version_info
+        data["implementation"]["version"] = ".".join(
+            [str(x) for x in pypy_version_info]
+        )
+    elif data["implementation"]["name"] == 'Jython':
+        # Complete Guess
+        data["implementation"]["version"] = platform.python_version()
+    elif data["implementation"]["name"] == 'IronPython':
+        # Complete Guess
+        data["implementation"]["version"] = platform.python_version()
+
+    if sys.platform.startswith("linux"):
+        from pip._vendor import distro
+        distro_infos = dict(filter(
+            lambda x: x[1],
+            zip(["name", "version", "id"], distro.linux_distribution()),
+        ))
+        libc = dict(filter(
+            lambda x: x[1],
+            zip(["lib", "version"], libc_ver()),
+        ))
+        if libc:
+            distro_infos["libc"] = libc
+        if distro_infos:
+            data["distro"] = distro_infos
+
+    if sys.platform.startswith("darwin") and platform.mac_ver()[0]:
+        data["distro"] = {"name": "macOS", "version": platform.mac_ver()[0]}
+
+    if platform.system():
+        data.setdefault("system", {})["name"] = platform.system()
+
+    if platform.release():
+        data.setdefault("system", {})["release"] = platform.release()
+
+    if platform.machine():
+        data["cpu"] = platform.machine()
+
+    if HAS_TLS:
+        data["openssl_version"] = ssl.OPENSSL_VERSION
+
+    setuptools_version = get_installed_version("setuptools")
+    if setuptools_version is not None:
+        data["setuptools_version"] = setuptools_version
+
+    # Use None rather than False so as not to give the impression that
+    # pip knows it is not being run under CI.  Rather, it is a null or
+    # inconclusive result.  Also, we include some value rather than no
+    # value to make it easier to know that the check has been run.
+    data["ci"] = True if looks_like_ci() else None
+
+    user_data = os.environ.get("PIP_USER_AGENT_USER_DATA")
+    if user_data is not None:
+        data["user_data"] = user_data
+
+    return "{data[installer][name]}/{data[installer][version]} {json}".format(
+        data=data,
+        json=json.dumps(data, separators=(",", ":"), sort_keys=True),
+    )
+
+
+class MultiDomainBasicAuth(AuthBase):
+
+    def __init__(self, prompting=True):
+        # type: (bool) -> None
+        self.prompting = prompting
+        self.passwords = {}  # type: Dict[str, AuthInfo]
+
+    def __call__(self, req):
+        parsed = urllib_parse.urlparse(req.url)
+
+        # Split the credentials from the netloc.
+        netloc, url_user_password = split_auth_from_netloc(parsed.netloc)
+
+        # Set the url of the request to the url without any credentials
+        req.url = urllib_parse.urlunparse(parsed[:1] + (netloc,) + parsed[2:])
+
+        # Use any stored credentials that we have for this netloc
+        username, password = self.passwords.get(netloc, (None, None))
+
+        # Use the credentials embedded in the url if we have none stored
+        if username is None:
+            username, password = url_user_password
+
+        # Get creds from netrc if we still don't have them
+        if username is None and password is None:
+            netrc_auth = get_netrc_auth(req.url)
+            username, password = netrc_auth if netrc_auth else (None, None)
+
+        if username or password:
+            # Store the username and password
+            self.passwords[netloc] = (username, password)
+
+            # Send the basic auth with this request
+            req = HTTPBasicAuth(username or "", password or "")(req)
+
+        # Attach a hook to handle 401 responses
+        req.register_hook("response", self.handle_401)
+
+        return req
+
+    def handle_401(self, resp, **kwargs):
+        # We only care about 401 responses, anything else we want to just
+        #   pass through the actual response
+        if resp.status_code != 401:
+            return resp
+
+        # We are not able to prompt the user so simply return the response
+        if not self.prompting:
+            return resp
+
+        parsed = urllib_parse.urlparse(resp.url)
+
+        # Prompt the user for a new username and password
+        username = six.moves.input("User for %s: " % parsed.netloc)
+        password = getpass.getpass("Password: ")
+
+        # Store the new username and password to use for future requests
+        if username or password:
+            self.passwords[parsed.netloc] = (username, password)
+
+        # Consume content and release the original connection to allow our new
+        #   request to reuse the same one.
+        resp.content
+        resp.raw.release_conn()
+
+        # Add our new username and password to the request
+        req = HTTPBasicAuth(username or "", password or "")(resp.request)
+        req.register_hook("response", self.warn_on_401)
+
+        # Send our new request
+        new_resp = resp.connection.send(req, **kwargs)
+        new_resp.history.append(resp)
+
+        return new_resp
+
+    def warn_on_401(self, resp, **kwargs):
+        # warn user that they provided incorrect credentials
+        if resp.status_code == 401:
+            logger.warning('401 Error, Credentials not correct for %s',
+                           resp.request.url)
+
+
+class LocalFSAdapter(BaseAdapter):
+
+    def send(self, request, stream=None, timeout=None, verify=None, cert=None,
+             proxies=None):
+        pathname = url_to_path(request.url)
+
+        resp = Response()
+        resp.status_code = 200
+        resp.url = request.url
+
+        try:
+            stats = os.stat(pathname)
+        except OSError as exc:
+            resp.status_code = 404
+            resp.raw = exc
+        else:
+            modified = email.utils.formatdate(stats.st_mtime, usegmt=True)
+            content_type = mimetypes.guess_type(pathname)[0] or "text/plain"
+            resp.headers = CaseInsensitiveDict({
+                "Content-Type": content_type,
+                "Content-Length": stats.st_size,
+                "Last-Modified": modified,
+            })
+
+            resp.raw = open(pathname, "rb")
+            resp.close = resp.raw.close
+
+        return resp
+
+    def close(self):
+        pass
+
+
+class SafeFileCache(FileCache):
+    """
+    A file based cache which is safe to use even when the target directory may
+    not be accessible or writable.
+    """
+
+    def __init__(self, *args, **kwargs):
+        super(SafeFileCache, self).__init__(*args, **kwargs)
+
+        # Check to ensure that the directory containing our cache directory
+        # is owned by the user current executing pip. If it does not exist
+        # we will check the parent directory until we find one that does exist.
+        # If it is not owned by the user executing pip then we will disable
+        # the cache and log a warning.
+        if not check_path_owner(self.directory):
+            logger.warning(
+                "The directory '%s' or its parent directory is not owned by "
+                "the current user and the cache has been disabled. Please "
+                "check the permissions and owner of that directory. If "
+                "executing pip with sudo, you may want sudo's -H flag.",
+                self.directory,
+            )
+
+            # Set our directory to None to disable the Cache
+            self.directory = None
+
+    def get(self, *args, **kwargs):
+        # If we don't have a directory, then the cache should be a no-op.
+        if self.directory is None:
+            return
+
+        try:
+            return super(SafeFileCache, self).get(*args, **kwargs)
+        except (LockError, OSError, IOError):
+            # We intentionally silence this error, if we can't access the cache
+            # then we can just skip caching and process the request as if
+            # caching wasn't enabled.
+            pass
+
+    def set(self, *args, **kwargs):
+        # If we don't have a directory, then the cache should be a no-op.
+        if self.directory is None:
+            return
+
+        try:
+            return super(SafeFileCache, self).set(*args, **kwargs)
+        except (LockError, OSError, IOError):
+            # We intentionally silence this error, if we can't access the cache
+            # then we can just skip caching and process the request as if
+            # caching wasn't enabled.
+            pass
+
+    def delete(self, *args, **kwargs):
+        # If we don't have a directory, then the cache should be a no-op.
+        if self.directory is None:
+            return
+
+        try:
+            return super(SafeFileCache, self).delete(*args, **kwargs)
+        except (LockError, OSError, IOError):
+            # We intentionally silence this error, if we can't access the cache
+            # then we can just skip caching and process the request as if
+            # caching wasn't enabled.
+            pass
+
+
+class InsecureHTTPAdapter(HTTPAdapter):
+
+    def cert_verify(self, conn, url, verify, cert):
+        conn.cert_reqs = 'CERT_NONE'
+        conn.ca_certs = None
+
+
+class PipSession(requests.Session):
+
+    timeout = None  # type: Optional[int]
+
+    def __init__(self, *args, **kwargs):
+        retries = kwargs.pop("retries", 0)
+        cache = kwargs.pop("cache", None)
+        insecure_hosts = kwargs.pop("insecure_hosts", [])
+
+        super(PipSession, self).__init__(*args, **kwargs)
+
+        # Attach our User Agent to the request
+        self.headers["User-Agent"] = user_agent()
+
+        # Attach our Authentication handler to the session
+        self.auth = MultiDomainBasicAuth()
+
+        # Create our urllib3.Retry instance which will allow us to customize
+        # how we handle retries.
+        retries = urllib3.Retry(
+            # Set the total number of retries that a particular request can
+            # have.
+            total=retries,
+
+            # A 503 error from PyPI typically means that the Fastly -> Origin
+            # connection got interrupted in some way. A 503 error in general
+            # is typically considered a transient error so we'll go ahead and
+            # retry it.
+            # A 500 may indicate transient error in Amazon S3
+            # A 520 or 527 - may indicate transient error in CloudFlare
+            status_forcelist=[500, 503, 520, 527],
+
+            # Add a small amount of back off between failed requests in
+            # order to prevent hammering the service.
+            backoff_factor=0.25,
+        )
+
+        # We want to _only_ cache responses on securely fetched origins. We do
+        # this because we can't validate the response of an insecurely fetched
+        # origin, and we don't want someone to be able to poison the cache and
+        # require manual eviction from the cache to fix it.
+        if cache:
+            secure_adapter = CacheControlAdapter(
+                cache=SafeFileCache(cache, use_dir_lock=True),
+                max_retries=retries,
+            )
+        else:
+            secure_adapter = HTTPAdapter(max_retries=retries)
+
+        # Our Insecure HTTPAdapter disables HTTPS validation. It does not
+        # support caching (see above) so we'll use it for all http:// URLs as
+        # well as any https:// host that we've marked as ignoring TLS errors
+        # for.
+        insecure_adapter = InsecureHTTPAdapter(max_retries=retries)
+
+        self.mount("https://", secure_adapter)
+        self.mount("http://", insecure_adapter)
+
+        # Enable file:// urls
+        self.mount("file://", LocalFSAdapter())
+
+        # We want to use a non-validating adapter for any requests which are
+        # deemed insecure.
+        for host in insecure_hosts:
+            self.mount("https://{}/".format(host), insecure_adapter)
+
+    def request(self, method, url, *args, **kwargs):
+        # Allow setting a default timeout on a session
+        kwargs.setdefault("timeout", self.timeout)
+
+        # Dispatch the actual request
+        return super(PipSession, self).request(method, url, *args, **kwargs)
+
+
+def get_file_content(url, comes_from=None, session=None):
+    # type: (str, Optional[str], Optional[PipSession]) -> Tuple[str, Text]
+    """Gets the content of a file; it may be a filename, file: URL, or
+    http: URL.  Returns (location, content).  Content is unicode.
+
+    :param url:         File path or url.
+    :param comes_from:  Origin description of requirements.
+    :param session:     Instance of pip.download.PipSession.
+    """
+    if session is None:
+        raise TypeError(
+            "get_file_content() missing 1 required keyword argument: 'session'"
+        )
+
+    match = _scheme_re.search(url)
+    if match:
+        scheme = match.group(1).lower()
+        if (scheme == 'file' and comes_from and
+                comes_from.startswith('http')):
+            raise InstallationError(
+                'Requirements file %s references URL %s, which is local'
+                % (comes_from, url))
+        if scheme == 'file':
+            path = url.split(':', 1)[1]
+            path = path.replace('\\', '/')
+            match = _url_slash_drive_re.match(path)
+            if match:
+                path = match.group(1) + ':' + path.split('|', 1)[1]
+            path = urllib_parse.unquote(path)
+            if path.startswith('/'):
+                path = '/' + path.lstrip('/')
+            url = path
+        else:
+            # FIXME: catch some errors
+            resp = session.get(url)
+            resp.raise_for_status()
+            return resp.url, resp.text
+    try:
+        with open(url, 'rb') as f:
+            content = auto_decode(f.read())
+    except IOError as exc:
+        raise InstallationError(
+            'Could not open requirements file: %s' % str(exc)
+        )
+    return url, content
+
+
+_scheme_re = re.compile(r'^(http|https|file):', re.I)
+_url_slash_drive_re = re.compile(r'/*([a-z])\|', re.I)
+
+
+def is_url(name):
+    # type: (Union[str, Text]) -> bool
+    """Returns true if the name looks like a URL"""
+    if ':' not in name:
+        return False
+    scheme = name.split(':', 1)[0].lower()
+    return scheme in ['http', 'https', 'file', 'ftp'] + vcs.all_schemes
+
+
+def url_to_path(url):
+    # type: (str) -> str
+    """
+    Convert a file: URL to a path.
+    """
+    assert url.startswith('file:'), (
+        "You can only turn file: urls into filenames (not %r)" % url)
+
+    _, netloc, path, _, _ = urllib_parse.urlsplit(url)
+
+    if not netloc or netloc == 'localhost':
+        # According to RFC 8089, same as empty authority.
+        netloc = ''
+    elif sys.platform == 'win32':
+        # If we have a UNC path, prepend UNC share notation.
+        netloc = '\\\\' + netloc
+    else:
+        raise ValueError(
+            'non-local file URIs are not supported on this platform: %r'
+            % url
+        )
+
+    path = urllib_request.url2pathname(netloc + path)
+    return path
+
+
+def path_to_url(path):
+    # type: (Union[str, Text]) -> str
+    """
+    Convert a path to a file: URL.  The path will be made absolute and have
+    quoted path parts.
+    """
+    path = os.path.normpath(os.path.abspath(path))
+    url = urllib_parse.urljoin('file:', urllib_request.pathname2url(path))
+    return url
+
+
+def is_archive_file(name):
+    # type: (str) -> bool
+    """Return True if `name` is a considered as an archive file."""
+    ext = splitext(name)[1].lower()
+    if ext in ARCHIVE_EXTENSIONS:
+        return True
+    return False
+
+
+def unpack_vcs_link(link, location):
+    vcs_backend = _get_used_vcs_backend(link)
+    vcs_backend.unpack(location)
+
+
+def _get_used_vcs_backend(link):
+    for backend in vcs.backends:
+        if link.scheme in backend.schemes:
+            vcs_backend = backend(link.url)
+            return vcs_backend
+
+
+def is_vcs_url(link):
+    # type: (Link) -> bool
+    return bool(_get_used_vcs_backend(link))
+
+
+def is_file_url(link):
+    # type: (Link) -> bool
+    return link.url.lower().startswith('file:')
+
+
+def is_dir_url(link):
+    # type: (Link) -> bool
+    """Return whether a file:// Link points to a directory.
+
+    ``link`` must not have any other scheme but file://. Call is_file_url()
+    first.
+
+    """
+    link_path = url_to_path(link.url_without_fragment)
+    return os.path.isdir(link_path)
+
+
+def _progress_indicator(iterable, *args, **kwargs):
+    return iterable
+
+
+def _download_url(
+    resp,  # type: Response
+    link,  # type: Link
+    content_file,  # type: IO
+    hashes,  # type: Hashes
+    progress_bar  # type: str
+):
+    # type: (...) -> None
+    try:
+        total_length = int(resp.headers['content-length'])
+    except (ValueError, KeyError, TypeError):
+        total_length = 0
+
+    cached_resp = getattr(resp, "from_cache", False)
+    if logger.getEffectiveLevel() > logging.INFO:
+        show_progress = False
+    elif cached_resp:
+        show_progress = False
+    elif total_length > (40 * 1000):
+        show_progress = True
+    elif not total_length:
+        show_progress = True
+    else:
+        show_progress = False
+
+    show_url = link.show_url
+
+    def resp_read(chunk_size):
+        try:
+            # Special case for urllib3.
+            for chunk in resp.raw.stream(
+                    chunk_size,
+                    # We use decode_content=False here because we don't
+                    # want urllib3 to mess with the raw bytes we get
+                    # from the server. If we decompress inside of
+                    # urllib3 then we cannot verify the checksum
+                    # because the checksum will be of the compressed
+                    # file. This breakage will only occur if the
+                    # server adds a Content-Encoding header, which
+                    # depends on how the server was configured:
+                    # - Some servers will notice that the file isn't a
+                    #   compressible file and will leave the file alone
+                    #   and with an empty Content-Encoding
+                    # - Some servers will notice that the file is
+                    #   already compressed and will leave the file
+                    #   alone and will add a Content-Encoding: gzip
+                    #   header
+                    # - Some servers won't notice anything at all and
+                    #   will take a file that's already been compressed
+                    #   and compress it again and set the
+                    #   Content-Encoding: gzip header
+                    #
+                    # By setting this not to decode automatically we
+                    # hope to eliminate problems with the second case.
+                    decode_content=False):
+                yield chunk
+        except AttributeError:
+            # Standard file-like object.
+            while True:
+                chunk = resp.raw.read(chunk_size)
+                if not chunk:
+                    break
+                yield chunk
+
+    def written_chunks(chunks):
+        for chunk in chunks:
+            content_file.write(chunk)
+            yield chunk
+
+    progress_indicator = _progress_indicator
+
+    if link.netloc == PyPI.netloc:
+        url = show_url
+    else:
+        url = link.url_without_fragment
+
+    if show_progress:  # We don't show progress on cached responses
+        progress_indicator = DownloadProgressProvider(progress_bar,
+                                                      max=total_length)
+        if total_length:
+            logger.info("Downloading %s (%s)", url, format_size(total_length))
+        else:
+            logger.info("Downloading %s", url)
+    elif cached_resp:
+        logger.info("Using cached %s", url)
+    else:
+        logger.info("Downloading %s", url)
+
+    logger.debug('Downloading from URL %s', link)
+
+    downloaded_chunks = written_chunks(
+        progress_indicator(
+            resp_read(CONTENT_CHUNK_SIZE),
+            CONTENT_CHUNK_SIZE
+        )
+    )
+    if hashes:
+        hashes.check_against_chunks(downloaded_chunks)
+    else:
+        consume(downloaded_chunks)
+
+
+def _copy_file(filename, location, link):
+    copy = True
+    download_location = os.path.join(location, link.filename)
+    if os.path.exists(download_location):
+        response = ask_path_exists(
+            'The file %s exists. (i)gnore, (w)ipe, (b)ackup, (a)abort' %
+            display_path(download_location), ('i', 'w', 'b', 'a'))
+        if response == 'i':
+            copy = False
+        elif response == 'w':
+            logger.warning('Deleting %s', display_path(download_location))
+            os.remove(download_location)
+        elif response == 'b':
+            dest_file = backup_dir(download_location)
+            logger.warning(
+                'Backing up %s to %s',
+                display_path(download_location),
+                display_path(dest_file),
+            )
+            shutil.move(download_location, dest_file)
+        elif response == 'a':
+            sys.exit(-1)
+    if copy:
+        shutil.copy(filename, download_location)
+        logger.info('Saved %s', display_path(download_location))
+
+
+def unpack_http_url(
+    link,  # type: Link
+    location,  # type: str
+    download_dir=None,  # type: Optional[str]
+    session=None,  # type: Optional[PipSession]
+    hashes=None,  # type: Optional[Hashes]
+    progress_bar="on"  # type: str
+):
+    # type: (...) -> None
+    if session is None:
+        raise TypeError(
+            "unpack_http_url() missing 1 required keyword argument: 'session'"
+        )
+
+    with TempDirectory(kind="unpack") as temp_dir:
+        # If a download dir is specified, is the file already downloaded there?
+        already_downloaded_path = None
+        if download_dir:
+            already_downloaded_path = _check_download_dir(link,
+                                                          download_dir,
+                                                          hashes)
+
+        if already_downloaded_path:
+            from_path = already_downloaded_path
+            content_type = mimetypes.guess_type(from_path)[0]
+        else:
+            # let's download to a tmp dir
+            from_path, content_type = _download_http_url(link,
+                                                         session,
+                                                         temp_dir.path,
+                                                         hashes,
+                                                         progress_bar)
+
+        # unpack the archive to the build dir location. even when only
+        # downloading archives, they have to be unpacked to parse dependencies
+        unpack_file(from_path, location, content_type, link)
+
+        # a download dir is specified; let's copy the archive there
+        if download_dir and not already_downloaded_path:
+            _copy_file(from_path, download_dir, link)
+
+        if not already_downloaded_path:
+            os.unlink(from_path)
+
+
+def unpack_file_url(
+    link,  # type: Link
+    location,  # type: str
+    download_dir=None,  # type: Optional[str]
+    hashes=None  # type: Optional[Hashes]
+):
+    # type: (...) -> None
+    """Unpack link into location.
+
+    If download_dir is provided and link points to a file, make a copy
+    of the link file inside download_dir.
+    """
+    link_path = url_to_path(link.url_without_fragment)
+
+    # If it's a url to a local directory
+    if is_dir_url(link):
+        if os.path.isdir(location):
+            rmtree(location)
+        shutil.copytree(link_path, location, symlinks=True)
+        if download_dir:
+            logger.info('Link is a directory, ignoring download_dir')
+        return
+
+    # If --require-hashes is off, `hashes` is either empty, the
+    # link's embedded hash, or MissingHashes; it is required to
+    # match. If --require-hashes is on, we are satisfied by any
+    # hash in `hashes` matching: a URL-based or an option-based
+    # one; no internet-sourced hash will be in `hashes`.
+    if hashes:
+        hashes.check_against_path(link_path)
+
+    # If a download dir is specified, is the file already there and valid?
+    already_downloaded_path = None
+    if download_dir:
+        already_downloaded_path = _check_download_dir(link,
+                                                      download_dir,
+                                                      hashes)
+
+    if already_downloaded_path:
+        from_path = already_downloaded_path
+    else:
+        from_path = link_path
+
+    content_type = mimetypes.guess_type(from_path)[0]
+
+    # unpack the archive to the build dir location. even when only downloading
+    # archives, they have to be unpacked to parse dependencies
+    unpack_file(from_path, location, content_type, link)
+
+    # a download dir is specified and not already downloaded
+    if download_dir and not already_downloaded_path:
+        _copy_file(from_path, download_dir, link)
+
+
+class PipXmlrpcTransport(xmlrpc_client.Transport):
+    """Provide a `xmlrpclib.Transport` implementation via a `PipSession`
+    object.
+    """
+
+    def __init__(self, index_url, session, use_datetime=False):
+        xmlrpc_client.Transport.__init__(self, use_datetime)
+        index_parts = urllib_parse.urlparse(index_url)
+        self._scheme = index_parts.scheme
+        self._session = session
+
+    def request(self, host, handler, request_body, verbose=False):
+        parts = (self._scheme, host, handler, None, None, None)
+        url = urllib_parse.urlunparse(parts)
+        try:
+            headers = {'Content-Type': 'text/xml'}
+            response = self._session.post(url, data=request_body,
+                                          headers=headers, stream=True)
+            response.raise_for_status()
+            self.verbose = verbose
+            return self.parse_response(response.raw)
+        except requests.HTTPError as exc:
+            logger.critical(
+                "HTTP error %s while getting %s",
+                exc.response.status_code, url,
+            )
+            raise
+
+
+def unpack_url(
+    link,  # type: Optional[Link]
+    location,  # type: Optional[str]
+    download_dir=None,  # type: Optional[str]
+    only_download=False,  # type: bool
+    session=None,  # type: Optional[PipSession]
+    hashes=None,  # type: Optional[Hashes]
+    progress_bar="on"  # type: str
+):
+    # type: (...) -> None
+    """Unpack link.
+       If link is a VCS link:
+         if only_download, export into download_dir and ignore location
+          else unpack into location
+       for other types of link:
+         - unpack into location
+         - if download_dir, copy the file into download_dir
+         - if only_download, mark location for deletion
+
+    :param hashes: A Hashes object, one of whose embedded hashes must match,
+        or HashMismatch will be raised. If the Hashes is empty, no matches are
+        required, and unhashable types of requirements (like VCS ones, which
+        would ordinarily raise HashUnsupported) are allowed.
+    """
+    # non-editable vcs urls
+    if is_vcs_url(link):
+        unpack_vcs_link(link, location)
+
+    # file urls
+    elif is_file_url(link):
+        unpack_file_url(link, location, download_dir, hashes=hashes)
+
+    # http urls
+    else:
+        if session is None:
+            session = PipSession()
+
+        unpack_http_url(
+            link,
+            location,
+            download_dir,
+            session,
+            hashes=hashes,
+            progress_bar=progress_bar
+        )
+    if only_download:
+        write_delete_marker_file(location)
+
+
+def _download_http_url(
+    link,  # type: Link
+    session,  # type: PipSession
+    temp_dir,  # type: str
+    hashes,  # type: Hashes
+    progress_bar  # type: str
+):
+    # type: (...) -> Tuple[str, str]
+    """Download link url into temp_dir using provided session"""
+    target_url = link.url.split('#', 1)[0]
+    try:
+        resp = session.get(
+            target_url,
+            # We use Accept-Encoding: identity here because requests
+            # defaults to accepting compressed responses. This breaks in
+            # a variety of ways depending on how the server is configured.
+            # - Some servers will notice that the file isn't a compressible
+            #   file and will leave the file alone and with an empty
+            #   Content-Encoding
+            # - Some servers will notice that the file is already
+            #   compressed and will leave the file alone and will add a
+            #   Content-Encoding: gzip header
+            # - Some servers won't notice anything at all and will take
+            #   a file that's already been compressed and compress it again
+            #   and set the Content-Encoding: gzip header
+            # By setting this to request only the identity encoding We're
+            # hoping to eliminate the third case. Hopefully there does not
+            # exist a server which when given a file will notice it is
+            # already compressed and that you're not asking for a
+            # compressed file and will then decompress it before sending
+            # because if that's the case I don't think it'll ever be
+            # possible to make this work.
+            headers={"Accept-Encoding": "identity"},
+            stream=True,
+        )
+        resp.raise_for_status()
+    except requests.HTTPError as exc:
+        logger.critical(
+            "HTTP error %s while getting %s", exc.response.status_code, link,
+        )
+        raise
+
+    content_type = resp.headers.get('content-type', '')
+    filename = link.filename  # fallback
+    # Have a look at the Content-Disposition header for a better guess
+    content_disposition = resp.headers.get('content-disposition')
+    if content_disposition:
+        type, params = cgi.parse_header(content_disposition)
+        # We use ``or`` here because we don't want to use an "empty" value
+        # from the filename param.
+        filename = params.get('filename') or filename
+    ext = splitext(filename)[1]
+    if not ext:
+        ext = mimetypes.guess_extension(content_type)
+        if ext:
+            filename += ext
+    if not ext and link.url != resp.url:
+        ext = os.path.splitext(resp.url)[1]
+        if ext:
+            filename += ext
+    file_path = os.path.join(temp_dir, filename)
+    with open(file_path, 'wb') as content_file:
+        _download_url(resp, link, content_file, hashes, progress_bar)
+    return file_path, content_type
+
+
+def _check_download_dir(link, download_dir, hashes):
+    # type: (Link, str, Hashes) -> Optional[str]
+    """ Check download_dir for previously downloaded file with correct hash
+        If a correct file is found return its path else None
+    """
+    download_path = os.path.join(download_dir, link.filename)
+    if os.path.exists(download_path):
+        # If already downloaded, does its hash match?
+        logger.info('File was already downloaded %s', download_path)
+        if hashes:
+            try:
+                hashes.check_against_path(download_path)
+            except HashMismatch:
+                logger.warning(
+                    'Previously-downloaded file %s has bad hash. '
+                    'Re-downloading.',
+                    download_path
+                )
+                os.unlink(download_path)
+                return None
+        return download_path
+    return None
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/download.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/download.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..fe5bb79225f69289f4b137b17e89b393a1d76f37
GIT binary patch
literal 28623
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

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/exceptions.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/exceptions.py
new file mode 100644
index 0000000..7b291a1
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/exceptions.py
@@ -0,0 +1,274 @@
+"""Exceptions used throughout package"""
+from __future__ import absolute_import
+
+from itertools import chain, groupby, repeat
+
+from pip._vendor.six import iteritems
+
+from pip._internal.utils.typing import MYPY_CHECK_RUNNING
+
+if MYPY_CHECK_RUNNING:
+    from typing import Optional
+    from pip._internal.req.req_install import InstallRequirement
+
+
+class PipError(Exception):
+    """Base pip exception"""
+
+
+class ConfigurationError(PipError):
+    """General exception in configuration"""
+
+
+class InstallationError(PipError):
+    """General exception during installation"""
+
+
+class UninstallationError(PipError):
+    """General exception during uninstallation"""
+
+
+class DistributionNotFound(InstallationError):
+    """Raised when a distribution cannot be found to satisfy a requirement"""
+
+
+class RequirementsFileParseError(InstallationError):
+    """Raised when a general error occurs parsing a requirements file line."""
+
+
+class BestVersionAlreadyInstalled(PipError):
+    """Raised when the most up-to-date version of a package is already
+    installed."""
+
+
+class BadCommand(PipError):
+    """Raised when virtualenv or a command is not found"""
+
+
+class CommandError(PipError):
+    """Raised when there is an error in command-line arguments"""
+
+
+class PreviousBuildDirError(PipError):
+    """Raised when there's a previous conflicting build directory"""
+
+
+class InvalidWheelFilename(InstallationError):
+    """Invalid wheel filename."""
+
+
+class UnsupportedWheel(InstallationError):
+    """Unsupported wheel."""
+
+
+class HashErrors(InstallationError):
+    """Multiple HashError instances rolled into one for reporting"""
+
+    def __init__(self):
+        self.errors = []
+
+    def append(self, error):
+        self.errors.append(error)
+
+    def __str__(self):
+        lines = []
+        self.errors.sort(key=lambda e: e.order)
+        for cls, errors_of_cls in groupby(self.errors, lambda e: e.__class__):
+            lines.append(cls.head)
+            lines.extend(e.body() for e in errors_of_cls)
+        if lines:
+            return '\n'.join(lines)
+
+    def __nonzero__(self):
+        return bool(self.errors)
+
+    def __bool__(self):
+        return self.__nonzero__()
+
+
+class HashError(InstallationError):
+    """
+    A failure to verify a package against known-good hashes
+
+    :cvar order: An int sorting hash exception classes by difficulty of
+        recovery (lower being harder), so the user doesn't bother fretting
+        about unpinned packages when he has deeper issues, like VCS
+        dependencies, to deal with. Also keeps error reports in a
+        deterministic order.
+    :cvar head: A section heading for display above potentially many
+        exceptions of this kind
+    :ivar req: The InstallRequirement that triggered this error. This is
+        pasted on after the exception is instantiated, because it's not
+        typically available earlier.
+
+    """
+    req = None  # type: Optional[InstallRequirement]
+    head = ''
+
+    def body(self):
+        """Return a summary of me for display under the heading.
+
+        This default implementation simply prints a description of the
+        triggering requirement.
+
+        :param req: The InstallRequirement that provoked this error, with
+            populate_link() having already been called
+
+        """
+        return '    %s' % self._requirement_name()
+
+    def __str__(self):
+        return '%s\n%s' % (self.head, self.body())
+
+    def _requirement_name(self):
+        """Return a description of the requirement that triggered me.
+
+        This default implementation returns long description of the req, with
+        line numbers
+
+        """
+        return str(self.req) if self.req else 'unknown package'
+
+
+class VcsHashUnsupported(HashError):
+    """A hash was provided for a version-control-system-based requirement, but
+    we don't have a method for hashing those."""
+
+    order = 0
+    head = ("Can't verify hashes for these requirements because we don't "
+            "have a way to hash version control repositories:")
+
+
+class DirectoryUrlHashUnsupported(HashError):
+    """A hash was provided for a version-control-system-based requirement, but
+    we don't have a method for hashing those."""
+
+    order = 1
+    head = ("Can't verify hashes for these file:// requirements because they "
+            "point to directories:")
+
+
+class HashMissing(HashError):
+    """A hash was needed for a requirement but is absent."""
+
+    order = 2
+    head = ('Hashes are required in --require-hashes mode, but they are '
+            'missing from some requirements. Here is a list of those '
+            'requirements along with the hashes their downloaded archives '
+            'actually had. Add lines like these to your requirements files to '
+            'prevent tampering. (If you did not enable --require-hashes '
+            'manually, note that it turns on automatically when any package '
+            'has a hash.)')
+
+    def __init__(self, gotten_hash):
+        """
+        :param gotten_hash: The hash of the (possibly malicious) archive we
+            just downloaded
+        """
+        self.gotten_hash = gotten_hash
+
+    def body(self):
+        # Dodge circular import.
+        from pip._internal.utils.hashes import FAVORITE_HASH
+
+        package = None
+        if self.req:
+            # In the case of URL-based requirements, display the original URL
+            # seen in the requirements file rather than the package name,
+            # so the output can be directly copied into the requirements file.
+            package = (self.req.original_link if self.req.original_link
+                       # In case someone feeds something downright stupid
+                       # to InstallRequirement's constructor.
+                       else getattr(self.req, 'req', None))
+        return '    %s --hash=%s:%s' % (package or 'unknown package',
+                                        FAVORITE_HASH,
+                                        self.gotten_hash)
+
+
+class HashUnpinned(HashError):
+    """A requirement had a hash specified but was not pinned to a specific
+    version."""
+
+    order = 3
+    head = ('In --require-hashes mode, all requirements must have their '
+            'versions pinned with ==. These do not:')
+
+
+class HashMismatch(HashError):
+    """
+    Distribution file hash values don't match.
+
+    :ivar package_name: The name of the package that triggered the hash
+        mismatch. Feel free to write to this after the exception is raise to
+        improve its error message.
+
+    """
+    order = 4
+    head = ('THESE PACKAGES DO NOT MATCH THE HASHES FROM THE REQUIREMENTS '
+            'FILE. If you have updated the package versions, please update '
+            'the hashes. Otherwise, examine the package contents carefully; '
+            'someone may have tampered with them.')
+
+    def __init__(self, allowed, gots):
+        """
+        :param allowed: A dict of algorithm names pointing to lists of allowed
+            hex digests
+        :param gots: A dict of algorithm names pointing to hashes we
+            actually got from the files under suspicion
+        """
+        self.allowed = allowed
+        self.gots = gots
+
+    def body(self):
+        return '    %s:\n%s' % (self._requirement_name(),
+                                self._hash_comparison())
+
+    def _hash_comparison(self):
+        """
+        Return a comparison of actual and expected hash values.
+
+        Example::
+
+               Expected sha256 abcdeabcdeabcdeabcdeabcdeabcdeabcdeabcdeabcde
+                            or 123451234512345123451234512345123451234512345
+                    Got        bcdefbcdefbcdefbcdefbcdefbcdefbcdefbcdefbcdef
+
+        """
+        def hash_then_or(hash_name):
+            # For now, all the decent hashes have 6-char names, so we can get
+            # away with hard-coding space literals.
+            return chain([hash_name], repeat('    or'))
+
+        lines = []
+        for hash_name, expecteds in iteritems(self.allowed):
+            prefix = hash_then_or(hash_name)
+            lines.extend(('        Expected %s %s' % (next(prefix), e))
+                         for e in expecteds)
+            lines.append('             Got        %s\n' %
+                         self.gots[hash_name].hexdigest())
+            prefix = '    or'
+        return '\n'.join(lines)
+
+
+class UnsupportedPythonVersion(InstallationError):
+    """Unsupported python version according to Requires-Python package
+    metadata."""
+
+
+class ConfigurationFileCouldNotBeLoaded(ConfigurationError):
+    """When there are errors while loading a configuration file
+    """
+
+    def __init__(self, reason="could not be loaded", fname=None, error=None):
+        super(ConfigurationFileCouldNotBeLoaded, self).__init__(error)
+        self.reason = reason
+        self.fname = fname
+        self.error = error
+
+    def __str__(self):
+        if self.fname is not None:
+            message_part = " in {}.".format(self.fname)
+        else:
+            assert self.error is not None
+            message_part = ".\n{}\n".format(self.error.message)
+        return "Configuration file {}{}".format(self.reason, message_part)
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/exceptions.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/exceptions.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..6fbc728cd6ea6b10e358efefe24d3282bdcb3845
GIT binary patch
literal 16273
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
aS&Rh<vLdl1#dO3t#W=-O#W=+*#8?4r>-|>%

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/index.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/index.py
new file mode 100644
index 0000000..81278e8
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/index.py
@@ -0,0 +1,1105 @@
+"""Routines related to PyPI, indexes"""
+from __future__ import absolute_import
+
+import cgi
+import itertools
+import logging
+import mimetypes
+import os
+import posixpath
+import re
+import sys
+from collections import namedtuple
+
+from pip._vendor import html5lib, requests, six
+from pip._vendor.distlib.compat import unescape
+from pip._vendor.packaging import specifiers
+from pip._vendor.packaging.utils import canonicalize_name
+from pip._vendor.packaging.version import parse as parse_version
+from pip._vendor.requests.exceptions import HTTPError, RetryError, SSLError
+from pip._vendor.six.moves.urllib import parse as urllib_parse
+from pip._vendor.six.moves.urllib import request as urllib_request
+
+from pip._internal.download import HAS_TLS, is_url, path_to_url, url_to_path
+from pip._internal.exceptions import (
+    BestVersionAlreadyInstalled, DistributionNotFound, InvalidWheelFilename,
+    UnsupportedWheel,
+)
+from pip._internal.models.candidate import InstallationCandidate
+from pip._internal.models.format_control import FormatControl
+from pip._internal.models.index import PyPI
+from pip._internal.models.link import Link
+from pip._internal.pep425tags import get_supported
+from pip._internal.utils.compat import ipaddress
+from pip._internal.utils.logging import indent_log
+from pip._internal.utils.misc import (
+    ARCHIVE_EXTENSIONS, SUPPORTED_EXTENSIONS, WHEEL_EXTENSION, normalize_path,
+    redact_password_from_url,
+)
+from pip._internal.utils.packaging import check_requires_python
+from pip._internal.utils.typing import MYPY_CHECK_RUNNING
+from pip._internal.wheel import Wheel
+
+if MYPY_CHECK_RUNNING:
+    from logging import Logger
+    from typing import (
+        Tuple, Optional, Any, List, Union, Callable, Set, Sequence,
+        Iterable, MutableMapping
+    )
+    from pip._vendor.packaging.version import _BaseVersion
+    from pip._vendor.requests import Response
+    from pip._internal.pep425tags import Pep425Tag
+    from pip._internal.req import InstallRequirement
+    from pip._internal.download import PipSession
+
+    SecureOrigin = Tuple[str, str, Optional[str]]
+    BuildTag = Tuple[Any, ...]  # either empty tuple or Tuple[int, str]
+    CandidateSortingKey = Tuple[int, _BaseVersion, BuildTag, Optional[int]]
+
+
+__all__ = ['FormatControl', 'FoundCandidates', 'PackageFinder']
+
+
+SECURE_ORIGINS = [
+    # protocol, hostname, port
+    # Taken from Chrome's list of secure origins (See: http://bit.ly/1qrySKC)
+    ("https", "*", "*"),
+    ("*", "localhost", "*"),
+    ("*", "127.0.0.0/8", "*"),
+    ("*", "::1/128", "*"),
+    ("file", "*", None),
+    # ssh is always secure.
+    ("ssh", "*", "*"),
+]  # type: List[SecureOrigin]
+
+
+logger = logging.getLogger(__name__)
+
+
+def _match_vcs_scheme(url):
+    # type: (str) -> Optional[str]
+    """Look for VCS schemes in the URL.
+
+    Returns the matched VCS scheme, or None if there's no match.
+    """
+    from pip._internal.vcs import VcsSupport
+    for scheme in VcsSupport.schemes:
+        if url.lower().startswith(scheme) and url[len(scheme)] in '+:':
+            return scheme
+    return None
+
+
+def _is_url_like_archive(url):
+    # type: (str) -> bool
+    """Return whether the URL looks like an archive.
+    """
+    filename = Link(url).filename
+    for bad_ext in ARCHIVE_EXTENSIONS:
+        if filename.endswith(bad_ext):
+            return True
+    return False
+
+
+class _NotHTML(Exception):
+    def __init__(self, content_type, request_desc):
+        # type: (str, str) -> None
+        super(_NotHTML, self).__init__(content_type, request_desc)
+        self.content_type = content_type
+        self.request_desc = request_desc
+
+
+def _ensure_html_header(response):
+    # type: (Response) -> None
+    """Check the Content-Type header to ensure the response contains HTML.
+
+    Raises `_NotHTML` if the content type is not text/html.
+    """
+    content_type = response.headers.get("Content-Type", "")
+    if not content_type.lower().startswith("text/html"):
+        raise _NotHTML(content_type, response.request.method)
+
+
+class _NotHTTP(Exception):
+    pass
+
+
+def _ensure_html_response(url, session):
+    # type: (str, PipSession) -> None
+    """Send a HEAD request to the URL, and ensure the response contains HTML.
+
+    Raises `_NotHTTP` if the URL is not available for a HEAD request, or
+    `_NotHTML` if the content type is not text/html.
+    """
+    scheme, netloc, path, query, fragment = urllib_parse.urlsplit(url)
+    if scheme not in {'http', 'https'}:
+        raise _NotHTTP()
+
+    resp = session.head(url, allow_redirects=True)
+    resp.raise_for_status()
+
+    _ensure_html_header(resp)
+
+
+def _get_html_response(url, session):
+    # type: (str, PipSession) -> Response
+    """Access an HTML page with GET, and return the response.
+
+    This consists of three parts:
+
+    1. If the URL looks suspiciously like an archive, send a HEAD first to
+       check the Content-Type is HTML, to avoid downloading a large file.
+       Raise `_NotHTTP` if the content type cannot be determined, or
+       `_NotHTML` if it is not HTML.
+    2. Actually perform the request. Raise HTTP exceptions on network failures.
+    3. Check the Content-Type header to make sure we got HTML, and raise
+       `_NotHTML` otherwise.
+    """
+    if _is_url_like_archive(url):
+        _ensure_html_response(url, session=session)
+
+    logger.debug('Getting page %s', redact_password_from_url(url))
+
+    resp = session.get(
+        url,
+        headers={
+            "Accept": "text/html",
+            # We don't want to blindly returned cached data for
+            # /simple/, because authors generally expecting that
+            # twine upload && pip install will function, but if
+            # they've done a pip install in the last ~10 minutes
+            # it won't. Thus by setting this to zero we will not
+            # blindly use any cached data, however the benefit of
+            # using max-age=0 instead of no-cache, is that we will
+            # still support conditional requests, so we will still
+            # minimize traffic sent in cases where the page hasn't
+            # changed at all, we will just always incur the round
+            # trip for the conditional GET now instead of only
+            # once per 10 minutes.
+            # For more information, please see pypa/pip#5670.
+            "Cache-Control": "max-age=0",
+        },
+    )
+    resp.raise_for_status()
+
+    # The check for archives above only works if the url ends with
+    # something that looks like an archive. However that is not a
+    # requirement of an url. Unless we issue a HEAD request on every
+    # url we cannot know ahead of time for sure if something is HTML
+    # or not. However we can check after we've downloaded it.
+    _ensure_html_header(resp)
+
+    return resp
+
+
+def _handle_get_page_fail(
+    link,  # type: Link
+    reason,  # type: Union[str, Exception]
+    meth=None  # type: Optional[Callable[..., None]]
+):
+    # type: (...) -> None
+    if meth is None:
+        meth = logger.debug
+    meth("Could not fetch URL %s: %s - skipping", link, reason)
+
+
+def _get_html_page(link, session=None):
+    # type: (Link, Optional[PipSession]) -> Optional[HTMLPage]
+    if session is None:
+        raise TypeError(
+            "_get_html_page() missing 1 required keyword argument: 'session'"
+        )
+
+    url = link.url.split('#', 1)[0]
+
+    # Check for VCS schemes that do not support lookup as web pages.
+    vcs_scheme = _match_vcs_scheme(url)
+    if vcs_scheme:
+        logger.debug('Cannot look at %s URL %s', vcs_scheme, link)
+        return None
+
+    # Tack index.html onto file:// URLs that point to directories
+    scheme, _, path, _, _, _ = urllib_parse.urlparse(url)
+    if (scheme == 'file' and os.path.isdir(urllib_request.url2pathname(path))):
+        # add trailing slash if not present so urljoin doesn't trim
+        # final segment
+        if not url.endswith('/'):
+            url += '/'
+        url = urllib_parse.urljoin(url, 'index.html')
+        logger.debug(' file: URL is directory, getting %s', url)
+
+    try:
+        resp = _get_html_response(url, session=session)
+    except _NotHTTP:
+        logger.debug(
+            'Skipping page %s because it looks like an archive, and cannot '
+            'be checked by HEAD.', link,
+        )
+    except _NotHTML as exc:
+        logger.debug(
+            'Skipping page %s because the %s request got Content-Type: %s',
+            link, exc.request_desc, exc.content_type,
+        )
+    except HTTPError as exc:
+        _handle_get_page_fail(link, exc)
+    except RetryError as exc:
+        _handle_get_page_fail(link, exc)
+    except SSLError as exc:
+        reason = "There was a problem confirming the ssl certificate: "
+        reason += str(exc)
+        _handle_get_page_fail(link, reason, meth=logger.info)
+    except requests.ConnectionError as exc:
+        _handle_get_page_fail(link, "connection error: %s" % exc)
+    except requests.Timeout:
+        _handle_get_page_fail(link, "timed out")
+    else:
+        return HTMLPage(resp.content, resp.url, resp.headers)
+    return None
+
+
+class CandidateEvaluator(object):
+
+    def __init__(
+        self,
+        valid_tags,          # type: List[Pep425Tag]
+        prefer_binary=False  # type: bool
+
+    ):
+        # type: (...) -> None
+        self._prefer_binary = prefer_binary
+        self._valid_tags = valid_tags
+
+    def is_wheel_supported(self, wheel):
+        # type: (Wheel) -> bool
+        return wheel.supported(self._valid_tags)
+
+    def _sort_key(self, candidate):
+        # type: (InstallationCandidate) -> CandidateSortingKey
+        """
+        Function used to generate link sort key for link tuples.
+        The greater the return value, the more preferred it is.
+        If not finding wheels, then sorted by version only.
+        If finding wheels, then the sort order is by version, then:
+          1. existing installs
+          2. wheels ordered via Wheel.support_index_min(self._valid_tags)
+          3. source archives
+        If prefer_binary was set, then all wheels are sorted above sources.
+        Note: it was considered to embed this logic into the Link
+              comparison operators, but then different sdist links
+              with the same version, would have to be considered equal
+        """
+        support_num = len(self._valid_tags)
+        build_tag = tuple()  # type: BuildTag
+        binary_preference = 0
+        if candidate.location.is_wheel:
+            # can raise InvalidWheelFilename
+            wheel = Wheel(candidate.location.filename)
+            if not wheel.supported(self._valid_tags):
+                raise UnsupportedWheel(
+                    "%s is not a supported wheel for this platform. It "
+                    "can't be sorted." % wheel.filename
+                )
+            if self._prefer_binary:
+                binary_preference = 1
+            pri = -(wheel.support_index_min(self._valid_tags))
+            if wheel.build_tag is not None:
+                match = re.match(r'^(\d+)(.*)$', wheel.build_tag)
+                build_tag_groups = match.groups()
+                build_tag = (int(build_tag_groups[0]), build_tag_groups[1])
+        else:  # sdist
+            pri = -(support_num)
+        return (binary_preference, candidate.version, build_tag, pri)
+
+    def get_best_candidate(self, candidates):
+        # type: (List[InstallationCandidate]) -> InstallationCandidate
+        """
+        Return the best candidate per the instance's sort order, or None if
+        no candidates are given.
+        """
+        if not candidates:
+            return None
+
+        return max(candidates, key=self._sort_key)
+
+
+class FoundCandidates(object):
+    """A collection of candidates, returned by `PackageFinder.find_candidates`.
+
+    This class is only intended to be instantiated by PackageFinder through
+    the `from_specifier()` constructor.
+
+    Arguments:
+
+    * `candidates`: A sequence of all available candidates found.
+    * `specifier`: Specifier to filter applicable versions.
+    * `prereleases`: Whether prereleases should be accounted. Pass None to
+        infer from the specifier.
+    * `evaluator`: A CandidateEvaluator object to sort applicable candidates
+        by order of preference.
+    """
+    def __init__(
+        self,
+        candidates,     # type: List[InstallationCandidate]
+        versions,       # type: Set[str]
+        evaluator,      # type: CandidateEvaluator
+    ):
+        # type: (...) -> None
+        self._candidates = candidates
+        self._evaluator = evaluator
+        self._versions = versions
+
+    @classmethod
+    def from_specifier(
+        cls,
+        candidates,     # type: List[InstallationCandidate]
+        specifier,      # type: specifiers.BaseSpecifier
+        prereleases,    # type: Optional[bool]
+        evaluator,      # type: CandidateEvaluator
+    ):
+        # type: (...) -> FoundCandidates
+        versions = {
+            str(v) for v in specifier.filter(
+                # We turn the version object into a str here because otherwise
+                # when we're debundled but setuptools isn't, Python will see
+                # packaging.version.Version and
+                # pkg_resources._vendor.packaging.version.Version as different
+                # types. This way we'll use a str as a common data interchange
+                # format. If we stop using the pkg_resources provided specifier
+                # and start using our own, we can drop the cast to str().
+                (str(c.version) for c in candidates),
+                prereleases=prereleases,
+            )
+        }
+        return cls(candidates, versions, evaluator)
+
+    def iter_all(self):
+        # type: () -> Iterable[InstallationCandidate]
+        """Iterate through all candidates.
+        """
+        return iter(self._candidates)
+
+    def iter_applicable(self):
+        # type: () -> Iterable[InstallationCandidate]
+        """Iterate through candidates matching the versions associated with
+        this instance.
+        """
+        # Again, converting version to str to deal with debundling.
+        return (c for c in self.iter_all() if str(c.version) in self._versions)
+
+    def get_best(self):
+        # type: () -> Optional[InstallationCandidate]
+        """Return the best candidate available, or None if no applicable
+        candidates are found.
+        """
+        candidates = list(self.iter_applicable())
+        return self._evaluator.get_best_candidate(candidates)
+
+
+class PackageFinder(object):
+    """This finds packages.
+
+    This is meant to match easy_install's technique for looking for
+    packages, by reading pages and looking for appropriate links.
+    """
+
+    def __init__(
+        self,
+        find_links,  # type: List[str]
+        index_urls,  # type: List[str]
+        allow_all_prereleases=False,  # type: bool
+        trusted_hosts=None,  # type: Optional[Iterable[str]]
+        session=None,  # type: Optional[PipSession]
+        format_control=None,  # type: Optional[FormatControl]
+        platform=None,  # type: Optional[str]
+        versions=None,  # type: Optional[List[str]]
+        abi=None,  # type: Optional[str]
+        implementation=None,  # type: Optional[str]
+        prefer_binary=False  # type: bool
+    ):
+        # type: (...) -> None
+        """Create a PackageFinder.
+
+        :param format_control: A FormatControl object or None. Used to control
+            the selection of source packages / binary packages when consulting
+            the index and links.
+        :param platform: A string or None. If None, searches for packages
+            that are supported by the current system. Otherwise, will find
+            packages that can be built on the platform passed in. These
+            packages will only be downloaded for distribution: they will
+            not be built locally.
+        :param versions: A list of strings or None. This is passed directly
+            to pep425tags.py in the get_supported() method.
+        :param abi: A string or None. This is passed directly
+            to pep425tags.py in the get_supported() method.
+        :param implementation: A string or None. This is passed directly
+            to pep425tags.py in the get_supported() method.
+        :param prefer_binary: Whether to prefer an old, but valid, binary
+            dist over a new source dist.
+        """
+        if session is None:
+            raise TypeError(
+                "PackageFinder() missing 1 required keyword argument: "
+                "'session'"
+            )
+
+        # Build find_links. If an argument starts with ~, it may be
+        # a local file relative to a home directory. So try normalizing
+        # it and if it exists, use the normalized version.
+        # This is deliberately conservative - it might be fine just to
+        # blindly normalize anything starting with a ~...
+        self.find_links = []  # type: List[str]
+        for link in find_links:
+            if link.startswith('~'):
+                new_link = normalize_path(link)
+                if os.path.exists(new_link):
+                    link = new_link
+            self.find_links.append(link)
+
+        self.index_urls = index_urls
+
+        # These are boring links that have already been logged somehow:
+        self.logged_links = set()  # type: Set[Link]
+
+        self.format_control = format_control or FormatControl(set(), set())
+
+        # Domains that we won't emit warnings for when not using HTTPS
+        self.secure_origins = [
+            ("*", host, "*")
+            for host in (trusted_hosts if trusted_hosts else [])
+        ]  # type: List[SecureOrigin]
+
+        # Do we want to allow _all_ pre-releases?
+        self.allow_all_prereleases = allow_all_prereleases
+
+        # The Session we'll use to make requests
+        self.session = session
+
+        # The valid tags to check potential found wheel candidates against
+        valid_tags = get_supported(
+            versions=versions,
+            platform=platform,
+            abi=abi,
+            impl=implementation,
+        )
+        self.candidate_evaluator = CandidateEvaluator(
+            valid_tags=valid_tags, prefer_binary=prefer_binary,
+        )
+
+        # If we don't have TLS enabled, then WARN if anyplace we're looking
+        # relies on TLS.
+        if not HAS_TLS:
+            for link in itertools.chain(self.index_urls, self.find_links):
+                parsed = urllib_parse.urlparse(link)
+                if parsed.scheme == "https":
+                    logger.warning(
+                        "pip is configured with locations that require "
+                        "TLS/SSL, however the ssl module in Python is not "
+                        "available."
+                    )
+                    break
+
+    def get_formatted_locations(self):
+        # type: () -> str
+        lines = []
+        if self.index_urls and self.index_urls != [PyPI.simple_url]:
+            lines.append(
+                "Looking in indexes: {}".format(", ".join(
+                    redact_password_from_url(url) for url in self.index_urls))
+            )
+        if self.find_links:
+            lines.append(
+                "Looking in links: {}".format(", ".join(self.find_links))
+            )
+        return "\n".join(lines)
+
+    @staticmethod
+    def _sort_locations(locations, expand_dir=False):
+        # type: (Sequence[str], bool) -> Tuple[List[str], List[str]]
+        """
+        Sort locations into "files" (archives) and "urls", and return
+        a pair of lists (files,urls)
+        """
+        files = []
+        urls = []
+
+        # puts the url for the given file path into the appropriate list
+        def sort_path(path):
+            url = path_to_url(path)
+            if mimetypes.guess_type(url, strict=False)[0] == 'text/html':
+                urls.append(url)
+            else:
+                files.append(url)
+
+        for url in locations:
+
+            is_local_path = os.path.exists(url)
+            is_file_url = url.startswith('file:')
+
+            if is_local_path or is_file_url:
+                if is_local_path:
+                    path = url
+                else:
+                    path = url_to_path(url)
+                if os.path.isdir(path):
+                    if expand_dir:
+                        path = os.path.realpath(path)
+                        for item in os.listdir(path):
+                            sort_path(os.path.join(path, item))
+                    elif is_file_url:
+                        urls.append(url)
+                    else:
+                        logger.warning(
+                            "Path '{0}' is ignored: "
+                            "it is a directory.".format(path),
+                        )
+                elif os.path.isfile(path):
+                    sort_path(path)
+                else:
+                    logger.warning(
+                        "Url '%s' is ignored: it is neither a file "
+                        "nor a directory.", url,
+                    )
+            elif is_url(url):
+                # Only add url with clear scheme
+                urls.append(url)
+            else:
+                logger.warning(
+                    "Url '%s' is ignored. It is either a non-existing "
+                    "path or lacks a specific scheme.", url,
+                )
+
+        return files, urls
+
+    def _validate_secure_origin(self, logger, location):
+        # type: (Logger, Link) -> bool
+        # Determine if this url used a secure transport mechanism
+        parsed = urllib_parse.urlparse(str(location))
+        origin = (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.)
+        protocol = origin[0].rsplit('+', 1)[-1]
+
+        # Determine if our origin is a secure origin by looking through our
+        # hardcoded list of secure origins, as well as any additional ones
+        # configured on this PackageFinder instance.
+        for secure_origin in (SECURE_ORIGINS + self.secure_origins):
+            if protocol != secure_origin[0] and secure_origin[0] != "*":
+                continue
+
+            try:
+                # We need to do this decode dance to ensure that we have a
+                # unicode object, even on Python 2.x.
+                addr = ipaddress.ip_address(
+                    origin[1]
+                    if (
+                        isinstance(origin[1], six.text_type) or
+                        origin[1] is None
+                    )
+                    else origin[1].decode("utf8")
+                )
+                network = ipaddress.ip_network(
+                    secure_origin[1]
+                    if isinstance(secure_origin[1], six.text_type)
+                    # setting secure_origin[1] to proper Union[bytes, str]
+                    # creates problems in other places
+                    else secure_origin[1].decode("utf8")  # type: ignore
+                )
+            except ValueError:
+                # We don't have both a valid address or a valid network, so
+                # we'll check this origin against hostnames.
+                if (origin[1] and
+                        origin[1].lower() != secure_origin[1].lower() and
+                        secure_origin[1] != "*"):
+                    continue
+            else:
+                # We have a valid address and network, so see if the address
+                # is contained within the network.
+                if addr not in network:
+                    continue
+
+            # Check to see if the port patches
+            if (origin[2] != secure_origin[2] and
+                    secure_origin[2] != "*" and
+                    secure_origin[2] is not None):
+                continue
+
+            # If we've gotten here, then this origin matches the current
+            # secure origin and we should return True
+            return True
+
+        # If we've gotten to this point, then the origin isn't secure and we
+        # will not accept it as a valid location to search. We will however
+        # log a warning that we are ignoring it.
+        logger.warning(
+            "The repository located at %s is not a trusted or secure host and "
+            "is being ignored. If this repository is available via HTTPS we "
+            "recommend you use HTTPS instead, otherwise you may silence "
+            "this warning and allow it anyway with '--trusted-host %s'.",
+            parsed.hostname,
+            parsed.hostname,
+        )
+
+        return False
+
+    def _get_index_urls_locations(self, project_name):
+        # type: (str) -> List[str]
+        """Returns the locations found via self.index_urls
+
+        Checks the url_name on the main (first in the list) index and
+        use this url_name to produce all locations
+        """
+
+        def mkurl_pypi_url(url):
+            loc = posixpath.join(
+                url,
+                urllib_parse.quote(canonicalize_name(project_name)))
+            # For maximum compatibility with easy_install, ensure the path
+            # ends in a trailing slash.  Although this isn't in the spec
+            # (and PyPI can handle it without the slash) some other index
+            # implementations might break if they relied on easy_install's
+            # behavior.
+            if not loc.endswith('/'):
+                loc = loc + '/'
+            return loc
+
+        return [mkurl_pypi_url(url) for url in self.index_urls]
+
+    def find_all_candidates(self, project_name):
+        # type: (str) -> List[Optional[InstallationCandidate]]
+        """Find all available InstallationCandidate for project_name
+
+        This checks index_urls and find_links.
+        All versions found are returned as an InstallationCandidate list.
+
+        See _link_package_versions for details on which files are accepted
+        """
+        index_locations = self._get_index_urls_locations(project_name)
+        index_file_loc, index_url_loc = self._sort_locations(index_locations)
+        fl_file_loc, fl_url_loc = self._sort_locations(
+            self.find_links, expand_dir=True,
+        )
+
+        file_locations = (Link(url) for url in itertools.chain(
+            index_file_loc, fl_file_loc,
+        ))
+
+        # We trust every url that the user has given us whether it was given
+        #   via --index-url or --find-links.
+        # We want to filter out any thing which does not have a secure origin.
+        url_locations = [
+            link for link in itertools.chain(
+                (Link(url) for url in index_url_loc),
+                (Link(url) for url in fl_url_loc),
+            )
+            if self._validate_secure_origin(logger, link)
+        ]
+
+        logger.debug('%d location(s) to search for versions of %s:',
+                     len(url_locations), project_name)
+
+        for location in url_locations:
+            logger.debug('* %s', location)
+
+        canonical_name = canonicalize_name(project_name)
+        formats = self.format_control.get_allowed_formats(canonical_name)
+        search = Search(project_name, canonical_name, formats)
+        find_links_versions = self._package_versions(
+            # We trust every directly linked archive in find_links
+            (Link(url, '-f') for url in self.find_links),
+            search
+        )
+
+        page_versions = []
+        for page in self._get_pages(url_locations, project_name):
+            logger.debug('Analyzing links from page %s', page.url)
+            with indent_log():
+                page_versions.extend(
+                    self._package_versions(page.iter_links(), search)
+                )
+
+        file_versions = self._package_versions(file_locations, search)
+        if file_versions:
+            file_versions.sort(reverse=True)
+            logger.debug(
+                'Local files found: %s',
+                ', '.join([
+                    url_to_path(candidate.location.url)
+                    for candidate in file_versions
+                ])
+            )
+
+        # This is an intentional priority ordering
+        return file_versions + find_links_versions + page_versions
+
+    def find_candidates(
+        self,
+        project_name,       # type: str
+        specifier=None,     # type: Optional[specifiers.BaseSpecifier]
+    ):
+        """Find matches for the given project and specifier.
+
+        If given, `specifier` should implement `filter` to allow version
+        filtering (e.g. ``packaging.specifiers.SpecifierSet``).
+
+        Returns a `FoundCandidates` instance.
+        """
+        if specifier is None:
+            specifier = specifiers.SpecifierSet()
+        return FoundCandidates.from_specifier(
+            self.find_all_candidates(project_name),
+            specifier=specifier,
+            prereleases=(self.allow_all_prereleases or None),
+            evaluator=self.candidate_evaluator,
+        )
+
+    def find_requirement(self, req, upgrade):
+        # type: (InstallRequirement, bool) -> Optional[Link]
+        """Try to find a Link matching req
+
+        Expects req, an InstallRequirement and upgrade, a boolean
+        Returns a Link if found,
+        Raises DistributionNotFound or BestVersionAlreadyInstalled otherwise
+        """
+        candidates = self.find_candidates(req.name, req.specifier)
+        best_candidate = candidates.get_best()
+
+        installed_version = None    # type: Optional[_BaseVersion]
+        if req.satisfied_by is not None:
+            installed_version = parse_version(req.satisfied_by.version)
+
+        def _format_versions(cand_iter):
+            # This repeated parse_version and str() conversion is needed to
+            # handle different vendoring sources from pip and pkg_resources.
+            # If we stop using the pkg_resources provided specifier and start
+            # using our own, we can drop the cast to str().
+            return ", ".join(sorted(
+                {str(c.version) for c in cand_iter},
+                key=parse_version,
+            )) or "none"
+
+        if installed_version is None and best_candidate is None:
+            logger.critical(
+                'Could not find a version that satisfies the requirement %s '
+                '(from versions: %s)',
+                req,
+                _format_versions(candidates.iter_all()),
+            )
+
+            raise DistributionNotFound(
+                'No matching distribution found for %s' % req
+            )
+
+        best_installed = False
+        if installed_version and (
+                best_candidate is None or
+                best_candidate.version <= installed_version):
+            best_installed = True
+
+        if not upgrade and installed_version is not None:
+            if best_installed:
+                logger.debug(
+                    'Existing installed version (%s) is most up-to-date and '
+                    'satisfies requirement',
+                    installed_version,
+                )
+            else:
+                logger.debug(
+                    'Existing installed version (%s) satisfies requirement '
+                    '(most up-to-date version is %s)',
+                    installed_version,
+                    best_candidate.version,
+                )
+            return None
+
+        if best_installed:
+            # We have an existing version, and its the best version
+            logger.debug(
+                'Installed version (%s) is most up-to-date (past versions: '
+                '%s)',
+                installed_version,
+                _format_versions(candidates.iter_applicable()),
+            )
+            raise BestVersionAlreadyInstalled
+
+        logger.debug(
+            'Using version %s (newest of versions: %s)',
+            best_candidate.version,
+            _format_versions(candidates.iter_applicable()),
+        )
+        return best_candidate.location
+
+    def _get_pages(self, locations, project_name):
+        # type: (Iterable[Link], str) -> Iterable[HTMLPage]
+        """
+        Yields (page, page_url) from the given locations, skipping
+        locations that have errors.
+        """
+        seen = set()  # type: Set[Link]
+        for location in locations:
+            if location in seen:
+                continue
+            seen.add(location)
+
+            page = _get_html_page(location, session=self.session)
+            if page is None:
+                continue
+
+            yield page
+
+    _py_version_re = re.compile(r'-py([123]\.?[0-9]?)$')
+
+    def _sort_links(self, links):
+        # type: (Iterable[Link]) -> List[Link]
+        """
+        Returns elements of links in order, non-egg links first, egg links
+        second, while eliminating duplicates
+        """
+        eggs, no_eggs = [], []
+        seen = set()  # type: Set[Link]
+        for link in links:
+            if link not in seen:
+                seen.add(link)
+                if link.egg_fragment:
+                    eggs.append(link)
+                else:
+                    no_eggs.append(link)
+        return no_eggs + eggs
+
+    def _package_versions(
+        self,
+        links,  # type: Iterable[Link]
+        search  # type: Search
+    ):
+        # type: (...) -> List[Optional[InstallationCandidate]]
+        result = []
+        for link in self._sort_links(links):
+            v = self._link_package_versions(link, search)
+            if v is not None:
+                result.append(v)
+        return result
+
+    def _log_skipped_link(self, link, reason):
+        # type: (Link, str) -> None
+        if link not in self.logged_links:
+            logger.debug('Skipping link %s; %s', link, reason)
+            self.logged_links.add(link)
+
+    def _link_package_versions(self, link, search):
+        # type: (Link, Search) -> Optional[InstallationCandidate]
+        """Return an InstallationCandidate or None"""
+        version = None
+        if link.egg_fragment:
+            egg_info = link.egg_fragment
+            ext = link.ext
+        else:
+            egg_info, ext = link.splitext()
+            if not ext:
+                self._log_skipped_link(link, 'not a file')
+                return None
+            if ext not in SUPPORTED_EXTENSIONS:
+                self._log_skipped_link(
+                    link, 'unsupported archive format: %s' % ext,
+                )
+                return None
+            if "binary" not in search.formats and ext == WHEEL_EXTENSION:
+                self._log_skipped_link(
+                    link, 'No binaries permitted for %s' % search.supplied,
+                )
+                return None
+            if "macosx10" in link.path and ext == '.zip':
+                self._log_skipped_link(link, 'macosx10 one')
+                return None
+            if ext == WHEEL_EXTENSION:
+                try:
+                    wheel = Wheel(link.filename)
+                except InvalidWheelFilename:
+                    self._log_skipped_link(link, 'invalid wheel filename')
+                    return None
+                if canonicalize_name(wheel.name) != search.canonical:
+                    self._log_skipped_link(
+                        link, 'wrong project name (not %s)' % search.supplied)
+                    return None
+
+                if not self.candidate_evaluator.is_wheel_supported(wheel):
+                    self._log_skipped_link(
+                        link, 'it is not compatible with this Python')
+                    return None
+
+                version = wheel.version
+
+        # This should be up by the search.ok_binary check, but see issue 2700.
+        if "source" not in search.formats and ext != WHEEL_EXTENSION:
+            self._log_skipped_link(
+                link, 'No sources permitted for %s' % search.supplied,
+            )
+            return None
+
+        if not version:
+            version = _egg_info_matches(egg_info, search.canonical)
+        if not version:
+            self._log_skipped_link(
+                link, 'Missing project version for %s' % search.supplied)
+            return None
+
+        match = self._py_version_re.search(version)
+        if match:
+            version = version[:match.start()]
+            py_version = match.group(1)
+            if py_version != sys.version[:3]:
+                self._log_skipped_link(
+                    link, 'Python version is incorrect')
+                return None
+        try:
+            support_this_python = check_requires_python(link.requires_python)
+        except specifiers.InvalidSpecifier:
+            logger.debug("Package %s has an invalid Requires-Python entry: %s",
+                         link.filename, link.requires_python)
+            support_this_python = True
+
+        if not support_this_python:
+            logger.debug("The package %s is incompatible with the python "
+                         "version in use. Acceptable python versions are: %s",
+                         link, link.requires_python)
+            return None
+        logger.debug('Found link %s, version: %s', link, version)
+
+        return InstallationCandidate(search.supplied, version, link)
+
+
+def _find_name_version_sep(egg_info, canonical_name):
+    # type: (str, str) -> int
+    """Find the separator's index based on the package's canonical name.
+
+    `egg_info` must be an egg info string for the given package, and
+    `canonical_name` must be the package's canonical name.
+
+    This function is needed since the canonicalized name does not necessarily
+    have the same length as the egg info's name part. An example::
+
+    >>> egg_info = 'foo__bar-1.0'
+    >>> canonical_name = 'foo-bar'
+    >>> _find_name_version_sep(egg_info, canonical_name)
+    8
+    """
+    # Project name and version must be separated by one single dash. Find all
+    # occurrences of dashes; if the string in front of it matches the canonical
+    # name, this is the one separating the name and version parts.
+    for i, c in enumerate(egg_info):
+        if c != "-":
+            continue
+        if canonicalize_name(egg_info[:i]) == canonical_name:
+            return i
+    raise ValueError("{} does not match {}".format(egg_info, canonical_name))
+
+
+def _egg_info_matches(egg_info, canonical_name):
+    # type: (str, str) -> Optional[str]
+    """Pull the version part out of a string.
+
+    :param egg_info: The string to parse. E.g. foo-2.1
+    :param canonical_name: The canonicalized name of the package this
+        belongs to.
+    """
+    try:
+        version_start = _find_name_version_sep(egg_info, canonical_name) + 1
+    except ValueError:
+        return None
+    version = egg_info[version_start:]
+    if not version:
+        return None
+    return version
+
+
+def _determine_base_url(document, page_url):
+    """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 _get_encoding_from_headers(headers):
+    """Determine if we have any encoding information in our headers.
+    """
+    if headers and "Content-Type" in headers:
+        content_type, params = cgi.parse_header(headers["Content-Type"])
+        if "charset" in params:
+            return params['charset']
+    return None
+
+
+def _clean_link(url):
+    # type: (str) -> str
+    """Makes sure a link is fully encoded.  That is, if a ' ' shows up in
+    the link, it will be rewritten to %20 (while not over-quoting
+    % or other characters)."""
+    # Split the URL into parts according to the general structure
+    # `scheme://netloc/path;parameters?query#fragment`. Note that the
+    # `netloc` can be empty and the URI will then refer to a local
+    # filesystem path.
+    result = urllib_parse.urlparse(url)
+    # In both cases below we unquote prior to quoting to make sure
+    # nothing is double quoted.
+    if result.netloc == "":
+        # On Windows the path part might contain a drive letter which
+        # should not be quoted. On Linux where drive letters do not
+        # exist, the colon should be quoted. We rely on urllib.request
+        # to do the right thing here.
+        path = urllib_request.pathname2url(
+            urllib_request.url2pathname(result.path))
+    else:
+        path = urllib_parse.quote(urllib_parse.unquote(result.path))
+    return urllib_parse.urlunparse(result._replace(path=path))
+
+
+class HTMLPage(object):
+    """Represents one page, along with its URL"""
+
+    def __init__(self, content, url, headers=None):
+        # type: (bytes, str, MutableMapping[str, str]) -> None
+        self.content = content
+        self.url = url
+        self.headers = headers
+
+    def __str__(self):
+        return redact_password_from_url(self.url)
+
+    def iter_links(self):
+        # type: () -> Iterable[Link]
+        """Yields all links in the page"""
+        document = html5lib.parse(
+            self.content,
+            transport_encoding=_get_encoding_from_headers(self.headers),
+            namespaceHTMLElements=False,
+        )
+        base_url = _determine_base_url(document, self.url)
+        for anchor in document.findall(".//a"):
+            if anchor.get("href"):
+                href = anchor.get("href")
+                url = _clean_link(urllib_parse.urljoin(base_url, href))
+                pyrequire = anchor.get('data-requires-python')
+                pyrequire = unescape(pyrequire) if pyrequire else None
+                yield Link(url, self.url, requires_python=pyrequire)
+
+
+Search = namedtuple('Search', 'supplied canonical formats')
+"""Capture key aspects of a search.
+
+:attribute supplied: The user supplied package.
+:attribute canonical: The canonical package name.
+:attribute formats: The formats allowed for this package. Should be a set
+    with 'binary' or 'source' or both in it.
+"""
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/index.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/index.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..de3710366f824665a76bd9b5e94ed1c294e4912f
GIT binary patch
literal 36261
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
bVxD6E8U8aka7u9saSC&CaY~5E@v{Q}&Rv}u

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/locations.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/locations.py
new file mode 100644
index 0000000..10860f7
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/locations.py
@@ -0,0 +1,211 @@
+"""Locations where we look for configs, install stuff, etc"""
+from __future__ import absolute_import
+
+import os
+import os.path
+import platform
+import site
+import sys
+import sysconfig
+from distutils import sysconfig as distutils_sysconfig
+from distutils.command.install import SCHEME_KEYS  # type: ignore
+
+from pip._internal.utils import appdirs
+from pip._internal.utils.compat import WINDOWS, expanduser
+from pip._internal.utils.typing import MYPY_CHECK_RUNNING
+
+if MYPY_CHECK_RUNNING:
+    from typing import Any, Union, Dict, List, Optional
+
+
+# Application Directories
+USER_CACHE_DIR = appdirs.user_cache_dir("pip")
+
+
+DELETE_MARKER_MESSAGE = '''\
+This file is placed here by pip to indicate the source was put
+here by pip.
+
+Once this package is successfully installed this source code will be
+deleted (unless you remove this file).
+'''
+PIP_DELETE_MARKER_FILENAME = 'pip-delete-this-directory.txt'
+
+
+def write_delete_marker_file(directory):
+    # type: (str) -> None
+    """
+    Write the pip delete marker file into this directory.
+    """
+    filepath = os.path.join(directory, PIP_DELETE_MARKER_FILENAME)
+    with open(filepath, 'w') as marker_fp:
+        marker_fp.write(DELETE_MARKER_MESSAGE)
+
+
+def running_under_virtualenv():
+    # type: () -> bool
+    """
+    Return True if we're running inside a virtualenv, False otherwise.
+
+    """
+    if hasattr(sys, 'real_prefix'):
+        return True
+    elif sys.prefix != getattr(sys, "base_prefix", sys.prefix):
+        return True
+
+    return False
+
+
+def virtualenv_no_global():
+    # type: () -> bool
+    """
+    Return True if in a venv and no system site packages.
+    """
+    # this mirrors the logic in virtualenv.py for locating the
+    # no-global-site-packages.txt file
+    site_mod_dir = os.path.dirname(os.path.abspath(site.__file__))
+    no_global_file = os.path.join(site_mod_dir, 'no-global-site-packages.txt')
+    if running_under_virtualenv() and os.path.isfile(no_global_file):
+        return True
+    else:
+        return False
+
+
+if running_under_virtualenv():
+    src_prefix = os.path.join(sys.prefix, 'src')
+else:
+    # FIXME: keep src in cwd for now (it is not a temporary folder)
+    try:
+        src_prefix = os.path.join(os.getcwd(), 'src')
+    except OSError:
+        # In case the current working directory has been renamed or deleted
+        sys.exit(
+            "The folder you are executing pip from can no longer be found."
+        )
+
+# under macOS + virtualenv sys.prefix is not properly resolved
+# it is something like /path/to/python/bin/..
+# Note: using realpath due to tmp dirs on OSX being symlinks
+src_prefix = os.path.abspath(src_prefix)
+
+# FIXME doesn't account for venv linked to global site-packages
+
+site_packages = sysconfig.get_path("purelib")  # type: Optional[str]
+
+# This is because of a bug in PyPy's sysconfig module, see
+# https://bitbucket.org/pypy/pypy/issues/2506/sysconfig-returns-incorrect-paths
+# for more information.
+if platform.python_implementation().lower() == "pypy":
+    site_packages = distutils_sysconfig.get_python_lib()
+try:
+    # Use getusersitepackages if this is present, as it ensures that the
+    # value is initialised properly.
+    user_site = site.getusersitepackages()
+except AttributeError:
+    user_site = site.USER_SITE
+user_dir = expanduser('~')
+if WINDOWS:
+    bin_py = os.path.join(sys.prefix, 'Scripts')
+    bin_user = os.path.join(user_site, 'Scripts')
+    # buildout uses 'bin' on Windows too?
+    if not os.path.exists(bin_py):
+        bin_py = os.path.join(sys.prefix, 'bin')
+        bin_user = os.path.join(user_site, 'bin')
+
+    config_basename = 'pip.ini'
+
+    legacy_storage_dir = os.path.join(user_dir, 'pip')
+    legacy_config_file = os.path.join(
+        legacy_storage_dir,
+        config_basename,
+    )
+else:
+    bin_py = os.path.join(sys.prefix, 'bin')
+    bin_user = os.path.join(user_site, 'bin')
+
+    config_basename = 'pip.conf'
+
+    legacy_storage_dir = os.path.join(user_dir, '.pip')
+    legacy_config_file = os.path.join(
+        legacy_storage_dir,
+        config_basename,
+    )
+    # Forcing to use /usr/local/bin for standard macOS framework installs
+    # Also log to ~/Library/Logs/ for use with the Console.app log viewer
+    if sys.platform[:6] == 'darwin' and sys.prefix[:16] == '/System/Library/':
+        bin_py = '/usr/local/bin'
+
+global_config_files = [
+    os.path.join(path, config_basename)
+    for path in appdirs.site_config_dirs('pip')
+]
+
+site_config_file = os.path.join(sys.prefix, config_basename)
+new_config_file = os.path.join(appdirs.user_config_dir("pip"), config_basename)
+
+
+def distutils_scheme(dist_name, user=False, home=None, root=None,
+                     isolated=False, prefix=None):
+    # type:(str, bool, str, str, bool, str) -> dict
+    """
+    Return a distutils install scheme
+    """
+    from distutils.dist import Distribution
+
+    scheme = {}
+
+    if isolated:
+        extra_dist_args = {"script_args": ["--no-user-cfg"]}
+    else:
+        extra_dist_args = {}
+    dist_args = {'name': dist_name}  # type: Dict[str, Union[str, List[str]]]
+    dist_args.update(extra_dist_args)
+
+    d = Distribution(dist_args)
+    # Ignoring, typeshed issue reported python/typeshed/issues/2567
+    d.parse_config_files()
+    # NOTE: Ignoring type since mypy can't find attributes on 'Command'
+    i = d.get_command_obj('install', create=True)  # type: Any
+    assert i is not None
+    # NOTE: setting user or home has the side-effect of creating the home dir
+    # or user base for installations during finalize_options()
+    # ideally, we'd prefer a scheme class that has no side-effects.
+    assert not (user and prefix), "user={} prefix={}".format(user, prefix)
+    i.user = user or i.user
+    if user:
+        i.prefix = ""
+    i.prefix = prefix or i.prefix
+    i.home = home or i.home
+    i.root = root or i.root
+    i.finalize_options()
+    for key in SCHEME_KEYS:
+        scheme[key] = getattr(i, 'install_' + key)
+
+    # install_lib specified in setup.cfg should install *everything*
+    # into there (i.e. it takes precedence over both purelib and
+    # platlib).  Note, i.install_lib is *always* set after
+    # finalize_options(); we only want to override here if the user
+    # has explicitly requested it hence going back to the config
+
+    # Ignoring, typeshed issue reported python/typeshed/issues/2567
+    if 'install_lib' in d.get_option_dict('install'):  # type: ignore
+        scheme.update(dict(purelib=i.install_lib, platlib=i.install_lib))
+
+    if running_under_virtualenv():
+        scheme['headers'] = os.path.join(
+            sys.prefix,
+            'include',
+            'site',
+            'python' + sys.version[:3],
+            dist_name,
+        )
+
+        if root is not None:
+            path_no_drive = os.path.splitdrive(
+                os.path.abspath(scheme["headers"]))[1]
+            scheme["headers"] = os.path.join(
+                root,
+                path_no_drive[1:],
+            )
+
+    return scheme
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/locations.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/locations.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..685ae8b3e6d6911e15ba0d40388509c66e86b891
GIT binary patch
literal 5685
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

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/models/__init__.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/models/__init__.py
new file mode 100644
index 0000000..7855226
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/models/__init__.py
@@ -0,0 +1,2 @@
+"""A package that contains models that represent entities.
+"""
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/models/__init__.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/models/__init__.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..5b73c8e3e48ade4f2e565b5ebaf8a9791ad61d51
GIT binary patch
literal 278
zcmZSn%**AGdLky70SXuy7#JKF7#NDV7#J8*7#N}$7*ZG+f;E^xVipVx42}u~iOJcC
z>8T1O8Hptd$@zIDiJ5uD3c2|ysX4_E!J^cHqSWHlyb^`fypqh4%+z8%E<X*B(IxB*
z3=Hw{Df!9q@fsj25kzqT0|SG8K~ZK|Vo9ogSz?iXT7FJSYEiL%Qi^_gQc_;7X>PHR
zVUl@zRl0?#MR`tEm6-tur03~}=oe%b=w{{>mn7!o=(?48cp3+QgupmHGp{7IC@(Qb
lAL2&+`1s7c%#!$cy@JXT4h9AWo80`A(wtN~updE=0s!w3OS}L8

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/models/candidate.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/models/candidate.py
new file mode 100644
index 0000000..b66c365
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/models/candidate.py
@@ -0,0 +1,31 @@
+from pip._vendor.packaging.version import parse as parse_version
+
+from pip._internal.utils.models import KeyBasedCompareMixin
+from pip._internal.utils.typing import MYPY_CHECK_RUNNING
+
+if MYPY_CHECK_RUNNING:
+    from pip._vendor.packaging.version import _BaseVersion
+    from pip._internal.models.link import Link
+    from typing import Any
+
+
+class InstallationCandidate(KeyBasedCompareMixin):
+    """Represents a potential "candidate" for installation.
+    """
+
+    def __init__(self, project, version, location):
+        # type: (Any, str, Link) -> None
+        self.project = project
+        self.version = parse_version(version)  # type: _BaseVersion
+        self.location = location
+
+        super(InstallationCandidate, self).__init__(
+            key=(self.project, self.version, self.location),
+            defining_class=InstallationCandidate
+        )
+
+    def __repr__(self):
+        # type: () -> str
+        return "<InstallationCandidate({!r}, {!r}, {!r})>".format(
+            self.project, self.version, self.location,
+        )
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/models/candidate.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/models/candidate.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..6b7e22f4286edc60c3432ab28b36e0683bf6f820
GIT binary patch
literal 1709
zcmZSn%**AGdLky70ScHI7#JKF7#ND185kH+7#LC*8FCmHav2$-m>3vAd?tn*W`<lA
zhA0*YpP3<tl_8gnA&QNGF_n#>C=;xU1+0smA&MQMij^UUgCUobA&L{iXJg3WV#wuY
zh~j2o%wu3kVP{BXVMt?SNa0{;VPI%xV2F(3VMyU*2-e_YU|`7n|NsAg4MqkAh7wi=
z28M#fqT*BtSA>Cq!8^6mDX};;#W_E>Ah9UbH?tx$4<akXz`)=e84wxo?BVL{9Um0x
z=jZ9?4w2(wU|@&`=?hCOD$dM@>R@4DVDQPz%Z8`{1%_i@Wr-*Q1A}K?aY<rMPGU)B
zex7q;UP@+4Vo54I*g$S`0tK4_0|P@U149%eC>WxcK;hTIz!1gEkirD=SriLHP_PEb
z++s@x28N*2f}+&o)Vz{ng+zsd{F2nXlFY;$1*K$|1xgBO`9%tuNOtRSDJUo?B!e6Z
z!l3YQ23Z`&z`#($$WX(;5YNC+!pKm=#Lx`kGBMOJgT<K{N?1T4Si`{3%*2qz269{t
z149-ANH&WJOfoa1f!$id%FxWf1d4HpbNxy{j?PZ4Ea3wsjMTKuyv)4x_~e|#;$jVU
zP|Sdcf};Ga)Z~&9URW%}mq9|e1SAV%b1*P4<m4xVgAyE}#ia$QML}#JQ$TX@@tJv<
zCGqhZAP<&+h~m_ov>;AUfN_HeP~2&N5-gY~E@WU}&@U*;EK4j&)h|md(of6JNl7g#
z)=x^&FHcI!%Qej{HZn{yPp?Y1FtsSp$*M9l0D<&8{Sf_v%mQ6#`0Bcqd3YKJfP}y}
zJ~OW*wJ0w!M?W_|B{ip5A091w1(iXda1a26JjgW+Oq`7TjGRnDj1r8=pu_;eAeV#V
zMg|mQjIe-a1P3%MxSN?7f;E^J7#RGDH5nKfY_O&?jcUcBS{(%hsc8oZ98j30<rn29
zmY@d@$N@q83=9n5Fai?;6Hq0PC@o4YD2k7l1_c->To{<x7&SnN7b=~Xn420OU%~~-
zmGQaxDWy3eE-2N+$EV~c$H#-iJ4g`4Lj&k5aB2m`d@(2r*qGRuIJx~aK<U0j7L@oi
z3-sd4Qu9*si}VT-ld}`kGxO5*pcx<tlyrkYUM-P=sf8sqz0#7*oMJslf(rsgB2G0W
zl?9o3=|P~h69mefC6XA1L5$JM$;`_R0)=`B$gxm;puh+F0vw76VgOT#4J6|2K;A9}
T=PxD!Mgb-^Mgc|vMqy?EpNy5D

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/models/format_control.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/models/format_control.py
new file mode 100644
index 0000000..53138e4
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/models/format_control.py
@@ -0,0 +1,73 @@
+from pip._vendor.packaging.utils import canonicalize_name
+
+from pip._internal.utils.typing import MYPY_CHECK_RUNNING
+
+if MYPY_CHECK_RUNNING:
+    from typing import Optional, Set, FrozenSet
+
+
+class FormatControl(object):
+    """Helper for managing formats from which a package can be installed.
+    """
+
+    def __init__(self, no_binary=None, only_binary=None):
+        # type: (Optional[Set], Optional[Set]) -> None
+        if no_binary is None:
+            no_binary = set()
+        if only_binary is None:
+            only_binary = set()
+
+        self.no_binary = no_binary
+        self.only_binary = only_binary
+
+    def __eq__(self, other):
+        return self.__dict__ == other.__dict__
+
+    def __ne__(self, other):
+        return not self.__eq__(other)
+
+    def __repr__(self):
+        return "{}({}, {})".format(
+            self.__class__.__name__,
+            self.no_binary,
+            self.only_binary
+        )
+
+    @staticmethod
+    def handle_mutual_excludes(value, target, other):
+        # type: (str, Optional[Set], Optional[Set]) -> None
+        new = value.split(',')
+        while ':all:' in new:
+            other.clear()
+            target.clear()
+            target.add(':all:')
+            del new[:new.index(':all:') + 1]
+            # Without a none, we want to discard everything as :all: covers it
+            if ':none:' not in new:
+                return
+        for name in new:
+            if name == ':none:':
+                target.clear()
+                continue
+            name = canonicalize_name(name)
+            other.discard(name)
+            target.add(name)
+
+    def get_allowed_formats(self, canonical_name):
+        # type: (str) -> FrozenSet
+        result = {"binary", "source"}
+        if canonical_name in self.only_binary:
+            result.discard('source')
+        elif canonical_name in self.no_binary:
+            result.discard('binary')
+        elif ':all:' in self.only_binary:
+            result.discard('source')
+        elif ':all:' in self.no_binary:
+            result.discard('binary')
+        return frozenset(result)
+
+    def disallow_binaries(self):
+        # type: () -> None
+        self.handle_mutual_excludes(
+            ':all:', self.no_binary, self.only_binary,
+        )
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/models/format_control.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/models/format_control.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..141f5e5aa71dbbf5c88f586fb687a7524638b383
GIT binary patch
literal 3380
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

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/models/index.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/models/index.py
new file mode 100644
index 0000000..ead1efb
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/models/index.py
@@ -0,0 +1,31 @@
+from pip._vendor.six.moves.urllib import parse as urllib_parse
+
+
+class PackageIndex(object):
+    """Represents a Package Index and provides easier access to endpoints
+    """
+
+    def __init__(self, url, file_storage_domain):
+        # type: (str, str) -> None
+        super(PackageIndex, self).__init__()
+        self.url = url
+        self.netloc = urllib_parse.urlsplit(url).netloc
+        self.simple_url = self._url_for_path('simple')
+        self.pypi_url = self._url_for_path('pypi')
+
+        # This is part of a temporary hack used to block installs of PyPI
+        # packages which depend on external urls only necessary until PyPI can
+        # block such packages themselves
+        self.file_storage_domain = file_storage_domain
+
+    def _url_for_path(self, path):
+        # type: (str) -> str
+        return urllib_parse.urljoin(self.url, path)
+
+
+PyPI = PackageIndex(
+    'https://pypi.org/', file_storage_domain='files.pythonhosted.org'
+)
+TestPyPI = PackageIndex(
+    'https://test.pypi.org/', file_storage_domain='test-files.pythonhosted.org'
+)
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/models/index.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/models/index.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..14c2220be2a37f7c1682484a0b6f554f231bf733
GIT binary patch
literal 1555
zcmZSn%**AGdLky70SZ_c7#JKF7#NEE7#J8*7#LC*8FCmHav2$-m>3vSm>5!-8PXUT
zQkWT97#Nxv7$T!s7*bgnQdk&LSQ%2-7@8RwqgcTr>|hZNum~GN3MWIb1{VVZL+1bg
z|Nm<+GB7Zdure?(6eJcEr<U+AFfarpCTAz6r+Vh4q*lOP15)P%a*YB514AkULlh&(
zO;JoBXSFaeL@_g@Fo9eW#ljF2ticRY>CV8w5R_U_lv<pcS5mByr~oxs0c^5DVqS_u
zK~a8LW=d+YLTX}hW@?c_Vsdh7aj`;4zCvnVN<n^RUP&>Rf`WoVGRQy}b_N-q1adb6
zLkS~84Ff|n6GIjgC=eKH!2Eb-h7uNrELMgZMuuiahAcLaqIfWw#SU_DGej8&NE{@>
z1X5PRz!1;LP{RZgjOPM*58@HO5;l;HnYjfysU@ITDX1*S)Zhj=02FY=r3I-)L7?y{
z;b353h>y?A%PfhHF9A8Xv?vE0q@_hUIhjfEkT3?RDlN(>F38C&0UMo{T9T8WT*3>|
zU0ReApO#+~UyxXmQNjhcHy&gXNF&H@Fh`hyfgvq3CpEsfB)=#zJvBZhKQ}Qm4;=Jh
zR~Dz{qy>Ro9t1L21C*-3L~$+y1A~4+QD#|UNveKXVv&AYeojhiQL%nfihg-gQeLiU
zZn2SJl6iVnx`nAlc}`Z9nE?o-=jn&&7i1RbX66-_B<AGkx|Ml&8V7)cz&JiLuOzi7
zFEK|yH$Npcr&vD|l!EjMDuY151af>aD0wk32{UpsiZTi@3b7_LF)%QIFetFV@e1-*
z2?IkGBPbTKn7}c}#1ITlr+#411+jxd9z>KD<z(e&=7Bw_0Wu|s4<rSSqQsI6uy4V{
z0C*V`b)ul?1G$TVNdpuF(Dad)n420O502dU_}u)I(i{*M<e~WZl>FrQcyM?HflL6q
z9zhI%KS1dk6rjbRl*Gow#>B~6EXcsXkWo@nP;8~I4@!@E`9<ma;8a#D22GX4dIgmw
z8Tok``NbuvDIf)4DVVO3)Z!97xYlB6P_(5Mm*|2LG^SQR4N%~e$bd?z%mTgmvedkk
z{35;L%nH5S{Ib+yJxKNn0wr-s>Hs-5KPf9Uxdf6iK|Tnm4DbZUKuBtF35bITS1^nI
cfeUtx4I~BFfdaZ16z2lWVq(mU{7lS@08FTQZvX%Q

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/models/link.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/models/link.py
new file mode 100644
index 0000000..2f42076
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/models/link.py
@@ -0,0 +1,163 @@
+import posixpath
+import re
+
+from pip._vendor.six.moves.urllib import parse as urllib_parse
+
+from pip._internal.download import path_to_url
+from pip._internal.utils.misc import (
+    WHEEL_EXTENSION, redact_password_from_url, splitext,
+)
+from pip._internal.utils.models import KeyBasedCompareMixin
+from pip._internal.utils.typing import MYPY_CHECK_RUNNING
+
+if MYPY_CHECK_RUNNING:
+    from typing import Optional, Tuple, Union
+    from pip._internal.index import HTMLPage
+
+
+class Link(KeyBasedCompareMixin):
+    """Represents a parsed link from a Package Index's simple URL
+    """
+
+    def __init__(self, url, comes_from=None, requires_python=None):
+        # type: (str, Optional[Union[str, HTMLPage]], Optional[str]) -> None
+        """
+        url:
+            url of the resource pointed to (href of the link)
+        comes_from:
+            instance of HTMLPage where the link was found, or string.
+        requires_python:
+            String containing the `Requires-Python` metadata field, specified
+            in PEP 345. This may be specified by a data-requires-python
+            attribute in the HTML link tag, as described in PEP 503.
+        """
+
+        # url can be a UNC windows share
+        if url.startswith('\\\\'):
+            url = path_to_url(url)
+
+        self.url = url
+        self.comes_from = comes_from
+        self.requires_python = requires_python if requires_python else None
+
+        super(Link, self).__init__(
+            key=(self.url),
+            defining_class=Link
+        )
+
+    def __str__(self):
+        if self.requires_python:
+            rp = ' (requires-python:%s)' % self.requires_python
+        else:
+            rp = ''
+        if self.comes_from:
+            return '%s (from %s)%s' % (redact_password_from_url(self.url),
+                                       self.comes_from, rp)
+        else:
+            return redact_password_from_url(str(self.url))
+
+    def __repr__(self):
+        return '<Link %s>' % self
+
+    @property
+    def filename(self):
+        # type: () -> str
+        _, netloc, path, _, _ = urllib_parse.urlsplit(self.url)
+        name = posixpath.basename(path.rstrip('/')) or netloc
+        name = urllib_parse.unquote(name)
+        assert name, ('URL %r produced no filename' % self.url)
+        return name
+
+    @property
+    def scheme(self):
+        # type: () -> str
+        return urllib_parse.urlsplit(self.url)[0]
+
+    @property
+    def netloc(self):
+        # type: () -> str
+        return urllib_parse.urlsplit(self.url)[1]
+
+    @property
+    def path(self):
+        # type: () -> str
+        return urllib_parse.unquote(urllib_parse.urlsplit(self.url)[2])
+
+    def splitext(self):
+        # type: () -> Tuple[str, str]
+        return splitext(posixpath.basename(self.path.rstrip('/')))
+
+    @property
+    def ext(self):
+        # type: () -> str
+        return self.splitext()[1]
+
+    @property
+    def url_without_fragment(self):
+        # type: () -> str
+        scheme, netloc, path, query, fragment = urllib_parse.urlsplit(self.url)
+        return urllib_parse.urlunsplit((scheme, netloc, path, query, None))
+
+    _egg_fragment_re = re.compile(r'[#&]egg=([^&]*)')
+
+    @property
+    def egg_fragment(self):
+        # type: () -> Optional[str]
+        match = self._egg_fragment_re.search(self.url)
+        if not match:
+            return None
+        return match.group(1)
+
+    _subdirectory_fragment_re = re.compile(r'[#&]subdirectory=([^&]*)')
+
+    @property
+    def subdirectory_fragment(self):
+        # type: () -> Optional[str]
+        match = self._subdirectory_fragment_re.search(self.url)
+        if not match:
+            return None
+        return match.group(1)
+
+    _hash_re = re.compile(
+        r'(sha1|sha224|sha384|sha256|sha512|md5)=([a-f0-9]+)'
+    )
+
+    @property
+    def hash(self):
+        # type: () -> Optional[str]
+        match = self._hash_re.search(self.url)
+        if match:
+            return match.group(2)
+        return None
+
+    @property
+    def hash_name(self):
+        # type: () -> Optional[str]
+        match = self._hash_re.search(self.url)
+        if match:
+            return match.group(1)
+        return None
+
+    @property
+    def show_url(self):
+        # type: () -> Optional[str]
+        return posixpath.basename(self.url.split('#', 1)[0].split('?', 1)[0])
+
+    @property
+    def is_wheel(self):
+        # type: () -> bool
+        return self.ext == WHEEL_EXTENSION
+
+    @property
+    def is_artifact(self):
+        # type: () -> bool
+        """
+        Determines if this points to an actual artifact (e.g. a tarball) or if
+        it points to an "abstract" thing like a path or a VCS location.
+        """
+        from pip._internal.vcs import vcs
+
+        if self.scheme in vcs.all_schemes:
+            return False
+
+        return True
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/models/link.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/models/link.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..b448ccd2d367801ca66335c520b0ad2ddd4027c0
GIT binary patch
literal 7361
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

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/operations/__init__.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/operations/__init__.py
new file mode 100644
index 0000000..e69de29
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/operations/__init__.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/operations/__init__.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..55cb6ab51a6868db7a2ad9a60809f1aab1359d92
GIT binary patch
literal 203
zcmZSn%**AGdLky70SXuy7#JKF7#NCK7#J8*7#M;zKq7t`AZawBxP*a$LBF6Vvn;VB
zRlh8;NIxw<CndG0SU)L6zdR`^FV{4;*vK%+JiRL2!qlQXC#%ZL00h$W^h5LuG7EGw
z^NLFnb8>Xu$~-)c13*Gx9G{t2l3J9Pn4_OxkXn>jl9``ZtREkrnU`4-AFo$XS;E1<
Tz+jV`pHiBWY6o&&G01fQ+H^EI

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/operations/check.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/operations/check.py
new file mode 100644
index 0000000..920df5d
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/operations/check.py
@@ -0,0 +1,155 @@
+"""Validation of dependencies of packages
+"""
+
+import logging
+from collections import namedtuple
+
+from pip._vendor.packaging.utils import canonicalize_name
+from pip._vendor.pkg_resources import RequirementParseError
+
+from pip._internal.operations.prepare import make_abstract_dist
+from pip._internal.utils.misc import get_installed_distributions
+from pip._internal.utils.typing import MYPY_CHECK_RUNNING
+
+logger = logging.getLogger(__name__)
+
+if MYPY_CHECK_RUNNING:
+    from pip._internal.req.req_install import InstallRequirement
+    from typing import (
+        Any, Callable, Dict, Optional, Set, Tuple, List
+    )
+
+    # Shorthands
+    PackageSet = Dict[str, 'PackageDetails']
+    Missing = Tuple[str, Any]
+    Conflicting = Tuple[str, str, Any]
+
+    MissingDict = Dict[str, List[Missing]]
+    ConflictingDict = Dict[str, List[Conflicting]]
+    CheckResult = Tuple[MissingDict, ConflictingDict]
+
+PackageDetails = namedtuple('PackageDetails', ['version', 'requires'])
+
+
+def create_package_set_from_installed(**kwargs):
+    # type: (**Any) -> Tuple[PackageSet, bool]
+    """Converts a list of distributions into a PackageSet.
+    """
+    # Default to using all packages installed on the system
+    if kwargs == {}:
+        kwargs = {"local_only": False, "skip": ()}
+
+    package_set = {}
+    problems = False
+    for dist in get_installed_distributions(**kwargs):
+        name = canonicalize_name(dist.project_name)
+        try:
+            package_set[name] = PackageDetails(dist.version, dist.requires())
+        except RequirementParseError as e:
+            # Don't crash on broken metadata
+            logging.warning("Error parsing requirements for %s: %s", name, e)
+            problems = True
+    return package_set, problems
+
+
+def check_package_set(package_set, should_ignore=None):
+    # type: (PackageSet, Optional[Callable[[str], bool]]) -> CheckResult
+    """Check if a package set is consistent
+
+    If should_ignore is passed, it should be a callable that takes a
+    package name and returns a boolean.
+    """
+    if should_ignore is None:
+        def should_ignore(name):
+            return False
+
+    missing = dict()
+    conflicting = dict()
+
+    for package_name in package_set:
+        # Info about dependencies of package_name
+        missing_deps = set()  # type: Set[Missing]
+        conflicting_deps = set()  # type: Set[Conflicting]
+
+        if should_ignore(package_name):
+            continue
+
+        for req in package_set[package_name].requires:
+            name = canonicalize_name(req.project_name)  # type: str
+
+            # Check if it's missing
+            if name not in package_set:
+                missed = True
+                if req.marker is not None:
+                    missed = req.marker.evaluate()
+                if missed:
+                    missing_deps.add((name, req))
+                continue
+
+            # Check if there's a conflict
+            version = package_set[name].version  # type: str
+            if not req.specifier.contains(version, prereleases=True):
+                conflicting_deps.add((name, version, req))
+
+        if missing_deps:
+            missing[package_name] = sorted(missing_deps, key=str)
+        if conflicting_deps:
+            conflicting[package_name] = sorted(conflicting_deps, key=str)
+
+    return missing, conflicting
+
+
+def check_install_conflicts(to_install):
+    # type: (List[InstallRequirement]) -> Tuple[PackageSet, CheckResult]
+    """For checking if the dependency graph would be consistent after \
+    installing given requirements
+    """
+    # Start from the current state
+    package_set, _ = create_package_set_from_installed()
+    # Install packages
+    would_be_installed = _simulate_installation_of(to_install, package_set)
+
+    # Only warn about directly-dependent packages; create a whitelist of them
+    whitelist = _create_whitelist(would_be_installed, package_set)
+
+    return (
+        package_set,
+        check_package_set(
+            package_set, should_ignore=lambda name: name not in whitelist
+        )
+    )
+
+
+def _simulate_installation_of(to_install, package_set):
+    # type: (List[InstallRequirement], PackageSet) -> Set[str]
+    """Computes the version of packages after installing to_install.
+    """
+
+    # Keep track of packages that were installed
+    installed = set()
+
+    # Modify it as installing requirement_set would (assuming no errors)
+    for inst_req in to_install:
+        dist = make_abstract_dist(inst_req).dist()
+        name = canonicalize_name(dist.key)
+        package_set[name] = PackageDetails(dist.version, dist.requires())
+
+        installed.add(name)
+
+    return installed
+
+
+def _create_whitelist(would_be_installed, package_set):
+    # type: (Set[str], PackageSet) -> Set[str]
+    packages_affected = set(would_be_installed)
+
+    for package_name in package_set:
+        if package_name in packages_affected:
+            continue
+
+        for req in package_set[package_name].requires:
+            if canonicalize_name(req.name) in packages_affected:
+                packages_affected.add(package_name)
+                break
+
+    return packages_affected
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/operations/check.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/operations/check.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..a0bd9391dff26a35060828f05782dffb7811a45c
GIT binary patch
literal 4985
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
TqX?rglPEK%D33m;D5o$04ZxF$

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/operations/freeze.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/operations/freeze.py
new file mode 100644
index 0000000..0c4c761
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/operations/freeze.py
@@ -0,0 +1,247 @@
+from __future__ import absolute_import
+
+import collections
+import logging
+import os
+import re
+
+from pip._vendor import six
+from pip._vendor.packaging.utils import canonicalize_name
+from pip._vendor.pkg_resources import RequirementParseError
+
+from pip._internal.exceptions import BadCommand, InstallationError
+from pip._internal.req.constructors import (
+    install_req_from_editable, install_req_from_line,
+)
+from pip._internal.req.req_file import COMMENT_RE
+from pip._internal.utils.misc import (
+    dist_is_editable, get_installed_distributions,
+)
+from pip._internal.utils.typing import MYPY_CHECK_RUNNING
+
+if MYPY_CHECK_RUNNING:
+    from typing import (
+        Iterator, Optional, List, Container, Set, Dict, Tuple, Iterable, Union
+    )
+    from pip._internal.cache import WheelCache
+    from pip._vendor.pkg_resources import (
+        Distribution, Requirement
+    )
+
+    RequirementInfo = Tuple[Optional[Union[str, Requirement]], bool, List[str]]
+
+
+logger = logging.getLogger(__name__)
+
+
+def freeze(
+    requirement=None,  # type: Optional[List[str]]
+    find_links=None,  # type: Optional[List[str]]
+    local_only=None,  # type: Optional[bool]
+    user_only=None,  # type: Optional[bool]
+    skip_regex=None,  # type: Optional[str]
+    isolated=False,  # type: bool
+    wheel_cache=None,  # type: Optional[WheelCache]
+    exclude_editable=False,  # type: bool
+    skip=()  # type: Container[str]
+):
+    # type: (...) -> Iterator[str]
+    find_links = find_links or []
+    skip_match = None
+
+    if skip_regex:
+        skip_match = re.compile(skip_regex).search
+
+    for link in find_links:
+        yield '-f %s' % link
+    installations = {}  # type: Dict[str, FrozenRequirement]
+    for dist in get_installed_distributions(local_only=local_only,
+                                            skip=(),
+                                            user_only=user_only):
+        try:
+            req = FrozenRequirement.from_dist(dist)
+        except RequirementParseError:
+            logger.warning(
+                "Could not parse requirement: %s",
+                dist.project_name
+            )
+            continue
+        if exclude_editable and req.editable:
+            continue
+        installations[req.name] = req
+
+    if requirement:
+        # the options that don't get turned into an InstallRequirement
+        # should only be emitted once, even if the same option is in multiple
+        # requirements files, so we need to keep track of what has been emitted
+        # so that we don't emit it again if it's seen again
+        emitted_options = set()  # type: Set[str]
+        # keep track of which files a requirement is in so that we can
+        # give an accurate warning if a requirement appears multiple times.
+        req_files = collections.defaultdict(list)  # type: Dict[str, List[str]]
+        for req_file_path in requirement:
+            with open(req_file_path) as req_file:
+                for line in req_file:
+                    if (not line.strip() or
+                            line.strip().startswith('#') or
+                            (skip_match and skip_match(line)) or
+                            line.startswith((
+                                '-r', '--requirement',
+                                '-Z', '--always-unzip',
+                                '-f', '--find-links',
+                                '-i', '--index-url',
+                                '--pre',
+                                '--trusted-host',
+                                '--process-dependency-links',
+                                '--extra-index-url'))):
+                        line = line.rstrip()
+                        if line not in emitted_options:
+                            emitted_options.add(line)
+                            yield line
+                        continue
+
+                    if line.startswith('-e') or line.startswith('--editable'):
+                        if line.startswith('-e'):
+                            line = line[2:].strip()
+                        else:
+                            line = line[len('--editable'):].strip().lstrip('=')
+                        line_req = install_req_from_editable(
+                            line,
+                            isolated=isolated,
+                            wheel_cache=wheel_cache,
+                        )
+                    else:
+                        line_req = install_req_from_line(
+                            COMMENT_RE.sub('', line).strip(),
+                            isolated=isolated,
+                            wheel_cache=wheel_cache,
+                        )
+
+                    if not line_req.name:
+                        logger.info(
+                            "Skipping line in requirement file [%s] because "
+                            "it's not clear what it would install: %s",
+                            req_file_path, line.strip(),
+                        )
+                        logger.info(
+                            "  (add #egg=PackageName to the URL to avoid"
+                            " this warning)"
+                        )
+                    elif line_req.name not in installations:
+                        # either it's not installed, or it is installed
+                        # but has been processed already
+                        if not req_files[line_req.name]:
+                            logger.warning(
+                                "Requirement file [%s] contains %s, but "
+                                "package %r is not installed",
+                                req_file_path,
+                                COMMENT_RE.sub('', line).strip(), line_req.name
+                            )
+                        else:
+                            req_files[line_req.name].append(req_file_path)
+                    else:
+                        yield str(installations[line_req.name]).rstrip()
+                        del installations[line_req.name]
+                        req_files[line_req.name].append(req_file_path)
+
+        # Warn about requirements that were included multiple times (in a
+        # single requirements file or in different requirements files).
+        for name, files in six.iteritems(req_files):
+            if len(files) > 1:
+                logger.warning("Requirement %s included multiple times [%s]",
+                               name, ', '.join(sorted(set(files))))
+
+        yield(
+            '## The following requirements were added by '
+            'pip freeze:'
+        )
+    for installation in sorted(
+            installations.values(), key=lambda x: x.name.lower()):
+        if canonicalize_name(installation.name) not in skip:
+            yield str(installation).rstrip()
+
+
+def get_requirement_info(dist):
+    # type: (Distribution) -> RequirementInfo
+    """
+    Compute and return values (req, editable, comments) for use in
+    FrozenRequirement.from_dist().
+    """
+    if not dist_is_editable(dist):
+        return (None, False, [])
+
+    location = os.path.normcase(os.path.abspath(dist.location))
+
+    from pip._internal.vcs import vcs, RemoteNotFoundError
+    vc_type = vcs.get_backend_type(location)
+
+    if not vc_type:
+        req = dist.as_requirement()
+        logger.debug(
+            'No VCS found for editable requirement {!r} in: {!r}', req,
+            location,
+        )
+        comments = [
+            '# Editable install with no version control ({})'.format(req)
+        ]
+        return (location, True, comments)
+
+    try:
+        req = vc_type.get_src_requirement(location, dist.project_name)
+    except RemoteNotFoundError:
+        req = dist.as_requirement()
+        comments = [
+            '# Editable {} install with no remote ({})'.format(
+                vc_type.__name__, req,
+            )
+        ]
+        return (location, True, comments)
+
+    except BadCommand:
+        logger.warning(
+            'cannot determine version of editable source in %s '
+            '(%s command not found in path)',
+            location,
+            vc_type.name,
+        )
+        return (None, True, [])
+
+    except InstallationError as exc:
+        logger.warning(
+            "Error when trying to get requirement for VCS system %s, "
+            "falling back to uneditable format", exc
+        )
+    else:
+        if req is not None:
+            return (req, True, [])
+
+    logger.warning(
+        'Could not determine repository location of %s', location
+    )
+    comments = ['## !! Could not determine repository location']
+
+    return (None, False, comments)
+
+
+class FrozenRequirement(object):
+    def __init__(self, name, req, editable, comments=()):
+        # type: (str, Union[str, Requirement], bool, Iterable[str]) -> None
+        self.name = name
+        self.req = req
+        self.editable = editable
+        self.comments = comments
+
+    @classmethod
+    def from_dist(cls, dist):
+        # type: (Distribution) -> FrozenRequirement
+        req, editable, comments = get_requirement_info(dist)
+        if req is None:
+            req = dist.as_requirement()
+
+        return cls(dist.project_name, req, editable, comments=comments)
+
+    def __str__(self):
+        req = self.req
+        if self.editable:
+            req = '-e %s' % req
+        return '\n'.join(list(self.comments) + [str(req)]) + '\n'
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/operations/freeze.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/operations/freeze.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..4ec480dc9b7d404c1883d2ace896ee28ed652f2e
GIT binary patch
literal 7528
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

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/operations/prepare.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/operations/prepare.py
new file mode 100644
index 0000000..bc7f86e
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/operations/prepare.py
@@ -0,0 +1,432 @@
+"""Prepares a distribution for installation
+"""
+
+import logging
+import os
+
+from pip._vendor import pkg_resources, requests
+
+from pip._internal.build_env import BuildEnvironment
+from pip._internal.download import (
+    is_dir_url, is_file_url, is_vcs_url, unpack_url, url_to_path,
+)
+from pip._internal.exceptions import (
+    DirectoryUrlHashUnsupported, HashUnpinned, InstallationError,
+    PreviousBuildDirError, VcsHashUnsupported,
+)
+from pip._internal.utils.compat import expanduser
+from pip._internal.utils.hashes import MissingHashes
+from pip._internal.utils.logging import indent_log
+from pip._internal.utils.misc import display_path, normalize_path
+from pip._internal.utils.typing import MYPY_CHECK_RUNNING
+
+if MYPY_CHECK_RUNNING:
+    from typing import Any, Optional
+    from pip._internal.req.req_install import InstallRequirement
+    from pip._internal.index import PackageFinder
+    from pip._internal.download import PipSession
+    from pip._internal.req.req_tracker import RequirementTracker
+
+logger = logging.getLogger(__name__)
+
+
+def make_abstract_dist(req):
+    # type: (InstallRequirement) -> DistAbstraction
+    """Factory to make an abstract dist object.
+
+    Preconditions: Either an editable req with a source_dir, or satisfied_by or
+    a wheel link, or a non-editable req with a source_dir.
+
+    :return: A concrete DistAbstraction.
+    """
+    if req.editable:
+        return IsSDist(req)
+    elif req.link and req.link.is_wheel:
+        return IsWheel(req)
+    else:
+        return IsSDist(req)
+
+
+class DistAbstraction(object):
+    """Abstracts out the wheel vs non-wheel Resolver.resolve() logic.
+
+    The requirements for anything installable are as follows:
+     - we must be able to determine the requirement name
+       (or we can't correctly handle the non-upgrade case).
+     - we must be able to generate a list of run-time dependencies
+       without installing any additional packages (or we would
+       have to either burn time by doing temporary isolated installs
+       or alternatively violate pips 'don't start installing unless
+       all requirements are available' rule - neither of which are
+       desirable).
+     - for packages with setup requirements, we must also be able
+       to determine their requirements without installing additional
+       packages (for the same reason as run-time dependencies)
+     - we must be able to create a Distribution object exposing the
+       above metadata.
+    """
+
+    def __init__(self, req):
+        # type: (InstallRequirement) -> None
+        self.req = req  # type: InstallRequirement
+
+    def dist(self):
+        # type: () -> Any
+        """Return a setuptools Dist object."""
+        raise NotImplementedError
+
+    def prep_for_dist(self, finder, build_isolation):
+        # type: (PackageFinder, bool) -> Any
+        """Ensure that we can get a Dist for this requirement."""
+        raise NotImplementedError
+
+
+class IsWheel(DistAbstraction):
+
+    def dist(self):
+        # type: () -> pkg_resources.Distribution
+        return list(pkg_resources.find_distributions(
+            self.req.source_dir))[0]
+
+    def prep_for_dist(self, finder, build_isolation):
+        # type: (PackageFinder, bool) -> Any
+        # FIXME:https://github.com/pypa/pip/issues/1112
+        pass
+
+
+class IsSDist(DistAbstraction):
+
+    def dist(self):
+        return self.req.get_dist()
+
+    def _raise_conflicts(self, conflicting_with, conflicting_reqs):
+        conflict_messages = [
+            '%s is incompatible with %s' % (installed, wanted)
+            for installed, wanted in sorted(conflicting_reqs)
+        ]
+        raise InstallationError(
+            "Some build dependencies for %s conflict with %s: %s." % (
+                self.req, conflicting_with, ', '.join(conflict_messages))
+        )
+
+    def install_backend_dependencies(self, finder):
+        # type: (PackageFinder) -> None
+        """
+        Install any extra build dependencies that the backend requests.
+
+        :param finder: a PackageFinder object.
+        """
+        req = self.req
+        with req.build_env:
+            # We need to have the env active when calling the hook.
+            req.spin_message = "Getting requirements to build wheel"
+            reqs = req.pep517_backend.get_requires_for_build_wheel()
+        conflicting, missing = req.build_env.check_requirements(reqs)
+        if conflicting:
+            self._raise_conflicts("the backend dependencies", conflicting)
+        req.build_env.install_requirements(
+            finder, missing, 'normal',
+            "Installing backend dependencies"
+        )
+
+    def prep_for_dist(self, finder, build_isolation):
+        # type: (PackageFinder, bool) -> None
+        # Prepare for building. We need to:
+        #   1. Load pyproject.toml (if it exists)
+        #   2. Set up the build environment
+
+        self.req.load_pyproject_toml()
+
+        should_isolate = (
+            (self.req.use_pep517 or self.req.pyproject_requires) and
+            build_isolation
+        )
+
+        if should_isolate:
+            # Isolate in a BuildEnvironment and install the build-time
+            # requirements.
+            self.req.build_env = BuildEnvironment()
+            self.req.build_env.install_requirements(
+                finder, self.req.pyproject_requires, 'overlay',
+                "Installing build dependencies"
+            )
+            conflicting, missing = self.req.build_env.check_requirements(
+                self.req.requirements_to_check
+            )
+            if conflicting:
+                self._raise_conflicts("PEP 517/518 supported requirements",
+                                      conflicting)
+            if missing:
+                logger.warning(
+                    "Missing build requirements in pyproject.toml for %s.",
+                    self.req,
+                )
+                logger.warning(
+                    "The project does not specify a build backend, and "
+                    "pip cannot fall back to setuptools without %s.",
+                    " and ".join(map(repr, sorted(missing)))
+                )
+
+            if self.req.use_pep517:
+                # If we're using PEP 517, then install any extra build
+                # dependencies that the backend requested.  This must be
+                # done in a second pass, as the pyproject.toml dependencies
+                # must be installed before we can call the backend.
+                self.install_backend_dependencies(finder=finder)
+
+        self.req.prepare_metadata()
+        self.req.assert_source_matches_version()
+
+
+class Installed(DistAbstraction):
+
+    def dist(self):
+        # type: () -> pkg_resources.Distribution
+        return self.req.satisfied_by
+
+    def prep_for_dist(self, finder, build_isolation):
+        # type: (PackageFinder, bool) -> Any
+        pass
+
+
+class RequirementPreparer(object):
+    """Prepares a Requirement
+    """
+
+    def __init__(
+        self,
+        build_dir,  # type: str
+        download_dir,  # type: Optional[str]
+        src_dir,  # type: str
+        wheel_download_dir,  # type: Optional[str]
+        progress_bar,  # type: str
+        build_isolation,  # type: bool
+        req_tracker  # type: RequirementTracker
+    ):
+        # type: (...) -> None
+        super(RequirementPreparer, self).__init__()
+
+        self.src_dir = src_dir
+        self.build_dir = build_dir
+        self.req_tracker = req_tracker
+
+        # Where still packed archives should be written to. If None, they are
+        # not saved, and are deleted immediately after unpacking.
+        self.download_dir = download_dir
+
+        # Where still-packed .whl files should be written to. If None, they are
+        # written to the download_dir parameter. Separate to download_dir to
+        # permit only keeping wheel archives for pip wheel.
+        if wheel_download_dir:
+            wheel_download_dir = normalize_path(wheel_download_dir)
+        self.wheel_download_dir = wheel_download_dir
+
+        # NOTE
+        # download_dir and wheel_download_dir overlap semantically and may
+        # be combined if we're willing to have non-wheel archives present in
+        # the wheelhouse output by 'pip wheel'.
+
+        self.progress_bar = progress_bar
+
+        # Is build isolation allowed?
+        self.build_isolation = build_isolation
+
+    @property
+    def _download_should_save(self):
+        # type: () -> bool
+        # TODO: Modify to reduce indentation needed
+        if self.download_dir:
+            self.download_dir = expanduser(self.download_dir)
+            if os.path.exists(self.download_dir):
+                return True
+            else:
+                logger.critical('Could not find download directory')
+                raise InstallationError(
+                    "Could not find or access download directory '%s'"
+                    % display_path(self.download_dir))
+        return False
+
+    def prepare_linked_requirement(
+        self,
+        req,  # type: InstallRequirement
+        session,  # type: PipSession
+        finder,  # type: PackageFinder
+        upgrade_allowed,  # type: bool
+        require_hashes  # type: bool
+    ):
+        # type: (...) -> DistAbstraction
+        """Prepare a requirement that would be obtained from req.link
+        """
+        # TODO: Breakup into smaller functions
+        if req.link and req.link.scheme == 'file':
+            path = url_to_path(req.link.url)
+            logger.info('Processing %s', display_path(path))
+        else:
+            logger.info('Collecting %s', req)
+
+        with indent_log():
+            # @@ if filesystem packages are not marked
+            # editable in a req, a non deterministic error
+            # occurs when the script attempts to unpack the
+            # build directory
+            req.ensure_has_source_dir(self.build_dir)
+            # If a checkout exists, it's unwise to keep going.  version
+            # inconsistencies are logged later, but do not fail the
+            # installation.
+            # FIXME: this won't upgrade when there's an existing
+            # package unpacked in `req.source_dir`
+            # package unpacked in `req.source_dir`
+            if os.path.exists(os.path.join(req.source_dir, 'setup.py')):
+                raise PreviousBuildDirError(
+                    "pip can't proceed with requirements '%s' due to a"
+                    " pre-existing build directory (%s). This is "
+                    "likely due to a previous installation that failed"
+                    ". pip is being responsible and not assuming it "
+                    "can delete this. Please delete it and try again."
+                    % (req, req.source_dir)
+                )
+            req.populate_link(finder, upgrade_allowed, require_hashes)
+
+            # We can't hit this spot and have populate_link return None.
+            # req.satisfied_by is None here (because we're
+            # guarded) and upgrade has no impact except when satisfied_by
+            # is not None.
+            # Then inside find_requirement existing_applicable -> False
+            # If no new versions are found, DistributionNotFound is raised,
+            # otherwise a result is guaranteed.
+            assert req.link
+            link = req.link
+
+            # Now that we have the real link, we can tell what kind of
+            # requirements we have and raise some more informative errors
+            # than otherwise. (For example, we can raise VcsHashUnsupported
+            # for a VCS URL rather than HashMissing.)
+            if require_hashes:
+                # We could check these first 2 conditions inside
+                # unpack_url and save repetition of conditions, but then
+                # we would report less-useful error messages for
+                # unhashable requirements, complaining that there's no
+                # hash provided.
+                if is_vcs_url(link):
+                    raise VcsHashUnsupported()
+                elif is_file_url(link) and is_dir_url(link):
+                    raise DirectoryUrlHashUnsupported()
+                if not req.original_link and not req.is_pinned:
+                    # Unpinned packages are asking for trouble when a new
+                    # version is uploaded. This isn't a security check, but
+                    # it saves users a surprising hash mismatch in the
+                    # future.
+                    #
+                    # file:/// URLs aren't pinnable, so don't complain
+                    # about them not being pinned.
+                    raise HashUnpinned()
+
+            hashes = req.hashes(trust_internet=not require_hashes)
+            if require_hashes and not hashes:
+                # Known-good hashes are missing for this requirement, so
+                # shim it with a facade object that will provoke hash
+                # computation and then raise a HashMissing exception
+                # showing the user what the hash should be.
+                hashes = MissingHashes()
+
+            try:
+                download_dir = self.download_dir
+                # We always delete unpacked sdists after pip ran.
+                autodelete_unpacked = True
+                if req.link.is_wheel and self.wheel_download_dir:
+                    # when doing 'pip wheel` we download wheels to a
+                    # dedicated dir.
+                    download_dir = self.wheel_download_dir
+                if req.link.is_wheel:
+                    if download_dir:
+                        # When downloading, we only unpack wheels to get
+                        # metadata.
+                        autodelete_unpacked = True
+                    else:
+                        # When installing a wheel, we use the unpacked
+                        # wheel.
+                        autodelete_unpacked = False
+                unpack_url(
+                    req.link, req.source_dir,
+                    download_dir, autodelete_unpacked,
+                    session=session, hashes=hashes,
+                    progress_bar=self.progress_bar
+                )
+            except requests.HTTPError as exc:
+                logger.critical(
+                    'Could not install requirement %s because of error %s',
+                    req,
+                    exc,
+                )
+                raise InstallationError(
+                    'Could not install requirement %s because of HTTP '
+                    'error %s for URL %s' %
+                    (req, exc, req.link)
+                )
+            abstract_dist = make_abstract_dist(req)
+            with self.req_tracker.track(req):
+                abstract_dist.prep_for_dist(finder, self.build_isolation)
+            if self._download_should_save:
+                # Make a .zip of the source_dir we already created.
+                if not req.link.is_artifact:
+                    req.archive(self.download_dir)
+        return abstract_dist
+
+    def prepare_editable_requirement(
+        self,
+        req,  # type: InstallRequirement
+        require_hashes,  # type: bool
+        use_user_site,  # type: bool
+        finder  # type: PackageFinder
+    ):
+        # type: (...) -> DistAbstraction
+        """Prepare an editable requirement
+        """
+        assert req.editable, "cannot prepare a non-editable req as editable"
+
+        logger.info('Obtaining %s', req)
+
+        with indent_log():
+            if require_hashes:
+                raise InstallationError(
+                    'The editable requirement %s cannot be installed when '
+                    'requiring hashes, because there is no single file to '
+                    'hash.' % req
+                )
+            req.ensure_has_source_dir(self.src_dir)
+            req.update_editable(not self._download_should_save)
+
+            abstract_dist = make_abstract_dist(req)
+            with self.req_tracker.track(req):
+                abstract_dist.prep_for_dist(finder, self.build_isolation)
+
+            if self._download_should_save:
+                req.archive(self.download_dir)
+            req.check_if_exists(use_user_site)
+
+        return abstract_dist
+
+    def prepare_installed_requirement(self, req, require_hashes, skip_reason):
+        # type: (InstallRequirement, bool, Optional[str]) -> DistAbstraction
+        """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 %r" % (req.satisfied_by,)
+        )
+        logger.info(
+            'Requirement %s: %s (%s)',
+            skip_reason, req, req.satisfied_by.version
+        )
+        with indent_log():
+            if require_hashes:
+                logger.debug(
+                    'Since it is already installed, we are trusting this '
+                    'package without checking its hash. To ensure a '
+                    'completely repeatable environment, install into an '
+                    'empty virtualenv.'
+                )
+            abstract_dist = Installed(req)
+
+        return abstract_dist
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/operations/prepare.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/operations/prepare.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..03cecd5e6391498a0314d87718c904f8cf753625
GIT binary patch
literal 13711
zcmZSn%**AGdLky70ScHI7#JKF7#NB#GcquwFfc?hFr+Xtq%bk$Ffv3j!q`j<QA}Vq
zGeZtDLoN$L6bnNxD?=1310zT^3quYYLoPc*6gz~^%8<jskju#s#mSJ%#Sq2Ckju>w
z#m$h*!w|*8kju*u#S2l##*o9ukju{y#m|r{zz`+CkSoX#CCHE~#1JLKkSoj(B@9u=
z&X6O*kSod%B?{qlFyx3a<cc#yi9`6D3^@`ExsnV~k`O)@Lyi<ft~5iGG()ZoLzE0e
zl$#+(mLXS;Axe&cF;$MC$P?^#9)=uwhFk@PC<TUGMTRIvh+1BT93_TaWriqa2%nE3
zM};9*l_5$M!siG3P>mr<4Z;^-$Wdp=)nJIyU|`H+U`S<T$kJp;)naI7WQfvcND*Xc
zVPJ^TVMq~TNY!OXV`NAX28lE?FhoY_F{Fqvr0Ri1Md70Q3@KtTQE|Aa0Yi!eOjHss
zYRHfx1v6I~E@}jd#b6B?P~>VdFfarZr4}R>r4}nBDx_o<mlS0tm6l}Y=P9J+7b#@s
z6_+ID<RpRwxHA9$|Nq}lgNcEGp@f%#fuSHfJ-#TlIKQ+gIkmWigMopeD7COOwYa2M
zgAt@gfPsO*sWdYu#Wk-ivnW3=H#M(BgB2vh#lXOjSsb5|SrlJdlvBbD;ihHgq=NZS
z>9XWvIJY#fATc=`%mt|~Ey{^6$&W8cEXjbFD9ymY;F4LCnp~1!R2f>7<B?dL5t>(A
zT2PQ*RFaxf!o$G801+$5%*#tnDG_8~VDLopooi81eo=`iBs|J8^Gl1tPIt*Hg2)Il
zFffEA7emZ|n+x$M$i1l*1&MhnrNya55HU~y`DPXuXXd4Y^rS+=1f(=GFC{gvBt9oU
z9TJuxx20qj7vv;Xf_+rN$H2glmtT~dn3GwR3KoKx337vPWI$xRvxlp*cYIK&pP#3n
zJH!xBes#>N1V@8^0Vuu_a}c_qJ`GAOEX^!R1xExpia@RmNKDR7Oiy(KIScA|kShZ+
z3xZRNi!<}{5XK<s4=GAa&Q2{#1{njwpj6=uN>ZRgqlSSYi-Dm?n4yG`p@spJ*n>er
zObkUvAbu7TLl!fLUBUw5HZw8=BNV1EG6aLYRQ#BMfx#^i9HR;)`3kv-*{KSNc?yY1
z#U(|F$tB>_s*s<Qm6}|l$Hk?fpr8;?l$xBMmy!wcezBE;Yi3DCY7t0JYD#8FVp2}3
zLQ!g=LV0FMhC-qOB;kS*p^id+kwS4|NoH|cW@<`&Ql&zE5!k#$h4PHl)EtGJ%)D%{
zqC|zf{5)O!ra|3eRg_v%T9jv{;HZ$CpO;*eT9T^Zl385h2z7pDex4rK5<f@^2IU`^
z!6odV)L9%1QeVQtz`y`<061zhi{rsgf~p7yIS&#)paf8qTBrdkzrjRtF#`jGenC-Y
zSz<}5epzCXep-G`N@`KDeo~5lc~Vkdu4!(ukztZ~dR4lGsYQ8CR+X6n2&Cufhv*k%
z7U)8Azph)Eho^A>NC=GMGxJJPi}Dh4^z#c+i@;?=v3>!h6wxcFECD4`P-Ml!Vk#a~
zt|)>M2Pk1NaB?zoF^V#BF_rLxb1h1kz$+k7qH+T10hLjy4B$$K0b1RF3QcBEF$Q9=
zFr+Yp3b!a$hM-^#P-qobGBYs1!ns%>zqCZ5BqJ3Xmu1D^I0T2HLQraPeok3xkshcV
z%PC9M&{W9DPtQz-#$iZCDk#Ok@=P(fOiawHEXl~sONSSZpmdd3l&X*jlF!M>FE6$N
zN34RbLV2n}ZfS9eLQ<*%IQf<2E2N~Bq!#67=B0w&1S&D1IZ`1nF*g;WQ9(f?zX+r`
zIWbSYL?Jo92voA=R4Qa7=B4C7bb=CMX+e5XVoIt)a$<3+CL}dsw=_L94-`|W3W*9i
znZ+dv`DqG8rFps~nYpP7DX9gipb{xLGqo6IJt&KSf(@DiK)y}Pt5ir#f#j{k90gEu
zoS2?k40CCDerZk$OnXLRSt=;Yrb04cQfX110@$vkN`;hskZC2Uxdr(}iA9wPnZ@}z
zi6yBiu;7HdA-_l=F$bK`N;1n*b1D_eGQlbp3Nj0d71UGmK|xbol2}v%(+V=UG%qK$
z7;Z*lP7Z1Wg5#+yF*64g9qI~2r8%hzx(azvhvug#lxJinXDB2V!DAvNwK%f~q#6;x
zpqdfxe^5{<6sMMy7NFRq1ByOy+$ZJ~=fe^JEP&9{L1qz(W^fUO9{%vKhZzEQf(FPz
zpcG!5m<vj<iN*POpwx&piZvnHv8K)BqSV9^P$B^pJn)79q=;2WttiL`RcD}d3o%1M
zAu%bxEL9;lwInemu_O_a0+T^i0Stqy1W+wg1Fi|;!EMQ4aEavyCWGV{7#P6iJ-DDN
zPR&V!2n~EW1}c%`<1_OzOXA~QK_wB$Qw&V-Di2gbf&B+6)k+u`n!wFsXyv8Az`zg$
zt^q(*4Jdh(<mcxUgR1~or3DFr5@7}g2EY6g&)k9>aMhfe0&a3Zf(KM=f{Sx7F<@mn
zs8|J+;-2tuU`__rI3SES9E=$l7+mv;ON&6IR$>V#S0pFqDWs>CC?rAx1Cn?%i;;7H
z9wcajltGCDWJeGv97@<27#PyP?G$j;kpya7#zP7aP&;MdlME=OgKEO~wEQA)t>=db
zFAb3E!IgM?JgBITk1qiwocQ?M{FKt1)cAOCogN>blAjzOAEX3IKPn(X9TWy|uMKE2
z2m+;QBaoLsd4o-mjfs<mlQl?|fq?<D-j-ruV1U=#po$vYQv@-XK@~M9Gr_YGD2l;Z
z31n0W1E}4Y#RO^_W-&8lv49$o&EU)>3CUf4nc(mM_a#6n6I7=KfrP+q4^RpL2R^I>
zD+ZS+;Lt`i`UX?>3IauR7${spzF}bEWW>x|Aej^f23Xk%@~s9a*uXg>NEMV))KF5&
zK$R6ipadHY@(d`78JNLMvLH~p4FWagz<vd*0SPf6hyimiD9wd{+zSd~HYQHiAW+i9
zOwc-b5_Ad^xCx5c7KJBqcqs`gBS5_&28Jv~hGs;Jf<g<DP(hh1J+%a!h6i0T1%*p7
z$gK>JL<%a^Kp32TBN!MM(is>^7#M1pK)Kc>R)!&liJ_L6p_T<SPE^CpP{YEI#>5~N
z$HY*`%TUV-%IYbQtj@$x!w722XE8I>u!3}_F*ArYGlJ_?P%wd_$FCR^H>$-7nZ*j3
zdCB>?1&Jk@pawX&8KzoXY{J065S*WzssOGWP#U-3*1Kvks5_RHlbKusZe=N`7F#K(
z7VCk%q@w^%tl)a47(8$g#0AP&pf(D)d6Jc%nFlV%!MUykG{TXbp9eNAGcP?J<OmGG
zqSV6T5>C(%2V}S*H3e*bd14-DU;;D_0W%^#H?_DJ)Tkc#Oab;qd{JU%acVrwdBtg<
zOaclJ1}0`k9VTW*W=3#h4;1|%3{C>|3=H6cn}MO036u)57#aFy!GmEnObqc5AxNRl
z07@6(DNGE35j9Mp%#g*(P{Rz0cu<mI0VR$a7KWlEuyJgllu^UN(98rLNP}u%2PK&r
zR)!Q7h7?wYW)=p<6efmXa10eUGB7Z}+NlcA0T2aHFDA93q$m+v`Y6drg!B}XKw}$u
zDc}|fXgmwr9Rv+ASQR7|CFUxC>X_6bD}_V_l;IOt%MNaDF{lOOo?21@>YE^S_KHE>
zBS;bj_eA}QB|rmX8L0{|yOFzP-~<C15h|7k4Gln2639$!$~8a*2&5<hr8}@S@u_)b
z;8C#Rg3LTvLIaO96{HrJ8k)yL4JrYR3xWzCsAG%4O&N$0V3&fc*yN1V<m`B;63}o`
zagZ6v{UV5Djv@<=5pbS?)Ku^c1<o9x5j|KU%gjp$w}WyaV`qaPCx8M3+7E^WQap0x
z6o7IC$m0y`oQzydoQ$H35{zt&!i=1Z(0Uw{H$Wpg;QXP$2+JRk;-3*(7cemttAbNH
z188t8UjvkPYMDV9qKJvHgauSnKvc%F!j!QxWU+xW0C>19iy2hHrZ9oC0YqsQD?=7L
zOf?5a&YA<3;zY|?tPDjD7)rPpvbaIn3Stl_*Fl9?8B*97vUos4z$JVPCH&B`x*1&F
zgVg20{l~;m#02)907D8mr#3S%G8Qs{2Erl6W(k741y;hqkR=4>fZI5r1ndV+2l-{G
zMLCI;#h^+Wnu)>59@O+lDcy@fE#?5%00mP+bA3}o3kCQfEjSxP2U#E$1ax2)S_U8|
zV};B-g@Ve0qI~eEVo82(4z$+LD^6fwU;qsWK_wMZ@>4-WNhJ!!1*yrIX_X4FG6kBG
zbQBWvQb2<h3dxCidHE#@X`s;vkR&MYgGUS?T|!W;0qX37Y9UaQ7OW4PPc%SXLr6vj
zv2yYgQ{v&SiwC(5+^8)rPK}4;VsPd}sDS#cI0#f<2U&osGFuQ~1InwQv2LgWa1I6y
zsDtx0BrAgwZBBlAdTJ3k9?BDo@-p+%gA71gLG8}m!~$@YSd>~&6r>L_)e$5GsuDpx
zpv0ooc-Xi=2`KUsi;Gi>O5&jn@Z7|b<c!qf__EX@@DMY|Hl*?a)RF}kPQ@9ZaV2OU
zFEz*>WDjVBdEm<ha1*u#l=neF!obGMEWyae%*M>m$iv9b$j-#WD9Xgf2pZ~SV`O7w
zX5?aGV`OGhV&-8LW8!6m6o?>SAT^3XMQ9Kx6v1YLBnLzD7}VfO1o;z`DcP7fnK`*Q
zMZgUjXnssh0ksK19TEmmBNseq3(`bv=MSU_Tr`537SMtLGzkC_hfFs?vH%ar5lEx-
zgRW`39ppezR%2iq>ixIf2(N&f#Dls21{!183UV)~g8&+m0FS64%~e5XIE&!P6ck6`
zWD3e`@MH>^%7zS3q_RM#7eEuWte_eaB+dq^5kU-gP;(Q+-~bI}fC{f-&<rHhBG6PS
zlJ(%mU@|E8fH0`+1gG|FP;m(!>HtlVF)?H@f$Kj|7m0x(o*7!P$FnfhfU9s&wa)~q
zu;bZ4eW)TIh7xuVqnQ!Zw*pnVEMQp<P=#E>z!1;LP{Rfm;R4Oy!^RCjZLJbeEmK@t
zkXjTJ04h*HH7B@`FD^<3&4+<AH>Amzl34_vo-Il(j0erSWv3Q_TahXG<$2)hC?&Hf
z2-JrG*F4|`Vmz`OSaCs7etJ=AadCW7Vo?yNXooaVK|^{$!5{~Of(Xz6P7r7iBq$uj
z1*r=Hb;}Xu;DC(~fCA_UD20KWdECNGpr##Y=!=b!pOKTDlNsL22PHvp?1D;6NLf}C
z3+m%S*v*XK7-3*20Z)Nufuk%7JVRP!!cfA>5M06rYO<v;f*Na#B^;nsSi%X?1W^U;
z59cv}T4=%G0U*C(P(V6^>PZD~Gb1xEMFAEE3MsHj@nTRlg{BHL#gd$yT3n1py@I-G
zvAPB*xdefuhZmGwK^Z5%7+mjz=H9{mlGKXK;u45hNKt8OkUK~rD5WPCWtL<nC+0x<
z(4d9^IN`Y^<`kz6rm`D6>yJpa&?ZN5Vp-}dP@IFNGZ|Po8HE@{8CjTk8A07%F~($2
zrU!)yKLY~;IL4PVF@W+cXyV%q%E$r_T4pmb6uE(7yoM1pEuIDL;?}Y;l&~;lv4SI*
z4U|=z86llp0hk212mrOHOV~jrL%$OfBgg~}aBAR$BoJ^j9n>0!FnGZh^MQ&fNQ1m+
z1E`6f!U_@xY32hDzCZ?5KxGCaLzV!jk5R({DmI##8NgOBFce>6C=mpWynr+@Fx0Yx
zq>CIFON2nhQ8Ob$(NBgFVUV+$7#Z?Z7)nH7;<Ah-qDX8pm>Njnh%@jMIe_hu0JBOY
zq4I?e;BEmULzWb%gHglEz|+jYSPL%AigFlhI2d?}au`dbLCR}681fhxD%-#TA;VD1
z$xtH8P|F4KV-^ELmK;OTd~lya9>J*P1ZjbI2BhFHV+|)m(Jn@a#=^slB?=%DK>11$
zY7R&-A43f%Lk$<W`@+PK!og6(!H@#Uj!F#8EX<7Id9DmBCCUt0Dh%0N3`LeqjJ4bh
zpzd0hDnkm`MK#<EpkOUgV@Tl!nOp-Vvlti<qg#253=t*jAW2YR&I9(A256yB4Y(NS
zmtbJ5;bF+q0!I`BLzXr;p@gUKfJROj7_xL2ismwboXfzFrOQwZVe5g7kpU-@!nsU&
z3=B{WJPg4apoCitO101$OCb@tlcWG12m#ONf+jBWlS&dZ^HNh3(u(qPLF)8C%Mrk}
z8fZiWTpEDZ?i7Pe4JgV76)2!Snrbmv#5q4FCp8&70HRu43@RAFeILDo%Hp@6RYaKu
zpbnCHi9!KLYibH)SPr>o0xpUaQcA&d%83dEMX9>rLI-3CxSB$gata!%#hQ8wAsL|Y
z!D5A+%xuuiF|t<h+8)@9F?jI;#Jg#UnK`K`df*OQX0bw2D#-Mr)Z&8tykhVOBd9kA
zDqj<ei%WAsl9?qShbyF{=783Alw@QU>nQ}}q$U=F=G4JrnI+)9TuD)-LSlMiW}Y6n
zPg7D<T3iBMM3GtosdynPZNTMeMq+VBYB9JH1dnDS%53N;1Skq%OA-`RK~7ChEG<q2
zP3otDRxv5478kpKN+o!eKv<(kNJxMJOgFg88ye)Jpjzyw0q)v?8aH6a6(?t;=B5UL
zMl(u4Et%4y97ur=s`xVV((;1@K$SPBPy`pNso<%<_>9D2SkDjCU;tP8pt0hhNRa9%
z5CN*5f^<PFP@Mx=V3uD{3R)Ww4@z&~pmPLwA~W;zz%!&lpmt0U4@eKl`XG>lf<Orj
ztUJFbGd(jeF$bcX6Erea91mIj6$Ii1C4n^Zfe3H~2b!`70uA;+8X>VD2~Z&qj)@>p
zX9V0X0)-UB_85=~E)W44lLNO^z!e<0odoW}fg3wPai9tj<f+W!_{5@;%(TR0NUSFo
zC1+%orGj%Kr1J|J7YhP49l+gx@FXX6jYoVUXk|%i3OE>`nFAE8pris0L{Jn#yae(M
zxCxwCT9OY*o$-+MbEzrdNK36q28R&J`kaApW|e?Cjj*u;P?V>pAP*w`1Xacvpl&9Q
zG@}rsB$EIW7pnlf3aCP66=M?S<Y(k$V`JlC<YAOx<Y5%y;AawM<YnbyVrJxIVq+9#
z2Fb87bFy$UGBffpax(HT@-Yd4`{vAy?4Z$XCMhN!Mqx%tMouOkMj6IrQ1Sw$08re4
z3d`avps{UmC0;BFYSclRX-$lv${jTP2A;tH*Vy3ky8Z<Wj5SOQMINA*T?)85N3`ES
z<ux0)jAjRy(I7qtn9s?;)6B@gSOTs-Ks5p@SeP3$>V{M!urg%vf;s@8mL(swMqq)~
z2%HQ>dqMR{7C%_40N4g-eJ=>AMnD#Xr+}5SG6aKHpcR8s0K7iPQ-Cc-LoROMg?_Ov
zXwDZht_6)U1uTo>5{u!+6oc}qKe#FZ6`rca#re<yHEb4v$~EY)SyC#jv<B4;8L4?t
z2Z2n1l$AOPNvV(`5VYPe6*M=Lm#+X?tCEwd0IHcl18yLtdVU(9)?APzDAR(H61eON
zN(FI2MHZx`ng-&6dLz*Mmy%eL8V_?MI5!8uGkj1ENHJ)}6Oz~SKwNMJ1epgOPK(b>
ziw9R%#gIWCP-`7Lpb-QbIR<A$&;TB2>1cd$W=SeI>j!}r?|~u&G6FPEJs<FF05pE#
zL4ceo%NZFMib1Oa7`Q}184{A6n0T247zH7jiHVa@m{FK18B{{UG88y7b>hlQHO!#i
zbv7qMu{k)CfpZn8!Ndrg4lDsrAc1leI8%YL4g;ty4VnNdVFNW0`_&;?ub2U(mL1$6
zW(3b1m2iME1}IyxFodVDf-(#XY|6+Gviujc92&H0G%=?rH8G_Uwhl5CG9d&VNk(J^
zP&9$ol|niW3gE?WNvWxMh$W>8Nu?zUnZ<ePCB>i-hm_0|a8C`i2&OnY6SQy)ykrZ+
zE=WxQt1e0{)GJ0B>;fg~;?xpQN>(i@76&CW#A06PBqq4=Q@k8B1DctaoT`usvQz=;
z3q&RYFHHk2gabE3K-s7S)LeotCj&RXK*Q1C#0!$mEGbq1=N^TSd<95_u8^nzntKH`
za&jsaic$+w6CvwsQxQwObzn9sWagFRgTga4x1a>HjIXGqG%+VNuT0NR16&dNgM0(Z
zj^L)GUw$5>6A8|j;N}r@lsE{Kr@&QgN@`MRdJt&f2V8U^Ri5BH1uC#Xff-+v3JTc4
zl9@om;IPaDZIYo@aWg@=2~-O*u!u79Gcq#@fCh~jg_*b*L4(L#tU^qX5CbJS$iT4{
zDC|Jv6X2Ca1x27Gxh0j5QmO<bR{<hwQC5b4bTbT8kpdoaIsmH6K@|cU6B`q!8b3d0
z9jB58XsuWf$V1>r2TeYJW*k86MDQ3?L1uwod|7H<N`4WjbY_6G$v{~FECXAWtOxEA
zfaW{F(;g*akWPjkw8fp6qX!!tfixIF1rwwt399QMO<T}pEUKZY70IdKW%b427AB+x
z32yv>5*xS?3TeN990_+yX-Q^Iu^uR^B$fp6g4%(g*hMuNq6U<~Qj3H5Kx#luIc#cR
zAp*_@m`;Qkl$%+c3~7W5g3Q8YUrA*FC~!g5A-G`=<%6b~f<!<X!HE^cGoT^~G!6(&
zx<Q}`Byc+u)vciQc@;sRP!9sd4S4bgRRzo-a6>t@C<x>gaN9aPwZsQJ<pddS28|?v
zt6H!NA<Iy~OVGe8&cLg5z-0h9Nr4kJf*7de4bFx(x!@&zcA()h@VFZr6AvQ~lNgf#
jqXx4EivS}Cih*;t7?>@<D9psq%qb|QB*rTiBE}5>C>v-(

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/pep425tags.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/pep425tags.py
new file mode 100644
index 0000000..3b68f28
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/pep425tags.py
@@ -0,0 +1,381 @@
+"""Generate and work with PEP 425 Compatibility Tags."""
+from __future__ import absolute_import
+
+import distutils.util
+import logging
+import platform
+import re
+import sys
+import sysconfig
+import warnings
+from collections import OrderedDict
+
+import pip._internal.utils.glibc
+from pip._internal.utils.compat import get_extension_suffixes
+from pip._internal.utils.typing import MYPY_CHECK_RUNNING
+
+if MYPY_CHECK_RUNNING:
+    from typing import (
+        Tuple, Callable, List, Optional, Union, Dict
+    )
+
+    Pep425Tag = Tuple[str, str, str]
+
+logger = logging.getLogger(__name__)
+
+_osx_arch_pat = re.compile(r'(.+)_(\d+)_(\d+)_(.+)')
+
+
+def get_config_var(var):
+    # type: (str) -> Optional[str]
+    try:
+        return sysconfig.get_config_var(var)
+    except IOError as e:  # Issue #1074
+        warnings.warn("{}".format(e), RuntimeWarning)
+        return None
+
+
+def get_abbr_impl():
+    # type: () -> str
+    """Return abbreviated implementation name."""
+    if hasattr(sys, 'pypy_version_info'):
+        pyimpl = 'pp'
+    elif sys.platform.startswith('java'):
+        pyimpl = 'jy'
+    elif sys.platform == 'cli':
+        pyimpl = 'ip'
+    else:
+        pyimpl = 'cp'
+    return pyimpl
+
+
+def get_impl_ver():
+    # type: () -> str
+    """Return implementation version."""
+    impl_ver = get_config_var("py_version_nodot")
+    if not impl_ver or get_abbr_impl() == 'pp':
+        impl_ver = ''.join(map(str, get_impl_version_info()))
+    return impl_ver
+
+
+def get_impl_version_info():
+    # type: () -> Tuple[int, ...]
+    """Return sys.version_info-like tuple for use in decrementing the minor
+    version."""
+    if get_abbr_impl() == 'pp':
+        # as per https://github.com/pypa/pip/issues/2882
+        # attrs exist only on pypy
+        return (sys.version_info[0],
+                sys.pypy_version_info.major,  # type: ignore
+                sys.pypy_version_info.minor)  # type: ignore
+    else:
+        return sys.version_info[0], sys.version_info[1]
+
+
+def get_impl_tag():
+    # type: () -> str
+    """
+    Returns the Tag for this specific implementation.
+    """
+    return "{}{}".format(get_abbr_impl(), get_impl_ver())
+
+
+def get_flag(var, fallback, expected=True, warn=True):
+    # type: (str, Callable[..., bool], Union[bool, int], bool) -> bool
+    """Use a fallback method for determining SOABI flags if the needed config
+    var is unset or unavailable."""
+    val = get_config_var(var)
+    if val is None:
+        if warn:
+            logger.debug("Config variable '%s' is unset, Python ABI tag may "
+                         "be incorrect", var)
+        return fallback()
+    return val == expected
+
+
+def get_abi_tag():
+    # type: () -> Optional[str]
+    """Return the ABI tag based on SOABI (if available) or emulate SOABI
+    (CPython 2, PyPy)."""
+    soabi = get_config_var('SOABI')
+    impl = get_abbr_impl()
+    if not soabi and impl in {'cp', 'pp'} and hasattr(sys, 'maxunicode'):
+        d = ''
+        m = ''
+        u = ''
+        if get_flag('Py_DEBUG',
+                    lambda: hasattr(sys, 'gettotalrefcount'),
+                    warn=(impl == 'cp')):
+            d = 'd'
+        if get_flag('WITH_PYMALLOC',
+                    lambda: impl == 'cp',
+                    warn=(impl == 'cp')):
+            m = 'm'
+        if get_flag('Py_UNICODE_SIZE',
+                    lambda: sys.maxunicode == 0x10ffff,
+                    expected=4,
+                    warn=(impl == 'cp' and
+                          sys.version_info < (3, 3))) \
+                and sys.version_info < (3, 3):
+            u = 'u'
+        abi = '%s%s%s%s%s' % (impl, get_impl_ver(), d, m, u)
+    elif soabi and soabi.startswith('cpython-'):
+        abi = 'cp' + soabi.split('-')[1]
+    elif soabi:
+        abi = soabi.replace('.', '_').replace('-', '_')
+    else:
+        abi = None
+    return abi
+
+
+def _is_running_32bit():
+    # type: () -> bool
+    return sys.maxsize == 2147483647
+
+
+def get_platform():
+    # type: () -> str
+    """Return our platform name 'win32', 'linux_x86_64'"""
+    if sys.platform == 'darwin':
+        # distutils.util.get_platform() returns the release based on the value
+        # of MACOSX_DEPLOYMENT_TARGET on which Python was built, which may
+        # be significantly older than the user's current machine.
+        release, _, machine = platform.mac_ver()
+        split_ver = release.split('.')
+
+        if machine == "x86_64" and _is_running_32bit():
+            machine = "i386"
+        elif machine == "ppc64" and _is_running_32bit():
+            machine = "ppc"
+
+        return 'macosx_{}_{}_{}'.format(split_ver[0], split_ver[1], machine)
+
+    # XXX remove distutils dependency
+    result = distutils.util.get_platform().replace('.', '_').replace('-', '_')
+    if result == "linux_x86_64" and _is_running_32bit():
+        # 32 bit Python program (running on a 64 bit Linux): pip should only
+        # install and run 32 bit compiled extensions in that case.
+        result = "linux_i686"
+
+    return result
+
+
+def is_manylinux1_compatible():
+    # type: () -> bool
+    # Only Linux, and only x86-64 / i686
+    if get_platform() not in {"linux_x86_64", "linux_i686"}:
+        return False
+
+    # Check for presence of _manylinux module
+    try:
+        import _manylinux
+        return bool(_manylinux.manylinux1_compatible)
+    except (ImportError, AttributeError):
+        # Fall through to heuristic check below
+        pass
+
+    # Check glibc version. CentOS 5 uses glibc 2.5.
+    return pip._internal.utils.glibc.have_compatible_glibc(2, 5)
+
+
+def is_manylinux2010_compatible():
+    # type: () -> bool
+    # Only Linux, and only x86-64 / i686
+    if get_platform() not in {"linux_x86_64", "linux_i686"}:
+        return False
+
+    # Check for presence of _manylinux module
+    try:
+        import _manylinux
+        return bool(_manylinux.manylinux2010_compatible)
+    except (ImportError, AttributeError):
+        # Fall through to heuristic check below
+        pass
+
+    # Check glibc version. CentOS 6 uses glibc 2.12.
+    return pip._internal.utils.glibc.have_compatible_glibc(2, 12)
+
+
+def get_darwin_arches(major, minor, machine):
+    # type: (int, int, str) -> List[str]
+    """Return a list of supported arches (including group arches) for
+    the given major, minor and machine architecture of an macOS machine.
+    """
+    arches = []
+
+    def _supports_arch(major, minor, arch):
+        # type: (int, int, str) -> bool
+        # Looking at the application support for macOS versions in the chart
+        # provided by https://en.wikipedia.org/wiki/OS_X#Versions it appears
+        # our timeline looks roughly like:
+        #
+        # 10.0 - Introduces ppc support.
+        # 10.4 - Introduces ppc64, i386, and x86_64 support, however the ppc64
+        #        and x86_64 support is CLI only, and cannot be used for GUI
+        #        applications.
+        # 10.5 - Extends ppc64 and x86_64 support to cover GUI applications.
+        # 10.6 - Drops support for ppc64
+        # 10.7 - Drops support for ppc
+        #
+        # Given that we do not know if we're installing a CLI or a GUI
+        # application, we must be conservative and assume it might be a GUI
+        # application and behave as if ppc64 and x86_64 support did not occur
+        # until 10.5.
+        #
+        # Note: The above information is taken from the "Application support"
+        #       column in the chart not the "Processor support" since I believe
+        #       that we care about what instruction sets an application can use
+        #       not which processors the OS supports.
+        if arch == 'ppc':
+            return (major, minor) <= (10, 5)
+        if arch == 'ppc64':
+            return (major, minor) == (10, 5)
+        if arch == 'i386':
+            return (major, minor) >= (10, 4)
+        if arch == 'x86_64':
+            return (major, minor) >= (10, 5)
+        if arch in groups:
+            for garch in groups[arch]:
+                if _supports_arch(major, minor, garch):
+                    return True
+        return False
+
+    groups = OrderedDict([
+        ("fat", ("i386", "ppc")),
+        ("intel", ("x86_64", "i386")),
+        ("fat64", ("x86_64", "ppc64")),
+        ("fat32", ("x86_64", "i386", "ppc")),
+    ])  # type: Dict[str, Tuple[str, ...]]
+
+    if _supports_arch(major, minor, machine):
+        arches.append(machine)
+
+    for garch in groups:
+        if machine in groups[garch] and _supports_arch(major, minor, garch):
+            arches.append(garch)
+
+    arches.append('universal')
+
+    return arches
+
+
+def get_all_minor_versions_as_strings(version_info):
+    # type: (Tuple[int, ...]) -> List[str]
+    versions = []
+    major = version_info[:-1]
+    # Support all previous minor Python versions.
+    for minor in range(version_info[-1], -1, -1):
+        versions.append(''.join(map(str, major + (minor,))))
+    return versions
+
+
+def get_supported(
+    versions=None,  # type: Optional[List[str]]
+    noarch=False,  # type: bool
+    platform=None,  # type: Optional[str]
+    impl=None,  # type: Optional[str]
+    abi=None  # type: Optional[str]
+):
+    # type: (...) -> List[Pep425Tag]
+    """Return a list of supported tags for each version specified in
+    `versions`.
+
+    :param versions: a list of string versions, of the form ["33", "32"],
+        or None. The first version will be assumed to support our ABI.
+    :param platform: specify the exact platform you want valid
+        tags for, or None. If None, use the local system platform.
+    :param impl: specify the exact implementation you want valid
+        tags for, or None. If None, use the local interpreter impl.
+    :param abi: specify the exact abi you want valid
+        tags for, or None. If None, use the local interpreter abi.
+    """
+    supported = []
+
+    # Versions must be given with respect to the preference
+    if versions is None:
+        version_info = get_impl_version_info()
+        versions = get_all_minor_versions_as_strings(version_info)
+
+    impl = impl or get_abbr_impl()
+
+    abis = []  # type: List[str]
+
+    abi = abi or get_abi_tag()
+    if abi:
+        abis[0:0] = [abi]
+
+    abi3s = set()
+    for suffix in get_extension_suffixes():
+        if suffix.startswith('.abi'):
+            abi3s.add(suffix.split('.', 2)[1])
+
+    abis.extend(sorted(list(abi3s)))
+
+    abis.append('none')
+
+    if not noarch:
+        arch = platform or get_platform()
+        arch_prefix, arch_sep, arch_suffix = arch.partition('_')
+        if arch.startswith('macosx'):
+            # support macosx-10.6-intel on macosx-10.9-x86_64
+            match = _osx_arch_pat.match(arch)
+            if match:
+                name, major, minor, actual_arch = match.groups()
+                tpl = '{}_{}_%i_%s'.format(name, major)
+                arches = []
+                for m in reversed(range(int(minor) + 1)):
+                    for a in get_darwin_arches(int(major), m, actual_arch):
+                        arches.append(tpl % (m, a))
+            else:
+                # arch pattern didn't match (?!)
+                arches = [arch]
+        elif arch_prefix == 'manylinux2010':
+            # manylinux1 wheels run on most manylinux2010 systems with the
+            # exception of wheels depending on ncurses. PEP 571 states
+            # manylinux1 wheels should be considered manylinux2010 wheels:
+            # https://www.python.org/dev/peps/pep-0571/#backwards-compatibility-with-manylinux1-wheels
+            arches = [arch, 'manylinux1' + arch_sep + arch_suffix]
+        elif platform is None:
+            arches = []
+            if is_manylinux2010_compatible():
+                arches.append('manylinux2010' + arch_sep + arch_suffix)
+            if is_manylinux1_compatible():
+                arches.append('manylinux1' + arch_sep + arch_suffix)
+            arches.append(arch)
+        else:
+            arches = [arch]
+
+        # Current version, current API (built specifically for our Python):
+        for abi in abis:
+            for arch in arches:
+                supported.append(('%s%s' % (impl, versions[0]), abi, arch))
+
+        # abi3 modules compatible with older version of Python
+        for version in versions[1:]:
+            # abi3 was introduced in Python 3.2
+            if version in {'31', '30'}:
+                break
+            for abi in abi3s:   # empty set if not Python 3
+                for arch in arches:
+                    supported.append(("%s%s" % (impl, version), abi, arch))
+
+        # Has binaries, does not use the Python API:
+        for arch in arches:
+            supported.append(('py%s' % (versions[0][0]), 'none', arch))
+
+    # No abi / arch, but requires our implementation:
+    supported.append(('%s%s' % (impl, versions[0]), 'none', 'any'))
+    # Tagged specifically as being cross-version compatible
+    # (with just the major version specified)
+    supported.append(('%s%s' % (impl, versions[0][0]), 'none', 'any'))
+
+    # No abi / arch, generic Python
+    for i, version in enumerate(versions):
+        supported.append(('py%s' % (version,), 'none', 'any'))
+        if i == 0:
+            supported.append(('py%s' % (version[0]), 'none', 'any'))
+
+    return supported
+
+
+implementation_tag = get_impl_tag()
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/pep425tags.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/pep425tags.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..1e95569bbf58f088416d62432c85062e31f78a5e
GIT binary patch
literal 11594
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

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/pyproject.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/pyproject.py
new file mode 100644
index 0000000..13a8f35
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/pyproject.py
@@ -0,0 +1,282 @@
+from __future__ import absolute_import
+
+import io
+import os
+import sys
+
+from pip._vendor import pytoml, six
+
+from pip._internal.exceptions import InstallationError
+from pip._internal.utils.typing import MYPY_CHECK_RUNNING
+
+if MYPY_CHECK_RUNNING:
+    from typing import Any, Dict, List, Optional, Tuple
+
+    Pep517Data = Tuple[str, List[str]]
+
+
+def _is_list_of_str(obj):
+    # type: (Any) -> bool
+    return (
+        isinstance(obj, list) and
+        all(isinstance(item, six.string_types) for item in obj)
+    )
+
+
+def make_pyproject_path(setup_py_dir):
+    # type: (str) -> str
+    path = os.path.join(setup_py_dir, 'pyproject.toml')
+
+    # Python2 __file__ should not be unicode
+    if six.PY2 and isinstance(path, six.text_type):
+        path = path.encode(sys.getfilesystemencoding())
+
+    return path
+
+
+def read_pyproject_toml(path):
+    # type: (str) -> Optional[Dict[str, str]]
+    """
+    Read a project's pyproject.toml file.
+
+    :param path: The path to the pyproject.toml file.
+
+    :return: The "build_system" value specified in the project's
+        pyproject.toml file.
+    """
+    with io.open(path, encoding="utf-8") as f:
+        pp_toml = pytoml.load(f)
+    build_system = pp_toml.get("build-system")
+
+    return build_system
+
+
+def make_editable_error(req_name, reason):
+    """
+    :param req_name: the name of the requirement.
+    :param reason: the reason the requirement is being processed as
+        pyproject.toml-style.
+    """
+    message = (
+        'Error installing {!r}: editable mode is not supported for '
+        'pyproject.toml-style projects. This project is being processed '
+        'as pyproject.toml-style because {}. '
+        'See PEP 517 for the relevant specification.'
+    ).format(req_name, reason)
+    return InstallationError(message)
+
+
+def get_build_system_requires(build_system, req_name):
+    if build_system is None:
+        return None
+
+    # Ensure that the build-system section in pyproject.toml conforms
+    # to PEP 518.
+    error_template = (
+        "{package} has a pyproject.toml file that does not comply "
+        "with PEP 518: {reason}"
+    )
+
+    # Specifying the build-system table but not the requires key is invalid
+    if "requires" not in build_system:
+        raise InstallationError(
+            error_template.format(package=req_name, reason=(
+                "it has a 'build-system' table but not "
+                "'build-system.requires' which is mandatory in the table"
+            ))
+        )
+
+    # Error out if requires is not a list of strings
+    requires = build_system["requires"]
+    if not _is_list_of_str(requires):
+        raise InstallationError(error_template.format(
+            package=req_name,
+            reason="'build-system.requires' is not a list of strings.",
+        ))
+
+    return requires
+
+
+def resolve_pyproject_toml(
+    build_system,  # type: Optional[Dict[str, Any]]
+    has_pyproject,  # type: bool
+    has_setup,  # type: bool
+    use_pep517,  # type: Optional[bool]
+    editable,  # type: bool
+    req_name,  # type: str
+):
+    # type: (...) -> Tuple[Optional[List[str]], Optional[Pep517Data]]
+    """
+    Return how a pyproject.toml file's contents should be interpreted.
+
+    :param build_system: the "build_system" value specified in a project's
+        pyproject.toml file, or None if the project either doesn't have the
+        file or does but the file doesn't have a "build_system" value.
+    :param has_pyproject: whether the project has a pyproject.toml file.
+    :param has_setup: whether the project has a setup.py file.
+    :param use_pep517: whether the user requested PEP 517 processing.  None
+        means the user didn't explicitly specify.
+    :param editable: whether editable mode was requested for the requirement.
+    :param req_name: the name of the requirement we're processing (for
+        error reporting).
+
+    :return: a tuple (requires, pep517_data), where `requires` is the list
+      of build requirements from pyproject.toml (or else None).  The value
+      `pep517_data` is None if `use_pep517` is False.  Otherwise, it is the
+      tuple (backend, check), where `backend` is the name of the PEP 517
+      backend and `check` is the list of requirements we should check are
+      installed after setting up the build environment.
+    """
+    # The following cases must use PEP 517
+    # We check for use_pep517 being non-None and falsey because that means
+    # the user explicitly requested --no-use-pep517.  The value 0 as
+    # opposed to False can occur when the value is provided via an
+    # environment variable or config file option (due to the quirk of
+    # strtobool() returning an integer in pip's configuration code).
+    if has_pyproject and not has_setup:
+        if use_pep517 is not None and not use_pep517:
+            raise InstallationError(
+                "Disabling PEP 517 processing is invalid: "
+                "project does not have a setup.py"
+            )
+        if editable:
+            raise make_editable_error(
+                req_name, 'it has a pyproject.toml file and no setup.py'
+            )
+        use_pep517 = True
+    elif build_system and "build-backend" in build_system:
+        if use_pep517 is not None and not use_pep517:
+            raise InstallationError(
+                "Disabling PEP 517 processing is invalid: "
+                "project specifies a build backend of {} "
+                "in pyproject.toml".format(
+                    build_system["build-backend"]
+                )
+            )
+        if editable:
+            reason = (
+                'it has a pyproject.toml file with a "build-backend" key '
+                'in the "build_system" value'
+            )
+            raise make_editable_error(req_name, reason)
+        use_pep517 = True
+    elif use_pep517:
+        if editable:
+            raise make_editable_error(
+                req_name, 'PEP 517 processing was explicitly requested'
+            )
+
+    # 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 (provided editable mode wasn't requested).
+    elif use_pep517 is None:
+        if has_pyproject and editable:
+            message = (
+                'Error installing {!r}: editable mode is not supported for '
+                'pyproject.toml-style projects. pip is processing this '
+                'project as pyproject.toml-style because it has a '
+                'pyproject.toml file. Since the project has a setup.py and '
+                'the pyproject.toml has no "build-backend" key for the '
+                '"build_system" value, you may pass --no-use-pep517 to opt '
+                'out of pyproject.toml-style processing. '
+                'See PEP 517 for details on pyproject.toml-style projects.'
+            ).format(req_name)
+            raise InstallationError(message)
+
+        use_pep517 = has_pyproject
+
+    # At this point, we know whether we're going to use PEP 517.
+    assert use_pep517 is not None
+
+    requires = get_build_system_requires(build_system, req_name=req_name)
+
+    # If we're using the legacy code path, there is nothing further
+    # for us to do here.
+    if not use_pep517:
+        return (requires, None)
+
+    if build_system is None:
+        # Either the user has a pyproject.toml with no build-system
+        # section, or the user has no pyproject.toml, but has opted in
+        # explicitly via --use-pep517.
+        # In the absence of any explicit backend specification, we
+        # assume the setuptools backend that most closely emulates the
+        # traditional direct setup.py execution, and require wheel and
+        # a version of setuptools that supports that backend.
+
+        requires = ["setuptools>=40.8.0", "wheel"]
+        build_system = {
+            "build-backend": "setuptools.build_meta:__legacy__",
+        }
+
+    # If we're using PEP 517, we have build system information (either
+    # from pyproject.toml, or defaulted by the code above).
+    # Note that at this point, we do not know if the user has actually
+    # specified a backend, though.
+    assert build_system is not None
+
+    backend = build_system.get("build-backend")
+    check = []  # type: List[str]
+    if backend is None:
+        # If the user didn't specify a backend, we assume they want to use
+        # the setuptools backend. But we can't be sure they have included
+        # a version of setuptools which supplies the backend, or wheel
+        # (which is needed by the backend) in their requirements. So we
+        # make a note to check that those requirements are present once
+        # we have set up the environment.
+        # This is quite a lot of work to check for a very specific case. But
+        # the problem is, that case is potentially quite common - projects that
+        # adopted PEP 518 early for the ability to specify requirements to
+        # execute setup.py, but never considered needing to mention the build
+        # tools themselves. The original PEP 518 code had a similar check (but
+        # implemented in a different way).
+        backend = "setuptools.build_meta:__legacy__"
+        check = ["setuptools>=40.8.0", "wheel"]
+
+    return (requires, (backend, check))
+
+
+def load_pyproject_toml(
+    use_pep517,  # type: Optional[bool]
+    editable,  # type: bool
+    pyproject_toml,  # type: str
+    setup_py,  # type: str
+    req_name  # type: str
+):
+    # type: (...) -> Tuple[Optional[List[str]], Optional[Pep517Data]]
+    """Load the pyproject.toml file.
+
+    Parameters:
+        use_pep517 - Has the user requested PEP 517 processing? None
+                     means the user hasn't explicitly specified.
+        editable - Whether editable mode was requested for the requirement.
+        pyproject_toml - Location of the project's pyproject.toml file
+        setup_py - Location of the project's setup.py file
+        req_name - The name of the requirement we're processing (for
+                   error reporting)
+
+    Returns: (requires, pep_517_data)
+      requires: requirements from pyproject.toml (can be None).
+      pep_517_data: None if we should use the legacy code path, otherwise:
+        (
+            name of PEP 517 backend,
+            requirements we should check are installed after setting up
+            the build environment
+        )
+    """
+    has_pyproject = os.path.isfile(pyproject_toml)
+    has_setup = os.path.isfile(setup_py)
+
+    if has_pyproject:
+        build_system = read_pyproject_toml(pyproject_toml)
+    else:
+        build_system = None
+
+    return resolve_pyproject_toml(
+        build_system=build_system,
+        has_pyproject=has_pyproject,
+        has_setup=has_setup,
+        use_pep517=use_pep517,
+        editable=editable,
+        req_name=req_name,
+    )
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/pyproject.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/pyproject.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..81ce6cf9a60c037f00d48aa597a836ce74e81def
GIT binary patch
literal 7954
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
QlY^6+Q;?INQ=YRM0FNJR{Qv*}

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/req/__init__.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/req/__init__.py
new file mode 100644
index 0000000..c39f63f
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/req/__init__.py
@@ -0,0 +1,78 @@
+from __future__ import absolute_import
+
+import logging
+
+from .req_install import InstallRequirement
+from .req_set import RequirementSet
+from .req_file import parse_requirements
+from pip._internal.utils.logging import indent_log
+from pip._internal.utils.typing import MYPY_CHECK_RUNNING
+
+if MYPY_CHECK_RUNNING:
+    from typing import Any, List, Sequence
+
+__all__ = [
+    "RequirementSet", "InstallRequirement",
+    "parse_requirements", "install_given_reqs",
+]
+
+logger = logging.getLogger(__name__)
+
+
+def install_given_reqs(
+    to_install,  # type: List[InstallRequirement]
+    install_options,  # type: List[str]
+    global_options=(),  # type: Sequence[str]
+    *args,  # type: Any
+    **kwargs  # type: Any
+):
+    # type: (...) -> List[InstallRequirement]
+    """
+    Install everything in the given list.
+
+    (to be called after having downloaded and unpacked the packages)
+    """
+
+    if to_install:
+        logger.info(
+            'Installing collected packages: %s',
+            ', '.join([req.name for req in to_install]),
+        )
+
+    with indent_log():
+        for requirement in to_install:
+            if requirement.conflicts_with:
+                logger.info(
+                    'Found existing installation: %s',
+                    requirement.conflicts_with,
+                )
+                with indent_log():
+                    uninstalled_pathset = requirement.uninstall(
+                        auto_confirm=True
+                    )
+            try:
+                requirement.install(
+                    install_options,
+                    global_options,
+                    *args,
+                    **kwargs
+                )
+            except Exception:
+                should_rollback = (
+                    requirement.conflicts_with and
+                    not requirement.install_succeeded
+                )
+                # if install did not succeed, rollback previous uninstall
+                if should_rollback:
+                    uninstalled_pathset.rollback()
+                raise
+            else:
+                should_commit = (
+                    requirement.conflicts_with and
+                    requirement.install_succeeded
+                )
+                if should_commit:
+                    uninstalled_pathset.commit()
+            requirement.remove_temporary_source()
+
+    return to_install
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/req/__init__.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/req/__init__.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..82c56e85ecdf7b98d3b7f97dcd102fa94faf8345
GIT binary patch
literal 1982
zcmZSn%**AGdLky70SZ_c7#JKJ7#NBVF)%QsFfgPrGUPBY<T5fuF)}cM_)H8rObk&>
z3@OYEDJ%>*%nZ3K3{fl$j37QMLk=rLE*nD>8-&lski*W9%fS%E0ny9Oki*H4%f%4I
z1>tir<Zv_O@-Rg4FfgX_FceJ$+sMg~!^@D%#}LKGkju{y#m|r{zz`+Cz?jFtkix}~
z!p)Gv!;r$ukj}yoCCHG<#E>P#kSfg3%*YTW!jQtxkiy5%!pIOM%8<gu5Ue4<z`&3R
z@|y-D0|P?|KLZ0pVp4H_PH9PMd}eMzeo={ECP)S%EyTdU;F(ukl9-bdlv-GtS(KWa
znpXmm<6~f8KoSg2g^Gjp6eJcEr^Xi{v=l@1aDi;kOG(WuiO<PThlqjH`$h&t#yfks
zI(x?lh5Gq<`nhW`gPaE<9P=tmK(XMHSzJ=W!N9-}oLX3#nwOj!!~}8y$gx2nbtNE!
zG9iwQPtPn%%>y~0I2j}dvX_T}fx#aXlPZi13^fc4MHUPt3=CO}peRjYV#s1*NC%6%
z#PT!LvNF`LGGs9`#4#}x%7DVMnF$==B`gfh3=I8u85k?Bf(&tqJ<Cwb#!$n?kj2VS
zGy!HJGgJhm3#vt&ff1yN4U|es*cqA`7;D)X!c$lo0weMm7%HW}Iye|=7#V7q7;2aq
zYFHThm>3wt^Q;(HN;ny^xfqI`F)%WM4Pj--KLu9L#lTa`!BE4&Q1pPIhMggc8{|4r
z!f0Y($Wvp80NKdOkpB&;xR#TlhLfR)hY_Tf2c{OJh!@N$^kfK!IH`t#Ay|Wrfq|j8
zl!1YPOF=<F0h$gJQp-|{DoZjl^U@VE^At)lQWd~~t&o#hT%yMXR;p2wuaK0gkery4
zlbWKCm{yWnq>zzV2GWv}U!IqfpO^v?&r4A#%_~Su&Q47Mn*(Adrl%Hbf(<EFL?k|t
z&gA@@oYdr!)D#7nIx7X$;$l!D&`~IsXJBA(%P-AKQAn-GEG_|QfTo4SlFa-(kkS%R
z3P>z1$&XLY&r8cJ%JtI#rQs5gH*@mS(^HGU=`1rZEg#It%FoOLGx8F1Q-eTBumq$Y
zq&X)uxuiJ0JhLRDgp+}Rp)?O_7g%{nQE6%kJ2<6-a}HREYejNu0mvmKf(V)T;?m^g
z)YO#J6mY^W%FoG3N=(iMyC^w7H#f7SM4W+vp(r&szbrMrBo&lD6N@V2i}Op1l2bK6
zsk#JA<j2Dt0Lsu%c6>hA!eX$i({u8Z5_8}}Am1bwr5A&($}R^pK^dhewXlR6Y$ZIm
zmk1;KFf}E<Ah9H)IJE>^b`)pim*%9z!(Gk`N-_{JhzB&lWetcZ&ShX=&@U*;EK4j&
z)h|md(of6JNl7g#)=x^&FHcI!%Qej{HZn{yPp?Y1FtsSp$*M9l0D<&8{Sf_v%mQ7g
zzjWQoJUop9Ktf;~pP5&ZT9lWVqhFL-s2?AnnU`4-AFo$X8N|uJz#s;4ksZhZd~A$t
zjLeLh%v_ATjGSOL7ZVpFC!-J(GnmKB$jr#i#LL9V$i>XY$jivi%*n{f1Y(IWLHq$S
z3>@O|@oA+crA4Xn@j)P?!O;y$Lz#K$u<(OLNf4-n0xKv=EsQTtEdiHXkO)sLj8DtV
zNrjYO(hLj?1(^kUaR2C)mSpA>>p{(hq(CVgib^UAGV{`dSV5&GC_zK{AZ8FKEe3%~
zPOvND;}dgo;^V=oGCj4#2a@tZ((&=2lpY@+1WEzmz=QZ2<U=rv{!s`HCY#*+l+v73
fJ5WFtOE54n2r%(52{1w-6C0yEGaDlhGd~*uGN9Mf

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/req/constructors.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/req/constructors.py
new file mode 100644
index 0000000..0f18b6a
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/req/constructors.py
@@ -0,0 +1,340 @@
+"""Backing implementation for InstallRequirement's various constructors
+
+The idea here is that these formed a major chunk of InstallRequirement's size
+so, moving them and support code dedicated to them outside of that class
+helps creates for better understandability for the rest of the code.
+
+These are meant to be used elsewhere within pip to create instances of
+InstallRequirement.
+"""
+
+import logging
+import os
+import re
+
+from pip._vendor.packaging.markers import Marker
+from pip._vendor.packaging.requirements import InvalidRequirement, Requirement
+from pip._vendor.packaging.specifiers import Specifier
+from pip._vendor.pkg_resources import RequirementParseError, parse_requirements
+
+from pip._internal.download import (
+    is_archive_file, is_url, path_to_url, url_to_path,
+)
+from pip._internal.exceptions import InstallationError
+from pip._internal.models.index import PyPI, TestPyPI
+from pip._internal.models.link import Link
+from pip._internal.pyproject import make_pyproject_path
+from pip._internal.req.req_install import InstallRequirement
+from pip._internal.utils.misc import is_installable_dir
+from pip._internal.utils.typing import MYPY_CHECK_RUNNING
+from pip._internal.vcs import vcs
+from pip._internal.wheel import Wheel
+
+if MYPY_CHECK_RUNNING:
+    from typing import (
+        Any, Dict, Optional, Set, Tuple, Union,
+    )
+    from pip._internal.cache import WheelCache
+
+
+__all__ = [
+    "install_req_from_editable", "install_req_from_line",
+    "parse_editable"
+]
+
+logger = logging.getLogger(__name__)
+operators = Specifier._operators.keys()
+
+
+def _strip_extras(path):
+    # type: (str) -> Tuple[str, Optional[str]]
+    m = re.match(r'^(.+)(\[[^\]]+\])$', path)
+    extras = None
+    if m:
+        path_no_extras = m.group(1)
+        extras = m.group(2)
+    else:
+        path_no_extras = path
+
+    return path_no_extras, extras
+
+
+def parse_editable(editable_req):
+    # type: (str) -> Tuple[Optional[str], str, Optional[Set[str]]]
+    """Parses an editable requirement into:
+        - a requirement name
+        - an URL
+        - extras
+        - editable options
+    Accepted requirements:
+        svn+http://blahblah@rev#egg=Foobar[baz]&subdirectory=version_subdir
+        .[some_extra]
+    """
+
+    url = editable_req
+
+    # If a file path is specified with extras, strip off the extras.
+    url_no_extras, extras = _strip_extras(url)
+
+    if os.path.isdir(url_no_extras):
+        if not os.path.exists(os.path.join(url_no_extras, 'setup.py')):
+            msg = (
+                'File "setup.py" not found. Directory cannot be installed '
+                'in editable mode: {}'.format(os.path.abspath(url_no_extras))
+            )
+            pyproject_path = make_pyproject_path(url_no_extras)
+            if os.path.isfile(pyproject_path):
+                msg += (
+                    '\n(A "pyproject.toml" file was found, but editable '
+                    'mode currently requires a setup.py based build.)'
+                )
+            raise InstallationError(msg)
+
+        # Treating it as code that has already been checked out
+        url_no_extras = path_to_url(url_no_extras)
+
+    if url_no_extras.lower().startswith('file:'):
+        package_name = Link(url_no_extras).egg_fragment
+        if extras:
+            return (
+                package_name,
+                url_no_extras,
+                Requirement("placeholder" + extras.lower()).extras,
+            )
+        else:
+            return package_name, url_no_extras, None
+
+    for version_control in vcs:
+        if url.lower().startswith('%s:' % version_control):
+            url = '%s+%s' % (version_control, url)
+            break
+
+    if '+' not in url:
+        raise InstallationError(
+            '%s should either be a path to a local project or a VCS url '
+            'beginning with svn+, git+, hg+, or bzr+' %
+            editable_req
+        )
+
+    vc_type = url.split('+', 1)[0].lower()
+
+    if not vcs.get_backend(vc_type):
+        error_message = 'For --editable=%s only ' % editable_req + \
+            ', '.join([backend.name + '+URL' for backend in vcs.backends]) + \
+            ' is currently supported'
+        raise InstallationError(error_message)
+
+    package_name = Link(url).egg_fragment
+    if not package_name:
+        raise InstallationError(
+            "Could not detect requirement name for '%s', please specify one "
+            "with #egg=your_package_name" % editable_req
+        )
+    return package_name, url, None
+
+
+def deduce_helpful_msg(req):
+    # type: (str) -> str
+    """Returns helpful msg in case requirements file does not exist,
+    or cannot be parsed.
+
+    :params req: Requirements file path
+    """
+    msg = ""
+    if os.path.exists(req):
+        msg = " It does exist."
+        # Try to parse and check if it is a requirements file.
+        try:
+            with open(req, 'r') as fp:
+                # parse first line only
+                next(parse_requirements(fp.read()))
+                msg += " The argument you provided " + \
+                    "(%s) appears to be a" % (req) + \
+                    " requirements file. If that is the" + \
+                    " case, use the '-r' flag to install" + \
+                    " the packages specified within it."
+        except RequirementParseError:
+            logger.debug("Cannot parse '%s' as requirements \
+            file" % (req), exc_info=True)
+    else:
+        msg += " File '%s' does not exist." % (req)
+    return msg
+
+
+# ---- The actual constructors follow ----
+
+
+def install_req_from_editable(
+    editable_req,  # type: str
+    comes_from=None,  # type: Optional[str]
+    use_pep517=None,  # type: Optional[bool]
+    isolated=False,  # type: bool
+    options=None,  # type: Optional[Dict[str, Any]]
+    wheel_cache=None,  # type: Optional[WheelCache]
+    constraint=False  # type: bool
+):
+    # type: (...) -> InstallRequirement
+    name, url, extras_override = parse_editable(editable_req)
+    if url.startswith('file:'):
+        source_dir = url_to_path(url)
+    else:
+        source_dir = None
+
+    if name is not None:
+        try:
+            req = Requirement(name)
+        except InvalidRequirement:
+            raise InstallationError("Invalid requirement: '%s'" % name)
+    else:
+        req = None
+    return InstallRequirement(
+        req, comes_from, source_dir=source_dir,
+        editable=True,
+        link=Link(url),
+        constraint=constraint,
+        use_pep517=use_pep517,
+        isolated=isolated,
+        options=options if options else {},
+        wheel_cache=wheel_cache,
+        extras=extras_override or (),
+    )
+
+
+def install_req_from_line(
+    name,  # type: str
+    comes_from=None,  # type: Optional[Union[str, InstallRequirement]]
+    use_pep517=None,  # type: Optional[bool]
+    isolated=False,  # type: bool
+    options=None,  # type: Optional[Dict[str, Any]]
+    wheel_cache=None,  # type: Optional[WheelCache]
+    constraint=False  # type: bool
+):
+    # type: (...) -> InstallRequirement
+    """Creates an InstallRequirement from a name, which might be a
+    requirement, directory containing 'setup.py', filename, or URL.
+    """
+    if is_url(name):
+        marker_sep = '; '
+    else:
+        marker_sep = ';'
+    if marker_sep in name:
+        name, markers_as_string = name.split(marker_sep, 1)
+        markers_as_string = markers_as_string.strip()
+        if not markers_as_string:
+            markers = None
+        else:
+            markers = Marker(markers_as_string)
+    else:
+        markers = None
+    name = name.strip()
+    req_as_string = None
+    path = os.path.normpath(os.path.abspath(name))
+    link = None
+    extras_as_string = None
+
+    if is_url(name):
+        link = Link(name)
+    else:
+        p, extras_as_string = _strip_extras(path)
+        looks_like_dir = os.path.isdir(p) and (
+            os.path.sep in name or
+            (os.path.altsep is not None and os.path.altsep in name) or
+            name.startswith('.')
+        )
+        if looks_like_dir:
+            if not is_installable_dir(p):
+                raise InstallationError(
+                    "Directory %r is not installable. Neither 'setup.py' "
+                    "nor 'pyproject.toml' found." % name
+                )
+            link = Link(path_to_url(p))
+        elif is_archive_file(p):
+            if not os.path.isfile(p):
+                logger.warning(
+                    'Requirement %r looks like a filename, but the '
+                    'file does not exist',
+                    name
+                )
+            link = Link(path_to_url(p))
+
+    # it's a local file, dir, or url
+    if link:
+        # Handle relative file URLs
+        if link.scheme == 'file' and re.search(r'\.\./', link.url):
+            link = Link(
+                path_to_url(os.path.normpath(os.path.abspath(link.path))))
+        # wheel file
+        if link.is_wheel:
+            wheel = Wheel(link.filename)  # can raise InvalidWheelFilename
+            req_as_string = "%s==%s" % (wheel.name, wheel.version)
+        else:
+            # set the req to the egg fragment.  when it's not there, this
+            # will become an 'unnamed' requirement
+            req_as_string = link.egg_fragment
+
+    # a requirement specifier
+    else:
+        req_as_string = name
+
+    if extras_as_string:
+        extras = Requirement("placeholder" + extras_as_string.lower()).extras
+    else:
+        extras = ()
+    if req_as_string is not None:
+        try:
+            req = Requirement(req_as_string)
+        except InvalidRequirement:
+            if os.path.sep in req_as_string:
+                add_msg = "It looks like a path."
+                add_msg += deduce_helpful_msg(req_as_string)
+            elif ('=' in req_as_string and
+                  not any(op in req_as_string for op in operators)):
+                add_msg = "= is not a valid operator. Did you mean == ?"
+            else:
+                add_msg = ""
+            raise InstallationError(
+                "Invalid requirement: '%s'\n%s" % (req_as_string, add_msg)
+            )
+    else:
+        req = None
+
+    return InstallRequirement(
+        req, comes_from, link=link, markers=markers,
+        use_pep517=use_pep517, isolated=isolated,
+        options=options if options else {},
+        wheel_cache=wheel_cache,
+        constraint=constraint,
+        extras=extras,
+    )
+
+
+def install_req_from_req_string(
+    req_string,  # type: str
+    comes_from=None,  # type: Optional[InstallRequirement]
+    isolated=False,  # type: bool
+    wheel_cache=None,  # type: Optional[WheelCache]
+    use_pep517=None  # type: Optional[bool]
+):
+    # type: (...) -> InstallRequirement
+    try:
+        req = Requirement(req_string)
+    except InvalidRequirement:
+        raise InstallationError("Invalid requirement: '%s'" % req_string)
+
+    domains_not_allowed = [
+        PyPI.file_storage_domain,
+        TestPyPI.file_storage_domain,
+    ]
+    if (req.url and comes_from and comes_from.link and
+            comes_from.link.netloc in domains_not_allowed):
+        # Explicitly disallow pypi packages that depend on external urls
+        raise InstallationError(
+            "Packages installed from PyPI cannot depend on packages "
+            "which are not also hosted on PyPI.\n"
+            "%s depends on %s " % (comes_from.name, req)
+        )
+
+    return InstallRequirement(
+        req, comes_from, isolated=isolated, wheel_cache=wheel_cache,
+        use_pep517=use_pep517
+    )
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/req/constructors.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/req/constructors.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..2f49220e85ac7821f2661f111bb6130adf7fa302
GIT binary patch
literal 9643
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
PM;=0hNS<^M$;=1<%#Y!r

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/req/req_file.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/req/req_file.py
new file mode 100644
index 0000000..270b75c
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/req/req_file.py
@@ -0,0 +1,383 @@
+"""
+Requirements file parsing
+"""
+
+from __future__ import absolute_import
+
+import optparse
+import os
+import re
+import shlex
+import sys
+
+from pip._vendor.six.moves import filterfalse
+from pip._vendor.six.moves.urllib import parse as urllib_parse
+
+from pip._internal.cli import cmdoptions
+from pip._internal.download import get_file_content
+from pip._internal.exceptions import RequirementsFileParseError
+from pip._internal.req.constructors import (
+    install_req_from_editable, install_req_from_line,
+)
+from pip._internal.utils.typing import MYPY_CHECK_RUNNING
+
+if MYPY_CHECK_RUNNING:
+    from typing import (
+        Any, Callable, Iterator, List, NoReturn, Optional, Text, Tuple,
+    )
+    from pip._internal.req import InstallRequirement
+    from pip._internal.cache import WheelCache
+    from pip._internal.index import PackageFinder
+    from pip._internal.download import PipSession
+
+    ReqFileLines = Iterator[Tuple[int, Text]]
+
+__all__ = ['parse_requirements']
+
+SCHEME_RE = re.compile(r'^(http|https|file):', re.I)
+COMMENT_RE = re.compile(r'(^|\s)+#.*$')
+
+# Matches environment variable-style values in '${MY_VARIABLE_1}' with the
+# variable name consisting of only uppercase letters, digits or the '_'
+# (underscore). This follows the POSIX standard defined in IEEE Std 1003.1,
+# 2013 Edition.
+ENV_VAR_RE = re.compile(r'(?P<var>\$\{(?P<name>[A-Z0-9_]+)\})')
+
+SUPPORTED_OPTIONS = [
+    cmdoptions.constraints,
+    cmdoptions.editable,
+    cmdoptions.requirements,
+    cmdoptions.no_index,
+    cmdoptions.index_url,
+    cmdoptions.find_links,
+    cmdoptions.extra_index_url,
+    cmdoptions.always_unzip,
+    cmdoptions.no_binary,
+    cmdoptions.only_binary,
+    cmdoptions.pre,
+    cmdoptions.trusted_host,
+    cmdoptions.require_hashes,
+]  # type: List[Callable[..., optparse.Option]]
+
+# options to be passed to requirements
+SUPPORTED_OPTIONS_REQ = [
+    cmdoptions.install_options,
+    cmdoptions.global_options,
+    cmdoptions.hash,
+]  # type: List[Callable[..., optparse.Option]]
+
+# the 'dest' string values
+SUPPORTED_OPTIONS_REQ_DEST = [str(o().dest) for o in SUPPORTED_OPTIONS_REQ]
+
+
+def parse_requirements(
+    filename,  # type: str
+    finder=None,  # type: Optional[PackageFinder]
+    comes_from=None,  # type: Optional[str]
+    options=None,  # type: Optional[optparse.Values]
+    session=None,  # type: Optional[PipSession]
+    constraint=False,  # type: bool
+    wheel_cache=None,  # type: Optional[WheelCache]
+    use_pep517=None  # type: Optional[bool]
+):
+    # type: (...) -> Iterator[InstallRequirement]
+    """Parse a requirements file and yield InstallRequirement instances.
+
+    :param filename:    Path or url of requirements file.
+    :param finder:      Instance of pip.index.PackageFinder.
+    :param comes_from:  Origin description of requirements.
+    :param options:     cli options.
+    :param session:     Instance of pip.download.PipSession.
+    :param constraint:  If true, parsing a constraint file rather than
+        requirements file.
+    :param wheel_cache: Instance of pip.wheel.WheelCache
+    :param use_pep517:  Value of the --use-pep517 option.
+    """
+    if session is None:
+        raise TypeError(
+            "parse_requirements() missing 1 required keyword argument: "
+            "'session'"
+        )
+
+    _, content = get_file_content(
+        filename, comes_from=comes_from, session=session
+    )
+
+    lines_enum = preprocess(content, options)
+
+    for line_number, line in lines_enum:
+        req_iter = process_line(line, filename, line_number, finder,
+                                comes_from, options, session, wheel_cache,
+                                use_pep517=use_pep517, constraint=constraint)
+        for req in req_iter:
+            yield req
+
+
+def preprocess(content, options):
+    # type: (Text, Optional[optparse.Values]) -> ReqFileLines
+    """Split, filter, and join lines, and return a line iterator
+
+    :param content: the content of the requirements file
+    :param options: cli options
+    """
+    lines_enum = enumerate(content.splitlines(), start=1)  # type: ReqFileLines
+    lines_enum = join_lines(lines_enum)
+    lines_enum = ignore_comments(lines_enum)
+    lines_enum = skip_regex(lines_enum, options)
+    lines_enum = expand_env_variables(lines_enum)
+    return lines_enum
+
+
+def process_line(
+    line,  # type: Text
+    filename,  # type: str
+    line_number,  # type: int
+    finder=None,  # type: Optional[PackageFinder]
+    comes_from=None,  # type: Optional[str]
+    options=None,  # type: Optional[optparse.Values]
+    session=None,  # type: Optional[PipSession]
+    wheel_cache=None,  # type: Optional[WheelCache]
+    use_pep517=None,  # type: Optional[bool]
+    constraint=False  # type: bool
+):
+    # type: (...) -> Iterator[InstallRequirement]
+    """Process a single requirements line; This can result in creating/yielding
+    requirements, or updating the finder.
+
+    For lines that contain requirements, the only options that have an effect
+    are from SUPPORTED_OPTIONS_REQ, and they are scoped to the
+    requirement. Other options from SUPPORTED_OPTIONS may be present, but are
+    ignored.
+
+    For lines that do not contain requirements, the only options that have an
+    effect are from SUPPORTED_OPTIONS. Options from SUPPORTED_OPTIONS_REQ may
+    be present, but are ignored. These lines may contain multiple options
+    (although our docs imply only one is supported), and all our parsed and
+    affect the finder.
+
+    :param constraint: If True, parsing a constraints file.
+    :param options: OptionParser options that we may update
+    """
+    parser = build_parser(line)
+    defaults = parser.get_default_values()
+    defaults.index_url = None
+    if finder:
+        defaults.format_control = finder.format_control
+    args_str, options_str = break_args_options(line)
+    # Prior to 2.7.3, shlex cannot deal with unicode entries
+    if sys.version_info < (2, 7, 3):
+        # https://github.com/python/mypy/issues/1174
+        options_str = options_str.encode('utf8')  # type: ignore
+    # https://github.com/python/mypy/issues/1174
+    opts, _ = parser.parse_args(
+        shlex.split(options_str), defaults)  # type: ignore
+
+    # preserve for the nested code path
+    line_comes_from = '%s %s (line %s)' % (
+        '-c' if constraint else '-r', filename, line_number,
+    )
+
+    # yield a line requirement
+    if args_str:
+        isolated = options.isolated_mode if options else False
+        if options:
+            cmdoptions.check_install_build_global(options, opts)
+        # get the options that apply to requirements
+        req_options = {}
+        for dest in SUPPORTED_OPTIONS_REQ_DEST:
+            if dest in opts.__dict__ and opts.__dict__[dest]:
+                req_options[dest] = opts.__dict__[dest]
+        yield install_req_from_line(
+            args_str, line_comes_from, constraint=constraint,
+            use_pep517=use_pep517,
+            isolated=isolated, options=req_options, wheel_cache=wheel_cache
+        )
+
+    # yield an editable requirement
+    elif opts.editables:
+        isolated = options.isolated_mode if options else False
+        yield install_req_from_editable(
+            opts.editables[0], comes_from=line_comes_from,
+            use_pep517=use_pep517,
+            constraint=constraint, isolated=isolated, wheel_cache=wheel_cache
+        )
+
+    # parse a nested requirements file
+    elif opts.requirements or opts.constraints:
+        if opts.requirements:
+            req_path = opts.requirements[0]
+            nested_constraint = False
+        else:
+            req_path = opts.constraints[0]
+            nested_constraint = True
+        # original file is over http
+        if SCHEME_RE.search(filename):
+            # do a url join so relative paths work
+            req_path = urllib_parse.urljoin(filename, req_path)
+        # original file and nested file are paths
+        elif not SCHEME_RE.search(req_path):
+            # do a join so relative paths work
+            req_path = os.path.join(os.path.dirname(filename), req_path)
+        # TODO: Why not use `comes_from='-r {} (line {})'` here as well?
+        parsed_reqs = parse_requirements(
+            req_path, finder, comes_from, options, session,
+            constraint=nested_constraint, wheel_cache=wheel_cache
+        )
+        for req in parsed_reqs:
+            yield req
+
+    # percolate hash-checking option upward
+    elif opts.require_hashes:
+        options.require_hashes = opts.require_hashes
+
+    # set finder options
+    elif finder:
+        if opts.index_url:
+            finder.index_urls = [opts.index_url]
+        if opts.no_index is True:
+            finder.index_urls = []
+        if opts.extra_index_urls:
+            finder.index_urls.extend(opts.extra_index_urls)
+        if opts.find_links:
+            # FIXME: it would be nice to keep track of the source
+            # of the find_links: support a find-links local path
+            # relative to a requirements file.
+            value = opts.find_links[0]
+            req_dir = os.path.dirname(os.path.abspath(filename))
+            relative_to_reqs_file = os.path.join(req_dir, value)
+            if os.path.exists(relative_to_reqs_file):
+                value = relative_to_reqs_file
+            finder.find_links.append(value)
+        if opts.pre:
+            finder.allow_all_prereleases = True
+        if opts.trusted_hosts:
+            finder.secure_origins.extend(
+                ("*", host, "*") for host in opts.trusted_hosts)
+
+
+def break_args_options(line):
+    # type: (Text) -> Tuple[str, Text]
+    """Break up the line into an args and options string.  We only want to shlex
+    (and then optparse) the options, not the args.  args can contain markers
+    which are corrupted by shlex.
+    """
+    tokens = line.split(' ')
+    args = []
+    options = tokens[:]
+    for token in tokens:
+        if token.startswith('-') or token.startswith('--'):
+            break
+        else:
+            args.append(token)
+            options.pop(0)
+    return ' '.join(args), ' '.join(options)  # type: ignore
+
+
+def build_parser(line):
+    # type: (Text) -> optparse.OptionParser
+    """
+    Return a parser for parsing requirement lines
+    """
+    parser = optparse.OptionParser(add_help_option=False)
+
+    option_factories = SUPPORTED_OPTIONS + SUPPORTED_OPTIONS_REQ
+    for option_factory in option_factories:
+        option = option_factory()
+        parser.add_option(option)
+
+    # By default optparse sys.exits on parsing errors. We want to wrap
+    # that in our own exception.
+    def parser_exit(self, msg):
+        # type: (Any, str) -> NoReturn
+        # add offending line
+        msg = 'Invalid requirement: %s\n%s' % (line, msg)
+        raise RequirementsFileParseError(msg)
+    # NOTE: mypy disallows assigning to a method
+    #       https://github.com/python/mypy/issues/2427
+    parser.exit = parser_exit  # type: ignore
+
+    return parser
+
+
+def join_lines(lines_enum):
+    # type: (ReqFileLines) -> ReqFileLines
+    """Joins a line ending in '\' with the previous line (except when following
+    comments).  The joined line takes on the index of the first line.
+    """
+    primary_line_number = None
+    new_line = []  # type: List[Text]
+    for line_number, line in lines_enum:
+        if not line.endswith('\\') or COMMENT_RE.match(line):
+            if COMMENT_RE.match(line):
+                # this ensures comments are always matched later
+                line = ' ' + line
+            if new_line:
+                new_line.append(line)
+                yield primary_line_number, ''.join(new_line)
+                new_line = []
+            else:
+                yield line_number, line
+        else:
+            if not new_line:
+                primary_line_number = line_number
+            new_line.append(line.strip('\\'))
+
+    # last line contains \
+    if new_line:
+        yield primary_line_number, ''.join(new_line)
+
+    # TODO: handle space after '\'.
+
+
+def ignore_comments(lines_enum):
+    # type: (ReqFileLines) -> ReqFileLines
+    """
+    Strips comments and filter empty lines.
+    """
+    for line_number, line in lines_enum:
+        line = COMMENT_RE.sub('', line)
+        line = line.strip()
+        if line:
+            yield line_number, line
+
+
+def skip_regex(lines_enum, options):
+    # type: (ReqFileLines, Optional[optparse.Values]) -> ReqFileLines
+    """
+    Skip lines that match '--skip-requirements-regex' pattern
+
+    Note: the regex pattern is only built once
+    """
+    skip_regex = options.skip_requirements_regex if options else None
+    if skip_regex:
+        pattern = re.compile(skip_regex)
+        lines_enum = filterfalse(lambda e: pattern.search(e[1]), lines_enum)
+    return lines_enum
+
+
+def expand_env_variables(lines_enum):
+    # type: (ReqFileLines) -> ReqFileLines
+    """Replace all environment variables that can be retrieved via `os.getenv`.
+
+    The only allowed format for environment variables defined in the
+    requirement file is `${MY_VARIABLE_1}` to ensure two things:
+
+    1. Strings that contain a `$` aren't accidentally (partially) expanded.
+    2. Ensure consistency across platforms for requirement files.
+
+    These points are the result of a discussion on the `github pull
+    request #3514 <https://github.com/pypa/pip/pull/3514>`_.
+
+    Valid characters in variable names follow the `POSIX standard
+    <http://pubs.opengroup.org/onlinepubs/9699919799/>`_ and are limited
+    to uppercase letter, digits and the `_` (underscore).
+    """
+    for line_number, line in lines_enum:
+        for env_var, var_name in ENV_VAR_RE.findall(line):
+            value = os.getenv(var_name)
+            if not value:
+                continue
+
+            line = line.replace(env_var, value)
+
+        yield line_number, line
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/req/req_file.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/req/req_file.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..912aef8cef67aec26f8c74f4a27c89341fdaa307
GIT binary patch
literal 11785
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

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/req/req_install.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/req/req_install.py
new file mode 100644
index 0000000..111ad0c
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/req/req_install.py
@@ -0,0 +1,1030 @@
+from __future__ import absolute_import
+
+import logging
+import os
+import shutil
+import sys
+import sysconfig
+import zipfile
+from distutils.util import change_root
+
+from pip._vendor import pkg_resources, six
+from pip._vendor.packaging.requirements import Requirement
+from pip._vendor.packaging.utils import canonicalize_name
+from pip._vendor.packaging.version import Version
+from pip._vendor.packaging.version import parse as parse_version
+from pip._vendor.pep517.wrappers import Pep517HookCaller
+
+from pip._internal import wheel
+from pip._internal.build_env import NoOpBuildEnvironment
+from pip._internal.exceptions import InstallationError
+from pip._internal.locations import (
+    PIP_DELETE_MARKER_FILENAME, running_under_virtualenv,
+)
+from pip._internal.models.link import Link
+from pip._internal.pyproject import load_pyproject_toml, make_pyproject_path
+from pip._internal.req.req_uninstall import UninstallPathSet
+from pip._internal.utils.compat import native_str
+from pip._internal.utils.hashes import Hashes
+from pip._internal.utils.logging import indent_log
+from pip._internal.utils.misc import (
+    _make_build_dir, ask_path_exists, backup_dir, call_subprocess,
+    display_path, dist_in_site_packages, dist_in_usersite, ensure_dir,
+    get_installed_version, redact_password_from_url, rmtree,
+)
+from pip._internal.utils.packaging import get_metadata
+from pip._internal.utils.setuptools_build import SETUPTOOLS_SHIM
+from pip._internal.utils.temp_dir import TempDirectory
+from pip._internal.utils.typing import MYPY_CHECK_RUNNING
+from pip._internal.utils.ui import open_spinner
+from pip._internal.vcs import vcs
+from pip._internal.wheel import move_wheel_files
+
+if MYPY_CHECK_RUNNING:
+    from typing import (
+        Any, Dict, Iterable, List, Mapping, Optional, Sequence, Union,
+    )
+    from pip._internal.build_env import BuildEnvironment
+    from pip._internal.cache import WheelCache
+    from pip._internal.index import PackageFinder
+    from pip._vendor.pkg_resources import Distribution
+    from pip._vendor.packaging.specifiers import SpecifierSet
+    from pip._vendor.packaging.markers import Marker
+
+
+logger = logging.getLogger(__name__)
+
+
+class InstallRequirement(object):
+    """
+    Represents something that may be installed later on, may have information
+    about where to fetch the relevant requirement and also contains logic for
+    installing the said requirement.
+    """
+
+    def __init__(
+        self,
+        req,  # type: Optional[Requirement]
+        comes_from,  # type: Optional[Union[str, InstallRequirement]]
+        source_dir=None,  # type: Optional[str]
+        editable=False,  # type: bool
+        link=None,  # type: Optional[Link]
+        update=True,  # type: bool
+        markers=None,  # type: Optional[Marker]
+        use_pep517=None,  # type: Optional[bool]
+        isolated=False,  # type: bool
+        options=None,  # type: Optional[Dict[str, Any]]
+        wheel_cache=None,  # type: Optional[WheelCache]
+        constraint=False,  # type: bool
+        extras=()  # type: Iterable[str]
+    ):
+        # type: (...) -> None
+        assert req is None or isinstance(req, Requirement), req
+        self.req = req
+        self.comes_from = comes_from
+        self.constraint = constraint
+        if source_dir is not None:
+            self.source_dir = os.path.normpath(os.path.abspath(source_dir))
+        else:
+            self.source_dir = None
+        self.editable = editable
+
+        self._wheel_cache = wheel_cache
+        if link is None and req and req.url:
+            # PEP 508 URL requirement
+            link = Link(req.url)
+        self.link = self.original_link = link
+
+        if extras:
+            self.extras = extras
+        elif req:
+            self.extras = {
+                pkg_resources.safe_extra(extra) for extra in req.extras
+            }
+        else:
+            self.extras = set()
+        if markers is None and req:
+            markers = req.marker
+        self.markers = markers
+
+        self._egg_info_path = None  # type: Optional[str]
+        # This holds the pkg_resources.Distribution object if this requirement
+        # is already available:
+        self.satisfied_by = None
+        # This hold the pkg_resources.Distribution object if this requirement
+        # conflicts with another installed distribution:
+        self.conflicts_with = None
+        # Temporary build location
+        self._temp_build_dir = TempDirectory(kind="req-build")
+        # Used to store the global directory where the _temp_build_dir should
+        # have been created. Cf _correct_build_location method.
+        self._ideal_build_dir = None  # type: Optional[str]
+        # True if the editable should be updated:
+        self.update = update
+        # Set to True after successful installation
+        self.install_succeeded = None  # type: Optional[bool]
+        # UninstallPathSet of uninstalled distribution (for possible rollback)
+        self.uninstalled_pathset = None
+        self.options = options if options else {}
+        # Set to True after successful preparation of this requirement
+        self.prepared = False
+        self.is_direct = False
+
+        self.isolated = isolated
+        self.build_env = NoOpBuildEnvironment()  # type: BuildEnvironment
+
+        # For PEP 517, the directory where we request the project metadata
+        # gets stored. We need this to pass to build_wheel, so the backend
+        # can ensure that the wheel matches the metadata (see the PEP for
+        # details).
+        self.metadata_directory = None  # type: Optional[str]
+
+        # The static build requirements (from pyproject.toml)
+        self.pyproject_requires = None  # type: Optional[List[str]]
+
+        # Build requirements that we will check are available
+        self.requirements_to_check = []  # type: List[str]
+
+        # The PEP 517 backend we should use to build the project
+        self.pep517_backend = None  # type: Optional[Pep517HookCaller]
+
+        # Are we using PEP 517 for this requirement?
+        # After pyproject.toml has been loaded, the only valid values are True
+        # and False. Before loading, None is valid (meaning "use the default").
+        # Setting an explicit value before loading pyproject.toml is supported,
+        # but after loading this flag should be treated as read only.
+        self.use_pep517 = use_pep517
+
+    def __str__(self):
+        # type: () -> str
+        if self.req:
+            s = str(self.req)
+            if self.link:
+                s += ' from %s' % redact_password_from_url(self.link.url)
+        elif self.link:
+            s = redact_password_from_url(self.link.url)
+        else:
+            s = '<InstallRequirement>'
+        if self.satisfied_by is not None:
+            s += ' in %s' % display_path(self.satisfied_by.location)
+        if self.comes_from:
+            if isinstance(self.comes_from, six.string_types):
+                comes_from = self.comes_from
+            else:
+                comes_from = self.comes_from.from_path()
+            if comes_from:
+                s += ' (from %s)' % comes_from
+        return s
+
+    def __repr__(self):
+        # type: () -> str
+        return '<%s object: %s editable=%r>' % (
+            self.__class__.__name__, str(self), self.editable)
+
+    def populate_link(self, finder, upgrade, require_hashes):
+        # type: (PackageFinder, bool, bool) -> None
+        """Ensure that if a link can be found for this, that it is found.
+
+        Note that self.link may still be None - if Upgrade is False and the
+        requirement is already installed.
+
+        If require_hashes is True, don't use the wheel cache, because cached
+        wheels, always built locally, have different hashes than the files
+        downloaded from the index server and thus throw false hash mismatches.
+        Furthermore, cached wheels at present have undeterministic contents due
+        to file modification times.
+        """
+        if self.link is None:
+            self.link = finder.find_requirement(self, upgrade)
+        if self._wheel_cache is not None and not require_hashes:
+            old_link = self.link
+            self.link = self._wheel_cache.get(self.link, self.name)
+            if old_link != self.link:
+                logger.debug('Using cached wheel link: %s', self.link)
+
+    # Things that are valid for all kinds of requirements?
+    @property
+    def name(self):
+        # type: () -> Optional[str]
+        if self.req is None:
+            return None
+        return native_str(pkg_resources.safe_name(self.req.name))
+
+    @property
+    def specifier(self):
+        # type: () -> SpecifierSet
+        return self.req.specifier
+
+    @property
+    def is_pinned(self):
+        # type: () -> bool
+        """Return whether I am pinned to an exact version.
+
+        For example, some-package==1.2 is pinned; some-package>1.2 is not.
+        """
+        specifiers = self.specifier
+        return (len(specifiers) == 1 and
+                next(iter(specifiers)).operator in {'==', '==='})
+
+    @property
+    def installed_version(self):
+        # type: () -> Optional[str]
+        return get_installed_version(self.name)
+
+    def match_markers(self, extras_requested=None):
+        # type: (Optional[Iterable[str]]) -> bool
+        if not extras_requested:
+            # Provide an extra to safely evaluate the markers
+            # without matching any extra
+            extras_requested = ('',)
+        if self.markers is not None:
+            return any(
+                self.markers.evaluate({'extra': extra})
+                for extra in extras_requested)
+        else:
+            return True
+
+    @property
+    def has_hash_options(self):
+        # type: () -> bool
+        """Return whether any known-good hashes are specified as options.
+
+        These activate --require-hashes mode; hashes specified as part of a
+        URL do not.
+
+        """
+        return bool(self.options.get('hashes', {}))
+
+    def hashes(self, trust_internet=True):
+        # type: (bool) -> Hashes
+        """Return a hash-comparer that considers my option- and URL-based
+        hashes to be known-good.
+
+        Hashes in URLs--ones embedded in the requirements file, not ones
+        downloaded from an index server--are almost peers with ones from
+        flags. They satisfy --require-hashes (whether it was implicitly or
+        explicitly activated) but do not activate it. md5 and sha224 are not
+        allowed in flags, which should nudge people toward good algos. We
+        always OR all hashes together, even ones from URLs.
+
+        :param trust_internet: Whether to trust URL-based (#md5=...) hashes
+            downloaded from the internet, as by populate_link()
+
+        """
+        good_hashes = self.options.get('hashes', {}).copy()
+        link = self.link if trust_internet else self.original_link
+        if link and link.hash:
+            good_hashes.setdefault(link.hash_name, []).append(link.hash)
+        return Hashes(good_hashes)
+
+    def from_path(self):
+        # type: () -> Optional[str]
+        """Format a nice indicator to show where this "comes from"
+        """
+        if self.req is None:
+            return None
+        s = str(self.req)
+        if self.comes_from:
+            if isinstance(self.comes_from, six.string_types):
+                comes_from = self.comes_from
+            else:
+                comes_from = self.comes_from.from_path()
+            if comes_from:
+                s += '->' + comes_from
+        return s
+
+    def build_location(self, build_dir):
+        # type: (str) -> Optional[str]
+        assert build_dir is not None
+        if self._temp_build_dir.path is not None:
+            return self._temp_build_dir.path
+        if self.req is None:
+            # for requirement via a path to a directory: the name of the
+            # package is not available yet so we create a temp directory
+            # Once run_egg_info will have run, we'll be able
+            # to fix it via _correct_build_location
+            # Some systems have /tmp as a symlink which confuses custom
+            # builds (such as numpy). Thus, we ensure that the real path
+            # is returned.
+            self._temp_build_dir.create()
+            self._ideal_build_dir = build_dir
+
+            return self._temp_build_dir.path
+        if self.editable:
+            name = self.name.lower()
+        else:
+            name = self.name
+        # FIXME: Is there a better place to create the build_dir? (hg and bzr
+        # need this)
+        if not os.path.exists(build_dir):
+            logger.debug('Creating directory %s', build_dir)
+            _make_build_dir(build_dir)
+        return os.path.join(build_dir, name)
+
+    def _correct_build_location(self):
+        # type: () -> None
+        """Move self._temp_build_dir to self._ideal_build_dir/self.req.name
+
+        For some requirements (e.g. a path to a directory), the name of the
+        package is not available until we run egg_info, so the build_location
+        will return a temporary directory and store the _ideal_build_dir.
+
+        This is only called by self.run_egg_info to fix the temporary build
+        directory.
+        """
+        if self.source_dir is not None:
+            return
+        assert self.req is not None
+        assert self._temp_build_dir.path
+        assert (self._ideal_build_dir is not None and
+                self._ideal_build_dir.path)  # type: ignore
+        old_location = self._temp_build_dir.path
+        self._temp_build_dir.path = None
+
+        new_location = self.build_location(self._ideal_build_dir)
+        if os.path.exists(new_location):
+            raise InstallationError(
+                'A package already exists in %s; please remove it to continue'
+                % display_path(new_location))
+        logger.debug(
+            'Moving package %s from %s to new location %s',
+            self, display_path(old_location), display_path(new_location),
+        )
+        shutil.move(old_location, new_location)
+        self._temp_build_dir.path = new_location
+        self._ideal_build_dir = None
+        self.source_dir = os.path.normpath(os.path.abspath(new_location))
+        self._egg_info_path = None
+
+        # Correct the metadata directory, if it exists
+        if self.metadata_directory:
+            old_meta = self.metadata_directory
+            rel = os.path.relpath(old_meta, start=old_location)
+            new_meta = os.path.join(new_location, rel)
+            new_meta = os.path.normpath(os.path.abspath(new_meta))
+            self.metadata_directory = new_meta
+
+    def remove_temporary_source(self):
+        # type: () -> None
+        """Remove the source files from this requirement, if they are marked
+        for deletion"""
+        if self.source_dir and os.path.exists(
+                os.path.join(self.source_dir, PIP_DELETE_MARKER_FILENAME)):
+            logger.debug('Removing source in %s', self.source_dir)
+            rmtree(self.source_dir)
+        self.source_dir = None
+        self._temp_build_dir.cleanup()
+        self.build_env.cleanup()
+
+    def check_if_exists(self, use_user_site):
+        # type: (bool) -> bool
+        """Find an installed distribution that satisfies or conflicts
+        with this requirement, and set self.satisfied_by or
+        self.conflicts_with appropriately.
+        """
+        if self.req is None:
+            return False
+        try:
+            # get_distribution() will resolve the entire list of requirements
+            # anyway, and we've already determined that we need the requirement
+            # in question, so strip the marker so that we don't try to
+            # evaluate it.
+            no_marker = Requirement(str(self.req))
+            no_marker.marker = None
+            self.satisfied_by = pkg_resources.get_distribution(str(no_marker))
+            if self.editable and self.satisfied_by:
+                self.conflicts_with = self.satisfied_by
+                # when installing editables, nothing pre-existing should ever
+                # satisfy
+                self.satisfied_by = None
+                return True
+        except pkg_resources.DistributionNotFound:
+            return False
+        except pkg_resources.VersionConflict:
+            existing_dist = pkg_resources.get_distribution(
+                self.req.name
+            )
+            if use_user_site:
+                if dist_in_usersite(existing_dist):
+                    self.conflicts_with = existing_dist
+                elif (running_under_virtualenv() and
+                        dist_in_site_packages(existing_dist)):
+                    raise InstallationError(
+                        "Will not install to the user site because it will "
+                        "lack sys.path precedence to %s in %s" %
+                        (existing_dist.project_name, existing_dist.location)
+                    )
+            else:
+                self.conflicts_with = existing_dist
+        return True
+
+    # Things valid for wheels
+    @property
+    def is_wheel(self):
+        # type: () -> bool
+        if not self.link:
+            return False
+        return self.link.is_wheel
+
+    def move_wheel_files(
+        self,
+        wheeldir,  # type: 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
+        move_wheel_files(
+            self.name, self.req, wheeldir,
+            user=use_user_site,
+            home=home,
+            root=root,
+            prefix=prefix,
+            pycompile=pycompile,
+            isolated=self.isolated,
+            warn_script_location=warn_script_location,
+        )
+
+    # Things valid for sdists
+    @property
+    def setup_py_dir(self):
+        # type: () -> str
+        return os.path.join(
+            self.source_dir,
+            self.link and self.link.subdirectory_fragment or '')
+
+    @property
+    def setup_py(self):
+        # type: () -> str
+        assert self.source_dir, "No source dir for %s" % self
+
+        setup_py = os.path.join(self.setup_py_dir, 'setup.py')
+
+        # Python2 __file__ should not be unicode
+        if six.PY2 and isinstance(setup_py, six.text_type):
+            setup_py = setup_py.encode(sys.getfilesystemencoding())
+
+        return setup_py
+
+    @property
+    def pyproject_toml(self):
+        # type: () -> str
+        assert self.source_dir, "No source dir for %s" % self
+
+        return make_pyproject_path(self.setup_py_dir)
+
+    def load_pyproject_toml(self):
+        # type: () -> None
+        """Load the pyproject.toml file.
+
+        After calling this routine, all of the attributes related to PEP 517
+        processing for this requirement have been set. In particular, the
+        use_pep517 attribute can be used to determine whether we should
+        follow the PEP 517 or legacy (setup.py) code path.
+        """
+        requires, pep517_data = load_pyproject_toml(
+            self.use_pep517,
+            self.editable,
+            self.pyproject_toml,
+            self.setup_py,
+            str(self)
+        )
+
+        use_pep517 = bool(pep517_data)
+
+        self.use_pep517 = use_pep517
+        self.pyproject_requires = requires
+
+        if use_pep517:
+            backend, check = pep517_data
+            self.requirements_to_check = check
+            self.pep517_backend = Pep517HookCaller(self.setup_py_dir, backend)
+
+            # Use a custom function to call subprocesses
+            self.spin_message = ""
+
+            def runner(
+                cmd,  # type: List[str]
+                cwd=None,  # type: Optional[str]
+                extra_environ=None  # type: Optional[Mapping[str, Any]]
+            ):
+                # type: (...) -> None
+                with open_spinner(self.spin_message) as spinner:
+                    call_subprocess(
+                        cmd,
+                        cwd=cwd,
+                        extra_environ=extra_environ,
+                        spinner=spinner
+                    )
+                self.spin_message = ""
+
+            self.pep517_backend._subprocess_runner = runner
+
+    def prepare_metadata(self):
+        # type: () -> None
+        """Ensure that project metadata is available.
+
+        Under PEP 517, call the backend hook to prepare the metadata.
+        Under legacy processing, call setup.py egg-info.
+        """
+        assert self.source_dir
+
+        with indent_log():
+            if self.use_pep517:
+                self.prepare_pep517_metadata()
+            else:
+                self.run_egg_info()
+
+        if not self.req:
+            if isinstance(parse_version(self.metadata["Version"]), Version):
+                op = "=="
+            else:
+                op = "==="
+            self.req = Requirement(
+                "".join([
+                    self.metadata["Name"],
+                    op,
+                    self.metadata["Version"],
+                ])
+            )
+            self._correct_build_location()
+        else:
+            metadata_name = canonicalize_name(self.metadata["Name"])
+            if canonicalize_name(self.req.name) != metadata_name:
+                logger.warning(
+                    'Generating metadata for package %s '
+                    'produced metadata for project name %s. Fix your '
+                    '#egg=%s fragments.',
+                    self.name, metadata_name, self.name
+                )
+                self.req = Requirement(metadata_name)
+
+    def prepare_pep517_metadata(self):
+        # type: () -> None
+        assert self.pep517_backend is not None
+
+        metadata_dir = os.path.join(
+            self.setup_py_dir,
+            'pip-wheel-metadata'
+        )
+        ensure_dir(metadata_dir)
+
+        with self.build_env:
+            # Note that Pep517HookCaller implements a fallback for
+            # prepare_metadata_for_build_wheel, so we don't have to
+            # consider the possibility that this hook doesn't exist.
+            backend = self.pep517_backend
+            self.spin_message = "Preparing wheel metadata"
+            distinfo_dir = backend.prepare_metadata_for_build_wheel(
+                metadata_dir
+            )
+
+        self.metadata_directory = os.path.join(metadata_dir, distinfo_dir)
+
+    def run_egg_info(self):
+        # type: () -> None
+        if self.name:
+            logger.debug(
+                'Running setup.py (path:%s) egg_info for package %s',
+                self.setup_py, self.name,
+            )
+        else:
+            logger.debug(
+                'Running setup.py (path:%s) egg_info for package from %s',
+                self.setup_py, self.link,
+            )
+        script = SETUPTOOLS_SHIM % self.setup_py
+        base_cmd = [sys.executable, '-c', script]
+        if self.isolated:
+            base_cmd += ["--no-user-cfg"]
+        egg_info_cmd = base_cmd + ['egg_info']
+        # We can't put the .egg-info files at the root, because then the
+        # source code will be mistaken for an installed egg, causing
+        # problems
+        if self.editable:
+            egg_base_option = []  # type: List[str]
+        else:
+            egg_info_dir = os.path.join(self.setup_py_dir, 'pip-egg-info')
+            ensure_dir(egg_info_dir)
+            egg_base_option = ['--egg-base', 'pip-egg-info']
+        with self.build_env:
+            call_subprocess(
+                egg_info_cmd + egg_base_option,
+                cwd=self.setup_py_dir,
+                command_desc='python setup.py egg_info')
+
+    @property
+    def egg_info_path(self):
+        # type: () -> str
+        if self._egg_info_path is None:
+            if self.editable:
+                base = self.source_dir
+            else:
+                base = os.path.join(self.setup_py_dir, 'pip-egg-info')
+            filenames = os.listdir(base)
+            if self.editable:
+                filenames = []
+                for root, dirs, files in os.walk(base):
+                    for dir in vcs.dirnames:
+                        if dir in dirs:
+                            dirs.remove(dir)
+                    # Iterate over a copy of ``dirs``, since mutating
+                    # a list while iterating over it can cause trouble.
+                    # (See https://github.com/pypa/pip/pull/462.)
+                    for dir in list(dirs):
+                        # Don't search in anything that looks like a virtualenv
+                        # environment
+                        if (
+                                os.path.lexists(
+                                    os.path.join(root, dir, 'bin', 'python')
+                                ) or
+                                os.path.exists(
+                                    os.path.join(
+                                        root, dir, 'Scripts', 'Python.exe'
+                                    )
+                                )):
+                            dirs.remove(dir)
+                        # Also don't search through tests
+                        elif dir == 'test' or dir == 'tests':
+                            dirs.remove(dir)
+                    filenames.extend([os.path.join(root, dir)
+                                      for dir in dirs])
+                filenames = [f for f in filenames if f.endswith('.egg-info')]
+
+            if not filenames:
+                raise InstallationError(
+                    "Files/directories not found in %s" % base
+                )
+            # if we have more than one match, we pick the toplevel one.  This
+            # can easily be the case if there is a dist folder which contains
+            # an extracted tarball for testing purposes.
+            if len(filenames) > 1:
+                filenames.sort(
+                    key=lambda x: x.count(os.path.sep) +
+                    (os.path.altsep and x.count(os.path.altsep) or 0)
+                )
+            self._egg_info_path = os.path.join(base, filenames[0])
+        return self._egg_info_path
+
+    @property
+    def metadata(self):
+        # type: () -> Any
+        if not hasattr(self, '_metadata'):
+            self._metadata = get_metadata(self.get_dist())
+
+        return self._metadata
+
+    def get_dist(self):
+        # type: () -> Distribution
+        """Return a pkg_resources.Distribution for this requirement"""
+        if self.metadata_directory:
+            base_dir, distinfo = os.path.split(self.metadata_directory)
+            metadata = pkg_resources.PathMetadata(
+                base_dir, self.metadata_directory
+            )
+            dist_name = os.path.splitext(distinfo)[0]
+            typ = pkg_resources.DistInfoDistribution
+        else:
+            egg_info = self.egg_info_path.rstrip(os.path.sep)
+            base_dir = os.path.dirname(egg_info)
+            metadata = pkg_resources.PathMetadata(base_dir, egg_info)
+            dist_name = os.path.splitext(os.path.basename(egg_info))[0]
+            # https://github.com/python/mypy/issues/1174
+            typ = pkg_resources.Distribution  # type: ignore
+
+        return typ(
+            base_dir,
+            project_name=dist_name,
+            metadata=metadata,
+        )
+
+    def assert_source_matches_version(self):
+        # type: () -> None
+        assert self.source_dir
+        version = self.metadata['version']
+        if self.req.specifier and version not in self.req.specifier:
+            logger.warning(
+                'Requested %s, but installing version %s',
+                self,
+                version,
+            )
+        else:
+            logger.debug(
+                'Source in %s has version %s, which satisfies requirement %s',
+                display_path(self.source_dir),
+                version,
+                self,
+            )
+
+    # For both source distributions and editables
+    def ensure_has_source_dir(self, parent_dir):
+        # type: (str) -> str
+        """Ensure that a source_dir is set.
+
+        This will create a temporary build dir if the name of the requirement
+        isn't known yet.
+
+        :param parent_dir: The ideal pip parent_dir for the source_dir.
+            Generally src_dir for editables and build_dir for sdists.
+        :return: self.source_dir
+        """
+        if self.source_dir is None:
+            self.source_dir = self.build_location(parent_dir)
+        return self.source_dir
+
+    # For editable installations
+    def install_editable(
+        self,
+        install_options,  # type: List[str]
+        global_options=(),  # type: Sequence[str]
+        prefix=None  # type: Optional[str]
+    ):
+        # type: (...) -> None
+        logger.info('Running setup.py develop for %s', self.name)
+
+        if self.isolated:
+            global_options = list(global_options) + ["--no-user-cfg"]
+
+        if prefix:
+            prefix_param = ['--prefix={}'.format(prefix)]
+            install_options = list(install_options) + prefix_param
+
+        with indent_log():
+            # FIXME: should we do --install-headers here too?
+            with self.build_env:
+                call_subprocess(
+                    [
+                        sys.executable,
+                        '-c',
+                        SETUPTOOLS_SHIM % self.setup_py
+                    ] +
+                    list(global_options) +
+                    ['develop', '--no-deps'] +
+                    list(install_options),
+
+                    cwd=self.setup_py_dir,
+                )
+
+        self.install_succeeded = True
+
+    def update_editable(self, obtain=True):
+        # type: (bool) -> None
+        if not self.link:
+            logger.debug(
+                "Cannot update repository at %s; repository location is "
+                "unknown",
+                self.source_dir,
+            )
+            return
+        assert self.editable
+        assert self.source_dir
+        if self.link.scheme == 'file':
+            # Static paths don't get updated
+            return
+        assert '+' in self.link.url, "bad url: %r" % self.link.url
+        if not self.update:
+            return
+        vc_type, url = self.link.url.split('+', 1)
+        backend = vcs.get_backend(vc_type)
+        if backend:
+            vcs_backend = backend(self.link.url)
+            if obtain:
+                vcs_backend.obtain(self.source_dir)
+            else:
+                vcs_backend.export(self.source_dir)
+        else:
+            assert 0, (
+                'Unexpected version control type (in %s): %s'
+                % (self.link, vc_type))
+
+    # Top-level Actions
+    def uninstall(self, auto_confirm=False, verbose=False,
+                  use_user_site=False):
+        # type: (bool, bool, bool) -> Optional[UninstallPathSet]
+        """
+        Uninstall the distribution currently satisfying this requirement.
+
+        Prompts before removing or modifying files unless
+        ``auto_confirm`` is True.
+
+        Refuses to delete or modify files outside of ``sys.prefix`` -
+        thus uninstallation within a virtual environment can only
+        modify that virtual environment, even if the virtualenv is
+        linked to global site-packages.
+
+        """
+        if not self.check_if_exists(use_user_site):
+            logger.warning("Skipping %s as it is not installed.", self.name)
+            return None
+        dist = self.satisfied_by or self.conflicts_with
+
+        uninstalled_pathset = UninstallPathSet.from_dist(dist)
+        uninstalled_pathset.remove(auto_confirm, verbose)
+        return uninstalled_pathset
+
+    def _clean_zip_name(self, name, prefix):  # only used by archive.
+        # type: (str, str) -> str
+        assert name.startswith(prefix + os.path.sep), (
+            "name %r doesn't start with prefix %r" % (name, prefix)
+        )
+        name = name[len(prefix) + 1:]
+        name = name.replace(os.path.sep, '/')
+        return name
+
+    def _get_archive_name(self, path, parentdir, rootdir):
+        # type: (str, str, str) -> str
+        path = os.path.join(parentdir, path)
+        name = self._clean_zip_name(path, rootdir)
+        return self.name + '/' + name
+
+    # TODO: Investigate if this should be kept in InstallRequirement
+    #       Seems to be used only when VCS + downloads
+    def archive(self, build_dir):
+        # type: (str) -> None
+        assert self.source_dir
+        create_archive = True
+        archive_name = '%s-%s.zip' % (self.name, self.metadata["version"])
+        archive_path = os.path.join(build_dir, archive_name)
+        if os.path.exists(archive_path):
+            response = ask_path_exists(
+                'The file %s exists. (i)gnore, (w)ipe, (b)ackup, (a)bort ' %
+                display_path(archive_path), ('i', 'w', 'b', 'a'))
+            if response == 'i':
+                create_archive = False
+            elif response == 'w':
+                logger.warning('Deleting %s', display_path(archive_path))
+                os.remove(archive_path)
+            elif response == 'b':
+                dest_file = backup_dir(archive_path)
+                logger.warning(
+                    'Backing up %s to %s',
+                    display_path(archive_path),
+                    display_path(dest_file),
+                )
+                shutil.move(archive_path, dest_file)
+            elif response == 'a':
+                sys.exit(-1)
+        if create_archive:
+            zip = zipfile.ZipFile(
+                archive_path, 'w', zipfile.ZIP_DEFLATED,
+                allowZip64=True
+            )
+            dir = os.path.normcase(os.path.abspath(self.setup_py_dir))
+            for dirpath, dirnames, filenames in os.walk(dir):
+                if 'pip-egg-info' in dirnames:
+                    dirnames.remove('pip-egg-info')
+                for dirname in dirnames:
+                    dir_arcname = self._get_archive_name(dirname,
+                                                         parentdir=dirpath,
+                                                         rootdir=dir)
+                    zipdir = zipfile.ZipInfo(dir_arcname + '/')
+                    zipdir.external_attr = 0x1ED << 16  # 0o755
+                    zip.writestr(zipdir, '')
+                for filename in filenames:
+                    if filename == PIP_DELETE_MARKER_FILENAME:
+                        continue
+                    file_arcname = self._get_archive_name(filename,
+                                                          parentdir=dirpath,
+                                                          rootdir=dir)
+                    filename = os.path.join(dirpath, filename)
+                    zip.write(filename, file_arcname)
+            zip.close()
+            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 = global_options if global_options is not None else []
+        if self.editable:
+            self.install_editable(
+                install_options, global_options, prefix=prefix,
+            )
+            return
+        if self.is_wheel:
+            version = wheel.wheel_version(self.source_dir)
+            wheel.check_compatibility(version, self.name)
+
+            self.move_wheel_files(
+                self.source_dir, root=root, prefix=prefix, home=home,
+                warn_script_location=warn_script_location,
+                use_user_site=use_user_site, pycompile=pycompile,
+            )
+            self.install_succeeded = True
+            return
+
+        # 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.options.get('global_options', [])
+        install_options = list(install_options) + \
+            self.options.get('install_options', [])
+
+        if self.isolated:
+            # https://github.com/python/mypy/issues/1174
+            global_options = global_options + ["--no-user-cfg"]  # type: ignore
+
+        with TempDirectory(kind="record") as temp_dir:
+            record_filename = os.path.join(temp_dir.path, 'install-record.txt')
+            install_args = self.get_install_args(
+                global_options, record_filename, root, prefix, pycompile,
+            )
+            msg = 'Running setup.py install for %s' % (self.name,)
+            with open_spinner(msg) as spinner:
+                with indent_log():
+                    with self.build_env:
+                        call_subprocess(
+                            install_args + install_options,
+                            cwd=self.setup_py_dir,
+                            spinner=spinner,
+                        )
+
+            if not os.path.exists(record_filename):
+                logger.debug('Record file %s not found', record_filename)
+                return
+            self.install_succeeded = True
+
+            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)
+
+            with open(record_filename) as f:
+                for line in f:
+                    directory = os.path.dirname(line)
+                    if directory.endswith('.egg-info'):
+                        egg_info_dir = prepend_root(directory)
+                        break
+                else:
+                    logger.warning(
+                        'Could not find .egg-info directory in install record'
+                        ' for %s',
+                        self,
+                    )
+                    # FIXME: put the record somewhere
+                    # FIXME: should this be an error?
+                    return
+            new_lines = []
+            with open(record_filename) as f:
+                for line in f:
+                    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')
+
+    def get_install_args(
+        self,
+        global_options,  # type: Sequence[str]
+        record_filename,  # type: str
+        root,  # type: Optional[str]
+        prefix,  # type: Optional[str]
+        pycompile  # type: bool
+    ):
+        # type: (...) -> List[str]
+        install_args = [sys.executable, "-u"]
+        install_args.append('-c')
+        install_args.append(SETUPTOOLS_SHIM % self.setup_py)
+        install_args += list(global_options) + \
+            ['install', '--record', record_filename]
+        install_args += ['--single-version-externally-managed']
+
+        if root is not None:
+            install_args += ['--root', root]
+        if prefix is not None:
+            install_args += ['--prefix', prefix]
+
+        if pycompile:
+            install_args += ["--compile"]
+        else:
+            install_args += ["--no-compile"]
+
+        if running_under_virtualenv():
+            py_ver_str = 'python' + sysconfig.get_python_version()
+            install_args += ['--install-headers',
+                             os.path.join(sys.prefix, 'include', 'site',
+                                          py_ver_str, self.name)]
+
+        return install_args
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/req/req_install.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/req/req_install.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..6d5fb6156e2ca439411f2435d1ba21e9d0b3dbeb
GIT binary patch
literal 32293
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

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/req/req_set.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/req/req_set.py
new file mode 100644
index 0000000..d1966a4
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/req/req_set.py
@@ -0,0 +1,193 @@
+from __future__ import absolute_import
+
+import logging
+from collections import OrderedDict
+
+from pip._internal.exceptions import InstallationError
+from pip._internal.utils.logging import indent_log
+from pip._internal.utils.typing import MYPY_CHECK_RUNNING
+from pip._internal.wheel import Wheel
+
+if MYPY_CHECK_RUNNING:
+    from typing import Dict, Iterable, List, Optional, Tuple
+    from pip._internal.req.req_install import InstallRequirement
+
+
+logger = logging.getLogger(__name__)
+
+
+class RequirementSet(object):
+
+    def __init__(self, require_hashes=False, check_supported_wheels=True):
+        # type: (bool, bool) -> None
+        """Create a RequirementSet.
+        """
+
+        self.requirements = OrderedDict()  # type: Dict[str, InstallRequirement]  # noqa: E501
+        self.require_hashes = require_hashes
+        self.check_supported_wheels = check_supported_wheels
+
+        # Mapping of alias: real_name
+        self.requirement_aliases = {}  # type: Dict[str, str]
+        self.unnamed_requirements = []  # type: List[InstallRequirement]
+        self.successfully_downloaded = []  # type: List[InstallRequirement]
+        self.reqs_to_cleanup = []  # type: List[InstallRequirement]
+
+    def __str__(self):
+        # type: () -> str
+        reqs = [req for req in self.requirements.values()
+                if not req.comes_from]
+        reqs.sort(key=lambda req: req.name.lower())
+        return ' '.join([str(req.req) for req in reqs])
+
+    def __repr__(self):
+        # type: () -> str
+        reqs = [req for req in self.requirements.values()]
+        reqs.sort(key=lambda req: req.name.lower())
+        reqs_str = ', '.join([str(req.req) for req in reqs])
+        return ('<%s object; %d requirement(s): %s>'
+                % (self.__class__.__name__, len(reqs), reqs_str))
+
+    def add_requirement(
+        self,
+        install_req,  # type: InstallRequirement
+        parent_req_name=None,  # type: Optional[str]
+        extras_requested=None  # type: Optional[Iterable[str]]
+    ):
+        # type: (...) -> Tuple[List[InstallRequirement], Optional[InstallRequirement]]  # noqa: E501
+        """Add install_req as a requirement to install.
+
+        :param parent_req_name: The name of the requirement that needed this
+            added. The name is used because when multiple unnamed requirements
+            resolve to the same name, we could otherwise end up with dependency
+            links that point outside the Requirements set. parent_req must
+            already be added. Note that None implies that this is a user
+            supplied requirement, vs an inferred one.
+        :param extras_requested: an iterable of extras used to evaluate the
+            environment markers.
+        :return: Additional requirements to scan. That is either [] if
+            the requirement is not applicable, or [install_req] if the
+            requirement is applicable and has just been added.
+        """
+        name = install_req.name
+
+        # 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",
+                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)
+            if self.check_supported_wheels and not wheel.supported():
+                raise InstallationError(
+                    "%s is not a supported wheel on this platform." %
+                    wheel.filename
+                )
+
+        # This next bit is really a sanity check.
+        assert install_req.is_direct == (parent_req_name is None), (
+            "a direct req shouldn't have a parent and also, "
+            "a non direct req should have a parent"
+        )
+
+        # Unnamed requirements are scanned again and the requirement won't be
+        # added as a dependency until after scanning.
+        if not name:
+            # url or path requirement w/o an egg fragment
+            self.unnamed_requirements.append(install_req)
+            return [install_req], None
+
+        try:
+            existing_req = self.get_requirement(name)
+        except KeyError:
+            existing_req = None
+
+        has_conflicting_requirement = (
+            parent_req_name is None and
+            existing_req and
+            not existing_req.constraint and
+            existing_req.extras == install_req.extras and
+            existing_req.req.specifier != install_req.req.specifier
+        )
+        if has_conflicting_requirement:
+            raise InstallationError(
+                "Double requirement given: %s (already in %s, name=%r)"
+                % (install_req, existing_req, name)
+            )
+
+        # When no existing requirement exists, add the requirement as a
+        # dependency and it will be scanned again after.
+        if not existing_req:
+            self.requirements[name] = install_req
+            # FIXME: what about other normalizations?  E.g., _ vs. -?
+            if name.lower() != name:
+                self.requirement_aliases[name.lower()] = name
+            # We'd want to rescan this requirements later
+            return [install_req], install_req
+
+        # Assume there's no need to scan, and that we've already
+        # encountered this for scanning.
+        if install_req.constraint or not existing_req.constraint:
+            return [], existing_req
+
+        does_not_satisfy_constraint = (
+            install_req.link and
+            not (
+                existing_req.link and
+                install_req.link.path == existing_req.link.path
+            )
+        )
+        if does_not_satisfy_constraint:
+            self.reqs_to_cleanup.append(install_req)
+            raise InstallationError(
+                "Could not satisfy constraints for '%s': "
+                "installation from path or url cannot be "
+                "constrained to a version" % name,
+            )
+        # If we're now installing a constraint, mark the existing
+        # object for real installation.
+        existing_req.constraint = False
+        existing_req.extras = tuple(sorted(
+            set(existing_req.extras) | set(install_req.extras)
+        ))
+        logger.debug(
+            "Setting %s extras to: %s",
+            existing_req, existing_req.extras,
+        )
+        # Return the existing requirement for addition to the parent and
+        # scanning again.
+        return [existing_req], existing_req
+
+    def has_requirement(self, project_name):
+        # type: (str) -> bool
+        name = project_name.lower()
+        if (name in self.requirements and
+           not self.requirements[name].constraint or
+           name in self.requirement_aliases and
+           not self.requirements[self.requirement_aliases[name]].constraint):
+            return True
+        return False
+
+    def get_requirement(self, project_name):
+        # type: (str) -> InstallRequirement
+        for name in project_name, project_name.lower():
+            if name in self.requirements:
+                return self.requirements[name]
+            if name in self.requirement_aliases:
+                return self.requirements[self.requirement_aliases[name]]
+        raise KeyError("No project with the name %r" % project_name)
+
+    def cleanup_files(self):
+        # type: () -> None
+        """Clean up files, remove builds."""
+        logger.debug('Cleaning up...')
+        with indent_log():
+            for req in self.reqs_to_cleanup:
+                req.remove_temporary_source()
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/req/req_set.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/req/req_set.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..a375d3a67001777b0cc44a936334f5e37145162e
GIT binary patch
literal 6797
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
T6krly1Vbh^Mh!+`W`1S>(p6=s

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/req/req_tracker.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/req/req_tracker.py
new file mode 100644
index 0000000..e36a3f6
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/req/req_tracker.py
@@ -0,0 +1,96 @@
+from __future__ import absolute_import
+
+import contextlib
+import errno
+import hashlib
+import logging
+import os
+
+from pip._internal.utils.temp_dir import TempDirectory
+from pip._internal.utils.typing import MYPY_CHECK_RUNNING
+
+if MYPY_CHECK_RUNNING:
+    from types import TracebackType
+    from typing import Iterator, Optional, Set, Type
+    from pip._internal.req.req_install import InstallRequirement
+    from pip._internal.models.link import Link
+
+logger = logging.getLogger(__name__)
+
+
+class RequirementTracker(object):
+
+    def __init__(self):
+        # type: () -> None
+        self._root = os.environ.get('PIP_REQ_TRACKER')
+        if self._root is None:
+            self._temp_dir = TempDirectory(delete=False, kind='req-tracker')
+            self._temp_dir.create()
+            self._root = os.environ['PIP_REQ_TRACKER'] = self._temp_dir.path
+            logger.debug('Created requirements tracker %r', self._root)
+        else:
+            self._temp_dir = None
+            logger.debug('Re-using requirements tracker %r', self._root)
+        self._entries = set()  # type: Set[InstallRequirement]
+
+    def __enter__(self):
+        # type: () -> RequirementTracker
+        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
+        link = req.link
+        info = str(req)
+        entry_path = self._entry_path(link)
+        try:
+            with open(entry_path) as fp:
+                # Error, these's already a build in progress.
+                raise LookupError('%s is already being built: %s'
+                                  % (link, fp.read()))
+        except IOError as e:
+            if e.errno != errno.ENOENT:
+                raise
+            assert req not in self._entries
+            with open(entry_path, 'w') as fp:
+                fp.write(info)
+            self._entries.add(req)
+            logger.debug('Added %s to build tracker %r', req, self._root)
+
+    def remove(self, req):
+        # type: (InstallRequirement) -> None
+        link = req.link
+        self._entries.remove(req)
+        os.unlink(self._entry_path(link))
+        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)
+        remove = self._temp_dir is not None
+        if remove:
+            self._temp_dir.cleanup()
+        logger.debug('%s build tracker %r',
+                     'Removed' if remove else 'Cleaned',
+                     self._root)
+
+    @contextlib.contextmanager
+    def track(self, req):
+        # type: (InstallRequirement) -> Iterator[None]
+        self.add(req)
+        yield
+        self.remove(req)
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/req/req_tracker.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/req/req_tracker.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..000063c61a0f155dd937966fe4ef2d9d1d9b9b8d
GIT binary patch
literal 4564
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
T5?~Zy0%dC@Mgc})CVplB6e0JZ

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/req/req_uninstall.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/req/req_uninstall.py
new file mode 100644
index 0000000..733301c
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/req/req_uninstall.py
@@ -0,0 +1,633 @@
+from __future__ import absolute_import
+
+import csv
+import functools
+import logging
+import os
+import sys
+import sysconfig
+
+from pip._vendor import pkg_resources
+
+from pip._internal.exceptions import UninstallationError
+from pip._internal.locations import bin_py, bin_user
+from pip._internal.utils.compat import WINDOWS, cache_from_source, uses_pycache
+from pip._internal.utils.logging import indent_log
+from pip._internal.utils.misc import (
+    FakeFile, ask, dist_in_usersite, dist_is_local, egg_link_path, is_local,
+    normalize_path, renames, rmtree,
+)
+from pip._internal.utils.temp_dir import AdjacentTempDirectory, TempDirectory
+from pip._internal.utils.typing import MYPY_CHECK_RUNNING
+
+if MYPY_CHECK_RUNNING:
+    from typing import (
+        Any, Callable, Dict, Iterable, Iterator, List, Optional, Set, Tuple,
+    )
+    from pip._vendor.pkg_resources import Distribution
+
+logger = logging.getLogger(__name__)
+
+
+def _script_names(dist, script_name, is_gui):
+    # type: (Distribution, str, bool) -> List[str]
+    """Create the fully qualified name of the files created by
+    {console,gui}_scripts for the given ``dist``.
+    Returns the list of file names
+    """
+    if dist_in_usersite(dist):
+        bin_dir = bin_user
+    else:
+        bin_dir = bin_py
+    exe_name = os.path.join(bin_dir, script_name)
+    paths_to_remove = [exe_name]
+    if WINDOWS:
+        paths_to_remove.append(exe_name + '.exe')
+        paths_to_remove.append(exe_name + '.exe.manifest')
+        if is_gui:
+            paths_to_remove.append(exe_name + '-script.pyw')
+        else:
+            paths_to_remove.append(exe_name + '-script.py')
+    return paths_to_remove
+
+
+def _unique(fn):
+    # type: (Callable) -> Callable[..., Iterator[Any]]
+    @functools.wraps(fn)
+    def unique(*args, **kw):
+        # type: (Any, Any) -> Iterator[Any]
+        seen = set()  # type: Set[Any]
+        for item in fn(*args, **kw):
+            if item not in seen:
+                seen.add(item)
+                yield item
+    return unique
+
+
+@_unique
+def uninstallation_paths(dist):
+    # type: (Distribution) -> Iterator[str]
+    """
+    Yield all the uninstallation paths for dist based on RECORD-without-.py[co]
+
+    Yield paths to all the files in RECORD. For each .py file in RECORD, add
+    the .pyc and .pyo in the same directory.
+
+    UninstallPathSet.add() takes care of the __pycache__ .py[co].
+    """
+    r = csv.reader(FakeFile(dist.get_metadata_lines('RECORD')))
+    for row in r:
+        path = os.path.join(dist.location, row[0])
+        yield path
+        if path.endswith('.py'):
+            dn, fn = os.path.split(path)
+            base = fn[:-3]
+            path = os.path.join(dn, base + '.pyc')
+            yield path
+            path = os.path.join(dn, base + '.pyo')
+            yield path
+
+
+def compact(paths):
+    # type: (Iterable[str]) -> Set[str]
+    """Compact a path set to contain the minimal number of paths
+    necessary to contain all paths in the set. If /a/path/ and
+    /a/path/to/a/file.txt are both in the set, leave only the
+    shorter path."""
+
+    sep = os.path.sep
+    short_paths = set()  # type: Set[str]
+    for path in sorted(paths, key=len):
+        should_skip = any(
+            path.startswith(shortpath.rstrip("*")) and
+            path[len(shortpath.rstrip("*").rstrip(sep))] == sep
+            for shortpath in short_paths
+        )
+        if not should_skip:
+            short_paths.add(path)
+    return short_paths
+
+
+def compress_for_rename(paths):
+    # type: (Iterable[str]) -> Set[str]
+    """Returns a set containing the paths that need to be renamed.
+
+    This set may include directories when the original sequence of paths
+    included every file on disk.
+    """
+    case_map = dict((os.path.normcase(p), p) for p in paths)
+    remaining = set(case_map)
+    unchecked = sorted(set(os.path.split(p)[0]
+                           for p in case_map.values()), key=len)
+    wildcards = set()  # type: Set[str]
+
+    def norm_join(*a):
+        # type: (str) -> str
+        return os.path.normcase(os.path.join(*a))
+
+    for root in unchecked:
+        if any(os.path.normcase(root).startswith(w)
+               for w in wildcards):
+            # This directory has already been handled.
+            continue
+
+        all_files = set()  # type: Set[str]
+        all_subdirs = set()  # type: Set[str]
+        for dirname, subdirs, files in os.walk(root):
+            all_subdirs.update(norm_join(root, dirname, d)
+                               for d in subdirs)
+            all_files.update(norm_join(root, dirname, f)
+                             for f in files)
+        # If all the files we found are in our remaining set of files to
+        # remove, then remove them from the latter set and add a wildcard
+        # for the directory.
+        if not (all_files - remaining):
+            remaining.difference_update(all_files)
+            wildcards.add(root + os.sep)
+
+    return set(map(case_map.__getitem__, remaining)) | wildcards
+
+
+def compress_for_output_listing(paths):
+    # type: (Iterable[str]) -> Tuple[Set[str], Set[str]]
+    """Returns a tuple of 2 sets of which paths to display to user
+
+    The first set contains paths that would be deleted. Files of a package
+    are not added and the top-level directory of the package has a '*' added
+    at the end - to signify that all it's contents are removed.
+
+    The second set contains files that would have been skipped in the above
+    folders.
+    """
+
+    will_remove = set(paths)
+    will_skip = set()
+
+    # Determine folders and files
+    folders = set()
+    files = set()
+    for path in will_remove:
+        if path.endswith(".pyc"):
+            continue
+        if path.endswith("__init__.py") or ".dist-info" in path:
+            folders.add(os.path.dirname(path))
+        files.add(path)
+
+    # probably this one https://github.com/python/mypy/issues/390
+    _normcased_files = set(map(os.path.normcase, files))  # type: ignore
+
+    folders = compact(folders)
+
+    # This walks the tree using os.walk to not miss extra folders
+    # that might get added.
+    for folder in folders:
+        for dirpath, _, dirfiles in os.walk(folder):
+            for fname in dirfiles:
+                if fname.endswith(".pyc"):
+                    continue
+
+                file_ = os.path.join(dirpath, fname)
+                if (os.path.isfile(file_) and
+                        os.path.normcase(file_) not in _normcased_files):
+                    # We are skipping this file. Add it to the set.
+                    will_skip.add(file_)
+
+    will_remove = files | {
+        os.path.join(folder, "*") for folder in folders
+    }
+
+    return will_remove, will_skip
+
+
+class StashedUninstallPathSet(object):
+    """A set of file rename operations to stash files while
+    tentatively uninstalling them."""
+    def __init__(self):
+        # type: () -> None
+        # Mapping from source file root to [Adjacent]TempDirectory
+        # for files under that directory.
+        self._save_dirs = {}  # type: Dict[str, TempDirectory]
+        # (old path, new path) tuples for each move that may need
+        # to be undone.
+        self._moves = []  # type: List[Tuple[str, str]]
+
+    def _get_directory_stash(self, path):
+        # type: (str) -> str
+        """Stashes a directory.
+
+        Directories are stashed adjacent to their original location if
+        possible, or else moved/copied into the user's temp dir."""
+
+        try:
+            save_dir = AdjacentTempDirectory(path)  # type: TempDirectory
+            save_dir.create()
+        except OSError:
+            save_dir = TempDirectory(kind="uninstall")
+            save_dir.create()
+        self._save_dirs[os.path.normcase(path)] = save_dir
+
+        return save_dir.path
+
+    def _get_file_stash(self, path):
+        # type: (str) -> str
+        """Stashes a file.
+
+        If no root has been provided, one will be created for the directory
+        in the user's temp directory."""
+        path = os.path.normcase(path)
+        head, old_head = os.path.dirname(path), None
+        save_dir = None
+
+        while head != old_head:
+            try:
+                save_dir = self._save_dirs[head]
+                break
+            except KeyError:
+                pass
+            head, old_head = os.path.dirname(head), head
+        else:
+            # Did not find any suitable root
+            head = os.path.dirname(path)
+            save_dir = TempDirectory(kind='uninstall')
+            save_dir.create()
+            self._save_dirs[head] = save_dir
+
+        relpath = os.path.relpath(path, head)
+        if relpath and relpath != os.path.curdir:
+            return os.path.join(save_dir.path, relpath)
+        return save_dir.path
+
+    def stash(self, path):
+        # type: (str) -> str
+        """Stashes the directory or file and returns its new location.
+        """
+        if os.path.isdir(path):
+            new_path = self._get_directory_stash(path)
+        else:
+            new_path = self._get_file_stash(path)
+
+        self._moves.append((path, new_path))
+        if os.path.isdir(path) and os.path.isdir(new_path):
+            # If we're moving a directory, we need to
+            # remove the destination first or else it will be
+            # moved to inside the existing directory.
+            # We just created new_path ourselves, so it will
+            # be removable.
+            os.rmdir(new_path)
+        renames(path, new_path)
+        return new_path
+
+    def commit(self):
+        # type: () -> None
+        """Commits the uninstall by removing stashed files."""
+        for _, save_dir in self._save_dirs.items():
+            save_dir.cleanup()
+        self._moves = []
+        self._save_dirs = {}
+
+    def rollback(self):
+        # type: () -> None
+        """Undoes the uninstall by moving stashed files back."""
+        for p in self._moves:
+            logging.info("Moving to %s\n from %s", *p)
+
+        for new_path, path in self._moves:
+            try:
+                logger.debug('Replacing %s from %s', new_path, path)
+                if os.path.isfile(new_path):
+                    os.unlink(new_path)
+                elif os.path.isdir(new_path):
+                    rmtree(new_path)
+                renames(path, new_path)
+            except OSError as ex:
+                logger.error("Failed to restore %s", new_path)
+                logger.debug("Exception: %s", ex)
+
+        self.commit()
+
+    @property
+    def can_rollback(self):
+        # type: () -> bool
+        return bool(self._moves)
+
+
+class UninstallPathSet(object):
+    """A set of file paths to be removed in the uninstallation of a
+    requirement."""
+    def __init__(self, dist):
+        # type: (Distribution) -> None
+        self.paths = set()  # type: Set[str]
+        self._refuse = set()  # type: Set[str]
+        self.pth = {}  # type: Dict[str, UninstallPthEntries]
+        self.dist = dist
+        self._moved_paths = StashedUninstallPathSet()
+
+    def _permitted(self, path):
+        # type: (str) -> bool
+        """
+        Return True if the given path is one we are permitted to
+        remove/modify, False otherwise.
+
+        """
+        return is_local(path)
+
+    def add(self, path):
+        # type: (str) -> None
+        head, tail = os.path.split(path)
+
+        # we normalize the head to resolve parent directory symlinks, but not
+        # the tail, since we only want to uninstall symlinks, not their targets
+        path = os.path.join(normalize_path(head), os.path.normcase(tail))
+
+        if not os.path.exists(path):
+            return
+        if self._permitted(path):
+            self.paths.add(path)
+        else:
+            self._refuse.add(path)
+
+        # __pycache__ files can show up after 'installed-files.txt' is created,
+        # due to imports
+        if os.path.splitext(path)[1] == '.py' and uses_pycache:
+            self.add(cache_from_source(path))
+
+    def add_pth(self, pth_file, entry):
+        # type: (str, str) -> None
+        pth_file = normalize_path(pth_file)
+        if self._permitted(pth_file):
+            if pth_file not in self.pth:
+                self.pth[pth_file] = UninstallPthEntries(pth_file)
+            self.pth[pth_file].add(entry)
+        else:
+            self._refuse.add(pth_file)
+
+    def remove(self, auto_confirm=False, verbose=False):
+        # type: (bool, bool) -> None
+        """Remove paths in ``self.paths`` with confirmation (unless
+        ``auto_confirm`` is True)."""
+
+        if not self.paths:
+            logger.info(
+                "Can't uninstall '%s'. No files were found to uninstall.",
+                self.dist.project_name,
+            )
+            return
+
+        dist_name_version = (
+            self.dist.project_name + "-" + self.dist.version
+        )
+        logger.info('Uninstalling %s:', dist_name_version)
+
+        with indent_log():
+            if auto_confirm or self._allowed_to_proceed(verbose):
+                moved = self._moved_paths
+
+                for_rename = compress_for_rename(self.paths)
+
+                for path in sorted(compact(for_rename)):
+                    moved.stash(path)
+                    logger.debug('Removing file or directory %s', path)
+
+                for pth in self.pth.values():
+                    pth.remove()
+
+                logger.info('Successfully uninstalled %s', dist_name_version)
+
+    def _allowed_to_proceed(self, verbose):
+        # type: (bool) -> bool
+        """Display which files would be deleted and prompt for confirmation
+        """
+
+        def _display(msg, paths):
+            # type: (str, Iterable[str]) -> None
+            if not paths:
+                return
+
+            logger.info(msg)
+            with indent_log():
+                for path in sorted(compact(paths)):
+                    logger.info(path)
+
+        if not verbose:
+            will_remove, will_skip = compress_for_output_listing(self.paths)
+        else:
+            # In verbose mode, display all the files that are going to be
+            # deleted.
+            will_remove = set(self.paths)
+            will_skip = set()
+
+        _display('Would remove:', will_remove)
+        _display('Would not remove (might be manually added):', will_skip)
+        _display('Would not remove (outside of prefix):', self._refuse)
+        if verbose:
+            _display('Will actually move:', compress_for_rename(self.paths))
+
+        return ask('Proceed (y/n)? ', ('y', 'n')) == 'y'
+
+    def rollback(self):
+        # type: () -> None
+        """Rollback the changes previously made by remove()."""
+        if not self._moved_paths.can_rollback:
+            logger.error(
+                "Can't roll back %s; was not uninstalled",
+                self.dist.project_name,
+            )
+            return
+        logger.info('Rolling back uninstall of %s', self.dist.project_name)
+        self._moved_paths.rollback()
+        for pth in self.pth.values():
+            pth.rollback()
+
+    def commit(self):
+        # type: () -> None
+        """Remove temporary save dir: rollback will no longer be possible."""
+        self._moved_paths.commit()
+
+    @classmethod
+    def from_dist(cls, dist):
+        # type: (Distribution) -> UninstallPathSet
+        dist_path = normalize_path(dist.location)
+        if not dist_is_local(dist):
+            logger.info(
+                "Not uninstalling %s at %s, outside environment %s",
+                dist.key,
+                dist_path,
+                sys.prefix,
+            )
+            return cls(dist)
+
+        if dist_path in {p for p in {sysconfig.get_path("stdlib"),
+                                     sysconfig.get_path("platstdlib")}
+                         if p}:
+            logger.info(
+                "Not uninstalling %s at %s, as it is in the standard library.",
+                dist.key,
+                dist_path,
+            )
+            return cls(dist)
+
+        paths_to_remove = cls(dist)
+        develop_egg_link = egg_link_path(dist)
+        develop_egg_link_egg_info = '{}.egg-info'.format(
+            pkg_resources.to_filename(dist.project_name))
+        egg_info_exists = dist.egg_info and os.path.exists(dist.egg_info)
+        # Special case for distutils installed package
+        distutils_egg_info = getattr(dist._provider, 'path', None)
+
+        # Uninstall cases order do matter as in the case of 2 installs of the
+        # same package, pip needs to uninstall the currently detected version
+        if (egg_info_exists and dist.egg_info.endswith('.egg-info') and
+                not dist.egg_info.endswith(develop_egg_link_egg_info)):
+            # if dist.egg_info.endswith(develop_egg_link_egg_info), we
+            # are in fact in the develop_egg_link case
+            paths_to_remove.add(dist.egg_info)
+            if dist.has_metadata('installed-files.txt'):
+                for installed_file in dist.get_metadata(
+                        'installed-files.txt').splitlines():
+                    path = os.path.normpath(
+                        os.path.join(dist.egg_info, installed_file)
+                    )
+                    paths_to_remove.add(path)
+            # FIXME: need a test for this elif block
+            # occurs with --single-version-externally-managed/--record outside
+            # of pip
+            elif dist.has_metadata('top_level.txt'):
+                if dist.has_metadata('namespace_packages.txt'):
+                    namespaces = dist.get_metadata('namespace_packages.txt')
+                else:
+                    namespaces = []
+                for top_level_pkg in [
+                        p for p
+                        in dist.get_metadata('top_level.txt').splitlines()
+                        if p and p not in namespaces]:
+                    path = os.path.join(dist.location, top_level_pkg)
+                    paths_to_remove.add(path)
+                    paths_to_remove.add(path + '.py')
+                    paths_to_remove.add(path + '.pyc')
+                    paths_to_remove.add(path + '.pyo')
+
+        elif distutils_egg_info:
+            raise UninstallationError(
+                "Cannot uninstall {!r}. It is a distutils installed project "
+                "and thus we cannot accurately determine which files belong "
+                "to it which would lead to only a partial uninstall.".format(
+                    dist.project_name,
+                )
+            )
+
+        elif dist.location.endswith('.egg'):
+            # package installed by easy_install
+            # We cannot match on dist.egg_name because it can slightly vary
+            # i.e. setuptools-0.6c11-py2.6.egg vs setuptools-0.6rc11-py2.6.egg
+            paths_to_remove.add(dist.location)
+            easy_install_egg = os.path.split(dist.location)[1]
+            easy_install_pth = os.path.join(os.path.dirname(dist.location),
+                                            'easy-install.pth')
+            paths_to_remove.add_pth(easy_install_pth, './' + easy_install_egg)
+
+        elif egg_info_exists and dist.egg_info.endswith('.dist-info'):
+            for path in uninstallation_paths(dist):
+                paths_to_remove.add(path)
+
+        elif develop_egg_link:
+            # develop egg
+            with open(develop_egg_link, 'r') as fh:
+                link_pointer = os.path.normcase(fh.readline().strip())
+            assert (link_pointer == dist.location), (
+                'Egg-link %s does not match installed location of %s '
+                '(at %s)' % (link_pointer, dist.project_name, dist.location)
+            )
+            paths_to_remove.add(develop_egg_link)
+            easy_install_pth = os.path.join(os.path.dirname(develop_egg_link),
+                                            'easy-install.pth')
+            paths_to_remove.add_pth(easy_install_pth, dist.location)
+
+        else:
+            logger.debug(
+                'Not sure how to uninstall: %s - Check: %s',
+                dist, dist.location,
+            )
+
+        # find distutils scripts= scripts
+        if dist.has_metadata('scripts') and dist.metadata_isdir('scripts'):
+            for script in dist.metadata_listdir('scripts'):
+                if dist_in_usersite(dist):
+                    bin_dir = bin_user
+                else:
+                    bin_dir = bin_py
+                paths_to_remove.add(os.path.join(bin_dir, script))
+                if WINDOWS:
+                    paths_to_remove.add(os.path.join(bin_dir, script) + '.bat')
+
+        # find console_scripts
+        _scripts_to_remove = []
+        console_scripts = dist.get_entry_map(group='console_scripts')
+        for name in console_scripts.keys():
+            _scripts_to_remove.extend(_script_names(dist, name, False))
+        # find gui_scripts
+        gui_scripts = dist.get_entry_map(group='gui_scripts')
+        for name in gui_scripts.keys():
+            _scripts_to_remove.extend(_script_names(dist, name, True))
+
+        for s in _scripts_to_remove:
+            paths_to_remove.add(s)
+
+        return paths_to_remove
+
+
+class UninstallPthEntries(object):
+    def __init__(self, pth_file):
+        # type: (str) -> None
+        if not os.path.isfile(pth_file):
+            raise UninstallationError(
+                "Cannot remove entries from nonexistent file %s" % pth_file
+            )
+        self.file = pth_file
+        self.entries = set()  # type: Set[str]
+        self._saved_lines = None  # type: Optional[List[bytes]]
+
+    def add(self, entry):
+        # type: (str) -> None
+        entry = os.path.normcase(entry)
+        # On Windows, os.path.normcase converts the entry to use
+        # backslashes.  This is correct for entries that describe absolute
+        # paths outside of site-packages, but all the others use forward
+        # slashes.
+        if WINDOWS and not os.path.splitdrive(entry)[0]:
+            entry = entry.replace('\\', '/')
+        self.entries.add(entry)
+
+    def remove(self):
+        # type: () -> None
+        logger.debug('Removing pth entries from %s:', self.file)
+        with open(self.file, 'rb') as fh:
+            # windows uses '\r\n' with py3k, but uses '\n' with py2.x
+            lines = fh.readlines()
+            self._saved_lines = lines
+        if any(b'\r\n' in line for line in lines):
+            endline = '\r\n'
+        else:
+            endline = '\n'
+        # handle missing trailing newline
+        if lines and not lines[-1].endswith(endline.encode("utf-8")):
+            lines[-1] = lines[-1] + endline.encode("utf-8")
+        for entry in self.entries:
+            try:
+                logger.debug('Removing entry: %s', entry)
+                lines.remove((entry + endline).encode("utf-8"))
+            except ValueError:
+                pass
+        with open(self.file, 'wb') as fh:
+            fh.writelines(lines)
+
+    def rollback(self):
+        # type: () -> bool
+        if self._saved_lines is None:
+            logger.error(
+                'Cannot roll back changes to %s, none were made', self.file
+            )
+            return False
+        logger.debug('Rolling %s back to previous state', self.file)
+        with open(self.file, 'wb') as fh:
+            fh.writelines(self._saved_lines)
+        return True
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/req/req_uninstall.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/req/req_uninstall.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..93fe00c6ea97ac53dcd109f4d70357cd9f431e1e
GIT binary patch
literal 23635
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
KD-iq7zzG1fNQ^!J

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/resolve.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/resolve.py
new file mode 100644
index 0000000..f49667b
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/resolve.py
@@ -0,0 +1,393 @@
+"""Dependency Resolution
+
+The dependency resolution in pip is performed as follows:
+
+for top-level requirements:
+    a. only one spec allowed per project, regardless of conflicts or not.
+       otherwise a "double requirement" exception is raised
+    b. they override sub-dependency requirements.
+for sub-dependencies
+    a. "first found, wins" (where the order is breadth first)
+"""
+
+import logging
+from collections import defaultdict
+from itertools import chain
+
+from pip._internal.exceptions import (
+    BestVersionAlreadyInstalled, DistributionNotFound, HashError, HashErrors,
+    UnsupportedPythonVersion,
+)
+from pip._internal.req.constructors import install_req_from_req_string
+from pip._internal.utils.logging import indent_log
+from pip._internal.utils.misc import dist_in_usersite, ensure_dir
+from pip._internal.utils.packaging import check_dist_requires_python
+from pip._internal.utils.typing import MYPY_CHECK_RUNNING
+
+if MYPY_CHECK_RUNNING:
+    from typing import Optional, DefaultDict, List, Set
+    from pip._internal.download import PipSession
+    from pip._internal.req.req_install import InstallRequirement
+    from pip._internal.index import PackageFinder
+    from pip._internal.req.req_set import RequirementSet
+    from pip._internal.operations.prepare import (
+        DistAbstraction, RequirementPreparer
+    )
+    from pip._internal.cache import WheelCache
+
+logger = logging.getLogger(__name__)
+
+
+class Resolver(object):
+    """Resolves which packages need to be installed/uninstalled to perform \
+    the requested operation without breaking the requirements of any package.
+    """
+
+    _allowed_strategies = {"eager", "only-if-needed", "to-satisfy-only"}
+
+    def __init__(
+        self,
+        preparer,  # type: RequirementPreparer
+        session,  # type: PipSession
+        finder,  # type: PackageFinder
+        wheel_cache,  # type: Optional[WheelCache]
+        use_user_site,  # type: bool
+        ignore_dependencies,  # type: bool
+        ignore_installed,  # type: bool
+        ignore_requires_python,  # type: bool
+        force_reinstall,  # type: bool
+        isolated,  # type: bool
+        upgrade_strategy,  # type: str
+        use_pep517=None  # type: Optional[bool]
+    ):
+        # type: (...) -> None
+        super(Resolver, self).__init__()
+        assert upgrade_strategy in self._allowed_strategies
+
+        self.preparer = preparer
+        self.finder = finder
+        self.session = session
+
+        # NOTE: This would eventually be replaced with a cache that can give
+        #       information about both sdist and wheels transparently.
+        self.wheel_cache = wheel_cache
+
+        # This is set in resolve
+        self.require_hashes = None  # type: Optional[bool]
+
+        self.upgrade_strategy = upgrade_strategy
+        self.force_reinstall = force_reinstall
+        self.isolated = isolated
+        self.ignore_dependencies = ignore_dependencies
+        self.ignore_installed = ignore_installed
+        self.ignore_requires_python = ignore_requires_python
+        self.use_user_site = use_user_site
+        self.use_pep517 = use_pep517
+
+        self._discovered_dependencies = \
+            defaultdict(list)  # type: DefaultDict[str, List]
+
+    def resolve(self, requirement_set):
+        # type: (RequirementSet) -> None
+        """Resolve what operations need to be done
+
+        As a side-effect of this method, the packages (and their dependencies)
+        are downloaded, unpacked and prepared for installation. This
+        preparation is done by ``pip.operations.prepare``.
+
+        Once PyPI has static dependency metadata available, it would be
+        possible to move the preparation to become a step separated from
+        dependency resolution.
+        """
+        # make the wheelhouse
+        if self.preparer.wheel_download_dir:
+            ensure_dir(self.preparer.wheel_download_dir)
+
+        # If any top-level requirement has a hash specified, enter
+        # hash-checking mode, which requires hashes from all.
+        root_reqs = (
+            requirement_set.unnamed_requirements +
+            list(requirement_set.requirements.values())
+        )
+        self.require_hashes = (
+            requirement_set.require_hashes or
+            any(req.has_hash_options for req in root_reqs)
+        )
+
+        # Display where finder is looking for packages
+        locations = self.finder.get_formatted_locations()
+        if locations:
+            logger.info(locations)
+
+        # Actually prepare the files, and collect any exceptions. Most hash
+        # exceptions cannot be checked ahead of time, because
+        # req.populate_link() needs to be called before we can make decisions
+        # based on link type.
+        discovered_reqs = []  # type: List[InstallRequirement]
+        hash_errors = HashErrors()
+        for req in chain(root_reqs, discovered_reqs):
+            try:
+                discovered_reqs.extend(
+                    self._resolve_one(requirement_set, req)
+                )
+            except HashError as exc:
+                exc.req = req
+                hash_errors.append(exc)
+
+        if hash_errors:
+            raise hash_errors
+
+    def _is_upgrade_allowed(self, req):
+        # type: (InstallRequirement) -> bool
+        if self.upgrade_strategy == "to-satisfy-only":
+            return False
+        elif self.upgrade_strategy == "eager":
+            return True
+        else:
+            assert self.upgrade_strategy == "only-if-needed"
+            return req.is_direct
+
+    def _set_req_to_reinstall(self, req):
+        # type: (InstallRequirement) -> None
+        """
+        Set a requirement to be installed.
+        """
+        # Don't uninstall the conflict if doing a user install and the
+        # conflict is not a user install.
+        if not self.use_user_site or dist_in_usersite(req.satisfied_by):
+            req.conflicts_with = req.satisfied_by
+        req.satisfied_by = None
+
+    # XXX: Stop passing requirement_set for options
+    def _check_skip_installed(self, req_to_install):
+        # type: (InstallRequirement) -> Optional[str]
+        """Check if req_to_install should be skipped.
+
+        This will check if the req is installed, and whether we should upgrade
+        or reinstall it, taking into account all the relevant user options.
+
+        After calling this req_to_install will only have satisfied_by set to
+        None if the req_to_install is to be upgraded/reinstalled etc. Any
+        other value will be a dist recording the current thing installed that
+        satisfies the requirement.
+
+        Note that for vcs urls and the like we can't assess skipping in this
+        routine - we simply identify that we need to pull the thing down,
+        then later on it is pulled down and introspected to assess upgrade/
+        reinstalls etc.
+
+        :return: A text reason for why it was skipped, or None.
+        """
+        if self.ignore_installed:
+            return None
+
+        req_to_install.check_if_exists(self.use_user_site)
+        if not req_to_install.satisfied_by:
+            return None
+
+        if self.force_reinstall:
+            self._set_req_to_reinstall(req_to_install)
+            return None
+
+        if not self._is_upgrade_allowed(req_to_install):
+            if self.upgrade_strategy == "only-if-needed":
+                return 'already satisfied, skipping upgrade'
+            return 'already satisfied'
+
+        # Check for the possibility of an upgrade.  For link-based
+        # requirements we have to pull the tree down and inspect to assess
+        # the version #, so it's handled way down.
+        if not req_to_install.link:
+            try:
+                self.finder.find_requirement(req_to_install, upgrade=True)
+            except BestVersionAlreadyInstalled:
+                # Then the best version is installed.
+                return 'already up-to-date'
+            except DistributionNotFound:
+                # No distribution found, so we squash the error.  It will
+                # be raised later when we re-try later to do the install.
+                # Why don't we just raise here?
+                pass
+
+        self._set_req_to_reinstall(req_to_install)
+        return None
+
+    def _get_abstract_dist_for(self, req):
+        # type: (InstallRequirement) -> DistAbstraction
+        """Takes a InstallRequirement and returns a single AbstractDist \
+        representing a prepared variant of the same.
+        """
+        assert self.require_hashes is not None, (
+            "require_hashes should have been set in Resolver.resolve()"
+        )
+
+        if req.editable:
+            return self.preparer.prepare_editable_requirement(
+                req, self.require_hashes, self.use_user_site, self.finder,
+            )
+
+        # satisfied_by is only evaluated by calling _check_skip_installed,
+        # so it must be None here.
+        assert req.satisfied_by is None
+        skip_reason = self._check_skip_installed(req)
+
+        if req.satisfied_by:
+            return self.preparer.prepare_installed_requirement(
+                req, self.require_hashes, skip_reason
+            )
+
+        upgrade_allowed = self._is_upgrade_allowed(req)
+        abstract_dist = self.preparer.prepare_linked_requirement(
+            req, self.session, self.finder, upgrade_allowed,
+            self.require_hashes
+        )
+
+        # NOTE
+        # The following portion is for determining if a certain package is
+        # going to be re-installed/upgraded or not and reporting to the user.
+        # This should probably get cleaned up in a future refactor.
+
+        # req.req is only avail after unpack for URL
+        # pkgs repeat check_if_exists to uninstall-on-upgrade
+        # (#14)
+        if not self.ignore_installed:
+            req.check_if_exists(self.use_user_site)
+
+        if req.satisfied_by:
+            should_modify = (
+                self.upgrade_strategy != "to-satisfy-only" or
+                self.force_reinstall or
+                self.ignore_installed or
+                req.link.scheme == 'file'
+            )
+            if should_modify:
+                self._set_req_to_reinstall(req)
+            else:
+                logger.info(
+                    'Requirement already satisfied (use --upgrade to upgrade):'
+                    ' %s', req,
+                )
+
+        return abstract_dist
+
+    def _resolve_one(
+        self,
+        requirement_set,  # type: RequirementSet
+        req_to_install  # type: InstallRequirement
+    ):
+        # type: (...) -> List[InstallRequirement]
+        """Prepare a single requirements file.
+
+        :return: A list of additional InstallRequirements to also install.
+        """
+        # Tell user what we are doing for this requirement:
+        # obtain (editable), skipping, processing (local url), collecting
+        # (remote url or package name)
+        if req_to_install.constraint or req_to_install.prepared:
+            return []
+
+        req_to_install.prepared = True
+
+        # register tmp src for cleanup in case something goes wrong
+        requirement_set.reqs_to_cleanup.append(req_to_install)
+
+        abstract_dist = self._get_abstract_dist_for(req_to_install)
+
+        # Parse and return dependencies
+        dist = abstract_dist.dist()
+        try:
+            check_dist_requires_python(dist)
+        except UnsupportedPythonVersion as err:
+            if self.ignore_requires_python:
+                logger.warning(err.args[0])
+            else:
+                raise
+
+        more_reqs = []  # type: List[InstallRequirement]
+
+        def add_req(subreq, extras_requested):
+            sub_install_req = install_req_from_req_string(
+                str(subreq),
+                req_to_install,
+                isolated=self.isolated,
+                wheel_cache=self.wheel_cache,
+                use_pep517=self.use_pep517
+            )
+            parent_req_name = req_to_install.name
+            to_scan_again, add_to_parent = requirement_set.add_requirement(
+                sub_install_req,
+                parent_req_name=parent_req_name,
+                extras_requested=extras_requested,
+            )
+            if parent_req_name and add_to_parent:
+                self._discovered_dependencies[parent_req_name].append(
+                    add_to_parent
+                )
+            more_reqs.extend(to_scan_again)
+
+        with indent_log():
+            # We add req_to_install before its dependencies, so that we
+            # can refer to it when adding dependencies.
+            if not requirement_set.has_requirement(req_to_install.name):
+                # 'unnamed' requirements will get added here
+                req_to_install.is_direct = True
+                requirement_set.add_requirement(
+                    req_to_install, parent_req_name=None,
+                )
+
+            if not self.ignore_dependencies:
+                if req_to_install.extras:
+                    logger.debug(
+                        "Installing extra requirements: %r",
+                        ','.join(req_to_install.extras),
+                    )
+                missing_requested = sorted(
+                    set(req_to_install.extras) - set(dist.extras)
+                )
+                for missing in missing_requested:
+                    logger.warning(
+                        '%s does not provide the extra \'%s\'',
+                        dist, missing
+                    )
+
+                available_requested = sorted(
+                    set(dist.extras) & set(req_to_install.extras)
+                )
+                for subreq in dist.requires(available_requested):
+                    add_req(subreq, extras_requested=available_requested)
+
+            if not req_to_install.editable and not req_to_install.satisfied_by:
+                # XXX: --no-install leads this to report 'Successfully
+                # downloaded' for only non-editable reqs, even though we took
+                # action on them.
+                requirement_set.successfully_downloaded.append(req_to_install)
+
+        return more_reqs
+
+    def get_installation_order(self, req_set):
+        # type: (RequirementSet) -> List[InstallRequirement]
+        """Create the installation order.
+
+        The installation order is topological - requirements are installed
+        before the requiring thing. We break cycles at an arbitrary point,
+        and make no other guarantees.
+        """
+        # The current implementation, which we may change at any point
+        # installs the user specified things in the order given, except when
+        # dependencies must come earlier to achieve topological order.
+        order = []
+        ordered_reqs = set()  # type: Set[InstallRequirement]
+
+        def schedule(req):
+            if req.satisfied_by or req in ordered_reqs:
+                return
+            if req.constraint:
+                return
+            ordered_reqs.add(req)
+            for dep in self._discovered_dependencies[req.name]:
+                schedule(dep)
+            order.append(req)
+
+        for install_req in req_set.requirements.values():
+            schedule(install_req)
+        return order
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/resolve.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/resolve.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..f727136130d44774c1ed848b272ac17ce9f9a515
GIT binary patch
literal 11222
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
I!c6?k07YNxe*gdg

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/utils/__init__.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/utils/__init__.py
new file mode 100644
index 0000000..e69de29
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/utils/__init__.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/utils/__init__.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..e9cd5bfa10536793956691a81e1065dbf74abbda
GIT binary patch
literal 198
zcmZSn%**AGdLky70SXuy7#JKF7#NCK7#J8*7#M;zKq7t`AZawBIG=%mLBF6Vvn;VB
zRlh8;NIxw<CndG0SU)L6zdR`^FV{4;*vK%+JiRL2!qlQXC#%ZL00h$W^h5LuG7EGw
z^NLFnb8>Xu$~-)c13*Gx9G{t2l3J9Pn4@1>l9^MiA0MBYmst`YuUAl6!ok46V3V7l
OQks)$2Xa|4$YB7wureV4

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/utils/appdirs.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/utils/appdirs.py
new file mode 100644
index 0000000..fb26111
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/utils/appdirs.py
@@ -0,0 +1,268 @@
+"""
+This code was taken from https://github.com/ActiveState/appdirs and modified
+to suit our purposes.
+"""
+from __future__ import absolute_import
+
+import os
+import sys
+
+from pip._vendor.six import PY2, text_type
+
+from pip._internal.utils.compat import WINDOWS, expanduser
+from pip._internal.utils.typing import MYPY_CHECK_RUNNING
+
+if MYPY_CHECK_RUNNING:
+    from typing import List
+
+
+def user_cache_dir(appname):
+    # type: (str) -> str
+    r"""
+    Return full path to the user-specific cache dir for this application.
+
+        "appname" is the name of application.
+
+    Typical user cache directories are:
+        macOS:      ~/Library/Caches/<AppName>
+        Unix:       ~/.cache/<AppName> (XDG default)
+        Windows:    C:\Users\<username>\AppData\Local\<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`). 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.
+    """
+    if WINDOWS:
+        # Get the base path
+        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 PY2 and isinstance(path, text_type):
+            path = _win_path_to_bytes(path)
+
+        # Add our app name and Cache directory to it
+        path = os.path.join(path, appname, "Cache")
+    elif sys.platform == "darwin":
+        # Get the base path
+        path = expanduser("~/Library/Caches")
+
+        # Add our app name to it
+        path = os.path.join(path, appname)
+    else:
+        # Get the base path
+        path = os.getenv("XDG_CACHE_HOME", expanduser("~/.cache"))
+
+        # Add our app name to it
+        path = os.path.join(path, appname)
+
+    return path
+
+
+def user_data_dir(appname, roaming=False):
+    # type: (str, bool) -> str
+    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.
+        "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:
+        macOS:                  ~/Library/Application Support/<AppName>
+                                if it exists, else ~/.config/<AppName>
+        Unix:                   ~/.local/share/<AppName>    # or in
+                                $XDG_DATA_HOME, if defined
+        Win XP (not roaming):   C:\Documents and Settings\<username>\ ...
+                                ...Application Data\<AppName>
+        Win XP (roaming):       C:\Documents and Settings\<username>\Local ...
+                                ...Settings\Application Data\<AppName>
+        Win 7  (not roaming):   C:\\Users\<username>\AppData\Local\<AppName>
+        Win 7  (roaming):       C:\\Users\<username>\AppData\Roaming\<AppName>
+
+    For Unix, we follow the XDG spec and support $XDG_DATA_HOME.
+    That means, by default "~/.local/share/<AppName>".
+    """
+    if WINDOWS:
+        const = roaming and "CSIDL_APPDATA" or "CSIDL_LOCAL_APPDATA"
+        path = os.path.join(os.path.normpath(_get_win_folder(const)), appname)
+    elif sys.platform == "darwin":
+        path = os.path.join(
+            expanduser('~/Library/Application Support/'),
+            appname,
+        ) if os.path.isdir(os.path.join(
+            expanduser('~/Library/Application Support/'),
+            appname,
+        )
+        ) else os.path.join(
+            expanduser('~/.config/'),
+            appname,
+        )
+    else:
+        path = os.path.join(
+            os.getenv('XDG_DATA_HOME', expanduser("~/.local/share")),
+            appname,
+        )
+
+    return path
+
+
+def user_config_dir(appname, roaming=True):
+    # type: (str, bool) -> str
+    """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.
+        "roaming" (boolean, default True) can be set False to not 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:
+        macOS:                  same as user_data_dir
+        Unix:                   ~/.config/<AppName>
+        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 WINDOWS:
+        path = user_data_dir(appname, roaming=roaming)
+    elif sys.platform == "darwin":
+        path = user_data_dir(appname)
+    else:
+        path = os.getenv('XDG_CONFIG_HOME', expanduser("~/.config"))
+        path = os.path.join(path, appname)
+
+    return path
+
+
+# for the discussion regarding site_config_dirs locations
+# see <https://github.com/pypa/pip/issues/1733>
+def site_config_dirs(appname):
+    # type: (str) -> List[str]
+    r"""Return a list of potential user-shared config dirs for this application.
+
+        "appname" is the name of application.
+
+    Typical user config directories are:
+        macOS:      /Library/Application Support/<AppName>/
+        Unix:       /etc or $XDG_CONFIG_DIRS[i]/<AppName>/ for each value in
+                    $XDG_CONFIG_DIRS
+        Win XP:     C:\Documents and Settings\All Users\Application ...
+                    ...Data\<AppName>\
+        Vista:      (Fail! "C:\ProgramData" is a hidden *system* directory
+                    on Vista.)
+        Win 7:      Hidden, but writeable on Win 7:
+                    C:\ProgramData\<AppName>\
+    """
+    if WINDOWS:
+        path = os.path.normpath(_get_win_folder("CSIDL_COMMON_APPDATA"))
+        pathlist = [os.path.join(path, appname)]
+    elif sys.platform == 'darwin':
+        pathlist = [os.path.join('/Library/Application Support', appname)]
+    else:
+        # try looking in $XDG_CONFIG_DIRS
+        xdg_config_dirs = os.getenv('XDG_CONFIG_DIRS', '/etc/xdg')
+        if xdg_config_dirs:
+            pathlist = [
+                os.path.join(expanduser(x), appname)
+                for x in xdg_config_dirs.split(os.pathsep)
+            ]
+        else:
+            pathlist = []
+
+        # always look in /etc directly as well
+        pathlist.append('/etc')
+
+    return pathlist
+
+
+# -- Windows support functions --
+
+def _get_win_folder_from_registry(csidl_name):
+    # type: (str) -> str
+    """
+    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.
+    """
+    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"
+    )
+    directory, _type = _winreg.QueryValueEx(key, shell_folder_name)
+    return directory
+
+
+def _get_win_folder_with_ctypes(csidl_name):
+    # type: (str) -> str
+    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
+
+
+if WINDOWS:
+    try:
+        import ctypes
+        _get_win_folder = _get_win_folder_with_ctypes
+    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
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/utils/appdirs.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/utils/appdirs.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..8482e1cd630cf2957259d46ec67e042019f8b1e4
GIT binary patch
literal 9403
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
Yj}oUQr#Pn+8zVC#4<i>NFC#BA08u%O-v9sr

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/utils/compat.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/utils/compat.py
new file mode 100644
index 0000000..845436e
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/utils/compat.py
@@ -0,0 +1,264 @@
+"""Stuff that differs in different Python versions and platform
+distributions."""
+from __future__ import absolute_import, division
+
+import codecs
+import locale
+import logging
+import os
+import shutil
+import sys
+
+from pip._vendor.six import text_type
+
+from pip._internal.utils.typing import MYPY_CHECK_RUNNING
+
+if MYPY_CHECK_RUNNING:
+    from typing import Tuple, Text
+
+try:
+    import ipaddress
+except ImportError:
+    try:
+        from pip._vendor import ipaddress  # type: ignore
+    except ImportError:
+        import ipaddr as ipaddress  # type: ignore
+        ipaddress.ip_address = ipaddress.IPAddress  # type: ignore
+        ipaddress.ip_network = ipaddress.IPNetwork  # type: ignore
+
+
+__all__ = [
+    "ipaddress", "uses_pycache", "console_to_str", "native_str",
+    "get_path_uid", "stdlib_pkgs", "WINDOWS", "samefile", "get_terminal_size",
+    "get_extension_suffixes",
+]
+
+
+logger = logging.getLogger(__name__)
+
+if sys.version_info >= (3, 4):
+    uses_pycache = True
+    from importlib.util import cache_from_source
+else:
+    import imp
+
+    try:
+        cache_from_source = imp.cache_from_source  # type: ignore
+    except AttributeError:
+        # does not use __pycache__
+        cache_from_source = None
+
+    uses_pycache = cache_from_source is not None
+
+
+if sys.version_info >= (3, 5):
+    backslashreplace_decode = "backslashreplace"
+else:
+    # In version 3.4 and older, backslashreplace exists
+    # but does not support use for decoding.
+    # We implement our own replace handler for this
+    # situation, so that we can consistently use
+    # backslash replacement for all versions.
+    def backslashreplace_decode_fn(err):
+        raw_bytes = (err.object[i] for i in range(err.start, err.end))
+        if sys.version_info[0] == 2:
+            # Python 2 gave us characters - convert to numeric bytes
+            raw_bytes = (ord(b) for b in raw_bytes)
+        return u"".join(u"\\x%x" % c for c in raw_bytes), err.end
+    codecs.register_error(
+        "backslashreplace_decode",
+        backslashreplace_decode_fn,
+    )
+    backslashreplace_decode = "backslashreplace_decode"
+
+
+def console_to_str(data):
+    # type: (bytes) -> Text
+    """Return a string, safe for output, of subprocess output.
+
+    We assume the data is in the locale preferred encoding.
+    If it won't decode properly, we warn the user but decode as
+    best we can.
+
+    We also ensure that the output can be safely written to
+    standard output without encoding errors.
+    """
+
+    # First, get the encoding we assume. This is the preferred
+    # encoding for the locale, unless that is not found, or
+    # it is ASCII, in which case assume UTF-8
+    encoding = locale.getpreferredencoding()
+    if (not encoding) or codecs.lookup(encoding).name == "ascii":
+        encoding = "utf-8"
+
+    # Now try to decode the data - if we fail, warn the user and
+    # decode with replacement.
+    try:
+        decoded_data = data.decode(encoding)
+    except UnicodeDecodeError:
+        logger.warning(
+            "Subprocess output does not appear to be encoded as %s",
+            encoding,
+        )
+        decoded_data = data.decode(encoding, errors=backslashreplace_decode)
+
+    # Make sure we can print the output, by encoding it to the output
+    # encoding with replacement of unencodable characters, and then
+    # decoding again.
+    # We use stderr's encoding because it's less likely to be
+    # redirected and if we don't find an encoding we skip this
+    # step (on the assumption that output is wrapped by something
+    # that won't fail).
+    # The double getattr is to deal with the possibility that we're
+    # being called in a situation where sys.__stderr__ doesn't exist,
+    # or doesn't have an encoding attribute. Neither of these cases
+    # should occur in normal pip use, but there's no harm in checking
+    # in case people use pip in (unsupported) unusual situations.
+    output_encoding = getattr(getattr(sys, "__stderr__", None),
+                              "encoding", None)
+
+    if output_encoding:
+        output_encoded = decoded_data.encode(
+            output_encoding,
+            errors="backslashreplace"
+        )
+        decoded_data = output_encoded.decode(output_encoding)
+
+    return decoded_data
+
+
+if sys.version_info >= (3,):
+    def native_str(s, replace=False):
+        # type: (str, bool) -> str
+        if isinstance(s, bytes):
+            return s.decode('utf-8', 'replace' if replace else 'strict')
+        return s
+
+else:
+    def native_str(s, replace=False):
+        # type: (str, bool) -> str
+        # Replace is ignored -- unicode to UTF-8 can't fail
+        if isinstance(s, text_type):
+            return s.encode('utf-8')
+        return s
+
+
+def get_path_uid(path):
+    # type: (str) -> int
+    """
+    Return path's uid.
+
+    Does not follow symlinks:
+        https://github.com/pypa/pip/pull/935#discussion_r5307003
+
+    Placed this function in compat due to differences on AIX and
+    Jython, that should eventually go away.
+
+    :raises OSError: When path is a symlink or can't be read.
+    """
+    if hasattr(os, 'O_NOFOLLOW'):
+        fd = os.open(path, os.O_RDONLY | os.O_NOFOLLOW)
+        file_uid = os.fstat(fd).st_uid
+        os.close(fd)
+    else:  # AIX and Jython
+        # WARNING: time of check vulnerability, but best we can do w/o NOFOLLOW
+        if not os.path.islink(path):
+            # older versions of Jython don't have `os.fstat`
+            file_uid = os.stat(path).st_uid
+        else:
+            # raise OSError for parity with os.O_NOFOLLOW above
+            raise OSError(
+                "%s is a symlink; Will not return uid for symlinks" % path
+            )
+    return file_uid
+
+
+if sys.version_info >= (3, 4):
+    from importlib.machinery import EXTENSION_SUFFIXES
+
+    def get_extension_suffixes():
+        return EXTENSION_SUFFIXES
+else:
+    from imp import get_suffixes
+
+    def get_extension_suffixes():
+        return [suffix[0] for suffix in get_suffixes()]
+
+
+def expanduser(path):
+    # type: (str) -> str
+    """
+    Expand ~ and ~user constructions.
+
+    Includes a workaround for https://bugs.python.org/issue14768
+    """
+    expanded = os.path.expanduser(path)
+    if path.startswith('~/') and expanded.startswith('//'):
+        expanded = expanded[1:]
+    return expanded
+
+
+# packages in the stdlib that may have installation metadata, but should not be
+# considered 'installed'.  this theoretically could be determined based on
+# dist.location (py27:`sysconfig.get_paths()['stdlib']`,
+# py26:sysconfig.get_config_vars('LIBDEST')), but fear platform variation may
+# make this ineffective, so hard-coding
+stdlib_pkgs = {"python", "wsgiref", "argparse"}
+
+
+# windows detection, covers cpython and ironpython
+WINDOWS = (sys.platform.startswith("win") or
+           (sys.platform == 'cli' and os.name == 'nt'))
+
+
+def samefile(file1, file2):
+    # type: (str, str) -> bool
+    """Provide an alternative for os.path.samefile on Windows/Python2"""
+    if hasattr(os.path, 'samefile'):
+        return os.path.samefile(file1, file2)
+    else:
+        path1 = os.path.normcase(os.path.abspath(file1))
+        path2 = os.path.normcase(os.path.abspath(file2))
+        return path1 == path2
+
+
+if hasattr(shutil, 'get_terminal_size'):
+    def get_terminal_size():
+        # type: () -> Tuple[int, int]
+        """
+        Returns a tuple (x, y) representing the width(x) and the height(y)
+        in characters of the terminal window.
+        """
+        return tuple(shutil.get_terminal_size())  # type: ignore
+else:
+    def get_terminal_size():
+        # type: () -> Tuple[int, int]
+        """
+        Returns a tuple (x, y) representing the width(x) and the height(y)
+        in characters of the terminal window.
+        """
+        def ioctl_GWINSZ(fd):
+            try:
+                import fcntl
+                import termios
+                import struct
+                cr = struct.unpack_from(
+                    'hh',
+                    fcntl.ioctl(fd, termios.TIOCGWINSZ, '12345678')
+                )
+            except Exception:
+                return None
+            if cr == (0, 0):
+                return None
+            return cr
+        cr = ioctl_GWINSZ(0) or ioctl_GWINSZ(1) or ioctl_GWINSZ(2)
+        if not cr:
+            try:
+                fd = os.open(os.ctermid(), os.O_RDONLY)
+                cr = ioctl_GWINSZ(fd)
+                os.close(fd)
+            except Exception:
+                pass
+        if not cr:
+            cr = (os.environ.get('LINES', 25), os.environ.get('COLUMNS', 80))
+        return int(cr[1]), int(cr[0])
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/utils/compat.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/utils/compat.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..5853bd09455feb9eb70442687dabf7c839ca32bd
GIT binary patch
literal 8638
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

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/utils/deprecation.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/utils/deprecation.py
new file mode 100644
index 0000000..8c896f8
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/utils/deprecation.py
@@ -0,0 +1,93 @@
+"""
+A module that implements tooling to enable easy warnings about deprecations.
+"""
+from __future__ import absolute_import
+
+import logging
+import warnings
+
+from pip._vendor.packaging.version import parse
+
+from pip import __version__ as current_version
+from pip._internal.utils.typing import MYPY_CHECK_RUNNING
+
+if MYPY_CHECK_RUNNING:
+    from typing import Any, Optional
+
+
+DEPRECATION_MSG_PREFIX = "DEPRECATION: "
+
+
+class PipDeprecationWarning(Warning):
+    pass
+
+
+_original_showwarning = None  # type: Any
+
+
+# Warnings <-> Logging Integration
+def _showwarning(message, category, filename, lineno, file=None, line=None):
+    if file is not None:
+        if _original_showwarning is not None:
+            _original_showwarning(
+                message, category, filename, lineno, file, line,
+            )
+    elif issubclass(category, PipDeprecationWarning):
+        # We use a specially named logger which will handle all of the
+        # deprecation messages for pip.
+        logger = logging.getLogger("pip._internal.deprecations")
+        logger.warning(message)
+    else:
+        _original_showwarning(
+            message, category, filename, lineno, file, line,
+        )
+
+
+def install_warning_logger():
+    # type: () -> None
+    # Enable our Deprecation Warnings
+    warnings.simplefilter("default", PipDeprecationWarning, append=True)
+
+    global _original_showwarning
+
+    if _original_showwarning is None:
+        _original_showwarning = warnings.showwarning
+        warnings.showwarning = _showwarning
+
+
+def deprecated(reason, replacement, gone_in, issue=None):
+    # type: (str, Optional[str], Optional[str], Optional[int]) -> None
+    """Helper to deprecate existing functionality.
+
+    reason:
+        Textual reason shown to the user about why this functionality has
+        been deprecated.
+    replacement:
+        Textual suggestion shown to the user about what alternative
+        functionality they can use.
+    gone_in:
+        The version of pip does this functionality should get removed in.
+        Raises errors if pip's current version is greater than or equal to
+        this.
+    issue:
+        Issue number on the tracker that would serve as a useful place for
+        users to find related discussion and provide feedback.
+
+    Always pass replacement, gone_in and issue as keyword arguments for clarity
+    at the call site.
+    """
+
+    # Construct a nice message.
+    # This is purposely eagerly formatted as we want it to appear as if someone
+    # typed this entire message out.
+    message = DEPRECATION_MSG_PREFIX + reason
+    if replacement is not None:
+        message += " A possible replacement is {}.".format(replacement)
+    if issue is not None:
+        url = "https://github.com/pypa/pip/issues/" + str(issue)
+        message += " You can find discussion regarding this at {}.".format(url)
+
+    # Raise as an error if it has to be removed.
+    if gone_in is not None and parse(current_version) >= parse(gone_in):
+        raise PipDeprecationWarning(message)
+    warnings.warn(message, category=PipDeprecationWarning, stacklevel=2)
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/utils/deprecation.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/utils/deprecation.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..588c4567a3f628524122bc984c125dd2a9ce67ea
GIT binary patch
literal 3408
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
C;A=qu

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/utils/encoding.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/utils/encoding.py
new file mode 100644
index 0000000..30139f2
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/utils/encoding.py
@@ -0,0 +1,39 @@
+import codecs
+import locale
+import re
+import sys
+
+from pip._internal.utils.typing import MYPY_CHECK_RUNNING
+
+if MYPY_CHECK_RUNNING:
+    from typing import List, Tuple, Text
+
+BOMS = [
+    (codecs.BOM_UTF8, 'utf-8'),
+    (codecs.BOM_UTF16, 'utf-16'),
+    (codecs.BOM_UTF16_BE, 'utf-16-be'),
+    (codecs.BOM_UTF16_LE, 'utf-16-le'),
+    (codecs.BOM_UTF32, 'utf-32'),
+    (codecs.BOM_UTF32_BE, 'utf-32-be'),
+    (codecs.BOM_UTF32_LE, 'utf-32-le'),
+]  # type: List[Tuple[bytes, Text]]
+
+ENCODING_RE = re.compile(br'coding[:=]\s*([-\w.]+)')
+
+
+def auto_decode(data):
+    # type: (bytes) -> Text
+    """Check a bytes string for a BOM to correctly detect the encoding
+
+    Fallback to locale.getpreferredencoding(False) like open() on Python3"""
+    for bom, encoding in BOMS:
+        if data.startswith(bom):
+            return data[len(bom):].decode(encoding)
+    # Lets check the first two lines as in PEP263
+    for line in data.split(b'\n')[:2]:
+        if line[0:1] == b'#' and ENCODING_RE.search(line):
+            encoding = ENCODING_RE.search(line).groups()[0].decode('ascii')
+            return data.decode(encoding)
+    return data.decode(
+        locale.getpreferredencoding(False) or sys.getdefaultencoding(),
+    )
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/utils/encoding.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/utils/encoding.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..f3c51917998f258efd3bdc83c3b62f62e85a261f
GIT binary patch
literal 1649
zcmZSn%**AGdLky70SY)67#JKF7#NCgGcYiuFfgPrGUPBYM8VmN3{i|QaVCZ+CK#KU
zA&MEyW@5-;VaR1=h+<`6Ol4&#N(GBDGvu%_<gznFu`}dyFhp@M<Z?1ZaWXLGF)*Yu
zFl2Etq_8lgF@f3K3@NNIHV;Dz8;s4%kirgQ^D(4wz}Wl@DV#9207D8Fh@H;P5GBZv
z%EXW*#E`<x(9FmXCCre*!_dOO5G4ZgQ?Ldv0|P_m|NsC0`)M#TFffz|F)%RrMg~O2
zJA1e~d&dWb`uTbKxoa?k<X9LO7<@8|OG;Q77#KoI3vyCRKtds@6(z+Wq0*8xU5jEi
z1_lNY%h0Tt6VB94N=4@7q{5XM8^I-vjgXZY8|mhx7K<@3FeK-vWagzuTiM3O6l-Zj
z>&BGp#cFFNgWL<UAB3GjadnP?fuX{Rp@f0KCDw=`hKZq;k)f7}p@xAWi;<y*5#;|O
zb`ZCO3CfkvVrHme0!aiHvNMEN<bY(eSU^G3%*c?!#Gv338_rP6%uvJ3kira#9mNz@
zhHNH=qCkccR)#D#kVG>hIyZ}*p_u`sK{AUO6m`vTcOa|_WC#a2jG3W?gCUEPp@a+M
zih@%NCEN^IJRt4Oj10jV>>z)2F)%PVXQU=)D<mo;RhFa{D-@R$W#*+Tq~#YWBq})h
z`zn;=D<tO^6{RMZ<Wwr8q?V*6mnf8Eq$;H5K?0A9OF=<F!7VW-Cn+&G8>BoZKRGcc
zRWCiYq@XA@Ew!j9H3g<v!!0qVI8{?2Co?-$A-^CsPeW57KTjc`vLquv&$t*A?p&En
zpo9a;Etw#G35ZYzCyd16<jhQPx&o&TCx74I5-yN8N)n4oipw)gGD<+HDJM0r1e8=#
zQj_yjQo%Zl3vx0`O1K#q7+n3F{arl$+~b2>!HSAg6N{2Fz|8cb{L+GAFcad15)lRl
z25jB{n+f&`*uvt<VsPqCPc2DFO-n4zDS`VJl!CyHO-U?C1S?L;&n*F!0Wc+C*__P0
zR1J`q!9;OB0|SG8K~ZK|Vo9ogSz?iXT7FJSYEiL%Qi^_gQc_;7X>PHRVUl@zRl0?#
zMR`tEm6-tur03~}=oe%b=w{{>mn7!o=(?48cp3+QgupmHGp{7IC@(QbzqBMXr&u56
z2EBqxaNs1CmgL7nf=vPxuAnT-z$(nh&nV3##i+!n#3;zf#;73*%Cevk28C~OaS$Jf
z4~n&-)F43+TZ(~!p&+wB4{o0x*gn0I%7V<i^dOK&!NCmWgJL)cq(2B0ec;e>^7oAo
z4RNz50cCV3$Iz^Vhk=0s&Wm?)MHBFGMOJTYge+}rgr?ruDBj042;_|tP+myR&n?Kz
zNeu!ek|1#g1_p3cAcz5p6i`C3$<0qG%}KQbg;KE`0|NsOBN#FXFtIVpGlSU>5k?_q
Ger5pVyLH(B

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/utils/filesystem.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/utils/filesystem.py
new file mode 100644
index 0000000..1e6b033
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/utils/filesystem.py
@@ -0,0 +1,30 @@
+import os
+import os.path
+
+from pip._internal.utils.compat import get_path_uid
+
+
+def check_path_owner(path):
+    # type: (str) -> bool
+    # If we don't have a way to check the effective uid of this process, then
+    # we'll just assume that we own the directory.
+    if not hasattr(os, "geteuid"):
+        return True
+
+    previous = None
+    while path != previous:
+        if os.path.lexists(path):
+            # Check if path is writable by current user.
+            if os.geteuid() == 0:
+                # Special handling for root user in order to handle properly
+                # cases where users use sudo without -H flag.
+                try:
+                    path_uid = get_path_uid(path)
+                except OSError:
+                    return False
+                return path_uid == 0
+            else:
+                return os.access(path, os.W_OK)
+        else:
+            previous, path = path, os.path.dirname(path)
+    return False  # assume we don't own the path
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/utils/filesystem.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/utils/filesystem.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..9dc890727fba3e8bb1bddcd04e8753ca93ea3805
GIT binary patch
literal 912
zcmZSn%**AGdLky70ScHH7#JKF7#NC885kH+7#LC*8FCmHqTp;s7@LV9hlwGVnIVdq
zfiZ=dp@o4ViUp)PSc8Rufg$t%|NsB}G#D8e7)p2;7#Px1OX3R>OETh1GgFd5qRb2o
z46F<c49+0CHi48eFqANY3}|LzC>CZYVPXhQVPL3bWT=?LP{Y7b!^n`$%uuuzq$rDp
zA&V6x*v!aKG!ZPq#?Z{bkix`}&BRbt%}^=8P{IyXP|L&+o+re>Qo_NI&Bahuz`)4J
zSi;E=98tpr)ev05$dJVaQVwEpGc+?X1Q*J{_$&-rJRo*6BLh<{BSS3%L!k^qILHJI
zkRSX?*dg9aEzL~H1O=i7FUU6_(Tv36#FCPt5>S}t7ngv-C8Ve{70mF<&x0^Pp#nA|
zC$%E8xTH7;6goj5gTSKx!LCI``9&q5uyRYxDNZe6V_;xNOioTMhL{*0@9zy(nUYzQ
zmzbLhc2y8aQ3(eF14BVkYFTD}X)%NYjR6gi@nE93kb!|gzo00yEU_e2zbvsxKP^8e
zCAFwnKPg4OJSizJ*EF}-$S}z~y(-<p)S^5mtIEs(1k&^LL-Y$W3v@H{ic1o6a&+Cw
zJUop9Ktf;~pP5&ZT9lWVqhDH*nNzHvmYI`UTv=R_nyXh(St7u|z>u7gnw$+u6#3<O
zsYRd=E0zJdjD??(g^7)kpHYZOh?$vDfRUGxm63}{j7gSJ0~8KHpnwPaIlovB9DY(D
zpJo>5!EMz8+p3qGpIeYv0uId}eg*~xu%8jc0QnviFE+XPDWy57cA(fU2E`T+BM*}R
FGXQwM&=>#!

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/utils/glibc.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/utils/glibc.py
new file mode 100644
index 0000000..5bea655
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/utils/glibc.py
@@ -0,0 +1,93 @@
+from __future__ import absolute_import
+
+import ctypes
+import re
+import warnings
+
+from pip._internal.utils.typing import MYPY_CHECK_RUNNING
+
+if MYPY_CHECK_RUNNING:
+    from typing import Optional, Tuple
+
+
+def glibc_version_string():
+    # type: () -> Optional[str]
+    "Returns glibc version string, or None if not using glibc."
+
+    # ctypes.CDLL(None) internally calls dlopen(NULL), and as the dlopen
+    # manpage says, "If filename is NULL, then the returned handle is for the
+    # main program". This way we can let the linker do the work to figure out
+    # which libc our process is actually using.
+    process_namespace = ctypes.CDLL(None)
+    try:
+        gnu_get_libc_version = process_namespace.gnu_get_libc_version
+    except AttributeError:
+        # Symbol doesn't exist -> therefore, we are not linked to
+        # glibc.
+        return None
+
+    # Call gnu_get_libc_version, which returns a string like "2.5"
+    gnu_get_libc_version.restype = ctypes.c_char_p
+    version_str = gnu_get_libc_version()
+    # py2 / py3 compatibility:
+    if not isinstance(version_str, str):
+        version_str = version_str.decode("ascii")
+
+    return version_str
+
+
+# Separated out from have_compatible_glibc for easier unit testing
+def check_glibc_version(version_str, required_major, minimum_minor):
+    # type: (str, int, int) -> bool
+    # Parse string and check against requested version.
+    #
+    # We use a regexp instead of str.split because we want to discard any
+    # random junk that might come after the minor version -- this might happen
+    # in patched/forked versions of glibc (e.g. Linaro's version of glibc
+    # uses version strings like "2.20-2014.11"). See gh-3588.
+    m = re.match(r"(?P<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 False
+    return (int(m.group("major")) == required_major and
+            int(m.group("minor")) >= minimum_minor)
+
+
+def have_compatible_glibc(required_major, minimum_minor):
+    # type: (int, int) -> bool
+    version_str = glibc_version_string()  # type: Optional[str]
+    if version_str is None:
+        return False
+    return check_glibc_version(version_str, required_major, minimum_minor)
+
+
+# platform.libc_ver regularly returns completely nonsensical glibc
+# versions. E.g. on my computer, platform says:
+#
+#   ~$ python2.7 -c 'import platform; print(platform.libc_ver())'
+#   ('glibc', '2.7')
+#   ~$ python3.5 -c 'import platform; print(platform.libc_ver())'
+#   ('glibc', '2.9')
+#
+# But the truth is:
+#
+#   ~$ ldd --version
+#   ldd (Debian GLIBC 2.22-11) 2.22
+#
+# This is unfortunate, because it means that the linehaul data on libc
+# versions that was generated by pip 8.1.2 and earlier is useless and
+# misleading. Solution: instead of using platform, use our code that actually
+# works.
+def libc_ver():
+    # type: () -> Tuple[str, str]
+    """Try to determine the glibc version
+
+    Returns a tuple of strings (lib, version) which default to empty strings
+    in case the lookup fails.
+    """
+    glibc_version = glibc_version_string()
+    if glibc_version is None:
+        return ("", "")
+    else:
+        return ("glibc", glibc_version)
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/utils/glibc.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/utils/glibc.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..5fe9fd1a8c6a838c9324719ab62cb2848bbc828b
GIT binary patch
literal 2406
zcmZSn%**AGdLky70ScHH7#JKJ7#NDX85kH+7#LC*8FCmHav2$-7#SErd?tn*CWa^`
zupARZ4l_d(GmOo`5XAy!Gc)9{GUT!`M6oe2rm`^<C4)s-7;@Mdayb~HI2dv{8KO8D
z81onyQdk*U7#O0s7*g243~q)Lb})m7A%z3X;AKc*VhGmYWME*(1UXWJk%57sgr9+d
zAu*{qKc}=LH9j-9Ait=@4<aMPz`)=e84wxo?BVL{9Um0x=jZ9?t^x8`2?qlMgMUFu
zW`15`P6;am14Bq@K~5^z^UMqk3?LC_kms{ORxmJRF@o%FW@M;kV5sC}s9|8pVrHmi
zWC+g_Vqhs@VaVoUC^BGRWMl-nFrtKkA&ZrvhLItj4Ma9GFw`<Jl&~|@Ffo*HFf=nU
z6sLpOS)8Ci1sTf3kjDTL3Dy8vUTn$0zz~#LQd*Q(tdO3QnUt(hmReMtnV+XnTvC*o
zm#(9bU!>rdpO>nTnWm7JU!qW2oSBynQK|>_O=59!W~QG87s&N&3=9m(C6xuK#U(5Z
z3=GaLK0aUu$bb?N1_p-oywdpe)RK6RP4Q5hO86KU7#vGViZYW*OHy5nit>xVVU`@9
zoRL@*Ur@r%z`#(HS`0F`1Y}KSab{j|Nn&1dY6;j6B}FA5i&IjQ^HWm6-YOAfU|=XH
z%1=%$E{@Mj%uOvWNK8%*0>wlLHv<C$)aLl&k|GUo^n!@u90mpk{eq&*vc!^9{j$U&
z{j~g?l+>bP{iGEA@}#7^T+`fQBf})~^s00VQ;YJPtSU1D5J=C{5795kEYJlzD<?<S
zt<1yIH~=IB#_^eXC8<Sui8=bEC7C(J`rvTZE2xBo2y#$>9F&=t&db2SPz(w#1`d8k
zW=38{US?Ki9!5?kenugtWRRahp$nqH2`2><^pJ$Z2ud%_OboTm3^mLQ#Rd!|OrYeG
z!UPf*D`5ep2*wgthTsx5kb*3Bh7@LoW=0UIVPwc=V#rTsKuEEG#G4sG$t9bWAy@;H
zRQ-xo7#J8d>;r6a6SMM*?4k{HEn~GcWAwm6nRy7IVp|3V2G@#$)Z~)X6iAAJC$93$
zk_-hSh2;F)g8aPHypm!CuxWa^AOmz1((_BK6jY1B=?g3YVSywyz>x^bSVgH2(ZrJE
z3~+)ePb|vI%u9!)JrD<+vVuzUN-}d(!y%GjEpCZ9#gMd<nO6c9NiWJTEzkgkYLEaZ
zG(kzSD7COOvnVws9^wK}q~vDiW#*RV#)F+%0xA=72QvK#gR)yjYI1fwI7z`W6v#=%
zARjPr2r;rTax!u=vM@?BCW8VElxRTS1ScF#kXIQPAcaN^xOmOxU?`FVrJCRpW>CD>
zFo25{W`<yJLFWevBT)7V0%gk}Nl^JA4@warlY?YHTv-qS3PzAa7{CPm^Oh(B14Bk)
zS!z5ejU|?3Cgr3;LJ3sj6@wBH0~04B4<idBxFiO}B`AEr;i8TR7Y0zqNnvJygi8tw
zLog&Sr7<xCr+`8QlqZTOgG%+HN`;bqg_P8i)S}$Xyi|pfj8xQA&&8#npr8ONZ4(tr
zK=pt^ej2o>EmqLT$xPCL<q=JV@{G*n426``w8YY!5|G)cxdkPaFx6ngGV>IY6N@2s
z<>cpQmli0bC1&On>w#rUK*bs)eS=CFKX82%qzH;05CP%B;}RUfC7@)Ek(vf75<$@f
zayckv2Z0JjkN^WaINq2vKuH{2A;ib0m6ntirN+mD6fp#W;v@)Eeg=twVp0lJ8Dtjd
z!OLMia5=13Qdy9hmmUO)dT<2-<%5zz5I8l1g9enigA_nv1}^wOK?+XNV1oYX8WaLH
kx%nxjIjMFamxJpG0VW<s9!4G}0VXy^NoG!IPC-sd0LrdFtN;K2

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/utils/hashes.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/utils/hashes.py
new file mode 100644
index 0000000..a714206
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/utils/hashes.py
@@ -0,0 +1,115 @@
+from __future__ import absolute_import
+
+import hashlib
+
+from pip._vendor.six import iteritems, iterkeys, itervalues
+
+from pip._internal.exceptions import (
+    HashMismatch, HashMissing, InstallationError,
+)
+from pip._internal.utils.misc import read_chunks
+from pip._internal.utils.typing import MYPY_CHECK_RUNNING
+
+if MYPY_CHECK_RUNNING:
+    from typing import (
+        Dict, List, BinaryIO, NoReturn, Iterator
+    )
+    from pip._vendor.six import PY3
+    if PY3:
+        from hashlib import _Hash
+    else:
+        from hashlib import _hash as _Hash
+
+
+# The recommended hash algo of the moment. Change this whenever the state of
+# the art changes; it won't hurt backward compatibility.
+FAVORITE_HASH = 'sha256'
+
+
+# Names of hashlib algorithms allowed by the --hash option and ``pip hash``
+# Currently, those are the ones at least as collision-resistant as sha256.
+STRONG_HASHES = ['sha256', 'sha384', 'sha512']
+
+
+class Hashes(object):
+    """A wrapper that builds multiple hashes at once and checks them against
+    known-good values
+
+    """
+    def __init__(self, hashes=None):
+        # type: (Dict[str, List[str]]) -> None
+        """
+        :param hashes: A dict of algorithm names pointing to lists of allowed
+            hex digests
+        """
+        self._allowed = {} if hashes is None else hashes
+
+    def check_against_chunks(self, chunks):
+        # type: (Iterator[bytes]) -> None
+        """Check good hashes against ones built from iterable of chunks of
+        data.
+
+        Raise HashMismatch if none match.
+
+        """
+        gots = {}
+        for hash_name in iterkeys(self._allowed):
+            try:
+                gots[hash_name] = hashlib.new(hash_name)
+            except (ValueError, TypeError):
+                raise InstallationError('Unknown hash name: %s' % hash_name)
+
+        for chunk in chunks:
+            for hash in itervalues(gots):
+                hash.update(chunk)
+
+        for hash_name, got in iteritems(gots):
+            if got.hexdigest() in self._allowed[hash_name]:
+                return
+        self._raise(gots)
+
+    def _raise(self, gots):
+        # type: (Dict[str, _Hash]) -> NoReturn
+        raise HashMismatch(self._allowed, gots)
+
+    def check_against_file(self, file):
+        # type: (BinaryIO) -> None
+        """Check good hashes against a file-like object
+
+        Raise HashMismatch if none match.
+
+        """
+        return self.check_against_chunks(read_chunks(file))
+
+    def check_against_path(self, path):
+        # type: (str) -> None
+        with open(path, 'rb') as file:
+            return self.check_against_file(file)
+
+    def __nonzero__(self):
+        # type: () -> bool
+        """Return whether I know any known-good hashes."""
+        return bool(self._allowed)
+
+    def __bool__(self):
+        # type: () -> bool
+        return self.__nonzero__()
+
+
+class MissingHashes(Hashes):
+    """A workalike for Hashes used when we're missing a hash for a requirement
+
+    It computes the actual hash of the requirement and raises a HashMissing
+    exception showing it to the user.
+
+    """
+    def __init__(self):
+        # type: () -> None
+        """Don't offer the ``hashes`` kwarg."""
+        # Pass our favorite hash in to generate a "gotten hash". With the
+        # empty list, it will never match, so an error will always raise.
+        super(MissingHashes, self).__init__(hashes={FAVORITE_HASH: []})
+
+    def _raise(self, gots):
+        # type: (Dict[str, _Hash]) -> NoReturn
+        raise HashMissing(gots[FAVORITE_HASH].hexdigest())
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/utils/hashes.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/utils/hashes.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..acd2e906ed8651d5f1b455671c180cb56580fc52
GIT binary patch
literal 5026
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

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/utils/logging.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/utils/logging.py
new file mode 100644
index 0000000..a28e88c
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/utils/logging.py
@@ -0,0 +1,371 @@
+from __future__ import absolute_import
+
+import contextlib
+import errno
+import logging
+import logging.handlers
+import os
+import sys
+from logging import Filter
+
+from pip._vendor.six import PY2
+
+from pip._internal.utils.compat import WINDOWS
+from pip._internal.utils.deprecation import DEPRECATION_MSG_PREFIX
+from pip._internal.utils.misc import ensure_dir, subprocess_logger
+
+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()
+_log_state.indentation = 0
+
+
+class BrokenStdoutLoggingError(Exception):
+    """
+    Raised if BrokenPipeError occurs for the stdout stream while logging.
+    """
+    pass
+
+
+# BrokenPipeError does not exist in Python 2 and, in addition, manifests
+# differently in Windows and non-Windows.
+if WINDOWS:
+    # In Windows, a broken pipe can show up as EINVAL rather than EPIPE:
+    # https://bugs.python.org/issue19612
+    # https://bugs.python.org/issue30418
+    if PY2:
+        def _is_broken_pipe_error(exc_class, exc):
+            """See the docstring for non-Windows Python 3 below."""
+            return (exc_class is IOError and
+                    exc.errno in (errno.EINVAL, errno.EPIPE))
+    else:
+        # In Windows, a broken pipe IOError became OSError in Python 3.
+        def _is_broken_pipe_error(exc_class, exc):
+            """See the docstring for non-Windows Python 3 below."""
+            return ((exc_class is BrokenPipeError) or  # noqa: F821
+                    (exc_class is OSError and
+                     exc.errno in (errno.EINVAL, errno.EPIPE)))
+elif PY2:
+    def _is_broken_pipe_error(exc_class, exc):
+        """See the docstring for non-Windows Python 3 below."""
+        return (exc_class is IOError and exc.errno == errno.EPIPE)
+else:
+    # Then we are in the non-Windows Python 3 case.
+    def _is_broken_pipe_error(exc_class, exc):
+        """
+        Return whether an exception is a broken pipe error.
+
+        Args:
+          exc_class: an exception class.
+          exc: an exception instance.
+        """
+        return (exc_class is BrokenPipeError)  # noqa: F821
+
+
+@contextlib.contextmanager
+def indent_log(num=2):
+    """
+    A context manager which will cause the log output to be indented for any
+    log messages emitted inside it.
+    """
+    _log_state.indentation += num
+    try:
+        yield
+    finally:
+        _log_state.indentation -= num
+
+
+def get_indentation():
+    return getattr(_log_state, 'indentation', 0)
+
+
+class IndentingFormatter(logging.Formatter):
+    def __init__(self, *args, **kwargs):
+        """
+        A logging.Formatter that obeys the indent_log() context manager.
+
+        :param add_timestamp: A bool indicating output lines should be prefixed
+            with their record's timestamp.
+        """
+        self.add_timestamp = kwargs.pop("add_timestamp", False)
+        super(IndentingFormatter, self).__init__(*args, **kwargs)
+
+    def get_message_start(self, formatted, levelno):
+        """
+        Return the start of the formatted log message (not counting the
+        prefix to add to each line).
+        """
+        if levelno < logging.WARNING:
+            return ''
+        if formatted.startswith(DEPRECATION_MSG_PREFIX):
+            # Then the message already has a prefix.  We don't want it to
+            # look like "WARNING: DEPRECATION: ...."
+            return ''
+        if levelno < logging.ERROR:
+            return 'WARNING: '
+
+        return 'ERROR: '
+
+    def format(self, record):
+        """
+        Calls the standard formatter, but will indent all of the log messages
+        by our current indentation level.
+        """
+        formatted = super(IndentingFormatter, self).format(record)
+        message_start = self.get_message_start(formatted, record.levelno)
+        formatted = message_start + formatted
+
+        prefix = ''
+        if self.add_timestamp:
+            prefix = self.formatTime(record, "%Y-%m-%dT%H:%M:%S ")
+        prefix += " " * get_indentation()
+        formatted = "".join([
+            prefix + line
+            for line in formatted.splitlines(True)
+        ])
+        return formatted
+
+
+def _color_wrap(*colors):
+    def wrapped(inp):
+        return "".join(list(colors) + [inp, colorama.Style.RESET_ALL])
+    return wrapped
+
+
+class ColorizedStreamHandler(logging.StreamHandler):
+
+    # Don't build up a list of colors if we don't have colorama
+    if colorama:
+        COLORS = [
+            # This needs to be in order from highest logging level to lowest.
+            (logging.ERROR, _color_wrap(colorama.Fore.RED)),
+            (logging.WARNING, _color_wrap(colorama.Fore.YELLOW)),
+        ]
+    else:
+        COLORS = []
+
+    def __init__(self, stream=None, no_color=None):
+        logging.StreamHandler.__init__(self, stream)
+        self._no_color = no_color
+
+        if WINDOWS and colorama:
+            self.stream = colorama.AnsiToWin32(self.stream)
+
+    def _using_stdout(self):
+        """
+        Return whether the handler is using sys.stdout.
+        """
+        if WINDOWS and colorama:
+            # Then self.stream is an AnsiToWin32 object.
+            return self.stream.wrapped is sys.stdout
+
+        return self.stream is sys.stdout
+
+    def should_color(self):
+        # Don't colorize things if we do not have colorama or if told not to
+        if not colorama or self._no_color:
+            return False
+
+        real_stream = (
+            self.stream if not isinstance(self.stream, colorama.AnsiToWin32)
+            else self.stream.wrapped
+        )
+
+        # If the stream is a tty we should color it
+        if hasattr(real_stream, "isatty") and real_stream.isatty():
+            return True
+
+        # If we have an ANSI term we should color it
+        if os.environ.get("TERM") == "ANSI":
+            return True
+
+        # If anything else we should not color it
+        return False
+
+    def format(self, record):
+        msg = logging.StreamHandler.format(self, record)
+
+        if self.should_color():
+            for level, color in self.COLORS:
+                if record.levelno >= level:
+                    msg = color(msg)
+                    break
+
+        return msg
+
+    # The logging module says handleError() can be customized.
+    def handleError(self, record):
+        exc_class, exc = sys.exc_info()[:2]
+        # If a broken pipe occurred while calling write() or flush() on the
+        # stdout stream in logging's Handler.emit(), then raise our special
+        # exception so we can handle it in main() instead of logging the
+        # broken pipe error and continuing.
+        if (exc_class and self._using_stdout() and
+                _is_broken_pipe_error(exc_class, exc)):
+            raise BrokenStdoutLoggingError()
+
+        return super(ColorizedStreamHandler, self).handleError(record)
+
+
+class BetterRotatingFileHandler(logging.handlers.RotatingFileHandler):
+
+    def _open(self):
+        ensure_dir(os.path.dirname(self.baseFilename))
+        return logging.handlers.RotatingFileHandler._open(self)
+
+
+class MaxLevelFilter(Filter):
+
+    def __init__(self, level):
+        self.level = level
+
+    def filter(self, record):
+        return record.levelno < self.level
+
+
+class ExcludeLoggerFilter(Filter):
+
+    """
+    A logging Filter that excludes records from a logger (or its children).
+    """
+
+    def filter(self, record):
+        # The base Filter class allows only records from a logger (or its
+        # children).
+        return not super(ExcludeLoggerFilter, self).filter(record)
+
+
+def setup_logging(verbosity, no_color, user_log_file):
+    """Configures and sets up all of the logging
+
+    Returns the requested logging level, as its integer value.
+    """
+
+    # Determine the level to be logging at.
+    if verbosity >= 1:
+        level = "DEBUG"
+    elif verbosity == -1:
+        level = "WARNING"
+    elif verbosity == -2:
+        level = "ERROR"
+    elif verbosity <= -3:
+        level = "CRITICAL"
+    else:
+        level = "INFO"
+
+    level_number = getattr(logging, level)
+
+    # The "root" logger should match the "console" level *unless* we also need
+    # to log to a user log file.
+    include_user_log = user_log_file is not None
+    if include_user_log:
+        additional_log_file = user_log_file
+        root_level = "DEBUG"
+    else:
+        additional_log_file = "/dev/null"
+        root_level = level
+
+    # Disable any logging besides WARNING unless we have DEBUG level logging
+    # enabled for vendored libraries.
+    vendored_log_level = "WARNING" if level in ["INFO", "ERROR"] else "DEBUG"
+
+    # Shorthands for clarity
+    log_streams = {
+        "stdout": "ext://sys.stdout",
+        "stderr": "ext://sys.stderr",
+    }
+    handler_classes = {
+        "stream": "pip._internal.utils.logging.ColorizedStreamHandler",
+        "file": "pip._internal.utils.logging.BetterRotatingFileHandler",
+    }
+    handlers = ["console", "console_errors", "console_subprocess"] + (
+        ["user_log"] if include_user_log else []
+    )
+
+    logging.config.dictConfig({
+        "version": 1,
+        "disable_existing_loggers": False,
+        "filters": {
+            "exclude_warnings": {
+                "()": "pip._internal.utils.logging.MaxLevelFilter",
+                "level": logging.WARNING,
+            },
+            "restrict_to_subprocess": {
+                "()": "logging.Filter",
+                "name": subprocess_logger.name,
+            },
+            "exclude_subprocess": {
+                "()": "pip._internal.utils.logging.ExcludeLoggerFilter",
+                "name": subprocess_logger.name,
+            },
+        },
+        "formatters": {
+            "indent": {
+                "()": IndentingFormatter,
+                "format": "%(message)s",
+            },
+            "indent_with_timestamp": {
+                "()": IndentingFormatter,
+                "format": "%(message)s",
+                "add_timestamp": True,
+            },
+        },
+        "handlers": {
+            "console": {
+                "level": level,
+                "class": handler_classes["stream"],
+                "no_color": no_color,
+                "stream": log_streams["stdout"],
+                "filters": ["exclude_subprocess", "exclude_warnings"],
+                "formatter": "indent",
+            },
+            "console_errors": {
+                "level": "WARNING",
+                "class": handler_classes["stream"],
+                "no_color": no_color,
+                "stream": log_streams["stderr"],
+                "filters": ["exclude_subprocess"],
+                "formatter": "indent",
+            },
+            # A handler responsible for logging to the console messages
+            # from the "subprocessor" logger.
+            "console_subprocess": {
+                "level": level,
+                "class": handler_classes["stream"],
+                "no_color": no_color,
+                "stream": log_streams["stderr"],
+                "filters": ["restrict_to_subprocess"],
+                "formatter": "indent",
+            },
+            "user_log": {
+                "level": "DEBUG",
+                "class": handler_classes["file"],
+                "filename": additional_log_file,
+                "delay": True,
+                "formatter": "indent_with_timestamp",
+            },
+        },
+        "root": {
+            "level": root_level,
+            "handlers": handlers,
+        },
+        "loggers": {
+            "pip._vendor": {
+                "level": vendored_log_level
+            }
+        },
+    })
+
+    return level_number
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/utils/logging.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/utils/logging.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..9b09c818626c659f3e87d71094c1a01f4b8c4a28
GIT binary patch
literal 12636
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

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/utils/misc.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/utils/misc.py
new file mode 100644
index 0000000..ca7a529
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/utils/misc.py
@@ -0,0 +1,1011 @@
+from __future__ import absolute_import
+
+import contextlib
+import errno
+import io
+# we have a submodule named 'logging' which would shadow this if we used the
+# regular name:
+import logging as std_logging
+import os
+import posixpath
+import re
+import shutil
+import stat
+import subprocess
+import sys
+import tarfile
+import zipfile
+from collections import deque
+
+from pip._vendor import pkg_resources
+# NOTE: retrying is not annotated in typeshed as on 2017-07-17, which is
+#       why we ignore the type on this import.
+from pip._vendor.retrying import retry  # type: ignore
+from pip._vendor.six import PY2
+from pip._vendor.six.moves import input, shlex_quote
+from pip._vendor.six.moves.urllib import parse as urllib_parse
+from pip._vendor.six.moves.urllib.parse import unquote as urllib_unquote
+
+from pip._internal.exceptions import CommandError, InstallationError
+from pip._internal.locations import (
+    running_under_virtualenv, site_packages, user_site, virtualenv_no_global,
+    write_delete_marker_file,
+)
+from pip._internal.utils.compat import (
+    WINDOWS, console_to_str, expanduser, stdlib_pkgs,
+)
+from pip._internal.utils.typing import MYPY_CHECK_RUNNING
+
+if PY2:
+    from io import BytesIO as StringIO
+else:
+    from io import StringIO
+
+if MYPY_CHECK_RUNNING:
+    from typing import (
+        Optional, Tuple, Iterable, List, Match, Union, Any, Mapping, Text,
+        AnyStr, Container
+    )
+    from pip._vendor.pkg_resources import Distribution
+    from pip._internal.models.link import Link
+    from pip._internal.utils.ui import SpinnerInterface
+
+
+__all__ = ['rmtree', 'display_path', 'backup_dir',
+           'ask', 'splitext',
+           'format_size', 'is_installable_dir',
+           'is_svn_page', 'file_contents',
+           'split_leading_dir', 'has_leading_dir',
+           'normalize_path',
+           'renames', 'get_prog',
+           'unzip_file', 'untar_file', 'unpack_file', 'call_subprocess',
+           'captured_stdout', 'ensure_dir',
+           'ARCHIVE_EXTENSIONS', 'SUPPORTED_EXTENSIONS', 'WHEEL_EXTENSION',
+           'get_installed_version', 'remove_auth_from_url']
+
+
+logger = std_logging.getLogger(__name__)
+subprocess_logger = std_logging.getLogger('pip.subprocessor')
+
+LOG_DIVIDER = '----------------------------------------'
+
+WHEEL_EXTENSION = '.whl'
+BZ2_EXTENSIONS = ('.tar.bz2', '.tbz')
+XZ_EXTENSIONS = ('.tar.xz', '.txz', '.tlz', '.tar.lz', '.tar.lzma')
+ZIP_EXTENSIONS = ('.zip', WHEEL_EXTENSION)
+TAR_EXTENSIONS = ('.tar.gz', '.tgz', '.tar')
+ARCHIVE_EXTENSIONS = (
+    ZIP_EXTENSIONS + BZ2_EXTENSIONS + TAR_EXTENSIONS + XZ_EXTENSIONS)
+SUPPORTED_EXTENSIONS = ZIP_EXTENSIONS + TAR_EXTENSIONS
+
+try:
+    import bz2  # noqa
+    SUPPORTED_EXTENSIONS += BZ2_EXTENSIONS
+except ImportError:
+    logger.debug('bz2 module is not available')
+
+try:
+    # Only for Python 3.3+
+    import lzma  # noqa
+    SUPPORTED_EXTENSIONS += XZ_EXTENSIONS
+except ImportError:
+    logger.debug('lzma module is not available')
+
+
+def ensure_dir(path):
+    # type: (AnyStr) -> None
+    """os.path.makedirs without EEXIST."""
+    try:
+        os.makedirs(path)
+    except OSError as e:
+        if e.errno != errno.EEXIST:
+            raise
+
+
+def get_prog():
+    # type: () -> str
+    try:
+        prog = os.path.basename(sys.argv[0])
+        if prog in ('__main__.py', '-c'):
+            return "%s -m pip" % sys.executable
+        else:
+            return prog
+    except (AttributeError, TypeError, IndexError):
+        pass
+    return 'pip'
+
+
+# Retry every half second for up to 3 seconds
+@retry(stop_max_delay=3000, wait_fixed=500)
+def rmtree(dir, ignore_errors=False):
+    # type: (str, bool) -> None
+    shutil.rmtree(dir, ignore_errors=ignore_errors,
+                  onerror=rmtree_errorhandler)
+
+
+def rmtree_errorhandler(func, path, exc_info):
+    """On Windows, the files in .svn are read-only, so when rmtree() tries to
+    remove them, an exception is thrown.  We catch that here, remove the
+    read-only attribute, and hopefully continue without problems."""
+    # if file type currently read only
+    if os.stat(path).st_mode & stat.S_IREAD:
+        # convert to read/write
+        os.chmod(path, stat.S_IWRITE)
+        # use the original function to repeat the operation
+        func(path)
+        return
+    else:
+        raise
+
+
+def display_path(path):
+    # type: (Union[str, Text]) -> str
+    """Gives the display value for a given path, making it relative to cwd
+    if possible."""
+    path = os.path.normcase(os.path.abspath(path))
+    if sys.version_info[0] == 2:
+        path = path.decode(sys.getfilesystemencoding(), 'replace')
+        path = path.encode(sys.getdefaultencoding(), 'replace')
+    if path.startswith(os.getcwd() + os.path.sep):
+        path = '.' + path[len(os.getcwd()):]
+    return path
+
+
+def backup_dir(dir, ext='.bak'):
+    # type: (str, str) -> str
+    """Figure out the name of a directory to back up the given dir to
+    (adding .bak, .bak2, etc)"""
+    n = 1
+    extension = ext
+    while os.path.exists(dir + extension):
+        n += 1
+        extension = ext + str(n)
+    return dir + extension
+
+
+def ask_path_exists(message, options):
+    # type: (str, Iterable[str]) -> str
+    for action in os.environ.get('PIP_EXISTS_ACTION', '').split():
+        if action in options:
+            return action
+    return ask(message, options)
+
+
+def ask(message, options):
+    # type: (str, Iterable[str]) -> str
+    """Ask the message interactively, with the given possible responses"""
+    while 1:
+        if os.environ.get('PIP_NO_INPUT'):
+            raise Exception(
+                'No input was expected ($PIP_NO_INPUT set); question: %s' %
+                message
+            )
+        response = input(message)
+        response = response.strip().lower()
+        if response not in options:
+            print(
+                'Your response (%r) was not one of the expected responses: '
+                '%s' % (response, ', '.join(options))
+            )
+        else:
+            return response
+
+
+def format_size(bytes):
+    # type: (float) -> str
+    if bytes > 1000 * 1000:
+        return '%.1fMB' % (bytes / 1000.0 / 1000)
+    elif bytes > 10 * 1000:
+        return '%ikB' % (bytes / 1000)
+    elif bytes > 1000:
+        return '%.1fkB' % (bytes / 1000.0)
+    else:
+        return '%ibytes' % bytes
+
+
+def is_installable_dir(path):
+    # type: (str) -> bool
+    """Is path is a directory containing setup.py or pyproject.toml?
+    """
+    if not os.path.isdir(path):
+        return False
+    setup_py = os.path.join(path, 'setup.py')
+    if os.path.isfile(setup_py):
+        return True
+    pyproject_toml = os.path.join(path, 'pyproject.toml')
+    if os.path.isfile(pyproject_toml):
+        return True
+    return False
+
+
+def is_svn_page(html):
+    # type: (Union[str, Text]) -> Optional[Match[Union[str, Text]]]
+    """
+    Returns true if the page appears to be the index page of an svn repository
+    """
+    return (re.search(r'<title>[^<]*Revision \d+:', html) and
+            re.search(r'Powered by (?:<a[^>]*?>)?Subversion', html, re.I))
+
+
+def file_contents(filename):
+    # type: (str) -> Text
+    with open(filename, 'rb') as fp:
+        return fp.read().decode('utf-8')
+
+
+def read_chunks(file, size=io.DEFAULT_BUFFER_SIZE):
+    """Yield pieces of data from a file-like object until EOF."""
+    while True:
+        chunk = file.read(size)
+        if not chunk:
+            break
+        yield chunk
+
+
+def split_leading_dir(path):
+    # type: (Union[str, Text]) -> List[Union[str, Text]]
+    path = path.lstrip('/').lstrip('\\')
+    if '/' in path and (('\\' in path and path.find('/') < path.find('\\')) or
+                        '\\' not in path):
+        return path.split('/', 1)
+    elif '\\' in path:
+        return path.split('\\', 1)
+    else:
+        return [path, '']
+
+
+def has_leading_dir(paths):
+    # type: (Iterable[Union[str, Text]]) -> bool
+    """Returns true if all the paths have the same leading path name
+    (i.e., everything is in one subdirectory in an archive)"""
+    common_prefix = None
+    for path in paths:
+        prefix, rest = split_leading_dir(path)
+        if not prefix:
+            return False
+        elif common_prefix is None:
+            common_prefix = prefix
+        elif prefix != common_prefix:
+            return False
+    return True
+
+
+def normalize_path(path, resolve_symlinks=True):
+    # type: (str, bool) -> str
+    """
+    Convert a path to its canonical, case-normalized, absolute version.
+
+    """
+    path = expanduser(path)
+    if resolve_symlinks:
+        path = os.path.realpath(path)
+    else:
+        path = os.path.abspath(path)
+    return os.path.normcase(path)
+
+
+def splitext(path):
+    # type: (str) -> Tuple[str, str]
+    """Like os.path.splitext, but take off .tar too"""
+    base, ext = posixpath.splitext(path)
+    if base.lower().endswith('.tar'):
+        ext = base[-4:] + ext
+        base = base[:-4]
+    return base, ext
+
+
+def renames(old, new):
+    # type: (str, str) -> None
+    """Like os.renames(), but handles renaming across devices."""
+    # Implementation borrowed from os.renames().
+    head, tail = os.path.split(new)
+    if head and tail and not os.path.exists(head):
+        os.makedirs(head)
+
+    shutil.move(old, new)
+
+    head, tail = os.path.split(old)
+    if head and tail:
+        try:
+            os.removedirs(head)
+        except OSError:
+            pass
+
+
+def is_local(path):
+    # type: (str) -> bool
+    """
+    Return True if path is within sys.prefix, if we're running in a virtualenv.
+
+    If we're not in a virtualenv, all paths are considered "local."
+
+    """
+    if not running_under_virtualenv():
+        return True
+    return normalize_path(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.
+    """
+    norm_path = normalize_path(dist_location(dist))
+    return norm_path.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 normalize_path(
+        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,
+                                skip=stdlib_pkgs,
+                                include_editables=True,
+                                editables_only=False,
+                                user_only=False):
+    # type: (bool, Container[str], bool, bool, bool) -> List[Distribution]
+    """
+    Return a list of installed Distribution objects.
+
+    If ``local_only`` is True (default), only return installations
+    local to the current virtualenv, if in a virtualenv.
+
+    ``skip`` argument is an iterable of lower-case project names to
+    ignore; defaults to stdlib_pkgs
+
+    If ``include_editables`` is False, don't report editables.
+
+    If ``editables_only`` is True , only report editables.
+
+    If ``user_only`` is True , only report installations in the user
+    site directory.
+
+    """
+    if local_only:
+        local_test = dist_is_local
+    else:
+        def local_test(d):
+            return True
+
+    if include_editables:
+        def editable_test(d):
+            return True
+    else:
+        def editable_test(d):
+            return not dist_is_editable(d)
+
+    if editables_only:
+        def editables_only_test(d):
+            return dist_is_editable(d)
+    else:
+        def editables_only_test(d):
+            return True
+
+    if user_only:
+        user_test = dist_in_usersite
+    else:
+        def user_test(d):
+            return True
+
+    # because of pkg_resources vendoring, mypy cannot find stub in typeshed
+    return [d for d in pkg_resources.working_set  # type: ignore
+            if local_test(d) and
+            d.key not in skip and
+            editable_test(d) and
+            editables_only_test(d) and
+            user_test(d)
+            ]
+
+
+def egg_link_path(dist):
+    # type: (Distribution) -> Optional[str]
+    """
+    Return the path for the .egg-link file if it exists, otherwise, None.
+
+    There's 3 scenarios:
+    1) not in a virtualenv
+       try to find in site.USER_SITE, then site_packages
+    2) in a no-global virtualenv
+       try to find in site_packages
+    3) in a yes-global virtualenv
+       try to find in site_packages, then site.USER_SITE
+       (don't look in global location)
+
+    For #1 and #3, there could be odd cases, where there's an egg-link in 2
+    locations.
+
+    This method will just return the first one found.
+    """
+    sites = []
+    if running_under_virtualenv():
+        if virtualenv_no_global():
+            sites.append(site_packages)
+        else:
+            sites.append(site_packages)
+            if 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.
+
+    """
+    egg_link = egg_link_path(dist)
+    if egg_link:
+        return egg_link
+    return dist.location
+
+
+def current_umask():
+    """Get the current umask which involves having to set it temporarily."""
+    mask = os.umask(0)
+    os.umask(mask)
+    return mask
+
+
+def unzip_file(filename, location, flatten=True):
+    # type: (str, str, bool) -> None
+    """
+    Unzip the file (with path `filename`) to the destination `location`.  All
+    files are written based on system defaults and umask (i.e. permissions are
+    not preserved), except that regular file members with any execute
+    permissions (user, group, or world) have "chmod +x" applied after being
+    written. Note that for windows, any execute changes using os.chmod are
+    no-ops per the python docs.
+    """
+    ensure_dir(location)
+    zipfp = open(filename, 'rb')
+    try:
+        zip = zipfile.ZipFile(zipfp, allowZip64=True)
+        leading = has_leading_dir(zip.namelist()) and flatten
+        for info in zip.infolist():
+            name = info.filename
+            fn = name
+            if leading:
+                fn = split_leading_dir(name)[1]
+            fn = os.path.join(location, fn)
+            dir = os.path.dirname(fn)
+            if fn.endswith('/') or fn.endswith('\\'):
+                # A directory
+                ensure_dir(fn)
+            else:
+                ensure_dir(dir)
+                # Don't use read() to avoid allocating an arbitrarily large
+                # chunk of memory for the file's content
+                fp = zip.open(name)
+                try:
+                    with open(fn, 'wb') as destfp:
+                        shutil.copyfileobj(fp, destfp)
+                finally:
+                    fp.close()
+                    mode = info.external_attr >> 16
+                    # if mode and regular file and any execute permissions for
+                    # user/group/world?
+                    if mode and stat.S_ISREG(mode) and mode & 0o111:
+                        # make dest file have execute for user/group/world
+                        # (chmod +x) no-op on windows per python docs
+                        os.chmod(fn, (0o777 - current_umask() | 0o111))
+    finally:
+        zipfp.close()
+
+
+def untar_file(filename, location):
+    # type: (str, str) -> None
+    """
+    Untar the file (with path `filename`) to the destination `location`.
+    All files are written based on system defaults and umask (i.e. permissions
+    are not preserved), except that regular file members with any execute
+    permissions (user, group, or world) have "chmod +x" applied after being
+    written.  Note that for windows, any execute changes using os.chmod are
+    no-ops per the python docs.
+    """
+    ensure_dir(location)
+    if filename.lower().endswith('.gz') or filename.lower().endswith('.tgz'):
+        mode = 'r:gz'
+    elif filename.lower().endswith(BZ2_EXTENSIONS):
+        mode = 'r:bz2'
+    elif filename.lower().endswith(XZ_EXTENSIONS):
+        mode = 'r:xz'
+    elif filename.lower().endswith('.tar'):
+        mode = 'r'
+    else:
+        logger.warning(
+            'Cannot determine compression type for file %s', filename,
+        )
+        mode = 'r:*'
+    tar = tarfile.open(filename, mode)
+    try:
+        leading = has_leading_dir([
+            member.name for member in tar.getmembers()
+        ])
+        for member in tar.getmembers():
+            fn = member.name
+            if leading:
+                # https://github.com/python/mypy/issues/1174
+                fn = split_leading_dir(fn)[1]  # type: ignore
+            path = os.path.join(location, fn)
+            if member.isdir():
+                ensure_dir(path)
+            elif member.issym():
+                try:
+                    # https://github.com/python/typeshed/issues/2673
+                    tar._extract_member(member, path)  # type: ignore
+                except Exception as exc:
+                    # Some corrupt tar files seem to produce this
+                    # (specifically bad symlinks)
+                    logger.warning(
+                        'In the tar file %s the member %s is invalid: %s',
+                        filename, member.name, exc,
+                    )
+                    continue
+            else:
+                try:
+                    fp = tar.extractfile(member)
+                except (KeyError, AttributeError) as exc:
+                    # Some corrupt tar files seem to produce this
+                    # (specifically bad symlinks)
+                    logger.warning(
+                        'In the tar file %s the member %s is invalid: %s',
+                        filename, member.name, exc,
+                    )
+                    continue
+                ensure_dir(os.path.dirname(path))
+                with open(path, 'wb') as destfp:
+                    shutil.copyfileobj(fp, destfp)
+                fp.close()
+                # Update the timestamp (useful for cython compiled files)
+                # https://github.com/python/typeshed/issues/2673
+                tar.utime(member, path)  # type: ignore
+                # member have any execute permissions for user/group/world?
+                if member.mode & 0o111:
+                    # make dest file have execute for user/group/world
+                    # no-op on windows per python docs
+                    os.chmod(path, (0o777 - current_umask() | 0o111))
+    finally:
+        tar.close()
+
+
+def unpack_file(
+    filename,  # type: str
+    location,  # type: str
+    content_type,  # type: Optional[str]
+    link  # type: Optional[Link]
+):
+    # type: (...) -> None
+    filename = os.path.realpath(filename)
+    if (content_type == 'application/zip' or
+            filename.lower().endswith(ZIP_EXTENSIONS) or
+            zipfile.is_zipfile(filename)):
+        unzip_file(
+            filename,
+            location,
+            flatten=not filename.endswith('.whl')
+        )
+    elif (content_type == 'application/x-gzip' or
+            tarfile.is_tarfile(filename) or
+            filename.lower().endswith(
+                TAR_EXTENSIONS + BZ2_EXTENSIONS + XZ_EXTENSIONS)):
+        untar_file(filename, location)
+    elif (content_type and content_type.startswith('text/html') and
+            is_svn_page(file_contents(filename))):
+        # We don't really care about this
+        from pip._internal.vcs.subversion import Subversion
+        Subversion('svn+' + link.url).unpack(location)
+    else:
+        # FIXME: handle?
+        # FIXME: magic signatures?
+        logger.critical(
+            'Cannot unpack file %s (downloaded from %s, content-type: %s); '
+            'cannot detect archive format',
+            filename, location, content_type,
+        )
+        raise InstallationError(
+            'Cannot determine archive format of %s' % location
+        )
+
+
+def format_command_args(args):
+    # type: (List[str]) -> str
+    """
+    Format command arguments for display.
+    """
+    return ' '.join(shlex_quote(arg) for arg in args)
+
+
+def call_subprocess(
+    cmd,  # type: List[str]
+    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]
+):
+    # type: (...) -> Optional[Text]
+    """
+    Args:
+      show_stdout: if true, use INFO to log the subprocess's stderr and
+        stdout streams.  Otherwise, use DEBUG.  Defaults to False.
+      extra_ok_returncodes: an iterable of integer return codes that are
+        acceptable, in addition to 0. Defaults to None, which means [].
+      unset_environ: an iterable of environment variable names to unset
+        prior to calling subprocess.Popen().
+    """
+    if extra_ok_returncodes is None:
+        extra_ok_returncodes = []
+    if unset_environ is None:
+        unset_environ = []
+    # Most places in pip use show_stdout=False. What this means is--
+    #
+    # - We connect the child's output (combined stderr and stdout) to a
+    #   single pipe, which we read.
+    # - We log this output to stderr at DEBUG level as it is received.
+    # - If DEBUG logging isn't enabled (e.g. if --verbose logging wasn't
+    #   requested), then we show a spinner so the user can still see the
+    #   subprocess is in progress.
+    # - If the subprocess exits with an error, we log the output to stderr
+    #   at ERROR level if it hasn't already been displayed to the console
+    #   (e.g. if --verbose logging wasn't enabled).  This way we don't log
+    #   the output to the console twice.
+    #
+    # If show_stdout=True, then the above is still done, but with DEBUG
+    # replaced by INFO.
+    if show_stdout:
+        # Then log the subprocess output at INFO level.
+        log_subprocess = subprocess_logger.info
+        used_level = std_logging.INFO
+    else:
+        # Then log the subprocess output using DEBUG.  This also ensures
+        # it will be logged to the log file (aka user_log), if enabled.
+        log_subprocess = subprocess_logger.debug
+        used_level = std_logging.DEBUG
+
+    # Whether the subprocess will be visible in the console.
+    showing_subprocess = subprocess_logger.getEffectiveLevel() <= used_level
+
+    # Only use the spinner if we're not showing the subprocess output
+    # and we have a spinner.
+    use_spinner = not showing_subprocess and spinner is not None
+
+    if command_desc is None:
+        command_desc = format_command_args(cmd)
+
+    log_subprocess("Running command %s", command_desc)
+    env = os.environ.copy()
+    if extra_environ:
+        env.update(extra_environ)
+    for name in unset_environ:
+        env.pop(name, None)
+    try:
+        proc = subprocess.Popen(
+            cmd, stderr=subprocess.STDOUT, stdin=subprocess.PIPE,
+            stdout=subprocess.PIPE, cwd=cwd, env=env,
+        )
+        proc.stdin.close()
+    except Exception as exc:
+        subprocess_logger.critical(
+            "Error %s while executing command %s", exc, command_desc,
+        )
+        raise
+    all_output = []
+    while True:
+        line = console_to_str(proc.stdout.readline())
+        if not line:
+            break
+        line = line.rstrip()
+        all_output.append(line + '\n')
+
+        # Show the line immediately.
+        log_subprocess(line)
+        # Update the spinner.
+        if use_spinner:
+            spinner.spin()
+    try:
+        proc.wait()
+    finally:
+        if proc.stdout:
+            proc.stdout.close()
+    proc_had_error = (
+        proc.returncode and proc.returncode not in extra_ok_returncodes
+    )
+    if use_spinner:
+        if proc_had_error:
+            spinner.finish("error")
+        else:
+            spinner.finish("done")
+    if proc_had_error:
+        if on_returncode == 'raise':
+            if not showing_subprocess:
+                # Then the subprocess streams haven't been logged to the
+                # console yet.
+                subprocess_logger.error(
+                    'Complete output from command %s:', command_desc,
+                )
+                # The all_output value already ends in a newline.
+                subprocess_logger.error(''.join(all_output) + LOG_DIVIDER)
+            raise InstallationError(
+                'Command "%s" failed with error code %s in %s'
+                % (command_desc, proc.returncode, cwd))
+        elif on_returncode == 'warn':
+            subprocess_logger.warning(
+                'Command "%s" had error code %s in %s',
+                command_desc, proc.returncode, cwd,
+            )
+        elif on_returncode == 'ignore':
+            pass
+        else:
+            raise ValueError('Invalid value: on_returncode=%s' %
+                             repr(on_returncode))
+    return ''.join(all_output)
+
+
+def _make_build_dir(build_dir):
+    os.makedirs(build_dir)
+    write_delete_marker_file(build_dir)
+
+
+class FakeFile(object):
+    """Wrap a list of lines in an object with readline() to make
+    ConfigParser happy."""
+    def __init__(self, lines):
+        self._gen = (l for l in lines)
+
+    def readline(self):
+        try:
+            try:
+                return next(self._gen)
+            except NameError:
+                return self._gen.next()
+        except StopIteration:
+            return ''
+
+    def __iter__(self):
+        return self._gen
+
+
+class StreamWrapper(StringIO):
+
+    @classmethod
+    def from_stream(cls, orig_stream):
+        cls.orig_stream = orig_stream
+        return cls()
+
+    # compileall.compile_dir() needs stdout.encoding to print to stdout
+    @property
+    def encoding(self):
+        return self.orig_stream.encoding
+
+
+@contextlib.contextmanager
+def captured_output(stream_name):
+    """Return a context manager used by captured_stdout/stdin/stderr
+    that temporarily replaces the sys stream *stream_name* with a StringIO.
+
+    Taken from Lib/support/__init__.py in the CPython repo.
+    """
+    orig_stdout = getattr(sys, stream_name)
+    setattr(sys, stream_name, StreamWrapper.from_stream(orig_stdout))
+    try:
+        yield getattr(sys, stream_name)
+    finally:
+        setattr(sys, stream_name, orig_stdout)
+
+
+def captured_stdout():
+    """Capture the output of sys.stdout:
+
+       with captured_stdout() as stdout:
+           print('hello')
+       self.assertEqual(stdout.getvalue(), 'hello\n')
+
+    Taken from Lib/support/__init__.py in the CPython repo.
+    """
+    return captured_output('stdout')
+
+
+def captured_stderr():
+    """
+    See captured_stdout().
+    """
+    return captured_output('stderr')
+
+
+class cached_property(object):
+    """A property that is only computed once per instance and then replaces
+       itself with an ordinary attribute. Deleting the attribute resets the
+       property.
+
+       Source: https://github.com/bottlepy/bottle/blob/0.11.5/bottle.py#L175
+    """
+
+    def __init__(self, func):
+        self.__doc__ = getattr(func, '__doc__')
+        self.func = func
+
+    def __get__(self, obj, cls):
+        if obj is None:
+            # We're being accessed from the class itself, not from an object
+            return self
+        value = obj.__dict__[self.func.__name__] = self.func(obj)
+        return value
+
+
+def get_installed_version(dist_name, working_set=None):
+    """Get the installed version of dist_name avoiding pkg_resources cache"""
+    # Create a requirement that we'll look for inside of setuptools.
+    req = pkg_resources.Requirement.parse(dist_name)
+
+    if working_set is None:
+        # We want to avoid having this cached, so we need to construct a new
+        # working set each time.
+        working_set = pkg_resources.WorkingSet()
+
+    # Get the installed distribution from our working set
+    dist = working_set.find(req)
+
+    # Check to see if we got an installed distribution or not, if we did
+    # we want to return it's version.
+    return dist.version if dist else None
+
+
+def consume(iterator):
+    """Consume an iterable at C speed."""
+    deque(iterator, maxlen=0)
+
+
+# Simulates an enum
+def enum(*sequential, **named):
+    enums = dict(zip(sequential, range(len(sequential))), **named)
+    reverse = {value: key for key, value in enums.items()}
+    enums['reverse_mapping'] = reverse
+    return type('Enum', (), enums)
+
+
+def split_auth_from_netloc(netloc):
+    """
+    Parse out and remove the auth information from a netloc.
+
+    Returns: (netloc, (username, password)).
+    """
+    if '@' not in netloc:
+        return netloc, (None, None)
+
+    # Split from the right because that's how urllib.parse.urlsplit()
+    # behaves if more than one @ is present (which can be checked using
+    # the password attribute of urlsplit()'s return value).
+    auth, netloc = netloc.rsplit('@', 1)
+    if ':' in auth:
+        # Split from the left because that's how urllib.parse.urlsplit()
+        # behaves if more than one : is present (which again can be checked
+        # using the password attribute of the return value)
+        user_pass = auth.split(':', 1)
+    else:
+        user_pass = auth, None
+
+    user_pass = tuple(
+        None if x is None else urllib_unquote(x) for x in user_pass
+    )
+
+    return netloc, user_pass
+
+
+def redact_netloc(netloc):
+    # type: (str) -> str
+    """
+    Replace the password in a netloc with "****", if it exists.
+
+    For example, "user:pass@example.com" returns "user:****@example.com".
+    """
+    netloc, (user, password) = split_auth_from_netloc(netloc)
+    if user is None:
+        return netloc
+    password = '' if password is None else ':****'
+    return '{user}{password}@{netloc}'.format(user=urllib_parse.quote(user),
+                                              password=password,
+                                              netloc=netloc)
+
+
+def _transform_url(url, transform_netloc):
+    purl = urllib_parse.urlsplit(url)
+    netloc = transform_netloc(purl.netloc)
+    # stripped url
+    url_pieces = (
+        purl.scheme, netloc, purl.path, purl.query, purl.fragment
+    )
+    surl = urllib_parse.urlunsplit(url_pieces)
+    return surl
+
+
+def _get_netloc(netloc):
+    return split_auth_from_netloc(netloc)[0]
+
+
+def remove_auth_from_url(url):
+    # type: (str) -> str
+    # Return a copy of url with 'username:password@' removed.
+    # username/pass params are passed to subversion through flags
+    # and are not recognized in the url.
+    return _transform_url(url, _get_netloc)
+
+
+def redact_password_from_url(url):
+    # type: (str) -> str
+    """Replace the password in a given url with ****."""
+    return _transform_url(url, redact_netloc)
+
+
+def protect_pip_from_modification_on_windows(modifying_pip):
+    """Protection of pip.exe from modification on Windows
+
+    On Windows, any operation modifying pip should be run as:
+        python -m pip ...
+    """
+    pip_names = [
+        "pip.exe",
+        "pip{}.exe".format(sys.version_info[0]),
+        "pip{}.{}.exe".format(*sys.version_info[:2])
+    ]
+
+    # See https://github.com/pypa/pip/issues/1299 for more discussion
+    should_show_use_python_msg = (
+        modifying_pip and
+        WINDOWS and
+        os.path.basename(sys.argv[0]) in pip_names
+    )
+
+    if should_show_use_python_msg:
+        new_command = [
+            sys.executable, "-m", "pip"
+        ] + sys.argv[1:]
+        raise CommandError(
+            'To modify pip, please run the following command:\n{}'
+            .format(" ".join(new_command))
+        )
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/utils/misc.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/utils/misc.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..5c120339e9c5e44aaf0081c4195fe09b9bf5dc7f
GIT binary patch
literal 34905
zcmZSn%**AGdLky70SY7;7#JKJ7#NCIvNABFFfgPrGUPBY<T5fuF)}cM_)H8rObk&>
zU^ym+9A<_nW*D1=A&LdYW@U(CgR$8eqS#?<4u&WW7@LzJiWA1>Vu<2`vAG$dxM6G_
zhA18wo0lPq7slpeh~k5>`5B`4!E9!R907)0L53(nh+A10a)cOig&CrRA$(Sb91(_G
zQHCf{2%n81M~op?oFPga!e?j5kzmM`WQdYv$dzJ<l7fhGFyu%x<jOEa$wK&?3^{TP
zx$+EA3J^XQLyjUtt`b9(5<{*sLzFT^l$#+(g&|j!Axf1YSB)V`jUiW^AxfPgSA!u+
zgCSRwAxaaXj)x&fiy>E=AxfJeSBD`=hap#&Axf7aSC1h|52AvXAxEDf*MK3)fPpbp
zoS|qnI3D;Ia#$F04H=@07#Q;ez~1Kv3mJihQVkf29GE~6Ccuzm%#drs5M{!UYswI1
z%8+Zu5M{=YYt9g5&X8-t5M{xTYsnC0$&hQs5M{-XYt0a4&5&!u5M{%VYs(O2%aCiw
z5M>8(iXcOdJwvVoLzDxAFT{}J$dK#A5ak5n3p3<6GvvB3M7c09<}om&h%lsxGNgzx
zq=+-5NHC;GGNec`q)0QQ$S|bHGNi~cq{uU*C@`cbGNdRmq$o3_s4%3cGNh<6q^L8b
zXfUK`GNfoRq-Zmw=rE*9GDNvDq_Qz&xiO@=Gc+?YM0r5DDY{^;Cqs%JLzEXoiatY>
zH$zG}LzE9gN(DodFGGqsL#j7J8WTg5A45tdLzF*5svkqD4}*BBKZAIxFN1hg09eGI
zK|Csup;8JQm`n^gK@3qr45@)2rRGtA4B>fl3@oX^4B1=^Mf%K)jEt!s3|S!zDb^tC
z8S@w!A`n_b8KOeLT74PNwPqn{wSj9*v1MpsV2BE1NU;Mm!WmLU8B**SQXCjk92rua
z7@8TFQX?2roEcgeL7Ji>8B$!pDx(-uT)~WJh7>o36nBt<s2GM653pb?Ly9Mu5yz0?
z1!lxEq<DiF2@EMdU`8TCiZ7Uv#E{Cukd@4k;s-V)g(1ZsES}1c5&&kTF{Gw5qy&Ox
zGZ<2Wz=D|!DZyYy7DGx1n32tp5(;MIFr<Wm8MzE8;b2A{LrMggkq<H|RS!%?Fo3)k
z$<V^e5LLjC5(QRJ$dD2ZW)v}`#DE#aAjK)MVB1R=QsTgZr3@+YU`823N&=Ws4mOR6
zAtjL^g$WfUF|=?nL{&1RB!g8}F{Gq0q*gPeF*2m2f<&4b7$T!;7*f(0QjNf(>2T3n
zhEyhotU89246qO*LsUION+yUM)xeOF1!godq-4X)%K?di&1(X?As6iIW`>kJkVI4q
zLrOlF(aMlg0A{o?q!fY~?F=bJU`7W+N->zx$&gY4W^^&6l!6)E3@K$`Mi0pFV2vsU
z28K*f5w5|=z`#(#&%nTtm{gpfQ(BT5pP5^bUsU1;kzr+EU`R<VEKP-Qc^McO3bNDV
zi&Bg8ON)|Iiy^`wRYj>KMU@aPGXn!dK%|id6Uc0kTxMQDX-Nq;0|P^GMowx)d|_#R
z3DiW8bU|WKF_g>Bz`#(N2ayMB=V4%AaL&)oP0UMiEh@?{DiLI0VDQW<E=kPENi50C
z&jX8UfQ%`TU|?V<D$UEw%uA0i%}YrwiZ9D7Dk)9ONzE%O0Xe-mvm`aXATc>RF+H`o
zgcD>}acWUKNVr6Vfq?;`JU%Z!K0PNtDKQ6ZYIzYzXG&^LYDsE*Zeme(YEgVzW=^UG
z3&@KgM~8d*x%h_%m+&z#FeK;a73b%q#+T&B7nc;3a4|42q*fFp=B1Ptrxrnip(G_I
zGbz3xI~^K=LJSNHzL5cu@y;Hu&ff7sp?-dze(sRq1R3vCS&~}p=?@X$U|?VfE-A{)
zOZW8G0EKD^NW{MY6dZ{;C7`efDJ{rJ1q*wYq!uM6<)oH?oa&QVTmqK&O)N>y0JB2#
zGV}9FKvCwHS6KqG%Qvy0ATuu=tRW<|qNIe4fq}s>uQIr#2pne4`FSOYnR%&25Z8cW
z$R)G5q$o3~6yySkD8#nBYzR*P<l=(Nyu8#R&%Bb<qO`>1RIsr{xg|xZsU;vYQZkDR
zauO@!3ld8*z+sk@n4Dc&5TBA+1a@9xaW>dP#RWN;B_L;ke4dtHl$%%*Uz}N$S^^5g
z%;NY=XyQo9Nd@Z#Da$O5FD}cAFGx&J1t$bh+{Gv7=ar=9l@x=M6xh`GoYce=Q0f8M
z3Ca{1iNz>lpxDg=S(%er1xiUJ8Q>5rO3h2mO)UmHFFmy+zMv>S9qfhDysFFsa7ux4
zOA;Xo2b>B@^FV14A`P-FIWZ?EzPL20peR2%wYV6ZEt3-qN=l1TQ{szDQu0enz{aHJ
z6_*x4JO}c#W013lXP9feYea~vU$CdYUobc^2Zsg(_y>i!x*$t{tO@sUb@f3AmWVPi
zFo0YQ4Y<^l__EZZVo<68<%y!y-2AfC_{7qZjQF&o{M`7`qMTw-d=_LD=ph`NUsSBY
zz`&qOBq#=@554k?oMKSY)hkIX(o3o`f{2zRRTYEMAy~Ac3MvR^<RHoBR274AF<50z
zRc<0gZB=Fg!hm#`0dPiQQL!`w14B}kkwR{MN@-52LT0f-UVe!}Vp(El4k)h_%P=r7
zfXu_CAQ@C_g32dQUULSuf1Mc^7%BxBN*EZj7#V69Ky@x-c%C)`O9>OW1z^X(Sj))3
zSi{JW#mrE`%#g*xkj>0cWY5sVz))z<0BR1TFfs&#%gka01_p-wVm(k!(92ECPEE-y
zDpn}ZEXl|(Em3fFjqnT((es0pc_2sRLsA}0B{)g?2ZIYna28K3D$2_TXE%smuqEK^
z4YHvG<d;-X<S~GW;%o*62K|Df%(BFiRQ<BVBK@@doRrj}V*R8P{qm%wyj;`VVk5&O
z^Yp583sZ~ooUAG{0}x2h(+|-v$Slx>CL~?AG7nGV0FV$E$7h1FeqLgZerZW&PO*M&
zW^uA!L1mBy0|P@msBQoilnl(wjDn2(j6#gyJ_g8bptJxE<48~#TR_7&iwPQxDU1w~
z&5R7S44`07VPnW<V<<9aNMQj>voeSU*Dx>yhv!K#u#~Vdl&~|Da4@7XgX1KGfsqm1
z5KCcY2-W~u;|H!3i$O(3e0*+VW?p=}UO{CsD3EoN!AVWESV1>ep&+vWTqYG{7Jvg2
zhYk%+1_p*8I}ia%AK>yKDX|z_T7dNzR~CcgA+adE43f1gQj<$dKxq(MlQ@<@iq%v|
zWP*$fsVso<K*8mimy%immV^|vplk&yeZVmZCg>iWM$onexR79AVrG<N<YDAy;$ReG
zWMKsRs<<S-AU-#-B0eQGC$Tbf2R8!)*z@IynI-XQnH8xinO_(g7?MH34#J@N2b=(8
zLA5O`hovww)G&gYGbKz6&5TT-UQVzEs2=kJ7x9_tdHF@D@u{FjLoql@<mZ7oU^U>}
zP@Dluh(W3#Q-wio2XJKs(UOsvmy(lO1dd&BRHbAV1qCoLK=R1Ige=IR<)DlLie(07
zA;x5ocVQSDLXIH6Ktc%I?g!-(aFOFsWChMRETBLuVPwc+WoTw%V60&P@tZ-Nbw-BZ
zCU6HHS_oZaU|{giQwYz@OUW-U)=?<QNL2vUo5c#5c?x>PWqAsTMX3r!sfj7N`FS~&
zIts=43gsE8c?ys^T|-l$q$o4BSfM1JOF=<F0aA~EOv%+zNX%16tw>G<w^%@>Z%IZ`
zetDjrf<kzzLNcgnqEM2NSfY@TT9m4Tq!Vfo)JBCwSndEBn4*x8Uyzzsnv+wh0IJzD
z^GZ|UWoAK9eo{_qZn2)91}HIsvm`j<6_+HIfD=b?Nqla8N-CHg9Pb(A>gWP4JCieV
z^HabXH#puiJjgS|6_S2HQIJ-emmCDo*r^rC@tJvP`QWqxCg`5^f*BYX>OctuR5UQK
zN-_yEaWS$mfom&JNeXf_IGHSgClgQt0jHNNW>ERr3{Ew*3=AbKpd<n+TT_@AvY8l)
zQb5vKY+wm?hGqta6lPEgf)u-19AI%y6!AQ8iJZj+PIufODM;;@#ls-p%*ar*08~iV
zFff$xB2+XpGRTY9GB7~&27~Lk;t&P~2KUS|P+H1JRe-h=70MEGN>dfm@{1G_71A@y
zQu7o*wV94WZen(3Ub;eNi9%5-sEbgRs!)=zkX)VuPCc1v3I+Ma#hFPtse0hTJ`+^J
zfTO)AwIB!7E(L{@o(8C?2Tmu57zVZck`s#|i6k+p7-V0NJ18hY?N?}{37iJN#Y;+R
zGAKnsn^)khQ(0V+nwy%JoDXVcf)#-|khW`jYDr3JT4HHV30N>Q57LG#E=epZDF)U4
zU=8W1CCTL};3BCw6;cc3q~?K3f3QozDGyB0J^86IFfjCjk{>AS7+B;Og&8Fnr5WWJ
zWf>t2v!ujqaG?%LhoE8$oEE)7T}(!XS|(6QRLjgzVFFGLj0{;!pd?qr3`s3c3^h!k
z;YD+Z!V+c>znPIiyq1}vke?wORFW|>h(imn7zPFgx6Jg?qErP?n+a5Qftu(F`DqG?
z3MrXIsmUezMU|k00qSKaloo&rCTKEB$t;2uS{jKdpqNt7OG?bv0h2~L3aKT@nwg+P
z0`C1Gr4dlkl3I~jTv7~)o{}Pn3Q+n5i-3A9AdPw8epG5jNopRboehpHFhTbyQ)ggc
zm<5V5Pzq*XVPj-tlw{;$6k!C%6DW>A7#vTag08|C5jQD}pvt$I3Dlr%W?*oM6$8g1
zI2u81Fd0w;1sBRNgqN^@Ba#tRUcjnoP&YonGaw$^m<^71bPn<K_bUMpNr2ka;7|qU
z%GA8F%pzzHH9Zy5dj)saf<Pe#DU3l)x7^g?Vo>)E#Lfp-EXCmbl9&wcl!8qL5%dmX
za4#;gI2+urjfW(UWuOoTb$l3@lo)v!IS`=@${FC$u4G_fs3<}SZBUu10czEzfHQ_z
zGb2M2BdDZ=gfFNK%mfN^P}R=Bki`ZnaY2~{5+m#kMY*6d8<dM!7_!(wxviNIG|VaH
z?okNNO~HlC4B_CmFeoJ#JAk_V#o6GT0S#RRa1$OBq-Cj~Dj!rTf#snEFtlV<C`v6Z
z$j>WIEiT~!jRkoI#QXWjd-?^0h7_AKFfjP#D}aZD6v`8e6;dk-Qj<$kQxr5*KnVh-
zP@y=rMAKTKur#$86oFO>s>Q`N3=9mB`K3j0^A$8yi!{NefckIwd8wcb4$ACsL*Xs~
z8vrWnbrk$GKw%F~VnGF<#(5#A3<ou?U15!qAW$L%Hvm8b8wFriPJVf65xCWmm7kdh
zPI*DaAnl-J3vMF7ECZ!XNJEj{sSTVd)`60j7$~tbGcyV?GBYwW@-p!-3Ni99F*8aq
z!<z%}tR2AsuBuZw7_wOyiey0fx&~aqi>5F#h=O}iDV$(A6NVI4P-aGmGlIo^7*g24
z;>;lRDeNG&Sa1phL$C%HD8e&eFf%X|gOZi1o?)7=Q##0X3=aJcnILI!?Vy^O?F3hm
z?F8<@t7ayF2EH;KocI|s1=L}!Z%`QujuNo!0EV^}0|Ub$P-ydk{KLe<D8R@AfsjTQ
zD1<>6oTWiY4cY=?0)<aABSWzmC_e{7MOi?iDd1wVmJycqS)m!V$dRFhjR93D6R1S3
zWkOO4>IyLw<v^4&GeAn)Vkgj;X)(Bc1Zr&~*MOj=a$+WE$P|>}N(=M~Di!jJ6bdQ}
zit@8klS}kU@^f?S!A&RdP)%`a30P4v$j7Lvz&&V4t^(B+;0Ver1`VZwGLu_kPH}2b
zH7KWnl0jxMs6hnIO(8|4sgT?R)&|O(U|Zq~D#6`FxGnJ@w+vuxYcnt~oCC!+Xw;2?
zMTn7wQIruu!t)ip5C^#x61SkvDg!9C^3|cS1u4WqvP=xk@R$NM6~KWVlv+|+lvk`!
zQdF9%keLQ9WI@B13W)^;sfk6PZk0k(Dp)uZGzOpmmIO6#@)SUQv!c|3{NhYdBL{3;
zF=(RJrX;f@C)F-G&L&nXD77pT)b>z_Nzt|{RtA;QpyDkxMIotDLBrn4CNVnBE>_Fl
zPSZZPGzr?a1;<hes1PlJ4Br-~CKe@UfJcx#!A($bgl3fF=779DKt-Sq0|UcdP&9$!
zfq_+s5gaifSA!BBI4kOdk|Ctb1828>DTZ3`a6%R%sMgE^&jU3xG6aXGFfas0fXgvZ
zKK6rnKB*X#qDxECbS)r30<tN;AT<x{eNdM;C=oPN0J0NYF@VxKsQn4no>nk`fuqa7
z!0-$nI7~u_rU%He$)KT3P~cQ(fRbsE7N|r54QN8Th2Z8zu@XZ7sC&l55XJ~@Fu;c`
zK~;NXW@=7~LP2I~a%wTCGEPY>NmKxh8!IG&M-Oy!GP6?^@{>Sii$ZB$NoJ0MtG}C`
zA9$c8s1a11c7cKp6x!g>1O*+K0UqNAg?n;FX<qig1tECo9u&v%V22dH0fi<Pxcuj2
z<Y#1KWPv0&P$dQO1vtS?fz+^B-~pCqMg|ZATvpeDMQRwp!<Jdlnitf3_JamJs6JqX
zvB6rh85oMAU@F-ein746;LZ`GPaX^@TR^6?!Q_}gZNFwF2GD3|3JXIz69c4n1_h`e
zI0Ne!gIpW~?%4$8!{Y#yXL2BoAW$k#%gjp&Dgw!ZR1b8IQ;&gx;VUToLA4PBlLVs~
zBcu)%fYiSr-@)Sm)F(_~1ZDIJe^9Wv#JYoeEG3MfMsqVGLktr`Ei*$c3quVvL$N+X
z2`I1_L0!&l4u&EZkZ3I<Lm@ASQNsuxz2^lhD&%DdF9DU{pd3^TYPh2p-ibLm;F20N
zU{I`(kq8=+$VgQvPRvbJfKE9<DrZm`0WPmKGWAmRbQDs{Qj01}GQi^*;Bhxl6SufD
z3DJYi%mWRkflA@bvQ$k!aEB9|UHtO%QiDL@6I2h%RG^#%9!&vP%V39qhe?z3b93|a
z;tPsW(=sc-(FyJ~LHJ;Uic*V91}?V+fl4DrMh1pr&}0;-hsw(+1kPkUjGTzR6Da6G
z7@XNW;iWsMPXr#}EK+9x4SIq*tB~0l&>)i#Oc31if+&V61GjQPH2}C;EB0exU;syq
zbADb~YEg+oA|%2}@)a^miWQO*^YZgDlM{1v6hH$+x}cGwM9>^zijD$oVqF1RiRy8I
z4T20rf?5(tO(sy=rzkZs2NXX+pgEDCI8ast`3w>_pouro<a<t8YJ72JZcb)iHhA7`
zfT~&p1_lN}P~?EiKQ<mlHbzlUodPNwK=}^jaB!6PL!ty!m4N5QKzR)|=99$)u5+0|
zSq;?3bp^F}Q<xa!YnT|sK^<7|K!ZXpxUX9S&aG)ou%<1jviAX3DbV>c@Yq0VMTw3=
zQfY}oNg}AWNlQ}zO%W=T<mZFC8X!*Qpa1{=L$V7eXjMagab^WL*fl}f1++i{Tyv-9
zrGUrY!1X*N4nV~qXci|3G*LEyIRoTSd3fM6i!zEb@-gy4Ds+$=L4_YU@R!2_A2g%}
zuF65-4=(O%m>7!OK}A}TJE+Fb0#6pyfa@6^s1OUZd;~4gDq#f;EP%$^!0jeRQ2P}&
zQU@(U;l?fo8@m`bEy@lvCcJPl14{`9cnWSlXbP@yF+&7s`4>t<0v4&zxpfUqNQ6S>
zWr`KR!k}_7F}WzexL6@2wJb9^6*RyPicLh80@qbRppo7ndr-s%fx-e5I-pr?@T?PL
zVgfY98Uz~gfFub};?2*24728?mV*nzjMT&wFry?fb0FKdh71f0nxJ@xl!y|H@{9sZ
z0!$K&JdB{ZQ(i314^UDmVE|>bVqQ?07hJ*wssTX_5oS;w1{v*#4E_g0O1#;y5)V?D
zDS&!uppFPAkAOOnprN14JcZ)QVm(M@p#zdFPgMs^3PBd(fF_C(6%dPRpe3JYngT=_
zXv_vwe<3N+Q2^DIAUle|(@UVGG?^)>MX4zYN;&z-i8*>o$i*i&C`v(9TM(!u3Q7fW
zK?CwZ(?P{1s1yQc*@4TX;4&n$I3DbFYfz+t+EWZ1oLF0lpwhjB0Te-yIto$$%*7EK
zka0KU<u|albtb620A41QnxX)<KBp2=@qn5Z;F+<^JcZ=aqN3Ei5~LW=gvOF%PI+Qw
zF+AFF#u!vNr2P(_SK<W?=w}v}fISTwy8|aEaL!4|9LTl=xWNN*LOd)+JU}r5s-ze=
z;hjWK)(01xpy^h$*noBt!6Pmu%%DXch$wO+K8jG{CNoa~v@T2mv<giR5<{T!36i3h
zf>Ja%S%X3q63ELyMHr}*1GO^1!^#7gzClSA5~O+YAa8(t5dsQTkRRZkZ%|HzhpRlu
z{ivxNG7E_wqS0iBC^#64D~pr!^U^ZY^+2ne3Mxx7^7G<zGLtkk@dPsuyx;%@^8f}c
zXxb1Ku%JMNuUm`-g)X=hVPj_GhZOdpu!UFmUZAN1XJ~Ei5^DkK@su!u)+K@Fco{(j
ze-;a<u_fNj1nvMq<XEBga}gJK^stbNA-segwjv2MG6xP+wAuhm`IA`;>XD?TWP+Em
zC_onjL4q8-ghnqlJzW>na)k`TgUf4>`H)H*JVFSH1?T`|Jg83;)Bwr{;DR31n}IaO
zKoJC<NCQ<D@tGy5x!}?^H9b8ZY&xh*4vs*255kuqGDUGbEFdyK(Z&UG6RQBD45JWe
z)&~@2AR$m*0T(&@A;Sbk{GiyYWo5|Y1jSPe14Au1c8at>-F^_44J^eBTGLz025x7$
zf@ae}QtV(UR<IO1Lk$Z<Q7ouNspSBRvw_7q7}6O)^?nvJgG;P8LoFvm4J$(pC#XOx
zDgZIE!0SY^*%?4wHjoIYWnREg!;Zw}Kw@(;#4#}x7C_fg6@O=h_LrdPB~c+Kv$zB_
zAOuYhsVNFrYOP{uZQ_}xkdOebwBkW)OA-=5Ee>!CL<2fSuBoE{l2IrEkCVbu8F)o-
zF*u=ub%Q2&LDNB))f~9Bg4XzeTAq+loSj*akf4xQlwO((svRLoIup8*7UT=?T#zoP
zucrV_rwX8S3L2IL+YVWMWUT;oEl6CU7_sOV(uM*1GBYnZr!*xMo=%D(o&^t=>nNn;
z=c$7hGJuw3E5MQxN+`hv(L)LzK)CgS3T*t^ps@uBS5SKn6q+DyU|)jDCB$qxH2A<3
zDX72);b72!A}D#6fTn^#B9MjU;E_H^y8tAZ0?wykg6^3WlmWqsCB7uJxTFu1O~EY!
zNXZIv9S9TlNYHvv)d9-j1LF@+0|Ay8z+Rbz#Va76fxQB1IhTM(z?&Hvcpz<lXw-nF
z55ZA0z&;Av$iTob6`v<SQ3v<Lp!7otXk8&JR*J!S4IDQ!v3P4pB(tDR3=9l&hN|nq
z%>_{L1&)M82ycLgMuR{DB|$4eO$|^!0T1+-=NEyNlf@UOmVlS=WT#ewXSBgX2asX|
zR1blBH=t?*yqN%_Ob5?nq9y}`Q$YHIHh^peC3tWE2W<v%2e?21Es_VdoS}6<YDzq)
zJqp|AQ4E?iC{_WLcj9b}oJ^d|Y>Yh22$GYDlLa&z&JUgs2UiN9dH{sMO`RQ}T?Y){
zwkddEqR0=_N@-?bDAE9p|ABf0;0_jJVIeBNgoU99F2n+AvVfH2DT7uZf>tSlhoed$
z5}<i12p?irg#*YeaGRKk0Wy{aS_#7hZWD8W=4VqNE6Sj9oS>!^sO3`uVgwgfFodVT
zhaSb5P}?}5su9!_1+Pg2ao`PI@XQxzcqFq#0kQ%}M<Kr?BekeJvp7{p0W?$(tvo|O
zOJ3EB6^s>%lT-5&i!$?zt-w{Sp(c2X0$Pg&ETy2JPy$)Y2AZ4!Rnnk(SuZr$H7GvV
zGsG3VbT<#&zl3)pz#5G-L5dR<^73^ddz};zV>Ms}*iA+?#29KwWoj{brXV>F;bxfi
z8juE1PJVti$gNOkg7O_`U_leoj&jQ{QcyNjNX$!7P&Nh|SCp!doL`!g0-7SvPe}m}
z$`|W^mM0g1=gf;z)giqUXio%Wwh`D)n9;B{R!Bx>u|jTYNk)E(LV0FRjzU&xF{nWX
znw<yF>7->Aff}}Xprxp#c`4ZXIey?xT0x*HHwZLQ1)gC6&Ew~#1c7=wL7=J|()$7T
zgFs!Npw*xf0Nm{X%^iYAC4;~{9#E$N6v2?410WV;om_hQ0QY)8zDR|3zQDs0>p|tK
z9H@j4W@F@J<YW|J;$>uG6lP*$6kz0K;)QjCKouXTzy)D&*#KSV4;ci5jJXtvfpRWr
z_A(1JObpUe{2w+x;GS9njtfv==z{iCf%f--2faY41k_$H0YxKn@ujEWo|>0hl$Zk@
z6$2~CEC#JEF42P}0v+fobx`sEWoU4FKR*pL*qoY^58vpL3RzkVvly1nK-R&H0(D?O
zMihhhO)7v^2E!c)S-xJL3QmCKiFqZUZcBDvemNq+D!}^8(4qvEJRu`O2S6h#pt&QM
z!y&?;<Px-YKwG6jpaHCFpmYFo9s?(6hKL2RwFe&KpdC+;xdh03H)sVqcv(6m4S@D3
zKv(vH)-u838`iBW%}p%MRw&QNOwLfq%qz>!0j(9!NGt=*50vDC7B+#FgO{X&cD5!K
zW#&{umVQG*3A8;2JShq`1>Eoj*XAHI!7X_(LHBM6C^td<7Y}yXQ&1>^$9<UiLDM{-
zF&~g3P{4w7O&22rXxN|zJi)^Vn$`xdEdUMjFf&xeGlIr|m_hYe3KOWVY-VJvWdT)!
zH7uYxoo4X7T)rD<6sVS!p+cJxBo1Eb?-DD^2pVNzW60uQsAUHY0@QMVMhuEt7)m%n
z+-645@&ZZF7z21OPZl>r77r-H)_^P3S`N?#ACMp~14x7sJmSE?ki`cYv;eJxI|&j8
zaalnXdeJqoM>s%i#=<Z#2Rt|db`vAi##%0hDjiUxp@svr`mmXap<kS#mK(I4IZJ?{
zhKr$w8&sn+hNrMI1V(_!8ZL$`LC`D+V+|WamJmY<2ZMbr4?_(PLs1c9i7-Q!2#5`;
z?~52~co<SR85}?oTnt&FAorzkF_egbv`eILGB|;@&*U*ML==WGgo6!dh8Z4_0vb01
z75BySVdEg7pq-%LLJG8?ML`2JeFB+6P5=pj1`iT6LHQn3NTh()yyk&B-3s7g5Ku9e
zpr@eVn3Dr8BtTjq6C|LW$t9_I3ZMze6oq{7giJ|lE@I#TR4anhj{<m2fkHuQQEp~&
zab|uV*Z{C`poy4*qSWHlqO#N!O?atS0@{O9l$u_elUM{PcXCs6lTx935fu{iDiu<}
z`_&*N7qZD3phmWiLV8htX@L%CL1B4*QBH~`WbK0zcvFpnc7+mXHCs+*YKlT)T1je=
zLQ-mGUOL!CP;coe_~n;?YV5=kaI2~uwiyY@ZiVEG#Ju#>VujLTP=3!Z)`J+ISOjra
zUcPRAK{3eR;NXXh11qHDCl^EN>Yxr#>B$A!0-uwUUmlfNU}geY1Tzt|vIJDq#DLdr
zl_&XSf=2c-LF)@L|1&Z$Xo!O<Y0&<~piYn>pta{!nFXNO0oTb<nFVf{IjP{m4)8(-
z@Bk$!u0f+=U=C=<5Qr1h4KfP6UISDh1;HBvV1rUJi$J=9=71D|r!YaOD>=WQ5@c6?
zQWm%XOU}tJhU{+!Z7nFuOU#J}ZIKEJg}E&_-ZMDJ)jbHb-Z$t7sA2#WAP}n$!W5<D
zB$kw<=7CKFc?Pn_q$;xj>=Nj56>td&ayys-avL~^((-~pD;R@%K!$<JDo{#JD*!73
zZLb0srC@^I<!O*H0|UbwP!S56DP-W{V&rFJW)x+VU=(KLWCZPd5C$*ilw;y$;$jBL
z2{B4BaWV2T%QLGpfp<fIf*fAhwlg6Ywl(0os+j?_X9ZG$6`O$j6sXGyi)=x~WGxdz
zUIB_MWa6VJ8dMsBWP?y;!F`#cO3>14kSv<XY@kxIXgWg*J7_RJPYhI~XR(3GHc;Kk
z#K4%s36dyb2bJESnS02pVP=M^ZHy(Hpn>2TW`-;-P`Tz3%MV`v#KMrp4Ia<E1Tq^`
z8?-YbDXIij9H82Pn*mfUurd_MGnVi$)PP-*!o?t2%Ld+-zzZtiv-rXF02`<%2Gt!b
z3|RsoyNY~4iwA1hK{hZJeg_RyL(1l&MU0gqplT{h2qXwn!NkBAURc1yQX&jqG%$~m
zv6h2@5z<FX;RXd3#5JJ0g@plRT44cGMB#UaN@1`;A|Qi6%X>H(!t+cSSV}}e1$i1|
zXZ9Pyrh#^6gJuFD9ukMvKcHQcB^)453J=J4pxTFvp+tfqOA<6NUc&_vWDHN?WeAL@
z;bh2?0(l!8j?y6aKs^R>xeP-JAA>{DchFY2ELpIL{0t>>AoUU{e2}W9@H<1{cTi0O
zUVsKQEFy)MAy@-cC?VH0C5c7gq7GCxkXO@y%V5Wx9B`=*t|t_rB{EqR4cIu)ZqY$p
z(a@o$DF!v!^x)?ZKp90==~dwM#6?!HBM^$L;HMoV7J<fD7>bHP3wNCp^FSe(l3J2l
zl$)6c>g48v>TOVMu25200P2H6YiiYEux&+FTHv~@7_^MeGY_0BK*<A~G*pYhd`P9P
zpjr&-qh#ilCFW$NfOg9S9Ru&&K-6}iiCge){UFftC~##29@uh<GC~|D5e%MXkBCAR
z0o4RK`RVDYMc_K5Jh2G0;Q-7oNh|`n1zdkZsz^{xoSs?&aaD29RZx|OrCtmIZFB`!
zQkliYmAT+;R`ID7B}IwJCGil=K^35C2vlrC#X&ZKYhCZuO7N!nAkbWC&}onrpjtKP
z42X3Wqzlx`E-lH-O%1vM5<}FOAmb1<CRi3cFbLYE3Gye@>dPQq*FXfQCI_oXtw;t}
zj6v5yH7}@JJTNt(2?GOz6cYnOF=#<7s3z26<YW{@U?w(3E+#hU#vxTEaQ(;xsvUV4
zc|mK8m_!))nb{bb83mZQn3x%b8AYKyc1AHqAx1GqE@lBHUS>6>WYAzAC?G-M0`8)K
zdRLHc9%v;RxW@t7Knz~HoXx~g>;x*yvzS2zUlt3fA_MgeoIvx@pkX?&`l2Mz2@aro
z47@B5RP(ZcYE{rQMl%y5W8NW94<>~Lv}w6`7N~!c#RW1IWYR1U17SQjLkSOqcnL3L
zgXt=U5<ZYTsQ<*oz?fGBGN<Sth|J;#)xDs8!9Ru)0frJmkUGd}siJ?NzDEi>1LWwq
zS{4RSA0>qYTJL~1I)ge7kUm+S8mQjM5(o7xAU*)Cv}0jlERkSH;R4l@&`o_QpxH7|
zO7kn`2Q^F!3UV@&!TkaKs?36*3!sK6C~(0is0g8{sL)LZoq)m#O2(-bCHkQ47@!4k
z44}{lb;KAL5L-IH>miHF^0bSiKqoCh3K+=2G~mJ?R4izu<d^5=<R_-2ra+eRs}}2k
z_t>ZAmFR+s9Z+eZX$@Kh3oD+IOBA4Ml0ohE+{BV%&}tft@(WcBXrM;5SOc_G1!**F
zCMXl37C2Ghjia#BZi0@3d<rTyGK=FuEmlyI8`Rtjx`!kIEoi_6R)}K|Qt=dY3uMD>
z5CO^>kX2-$b)`X|GPeYD77XaD8~E`hdS%JQpp$Q)>v@A-fNTL3?WILI;GsQ8@CDrg
ziGv!9$wiqZpvA#KAU8s08o;f6aFZJ}00`QIm6}%)4+=|gTNyNx2R0X6LVyXnH<(Qs
z7(ly28Hzzc!N4xW$ipZKZZtD9vN4J<@i2l$_5~RQK+R?*0Y+ICHb!P9UM6P5yeTM5
zz}X(uO-g}ndT0U9I=Voz4|IbXsCEK365K$CE0rjKR;7bFuCN*SVo)jqjm?2hh=O$6
zz}2DxcwPZCiUhI?v||-~v`-BKL#!ZlY5|m;86jI$z_|+4pMy?xf{G>Z7!bJcqGtdu
zr4x(N!Ql-i=pE?b^)WW-sd=dt1x0p~K!r5Ob8L{T3*J2k$;6<{pIDS$40a`$ptn=O
zGn>%kx1iA#4{}j2%+U<2;M%z;F|#-|8B`d7maBqNJ2*-FWMTj{f<fC#IT(sWLEVsA
z7ErIDh8<Kog0@^}fd$#Yf{YABuArfwEGE#<5#;=&S}uk>$O?W|m>?TNEf-iBc-*Rn
ziy@m4G$K^P&A^ji2_C}XWXR@Z0FC*u!mODNtxrJx16HtQ;6*nzkONXmI6-}*Eb#Fa
zwY&^9Yz##w8ESaJ!&~6~4ro<$g&e5O4&DLJ2bSbzsNn;d4;mvXyuc7%=?<z~KwTjQ
z&<dUsK2Rqpg&8a;2<r8LL<B*V3}|~c8_0}iM%G$>h8lj*I8~M~s77QA&(maJDG>qp
zfnpdLYXulUqkLJSpsrty0BAt2nVEsHi2;0?R5}Agtsp~1GN{HWI>A^X4mJziIe`rI
z)e14x2r(3QGlF+>2|@cOAW=bvENPHj3J17mWUS!?@j%@j&`4PtV+{vGmJHZMg=vh1
zX^i1jd|<<6!D8VloM4^=L(ykOkozSVpza5amVpH181gxpAdDIohHQ3*T4B(*Tag7*
zjW9!z1{279c~FH2va-+u#^(li6+u&a!VE=km};0AQg}eMe9;`H8g7Q-S|-re4F!f2
zUT{b-K>|ks)V0b|WT+7Y=`K-%_$ZHop+uP>g&(96>JTQ-sZh}Bw-92w0NC^+U~^R%
zQUp;{H-kEw5OqReb(fh6-!PS^GNcGIl&FEK|7J!8sCl5p?R*SyR|IQ-vO@6!*w~<B
zQ95*%PeGwLBflJa)|(Y*#t^jsQwOv_RKe5F%^x&Cn3JClZnh)NUQ;gytu0C|DgsS`
zfs0Ylfjf``;}nWZic%AEi}e%~{1G#brNyZVF0M|Y?s^IeE|4=vz)O_CtBxS$tAYZ!
z(Hx(j9S>P!1)8!bwgRo~LtY34IuIZ|6|^HCJR=5H1UbAX5jy?`a!X=za%us1J)jO~
zE(LU|253kV<Q)S&6c>QzLO~NKprQQS)Wp1Eh3HtAgG%#?Q%mBZ2SQ-D1S$?*uvL~=
zlnFXS3%)2z0jw7uHU&kQ`Jh8S6hKGrfkq7xfvFb&+Q<o8BU%h<Tm?awvqOtH1y#t&
z62&DcsYONLLaw+ZB{L6P_d`M*T$3b2k7-HGD+6z^1@|~W?WyvN%$!u{&?(4rgt_1?
zcwBy9Gr@;dfm;J9psid#Ky5zIG>LP5ZUN{VO3=Y31*IjB78$|_EAZYuaHS1BH&a1L
zwOC0ZEip4E6*PxglA!=L8Zrk3>h<M;d<3ddKpivils<~ijKmbIIzZJYWSv_vsAuR2
z={Z8q<*`!8&qGQ#wyMP%prb~DKy#VkB@&1LkB9UOgRU?zFo2g_6qlrc#Xtw(fLsMi
z_}~ypNlhwE2eZIw7i>;?YKd!FT557hW?8CFYFTPd(05Qn4m^fh05TC|0%)KV96O~2
zDTyVi;Mgh1F95IMKsW?!GC20ZYJ)>u{6j;)5fI=R;2QJ`WG<+02<}z}eE@O6D^fv6
znFRd?*#&Csfp&)GWadHkM;C!NP6q7(NrD_wT#yObBMds~3~W6jZ-FgM%goCx&ItMk
zG8{Aw3=R+<fA@G7&oECH*C22cG6=N08LT@DbOsVQU4h+Mlv+>(E?dApOwLUKYey<l
zg8qP90vhy1i5~EIk=U|3`1lTJ+KNv}Elvh^?jb6n`3)=r&Rwva3GUZ}e43Y91a5BU
z<fkJaYYA!vmlmg{#OHwG3w&%R$cdnHH<2O()cYwdPK}2e6!aGqBv(Ps2L&YPh|Hkp
zARfpx(7BoUr6r(4W<iqR;0H~#gH*+5B&I-)bOSe&zy!V9N<n6zm29AfQ4^@!FUkYn
zy2vTO#>C0U!@|kP$t=Vo3~Es`@q%{{3o!CBiZFuO*%FKrOrYZs*%*15*cm~y=%Ucg
zkAlpgPP!l?Gb0}pC!-*f1QTcwTYyP`k&Tguk&T&+k&9UteD(+E{5?>29b^MD6C0y2
zqJ<7>T!NcpptU}bjyY)1n2`ZASqNnzwVFYVY)H=xyq5~pHH9=sLCw3Q(##yt5}_h+
z5Q7PNhcjdl2y_l+Jlr*6po2$1se*x#mk~Vp<Cd763YwMyA211u4^WrD3A9iZv`s3N
zfgy?!bfh=v(0WGDYH84k^-N#}c%T7v?lvn!P%wB&MsXkm14DRGVu1o;g)=Dmfi~ZO
zs!HfackpZ<tYiS4jF%5OrVKJa<qY1V5CA#@xkw=+v7n$*4?NufiW?9H#}Bjz1?oF7
zGJyI{HQ+Nd!Epmp<OlBvfq3AK5NHDds3XJ;>Il_fc7Z@X2lsx0zJT%(C=dp4R~u^2
zM;;VuAfG^cKH$<VK0P%L>|ijjI5j5?Tw;TR8=Tz01l`jdsL+p(&&<m#iI10qxtjrz
z$3O#M;5hUF9bak;-3|#Fw*n6e1&8NJ!%vAd1Z{_eNM(Un#RW%%=Ls>elt2zFbq7g<
zj){ewNC65UKX7#qPK)4R$xE#$3DN<r1mFaX-X`Wk4+{mA`N1Xm1>obLL2WN^#tqU1
z&0>O60*Ih@*ah)3GB7BD!VFYeGk{AgK}OI9Z=_9(po9qyKhW$dC~QDuV<16jFCOIC
z!QdHi*%A-hhf)+DuLbfHD1I0i!5h7ylAwvw_;_&D9S=HhvNR_(J|0|O#>c1RC&$MJ
z=`%7gfP*E-7$s^3By9(2F)}bngS-Mt<ZMiAjGWAzoZuQi7~HJ@m3#%MMevdo<YRD2
z3OWi9Qj(^E@BU~3kKINwgKi8+0hg+vD;dDWC`b=xfd`t?0`2t%7jvMR2sPHh4V(O;
z%yiHR>#2#kka7W3KPBfB2U(y59lcXE*lnOAPoQoy00khp24dnw6bqmf3{KXd1`H%w
z!&kOJPeTED1DtSR=RppJWF7?C#cBrf5-8#rn83+9$OM#ZO+m#DsNI&FlUQ5~Su`1B
z1rh`$pMs+Ng4CjtO0WUo<cuKb9YsOrj0_BVAWwkeg^h`y4PJkON*VAmIG_n3(4;RT
zc(9)dREw4{fd-dAN0x#Q@P-U6g2r5`gg|SQAWN>AK?mc6r!a!{S3yKT>X;cABS0m$
z1}M~u!81;&;2v`#WF)<!L?JgZFA>z02DObrr!b)%{jLx0WP-@lq9Sll7Q8+OX;qs7
z^aNALv|e!~XjlN$`B%__3<7|+(rJOW{wgFYz-|zLtvpW5PR)aKCVeuK^ovUiK>LRD
zVKp1*T(C^Y{GoFIcq=8ywtPs}9C{WxDCp8tK_}`KL5@WQ2^2#GKp_rJ4B!v|=Mf}V
zf%(w<3_9n2;F1Qo4G9l=NUy>glu|(Xl!2X}QIe6FQHTkp$b;wO63B`>&<a&>JcFhH
zoFOOpgU4(j#)0NJK>Ow)V+B@_Ma&8ckcfd>4UyH*R7eEHBPdWHE5SkIDGCY-1x1;8
zB^v4(sX00M>YCv6prD`tY8B}v7K84Ya4jrN%+Y|D0@?u!J}*~8Q%3=!hf7@(VsQus
z5fAS6LP{kklrk3_fAr7Q3=9ljptu4BJ_9FlaReGu0S8}jD(LWOl<O8?!$3hlK~uJ%
zB0Fdh_!BjWLWZHj;NE6|N+)Nerhsmu02jLOpaA&+TtkDr4XL417#Ohjb%LOiGobE)
zBWRl=*d)l{US=_5`(<)|Zb2#N@Xq|a<Wz-%)FQ}EOb`b&e^UZJ4;*r?GGtq(f&%Ek
zoYb5&NNP{aQ^+q$$;?YEsze;;4H^;5Ni6{lje%A}g4VEs?iNV}9s8MD0xsRa5eCi$
zkV*wwh$$#21cMh?TPb9eloS+O>FcLwmSmJB=_Tjq>L=xwl;orqR6-g0NjdpR`UZN2
zhI*z@A-#f1WgkOxQ?T*yMhU1{0nXx}VJ^^qGw`WU%}k(*As&2e9H=)2Zs$N2Df<PP
zfpP;#UyvQBW(0AAKohLs!Vlc)hHycx?t#fGpoV5DDA9mwKnBo#3n1r$I3ODAUC?YO
z=!ks=2GDej0LZ)01^A#Ejgf(+mKii>4VlV^oE&3Q13Cx`l*k}QQGo~iz+MG6Wa8sf
zGLuW<<H79(aHj<v7U1Ek{G_ZPOHgA0)M0`YRs$9~&?Y%(_fvc(D3Cx67zRcjCKg5o
zM#u~<yu|~KYe>5tbese@HW38f%Rm=K28LLWlR?9?Y;0^yoGjpk42oG$u?UV?Ur>)9
zyk-#+d7!y3@G-$DjNrJ|1vO`~SU~eR@MD*<z+2EkD#44$i#$Pd99e7(!H8xJXsHWq
zZ9aV080_3DP^|~r5&>?7C?uBUXM&H`M!8N(AvrNQBh?Rbk|@Zv;C4Y!YGG++5$NFb
zk|0o%0-UJ8ov3ig?!4gClAy^TFM(vC)AHcd1>R%_w=`%ANDU}?7o`@0H`5GYJlQZX
zFcgB~i3^m<nT42mnE9FcS-|a3Q2qhM7dWm!b48#+2i&ws0iDdm$e04kWgr#ck$30(
zyyDW_RM2=6d}=1KM8R31xF9t(MGri%oSRsYlbQ!!1_JFjgDe48-Qb)F)>x81kb`%i
z$OE1CQ<|IF3<?-f{4+orS|G22(z8Ekln%7Q7~U`kHOZMlB@<*l0jN-BWatGSEe7dl
z)-ZwY+5sI<4o|wEIaVeHn-W&gx}g-v@m8P!1r<DyfizGW0oe)ODh(?2Gr@}%VnxA+
z1cFTmbxxTWCNnV<vM~fB(h=ln3Q(09v=uaB?GCC4KrswfLhsU`7?ikdKxHndqPFXX
z1uG|LlLP}p5$JruV$h9dh#S9L^Gb8UZUuMjz+*}v{Xv&Nc?T3iMWEI8K^ZVE=-ds+
zRy5G+6-cfF*;)*`H7>6t6M7*TXyhXWJYJWYSDFjCkOgWz#5PbE(K~p+z5}_Z6BICz
zGF}C=fDO`32c-fK24_RiYz*WSU(l%-VxT0K!UkF(1FaI_$KivHRs&y0lmf0DL8ox~
zL#xRYX3*?EXhRMYLmqg4ObRQ=2+$GE%%Eiepz&QM@c1q$u`+=ysbK=C2nH94#h@82
zaN7htTnw541WoxO-H@UHx~EG4v@joZFIr|kv`3eyke6DLlb;N2CP5D6D7I42fC%d-
zfcI;F;z&oKAhEc(JijPK6M9Szc%h90coiv_X$3B#K$#O1HsGOV&^js5P_r_qlZ<FF
zNP~va^EknMX7E^N80f%Q@R&8I@PUqUfTsjO<A0?^IiO4Nkgxwk3{6)ITq;2wnqCG<
zDj?spF+e=vht$#m7qvy;BM89<&w&$s3Ft09aJc}Mh6Fh{>472(Tt$I)%fy2Me&Bpr
zA_kgZ2HmZPbk`fitrI|A22F%Bu<<Z*u}U!Vu!u5&&XN~~oFxxR2cW_moKHZ9RY9sN
z=y`w)C}m~}JGg<N0ZQ7zpn@2}w*sAWlgA9o9<|`3YC%UZL$2@wpF{)NU<Ph~K#rMj
zW?&8mpB_{^0k#J;2-3>{ce6nu2};7?wFc0n59x0xX=!O`DM1c@f$hbHW(v?Q;?#;n
z(B!&~f)Xf3tU%^CK*c~k2qoxoGsRGOkYOnDkl_&UkUV%vw-rbQ`0VX!kb$+;AQM3@
zt97V`gl#Q2A%G;o)i6vxD2b7Q0Wz!-lnUxWfO83`3WO}VDgiB|f@T=-^_k$52DvvA
z6dhpwL1`eJ=>u8=fd`9=Qd2;yvLQZR14>Px{La7*I<k<3QG!u|kqvTeCCG!IItHAQ
zpaXF5GeaRqfr9FDP$LL*RxgMRZj6E$;CdX=NX=qnNMi-<WC2ZSg3mw#6{oDA^*gXr
zLO_Lm5U5ZC2RrCaLr~HO2OBt-7AI$<=B9$TVL^iybP_K}S6WeGI%tszxB*&PlvA1q
z&hOyrGUy$sS_F+<mlP%D6@%g`9^z|oG#8W><v^_90^L1YloJm*C>tzUTv{}M^KamZ
z`gnw^ON(;$fFcUyPzFYRMt){RCg@>fpt2iO0D>b46p`@k4!SN1+5-l+G{MbFaQcO?
zK#6()OE_)@28MW0pAHfw$3gxBc?4;)4wQGm{sPUHLHtz$KIs&eZb0gTN<sOm43w`x
zVF8Zxf%8_7Edv9?X}Dil!PPU!T?G764Bk|Mv($u~>{eQo11UH`1(_aX^aAYr>_Ost
z@b$dV@&#6S!tW`)3=b7ZMFnco!;6<ipkpe*dkC_?hY^Bm9A@xUk|`{p^VvbG37J4k
zG8K9l7}A-+O&bP={BY2X9Uu~XK^o{nG)B;EIw=sXpo78LK-=v==jzS_wS2O`o0C)6
zK}LX#WC!iclLy^eRl*5cA__VQo(r_bv<7@c38WhXxz{I!n;}>ORM3NKxqzbl63{xQ
z{5()k8nhxkwIUTVV4s_xl9>kGAOP9}485}tGQNv^haYI$ENH+Cyp;fSxoKuvC1{wf
zAhQ6p@~|`~1$1IYQE8q+B78-nf&z5QEacux1wB1TEeF1!1?miN6R9Axpt@EswIUUq
z_lrRehX_GML0JcKm1b^`E9jC)P$De`Ez}Rmhq?uHv8IkfK~8F7ajF8y8KCjMw0zLM
zT#z%NE0L_Ys%wKjgQmA32Wx<i)&oyC1SNpFT%h6?vPuOs9uWjOmovx%B;g4nI6(xc
zF%Rjgfbuyw_(0(h54zVAq@W<P06a`lTp|T(6=i_V5{U;bQUaZE3A&dAbd+RnaXNT-
zA}_T(9_q4zD+Rzuv==~<2*?|dJOK6?G-1T&=fy+!Pu~RP3kgt<iygFoN0Jq^bV#0=
zjftO;54`LMoYBGey?~C&M!A|7Jo*KWd$1IIqZ*un?|xozD;S{}x&uzH1kOk-(g58c
z2d-P=<I_q(cOS>cgIWTRjVs`t5)~ymnMpz5t1dxlDl;EETnAc4n3<Oz#0)B&!R!A(
zM;HgSfZ`iu0C*d85I0B`eB>l(a|mSX2&i62&d<q#<gVf%P`U)iEGTuym!;;V<QD~j
zYyz*7LlV>jUwRI<6jbkn)<Yr77H3ujfr=dP4a;Z}dZ6>Ci^11S1%X;Uh;1ei`}B%4
zD<Eq0Ak93;$QQW9q69jxJhMO#>NE_cdf*me5U8;d6bBkn1w}R3e$Z-N(7tdz`0bm;
zL7?;wURGEFT4aQ(40fJKG34+XP?m-qRs*W`gFyZTXAo3Ppi5PYLCxiY#F8LzW(2R0
z1a%;SghAm1%2U|1lvIN59S;Hxcm;u0F9m_RB;eK<R0ib0AdqK*z<Y#1<^+LOt_6Yi
z=mddIjR}$iMK@@~CI~da5u^yR52P4uA2euDh8%-Hp;-b~0uLe3cJ-WMJ@8H((DgXr
z{t?&|xDtp*OEZH&r(l88V0=7iDPlahPnVur;sf6E2p;SP?*<BD0;N7t5Md2+Ct~B#
zOAr@ylSq&yh-C$GHmLqisxktnL{HGsB_-gMo<XdjC<Ub}&<)j){g_4|O`wxe!I#+v
zf$jkf0xiJ^0x!BP1IdDlrXbLLRYBSyE@)E^WPcMVN?css97BCV;+;a>+`y+sMY#rn
zdRCANBtW}!AZHkW_Ra@^R>=i{4j~T$9ruiMXxb`}!JyLvgLZ>hpi^nU=f8lD8USy=
z4+2do1c7!IL6+%)dNtt1kwKsX&B0L(SuqD*c><oL2RBTi*&aGW4xWPx0^K$f<O~W+
z(2#c!XgoD20K|<35#UY}sF8wbtbrR!LFFLX8c^#6RQ`cNWnk`30QWm=a={mngXV}B
zia{&91(?A1hcSam@X2WimH?9gvjC$2qZp$AqX3f_qXvr-vjAv4CliSDVFAerGeZtD
z02Sz<^`oHkb~qV%nE4s`nLz7zK;k@%Y)nFopskxc;0pr;nV6ZNEM`tFPCg+<el|{i
zPF@}!P7Y2HP99EvPEJlXeojsvP5~Z1PA*O%PF_wPPEJm4P9D(Rav;oO&Z*AH&&kfC
w$LYhV&dCK5Ltvf?PF68tF<v2lP99EnF%cdiPBu<<P8m)CPHs*XP7Y2s0M14v`v3p{

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/utils/models.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/utils/models.py
new file mode 100644
index 0000000..d5cb80a
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/utils/models.py
@@ -0,0 +1,40 @@
+"""Utilities for defining models
+"""
+
+import operator
+
+
+class KeyBasedCompareMixin(object):
+    """Provides comparision capabilities that is based on a key
+    """
+
+    def __init__(self, key, defining_class):
+        self._compare_key = key
+        self._defining_class = defining_class
+
+    def __hash__(self):
+        return hash(self._compare_key)
+
+    def __lt__(self, other):
+        return self._compare(other, operator.__lt__)
+
+    def __le__(self, other):
+        return self._compare(other, operator.__le__)
+
+    def __gt__(self, other):
+        return self._compare(other, operator.__gt__)
+
+    def __ge__(self, other):
+        return self._compare(other, operator.__ge__)
+
+    def __eq__(self, other):
+        return self._compare(other, operator.__eq__)
+
+    def __ne__(self, other):
+        return self._compare(other, operator.__ne__)
+
+    def _compare(self, other, method):
+        if not isinstance(other, self._defining_class):
+            return NotImplemented
+
+        return method(self._compare_key, other._compare_key)
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/utils/models.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/utils/models.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..139651247789dfa43533a7de97a5226e5ba95706
GIT binary patch
literal 2950
zcmZSn%**AGdLky70ScHI7#JKF7#NCm7#J8*7#N}$7*ZG+QkWQW7#X4%8B&-TQkfXi
z7#UJn7+M$@ni&`(qnJU`!5XX}U2+Tz451~NIhiGysl^Iu`9%sTscD&cnR)37x%nxn
zImKL=|NsC0?^hziz`)?0TIrNnoSNdCpIeYvl<J#Vk(mc~2qOangA>Tecm@WBR0go+
z3=C0BAm_9&FhFbtF<3y30x?*jj*4PqNMQxJE{dHYg$>N$U`SyHGdLMiIKT`ph7?XP
zgPS2JSc3~>ku3uQLqJh}S!POVu|hJ~O_{}+`FRS-i3N#CFh7-KB$g;-7AquyT&|Fx
zr;w<Som$DIprD|T3<^9DW@2DqaAsg&C>CR2V5nhas9|7;XJDvd0y7vv!5XXq@}Hju
zNM#8R0|P@m#KP40?9|E<evkkx;Np{W5{rv9K<1XPfDBE|Nh<;IKq~n_u>=ias6tRg
zYJiC1Tm}XP{eq&*vc!^9{j$U&{j~g?l+>bP{iGEA@}#7^T+`fQBf})~^s00VQ;YJP
ztSU1D5J=C{5795kEYQu&D=taQ$<cKy^YAnd011I{d}dxrYEfQdj(%xLW=^p_Bxdyr
zDoZ#(4v){w%PfhH=LWeI<X{FyPR3-AcR?8BVQ|p!GB7ZdFn~fNi;<z3kpU${K-w}A
zi!*{iTEIaS1oAQ1TVP_q{04GWd^{+Eia}msU`z&4APjOK*k{6^NM~Tk0!MubBSRJw
zLo*ZHe;{R$aDv7-n3G?ST9jClUsS>d4#Av~_;_&I0DHRxl(q6pGE$4ceg_lu4}c(0
zgbINo735p;JRZc!z`zj11&Vs8M^lkK8U)G-VDEv60q`RzRf<yCkLf6pIq-f2l^GJ$
z_TwOnM^FZprm`PX3kO$P6<}as0M)k?6hs*LF>jE?qaXtVgCbHqf=W*q1{b!Ppt1y9
z($+9AfNByZP_0|S#1IUrZnKy{6>t_aauE!wT}nWOP-Zc>hRaJ%4FZ*EC7_()mtW$U
zTac5Qo0?aWngXeSKsJI)VsPdKm(jVYB^miC;9?3)3_w{0Doa&BVFM~k85o5aS(r3H
z1t_>eiI2}q%uS7t2m3QVJ~uz5GzY|G2iGqt`N{F|K_GoWpeh?&v<HF8z93K#1c7o-
z5GZ*Cfx;i0NWh*%5Ch;{P?HAa`eIPik&TIsiIats85wGT;x$MdrH08*%1TWx2?FUw
bI3CQRzYoCiVgrc@J5YKn2056GiH8{g%o(LM

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/utils/outdated.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/utils/outdated.py
new file mode 100644
index 0000000..3b58cd5
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/utils/outdated.py
@@ -0,0 +1,162 @@
+from __future__ import absolute_import
+
+import datetime
+import json
+import logging
+import os.path
+import sys
+
+from pip._vendor import lockfile, pkg_resources
+from pip._vendor.packaging import version as packaging_version
+
+from pip._internal.index import PackageFinder
+from pip._internal.utils.compat import WINDOWS
+from pip._internal.utils.filesystem import check_path_owner
+from pip._internal.utils.misc import ensure_dir, get_installed_version
+from pip._internal.utils.typing import MYPY_CHECK_RUNNING
+
+if MYPY_CHECK_RUNNING:
+    import optparse
+    from typing import Any, Dict
+    from pip._internal.download import PipSession
+
+
+SELFCHECK_DATE_FMT = "%Y-%m-%dT%H:%M:%SZ"
+
+
+logger = logging.getLogger(__name__)
+
+
+class SelfCheckState(object):
+    def __init__(self, cache_dir):
+        # type: (str) -> None
+        self.state = {}  # type: Dict[str, Any]
+        self.statefile_path = None
+
+        # Try to load the existing state
+        if cache_dir:
+            self.statefile_path = os.path.join(cache_dir, "selfcheck.json")
+            try:
+                with open(self.statefile_path) as statefile:
+                    self.state = json.load(statefile)[sys.prefix]
+            except (IOError, ValueError, KeyError):
+                # Explicitly suppressing exceptions, since we don't want to
+                # error out if the cache file is invalid.
+                pass
+
+    def save(self, pypi_version, current_time):
+        # type: (str, datetime.datetime) -> None
+        # If we do not have a path to cache in, don't bother saving.
+        if not self.statefile_path:
+            return
+
+        # Check to make sure that we own the directory
+        if not check_path_owner(os.path.dirname(self.statefile_path)):
+            return
+
+        # Now that we've ensured the directory is owned by this user, we'll go
+        # ahead and make sure that all our directories are created.
+        ensure_dir(os.path.dirname(self.statefile_path))
+
+        # Attempt to write out our version check file
+        with lockfile.LockFile(self.statefile_path):
+            if os.path.exists(self.statefile_path):
+                with open(self.statefile_path) as statefile:
+                    state = json.load(statefile)
+            else:
+                state = {}
+
+            state[sys.prefix] = {
+                "last_check": current_time.strftime(SELFCHECK_DATE_FMT),
+                "pypi_version": pypi_version,
+            }
+
+            with open(self.statefile_path, "w") as statefile:
+                json.dump(state, statefile, sort_keys=True,
+                          separators=(",", ":"))
+
+
+def was_installed_by_pip(pkg):
+    # type: (str) -> bool
+    """Checks whether pkg was installed by pip
+
+    This is used not to display the upgrade message when pip is in fact
+    installed by system package manager, such as dnf on Fedora.
+    """
+    try:
+        dist = pkg_resources.get_distribution(pkg)
+        return (dist.has_metadata('INSTALLER') and
+                'pip' in dist.get_metadata_lines('INSTALLER'))
+    except pkg_resources.DistributionNotFound:
+        return False
+
+
+def pip_version_check(session, options):
+    # type: (PipSession, optparse.Values) -> None
+    """Check for an update for pip.
+
+    Limit the frequency of checks to once per week. State is stored either in
+    the active virtualenv or in the user's USER_CACHE_DIR keyed off the prefix
+    of the pip script path.
+    """
+    installed_version = get_installed_version("pip")
+    if not installed_version:
+        return
+
+    pip_version = packaging_version.parse(installed_version)
+    pypi_version = None
+
+    try:
+        state = SelfCheckState(cache_dir=options.cache_dir)
+
+        current_time = datetime.datetime.utcnow()
+        # Determine if we need to refresh the state
+        if "last_check" in state.state and "pypi_version" in state.state:
+            last_check = datetime.datetime.strptime(
+                state.state["last_check"],
+                SELFCHECK_DATE_FMT
+            )
+            if (current_time - last_check).total_seconds() < 7 * 24 * 60 * 60:
+                pypi_version = state.state["pypi_version"]
+
+        # Refresh the version if we need to or just see if we need to warn
+        if pypi_version is None:
+            # Lets use PackageFinder to see what the latest pip version is
+            finder = PackageFinder(
+                find_links=options.find_links,
+                index_urls=[options.index_url] + options.extra_index_urls,
+                allow_all_prereleases=False,  # Explicitly set to False
+                trusted_hosts=options.trusted_hosts,
+                session=session,
+            )
+            candidate = finder.find_candidates("pip").get_best()
+            if candidate is None:
+                return
+            pypi_version = str(candidate.version)
+
+            # save that we've performed a check
+            state.save(pypi_version, current_time)
+
+        remote_version = packaging_version.parse(pypi_version)
+
+        # Determine if our pypi_version is older
+        if (pip_version < remote_version and
+                pip_version.base_version != remote_version.base_version and
+                was_installed_by_pip('pip')):
+            # Advise "python -m pip" on Windows to avoid issues
+            # with overwriting pip.exe.
+            if WINDOWS:
+                pip_cmd = "python -m pip"
+            else:
+                pip_cmd = "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
+            )
+    except Exception:
+        logger.debug(
+            "There was an error checking the latest version of pip",
+            exc_info=True,
+        )
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/utils/outdated.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/utils/outdated.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..e4faa81f2bc02cde3f4a46dfe0cde95346f84055
GIT binary patch
literal 5214
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

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/utils/packaging.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/utils/packaging.py
new file mode 100644
index 0000000..449f3fd
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/utils/packaging.py
@@ -0,0 +1,85 @@
+from __future__ import absolute_import
+
+import logging
+import sys
+from email.parser import FeedParser
+
+from pip._vendor import pkg_resources
+from pip._vendor.packaging import specifiers, version
+
+from pip._internal import exceptions
+from pip._internal.utils.misc import display_path
+from pip._internal.utils.typing import MYPY_CHECK_RUNNING
+
+if MYPY_CHECK_RUNNING:
+    from typing import Optional
+    from email.message import Message
+    from pip._vendor.pkg_resources import Distribution
+
+
+logger = logging.getLogger(__name__)
+
+
+def check_requires_python(requires_python):
+    # type: (Optional[str]) -> bool
+    """
+    Check if the python version in use match the `requires_python` specifier.
+
+    Returns `True` if the version of python in use matches the requirement.
+    Returns `False` if the version of python in use does not matches the
+    requirement.
+
+    Raises an InvalidSpecifier if `requires_python` have an invalid format.
+    """
+    if requires_python is None:
+        # The package provides no information
+        return True
+    requires_python_specifier = specifiers.SpecifierSet(requires_python)
+
+    # We only use major.minor.micro
+    python_version = version.parse('.'.join(map(str, sys.version_info[:3])))
+    return python_version in requires_python_specifier
+
+
+def get_metadata(dist):
+    # type: (Distribution) -> Message
+    if (isinstance(dist, pkg_resources.DistInfoDistribution) and
+            dist.has_metadata('METADATA')):
+        metadata = dist.get_metadata('METADATA')
+    elif dist.has_metadata('PKG-INFO'):
+        metadata = dist.get_metadata('PKG-INFO')
+    else:
+        logger.warning("No metadata found in %s", display_path(dist.location))
+        metadata = ''
+
+    feed_parser = FeedParser()
+    feed_parser.feed(metadata)
+    return feed_parser.close()
+
+
+def check_dist_requires_python(dist):
+    pkg_info_dict = get_metadata(dist)
+    requires_python = pkg_info_dict.get('Requires-Python')
+    try:
+        if not check_requires_python(requires_python):
+            raise exceptions.UnsupportedPythonVersion(
+                "%s requires Python '%s' but the running Python is %s" % (
+                    dist.project_name,
+                    requires_python,
+                    '.'.join(map(str, sys.version_info[:3])),)
+            )
+    except specifiers.InvalidSpecifier as e:
+        logger.warning(
+            "Package %s has an invalid Requires-Python entry %s - %s",
+            dist.project_name, requires_python, e,
+        )
+        return
+
+
+def get_installer(dist):
+    # type: (Distribution) -> str
+    if dist.has_metadata('INSTALLER'):
+        for line in dist.get_metadata_lines('INSTALLER'):
+            if line.strip():
+                return line.strip()
+    return ''
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/utils/packaging.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/utils/packaging.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..a00f915449ee99474bf5deb99fa218a85436a103
GIT binary patch
literal 3489
zcmZSn%**AGdLky70ScHH7#JKJ7#NEGF)%QsFfgPrGUPBY<T5fuF)}cM_)H8rObk&>
zU^ym+9A<_nW-yzXA%}$_mz5!k6{3!XA%~42mz^Ps9l~d2$l+kf<z$HBWXR=Wh~k2X
zvN7avGvx9xMDalQ><l@)47q#^QG5_S2SW}&L#_ZrlmG)`ssKaLaj;#S3^{@fxk3z4
zLJ(D43^~FKxgrcvA`m_|Lyjmzt{6j<7z1M-14AkkLzXy0ssuwbBSVxVLkbT=3j;%x
z6hjIxm?6!O!Utx^Fr@H<8L|v1Obo#q0t^fcnV@jdU}RumDB)*dU`R|V&d(_=NsZ6U
zEyyn_@q@^4F)%Q=rKY9?Bo-B?7D2>#85kG}veV;>Qj7CTi;`1|H9$dI0#aIBkeZyC
zmYG^qT*A)4z)+T2RGgWg2hj$SPpwE!Ehx#%&nt$A@qnTtv$!B9u`<3Ou_OZ`D#XCR
z;2Rkb8Sm`j>g*jK6zb>a>E{lS<6vN5@CO@_m;(_3S>&5qT%4Gm3K0Mq>XKPpQk0og
z3bHF1<VR)(1_m|;1_ozP3J7FiV5nhWNMUBk=3poiU?^c^2rgk_$YKVGHZwBRGBT8~
zFl4cU(nuB?LkT-W2?s+7Cqot&DEJhbnLyzUQpdzl!^BX-$dJv(5Ujz%z`#)K&d9*P
zrJ$go;GB_~oUM?VrcjcRs!&i_l98XM01Xd?%shqC;#7s)#FFF;uzW&MYGG++QEG8K
zL}h{kJS6qFz{UlomXsFd6)Pl!6qTkXz|4gin4bo-0@>))VzA**vvX7PO7u|8a!br9
zCc?0k{M2HFy!;Y~gCVAZ4MH&)EE1HMS)5v|keH|7nOByWlbI3>OA#O^V|p_qu`Cs&
zIuoK=AuYcsHxcU05>UM9WrAYPPlFqjPC+5;m!Fqf0%CvyA_yc|0*Y|BJ;A9ZK_KZ8
zR!}kpC0nrSto+Qp5|HZL!~!r~Tv7y~D~rJfK!Y+qGcPS)1Edg~E1*7v#Y>4K0|Nt^
zSUfzcO87ulf}=VfYMcf*lYxlh0tN;K{eq&*vc!^9{j$U&{j~g?l+>bP{iGEA@}#7^
zT+`fQBf})~^s00VQ;YJPtSU1D5J=C{5795kEYQu&D=taQ$<cKy^YAnd011I{d}dxr
zYEfQdj(%xLW=^qwL1J=tVtQs?x?VwLi6{dDLoz5O#-q7f9F$l=S(1U9hlz!epIL(u
zo=-r*2hJyxL4gj=DkY2zSxgMgObkWFpgfYr49XhKj4&<>lv~TlkmmqX0L~>vAz&^G
zDC2-~3?oCHJVOa9Llzq-`<1YRWjVn4iHU(Rg$11VI2oE57;3?pD~k)1znU2t7;Bgq
zvbaGK!5W~b^(z4t1-`B!jxLTNj>RBOfVaD@r=OdDG01a%`3kwIC5b7CC5Z}Y`K5U&
zpj@X~Tmp&<4N!^!7g(9a;84v=P7MMVVj>I-44|^ZGcPS4M8nDua1zN#ERKhn2^L6C
zEkOu?N|&7c^z_ssaM@R$Sd^EUmmUNX20Jw;KRFRp90h@rH8@SCrKYBUlWB5JesL-!
z(SgD~C9}8$tOafvDD{I>#}|MSbkP8(svtQA1_m8a0s;jW1CtOVKO-13NiwoAaWe8k
zk`l-(oUkHyE<7ngQb7$PLlz?})i5zsdNY)O<GY!Wp*WSHgqa}=oMdVkK*ewk6DYBu
zm&7a#(2_WfnL(_Xk)er^A&-F}JkNlErG%Ryi-#ebi=k)+17j^S17is<Llz%H3M)9d
zv4Tr&W`<@KaHSd?k;1?btO1HBzhZs{28JMLVXPYf&dbFn3=9ma#R{+-qyQ0CP**Kh
zS4b)?ffTZ(d7$Wq$z>KRs1^r-q77Vr6`M0KFa&@zW~zc}u|h^7xQv9AdT16Zq~?_r
zRf5#%DySA~fSm*ia&UQ-o>~$l0dgcL6O@2hp?Srn1)w@RH3j0bFi5ovPND@x`B|yS
zCGmNQxv4>*YClL2q#0Dj1_^^$peTeCqaa!IQaeZ<q(*^(fdO2-1*w3dkr!0VWv7FS
z%J`Jb<dPszF#|5HQwKO{mPo-1JWwt|FZFCdiB<+w1TgY2@-s3s@-VV7GJ~-$lMt8|
zU;>wepwa+@!R4SEq`i;@ZZv{QJtu|=18`D;C1ICX8BoauO4UrDGO9=(RBVBYOa_MF
zLV1SpJO)q+7!1zjekGu6;prC~;^^b!8WaR_Ggu->78JaoxIr#i;&U?dQj5U_1*lO|
z0B&wUVgi)KK(YfJ>Yx+>ax%Cu&B;kE@&^SpxO!pYXB1=PVH9N404HIPSbTh1X-R2O
zYJ7YUC@R3kC8*>C6_=ni2~N1Fxrv!MdXVxCQe=X1Q$c2dUVK?<UP^uuq`(HHJS0Iq
zc<l#H(~y<`$aP>fu$nRmo_A1$^}rRVUT$V_GNjlBMGQ6-C6xsrw}M)pC7@yh$_Ld!
zB_PWnZqJ1@N`pX=4Q@Dqje<B{52XPe1PT>!qDW6I@qyGKAj9Ip*)~2Nk_$n39bEJV
z>4Gw)5hzoF!f&7>ALLS--29Z%oK!nd-Bzr`z`!8D#KXwLD8MAZD8?kfD8MMd#0DZ6
Og_-%8IYl`IIE4WY|4f4b

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/utils/setuptools_build.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/utils/setuptools_build.py
new file mode 100644
index 0000000..03973e9
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/utils/setuptools_build.py
@@ -0,0 +1,8 @@
+# Shim to wrap setup.py invocation with setuptools
+SETUPTOOLS_SHIM = (
+    "import setuptools, tokenize;__file__=%r;"
+    "f=getattr(tokenize, 'open', open)(__file__);"
+    "code=f.read().replace('\\r\\n', '\\n');"
+    "f.close();"
+    "exec(compile(code, __file__, 'exec'))"
+)
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/utils/setuptools_build.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/utils/setuptools_build.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..3a3e1df827bcbf58b5c035d0114d2d372bbdf7e3
GIT binary patch
literal 404
zcmZSn%**AGdLky70SXuy7#JKF7#NDV7#J8*7#N}$7*ZG+f;E^xV#^sA7&3DU@{39o
zic?EU3rh0ybBc8oO7gQ)^D?Vat>fd<GILVn<84)otkZ1MQ%e#{N{TdK(mD$2`30$Y
z>N*M_N>c--TGKi?KPA;RO|K|5F-1dDuPC)3CowryLp`P_2Bca&CQn_{I!!M*C%-sV
zL(@97A~jhfIX|}`GbdF8q*X@&W|WSCI!IPsQ`1ia<dYJ91_p*;*O1VF5PyH4;P_w<
zPhSm?PZ30MIRgWOenC-YSz<}5epzCXep-G`N@`KDeo~5lc~Vkdu4!(ukztZ~dR4lG
zsYQ8CR+X6n2&Cufhv*k%7U*W?6_+ID<mkGUd3YKJfP}y}J~OW*wJ0w!N58ZrGpAS|
i5n}O4rI|S?dIgmw91IK$Ho5sJr8%i~%%BhkxeWjg>~=)}

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/utils/temp_dir.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/utils/temp_dir.py
new file mode 100644
index 0000000..2c81ad5
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/utils/temp_dir.py
@@ -0,0 +1,155 @@
+from __future__ import absolute_import
+
+import errno
+import itertools
+import logging
+import os.path
+import tempfile
+
+from pip._internal.utils.misc import rmtree
+
+logger = logging.getLogger(__name__)
+
+
+class TempDirectory(object):
+    """Helper class that owns and cleans up a temporary directory.
+
+    This class can be used as a context manager or as an OO representation of a
+    temporary directory.
+
+    Attributes:
+        path
+            Location to the created temporary directory or None
+        delete
+            Whether the directory should be deleted when exiting
+            (when used as a contextmanager)
+
+    Methods:
+        create()
+            Creates a temporary directory and stores its path in the path
+            attribute.
+        cleanup()
+            Deletes the temporary directory and sets path attribute to None
+
+    When used as a context manager, a temporary directory is created on
+    entering the context and, if the delete attribute is True, on exiting the
+    context the created directory is deleted.
+    """
+
+    def __init__(self, path=None, delete=None, kind="temp"):
+        super(TempDirectory, self).__init__()
+
+        if path is None and delete is None:
+            # If we were not given an explicit directory, and we were not given
+            # an explicit delete option, then we'll default to deleting.
+            delete = True
+
+        self.path = path
+        self.delete = delete
+        self.kind = kind
+
+    def __repr__(self):
+        return "<{} {!r}>".format(self.__class__.__name__, self.path)
+
+    def __enter__(self):
+        self.create()
+        return self
+
+    def __exit__(self, exc, value, tb):
+        if self.delete:
+            self.cleanup()
+
+    def create(self):
+        """Create a temporary directory and store its path in self.path
+        """
+        if self.path is not None:
+            logger.debug(
+                "Skipped creation of temporary directory: {}".format(self.path)
+            )
+            return
+        # We realpath here because some systems have their default tmpdir
+        # symlinked to another directory.  This tends to confuse build
+        # scripts, so we canonicalize the path by traversing potential
+        # symlinks here.
+        self.path = os.path.realpath(
+            tempfile.mkdtemp(prefix="pip-{}-".format(self.kind))
+        )
+        logger.debug("Created temporary directory: {}".format(self.path))
+
+    def cleanup(self):
+        """Remove the temporary directory created and reset state
+        """
+        if self.path is not None and os.path.exists(self.path):
+            rmtree(self.path)
+        self.path = None
+
+
+class AdjacentTempDirectory(TempDirectory):
+    """Helper class that creates a temporary directory adjacent to a real one.
+
+    Attributes:
+        original
+            The original directory to create a temp directory for.
+        path
+            After calling create() or entering, contains the full
+            path to the temporary directory.
+        delete
+            Whether the directory should be deleted when exiting
+            (when used as a contextmanager)
+
+    """
+    # The characters that may be used to name the temp directory
+    # We always prepend a ~ and then rotate through these until
+    # a usable name is found.
+    # pkg_resources raises a different error for .dist-info folder
+    # with leading '-' and invalid metadata
+    LEADING_CHARS = "-~.=%0123456789"
+
+    def __init__(self, original, delete=None):
+        super(AdjacentTempDirectory, self).__init__(delete=delete)
+        self.original = original.rstrip('/\\')
+
+    @classmethod
+    def _generate_names(cls, name):
+        """Generates a series of temporary names.
+
+        The algorithm replaces the leading characters in the name
+        with ones that are valid filesystem characters, but are not
+        valid package names (for both Python and pip definitions of
+        package).
+        """
+        for i in range(1, len(name)):
+            for candidate in itertools.combinations_with_replacement(
+                    cls.LEADING_CHARS, i - 1):
+                new_name = '~' + ''.join(candidate) + name[i:]
+                if new_name != name:
+                    yield new_name
+
+        # If we make it this far, we will have to make a longer name
+        for i in range(len(cls.LEADING_CHARS)):
+            for candidate in itertools.combinations_with_replacement(
+                    cls.LEADING_CHARS, i):
+                new_name = '~' + ''.join(candidate) + name
+                if new_name != name:
+                    yield new_name
+
+    def create(self):
+        root, name = os.path.split(self.original)
+        for candidate in self._generate_names(name):
+            path = os.path.join(root, candidate)
+            try:
+                os.mkdir(path)
+            except OSError as ex:
+                # Continue if the name exists already
+                if ex.errno != errno.EEXIST:
+                    raise
+            else:
+                self.path = os.path.realpath(path)
+                break
+
+        if not self.path:
+            # Final fallback on the default behavior.
+            self.path = os.path.realpath(
+                tempfile.mkdtemp(prefix="pip-{}-".format(self.kind))
+            )
+        logger.debug("Created temporary directory: {}".format(self.path))
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/utils/temp_dir.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/utils/temp_dir.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..d606d9371243ebf219c7f95dec3cbaa2bdcd1d2e
GIT binary patch
literal 6397
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
Gc>(~cClxyY

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/utils/typing.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/utils/typing.py
new file mode 100644
index 0000000..10170ce
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/utils/typing.py
@@ -0,0 +1,29 @@
+"""For neatly implementing static typing in pip.
+
+`mypy` - the static type analysis tool we use - uses the `typing` module, which
+provides core functionality fundamental to mypy's functioning.
+
+Generally, `typing` would be imported at runtime and used in that fashion -
+it acts as a no-op at runtime and does not have any run-time overhead by
+design.
+
+As it turns out, `typing` is not vendorable - it uses separate sources for
+Python 2/Python 3. Thus, this codebase can not expect it to be present.
+To work around this, mypy allows the typing import to be behind a False-y
+optional to prevent it from running at runtime and type-comments can be used
+to remove the need for the types to be accessible directly during runtime.
+
+This module provides the False-y guard in a nicely named fashion so that a
+curious maintainer can reach here to read this.
+
+In pip, all static-typing related imports should be guarded as follows:
+
+    from pip._internal.utils.typing import MYPY_CHECK_RUNNING
+
+    if MYPY_CHECK_RUNNING:
+        from typing import ...
+
+Ref: https://github.com/python/mypy/issues/3216
+"""
+
+MYPY_CHECK_RUNNING = False
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/utils/typing.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/utils/typing.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..db0df4f3cfa264bfa666440fc6599b708f694dbb
GIT binary patch
literal 1350
zcmZSn%**AGdLky70SXuy7#JKF7#NBL7#J8*7#N}$7*ZJ-qL>&`7#V^!m_Ra4EDQ{8
z`9%tOsfi^yl?s`;1v#m?sd*)tdFcwpC5a`O$qFTv1t4B#o<c!pfgTrELT+V2WrBjP
zLP<s{lA2V7#Jt3u%Hqsog_8XI9EI{!h0@|w1ziwX3|5-}F)2YIH$SB`CsjwGJR>tX
zgR7t@zbrE)wOAoJzbI89tu!yWBr`uRF(<R662wbM1i2?MN1-HN0c5j!F-R1wCNnQx
zkBiGaH7~U&F(;=|M*(g_d46e5ib7H<$V2%>C8;S2i6sg}rFkWpxgd9@fE<;gkeR1Y
zl95=Vkd|1Sk(r;Tpv#q6qL7$eQml|ztdOXXm#>>&fUYqmKebpPFTX?~Be4u*R3*q*
zU9h?NWvN9Osfj5HNtIkFsl}P;d3s!2j>QU@B?={_MR~;v`K2XDZp?(3Q<j>Sl3$dV
zlmiN@%o32xiWQ1e3lfVGOHvhz^Gl18Q;QYS@{70vDoZl*^AwEqp$ua^g^-NWVjYE&
zj7(7IrKBb$7N;sCC+2}2m|9Vgnp^_5Js%Vl1x2aFsd*)OTp{@i<@rU~3W-JerFkh}
z-8$f)RY=Uq$uEaQ79_5q;Rg!)q*R5Z)Qrr$6oo_ux5S*{RNYFh`~pZ+f#eH{Qp-~F
z!1kpT<>!KeB@dKt&;q`svLIDAIX@Q^sl{NoCV>-53Rg+KLQ!gNepxCwvE-$urht46
z=72PTk`>4siOI>S#l@MR@Jh)nN=*hO+mzBGkX6tK*5l#|0fh)8nJK{27bv|#U9ON`
znpgx*0Er5DnaQa+l?r)@xgZ;%Nuf9&k~9*zl1qy+^Gk~rauYN2N)j{kQj5T@E=o;I
z&QQomElLG>z6ccUplHzJ;_?J%6dh1tLbHc1G%$-&a}q&mF*COyzo?{Gp*RDUOu^0p
zrBYB#gCoI;i%UU4K>-|;pnMmfnOBlpl$V&JS6Y&pQ>+Iy5@M8sZ)8AZyt9X^vv+(@
zsGpywpF2c*W*QbLE3nCM(@{;*)6?VP3QA40QphMNDJZtm*H6zZ$tX?IOU}>LF94@N
zeNZ;k&nzx3O)b_pHZnBh^3z~uU|=X=XJBB6k59=@j*l;4Wnf?c2X=`N0|Nu5`!qmh
z6oM$uWnf^?FDS|^ODsv%FH0=aPs`6qNi8bYPfF1*PfE(mHO(zHGE6d0uS&NtwJ6WY
zsxmVGf%H865dDJ80^Q8K;*!Li99_3E4^QI&kPsNd!%ZI?Zu$`4>J?O$a4;}1*g(>V
NoiwN{1Qm#EOaL3NzzqNZ

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/utils/ui.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/utils/ui.py
new file mode 100644
index 0000000..0902ce7
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/utils/ui.py
@@ -0,0 +1,424 @@
+from __future__ import absolute_import, division
+
+import contextlib
+import itertools
+import logging
+import sys
+import time
+from signal import SIGINT, default_int_handler, signal
+
+from pip._vendor import six
+from pip._vendor.progress import HIDE_CURSOR, SHOW_CURSOR
+from pip._vendor.progress.bar import Bar, FillingCirclesBar, IncrementalBar
+from pip._vendor.progress.spinner import Spinner
+
+from pip._internal.utils.compat import WINDOWS
+from pip._internal.utils.logging import get_indentation
+from pip._internal.utils.misc import format_size
+from pip._internal.utils.typing import MYPY_CHECK_RUNNING
+
+if MYPY_CHECK_RUNNING:
+    from typing import Any, Iterator, IO
+
+try:
+    from pip._vendor import colorama
+# Lots of different errors can come from this, including SystemError and
+# ImportError.
+except Exception:
+    colorama = None
+
+logger = logging.getLogger(__name__)
+
+
+def _select_progress_class(preferred, fallback):
+    encoding = getattr(preferred.file, "encoding", None)
+
+    # If we don't know what encoding this file is in, then we'll just assume
+    # that it doesn't support unicode and use the ASCII bar.
+    if not encoding:
+        return fallback
+
+    # Collect all of the possible characters we want to use with the preferred
+    # bar.
+    characters = [
+        getattr(preferred, "empty_fill", six.text_type()),
+        getattr(preferred, "fill", six.text_type()),
+    ]
+    characters += list(getattr(preferred, "phases", []))
+
+    # Try to decode the characters we're using for the bar using the encoding
+    # of the given file, if this works then we'll assume that we can use the
+    # fancier bar and if not we'll fall back to the plaintext bar.
+    try:
+        six.text_type().join(characters).encode(encoding)
+    except UnicodeEncodeError:
+        return fallback
+    else:
+        return preferred
+
+
+_BaseBar = _select_progress_class(IncrementalBar, Bar)  # type: Any
+
+
+class InterruptibleMixin(object):
+    """
+    Helper to ensure that self.finish() gets called on keyboard interrupt.
+
+    This allows downloads to be interrupted without leaving temporary state
+    (like hidden cursors) behind.
+
+    This class is similar to the progress library's existing SigIntMixin
+    helper, but as of version 1.2, that helper has the following problems:
+
+    1. It calls sys.exit().
+    2. It discards the existing SIGINT handler completely.
+    3. It leaves its own handler in place even after an uninterrupted finish,
+       which will have unexpected delayed effects if the user triggers an
+       unrelated keyboard interrupt some time after a progress-displaying
+       download has already completed, for example.
+    """
+
+    def __init__(self, *args, **kwargs):
+        """
+        Save the original SIGINT handler for later.
+        """
+        super(InterruptibleMixin, self).__init__(*args, **kwargs)
+
+        self.original_handler = signal(SIGINT, self.handle_sigint)
+
+        # If signal() returns None, the previous handler was not installed from
+        # Python, and we cannot restore it. This probably should not happen,
+        # but if it does, we must restore something sensible instead, at least.
+        # The least bad option should be Python's default SIGINT handler, which
+        # just raises KeyboardInterrupt.
+        if self.original_handler is None:
+            self.original_handler = default_int_handler
+
+    def finish(self):
+        """
+        Restore the original SIGINT handler after finishing.
+
+        This should happen regardless of whether the progress display finishes
+        normally, or gets interrupted.
+        """
+        super(InterruptibleMixin, self).finish()
+        signal(SIGINT, self.original_handler)
+
+    def handle_sigint(self, signum, frame):
+        """
+        Call self.finish() before delegating to the original SIGINT handler.
+
+        This handler should only be in place while the progress display is
+        active.
+        """
+        self.finish()
+        self.original_handler(signum, frame)
+
+
+class SilentBar(Bar):
+
+    def update(self):
+        pass
+
+
+class BlueEmojiBar(IncrementalBar):
+
+    suffix = "%(percent)d%%"
+    bar_prefix = " "
+    bar_suffix = " "
+    phases = (u"\U0001F539", u"\U0001F537", u"\U0001F535")  # type: Any
+
+
+class DownloadProgressMixin(object):
+
+    def __init__(self, *args, **kwargs):
+        super(DownloadProgressMixin, self).__init__(*args, **kwargs)
+        self.message = (" " * (get_indentation() + 2)) + self.message
+
+    @property
+    def downloaded(self):
+        return format_size(self.index)
+
+    @property
+    def download_speed(self):
+        # Avoid zero division errors...
+        if self.avg == 0.0:
+            return "..."
+        return format_size(1 / self.avg) + "/s"
+
+    @property
+    def pretty_eta(self):
+        if self.eta:
+            return "eta %s" % self.eta_td
+        return ""
+
+    def iter(self, it, n=1):
+        for x in it:
+            yield x
+            self.next(n)
+        self.finish()
+
+
+class WindowsMixin(object):
+
+    def __init__(self, *args, **kwargs):
+        # The Windows terminal does not support the hide/show cursor ANSI codes
+        # even with colorama. So we'll ensure that hide_cursor is False on
+        # Windows.
+        # This call needs to go before the super() call, so that hide_cursor
+        # is set in time. The base progress bar class writes the "hide cursor"
+        # code to the terminal in its init, so if we don't set this soon
+        # enough, we get a "hide" with no corresponding "show"...
+        if WINDOWS and self.hide_cursor:
+            self.hide_cursor = False
+
+        super(WindowsMixin, self).__init__(*args, **kwargs)
+
+        # Check if we are running on Windows and we have the colorama module,
+        # if we do then wrap our file with it.
+        if WINDOWS and colorama:
+            self.file = colorama.AnsiToWin32(self.file)
+            # The progress code expects to be able to call self.file.isatty()
+            # but the colorama.AnsiToWin32() object doesn't have that, so we'll
+            # add it.
+            self.file.isatty = lambda: self.file.wrapped.isatty()
+            # The progress code expects to be able to call self.file.flush()
+            # but the colorama.AnsiToWin32() object doesn't have that, so we'll
+            # add it.
+            self.file.flush = lambda: self.file.wrapped.flush()
+
+
+class BaseDownloadProgressBar(WindowsMixin, InterruptibleMixin,
+                              DownloadProgressMixin):
+
+    file = sys.stdout
+    message = "%(percent)d%%"
+    suffix = "%(downloaded)s %(download_speed)s %(pretty_eta)s"
+
+# NOTE: The "type: ignore" comments on the following classes are there to
+#       work around https://github.com/python/typing/issues/241
+
+
+class DefaultDownloadProgressBar(BaseDownloadProgressBar,
+                                 _BaseBar):
+    pass
+
+
+class DownloadSilentBar(BaseDownloadProgressBar, SilentBar):  # type: ignore
+    pass
+
+
+class DownloadIncrementalBar(BaseDownloadProgressBar,  # type: ignore
+                             IncrementalBar):
+    pass
+
+
+class DownloadFillingCirclesBar(BaseDownloadProgressBar,  # type: ignore
+                                FillingCirclesBar):
+    pass
+
+
+class DownloadBlueEmojiProgressBar(BaseDownloadProgressBar,  # type: ignore
+                                   BlueEmojiBar):
+    pass
+
+
+class DownloadProgressSpinner(WindowsMixin, InterruptibleMixin,
+                              DownloadProgressMixin, Spinner):
+
+    file = sys.stdout
+    suffix = "%(downloaded)s %(download_speed)s"
+
+    def next_phase(self):
+        if not hasattr(self, "_phaser"):
+            self._phaser = itertools.cycle(self.phases)
+        return next(self._phaser)
+
+    def update(self):
+        message = self.message % self
+        phase = self.next_phase()
+        suffix = self.suffix % self
+        line = ''.join([
+            message,
+            " " if message else "",
+            phase,
+            " " if suffix else "",
+            suffix,
+        ])
+
+        self.writeln(line)
+
+
+BAR_TYPES = {
+    "off": (DownloadSilentBar, DownloadSilentBar),
+    "on": (DefaultDownloadProgressBar, DownloadProgressSpinner),
+    "ascii": (DownloadIncrementalBar, DownloadProgressSpinner),
+    "pretty": (DownloadFillingCirclesBar, DownloadProgressSpinner),
+    "emoji": (DownloadBlueEmojiProgressBar, DownloadProgressSpinner)
+}
+
+
+def DownloadProgressProvider(progress_bar, max=None):
+    if max is None or max == 0:
+        return BAR_TYPES[progress_bar][1]().iter
+    else:
+        return BAR_TYPES[progress_bar][0](max=max).iter
+
+
+################################################################
+# Generic "something is happening" spinners
+#
+# We don't even try using progress.spinner.Spinner here because it's actually
+# simpler to reimplement from scratch than to coerce their code into doing
+# what we need.
+################################################################
+
+@contextlib.contextmanager
+def hidden_cursor(file):
+    # type: (IO) -> Iterator[None]
+    # The Windows terminal does not support the hide/show cursor ANSI codes,
+    # even via colorama. So don't even try.
+    if WINDOWS:
+        yield
+    # We don't want to clutter the output with control characters if we're
+    # writing to a file, or if the user is running with --quiet.
+    # See https://github.com/pypa/pip/issues/3418
+    elif not file.isatty() or logger.getEffectiveLevel() > logging.INFO:
+        yield
+    else:
+        file.write(HIDE_CURSOR)
+        try:
+            yield
+        finally:
+            file.write(SHOW_CURSOR)
+
+
+class RateLimiter(object):
+    def __init__(self, min_update_interval_seconds):
+        # type: (float) -> None
+        self._min_update_interval_seconds = min_update_interval_seconds
+        self._last_update = 0  # type: float
+
+    def ready(self):
+        # type: () -> bool
+        now = time.time()
+        delta = now - self._last_update
+        return delta >= self._min_update_interval_seconds
+
+    def reset(self):
+        # type: () -> None
+        self._last_update = time.time()
+
+
+class SpinnerInterface(object):
+    def spin(self):
+        # type: () -> None
+        raise NotImplementedError()
+
+    def finish(self, final_status):
+        # type: (str) -> None
+        raise NotImplementedError()
+
+
+class InteractiveSpinner(SpinnerInterface):
+    def __init__(self, message, file=None, spin_chars="-\\|/",
+                 # Empirically, 8 updates/second looks nice
+                 min_update_interval_seconds=0.125):
+        self._message = message
+        if file is None:
+            file = sys.stdout
+        self._file = file
+        self._rate_limiter = RateLimiter(min_update_interval_seconds)
+        self._finished = False
+
+        self._spin_cycle = itertools.cycle(spin_chars)
+
+        self._file.write(" " * get_indentation() + self._message + " ... ")
+        self._width = 0
+
+    def _write(self, status):
+        assert not self._finished
+        # Erase what we wrote before by backspacing to the beginning, writing
+        # spaces to overwrite the old text, and then backspacing again
+        backup = "\b" * self._width
+        self._file.write(backup + " " * self._width + backup)
+        # Now we have a blank slate to add our status
+        self._file.write(status)
+        self._width = len(status)
+        self._file.flush()
+        self._rate_limiter.reset()
+
+    def spin(self):
+        # type: () -> None
+        if self._finished:
+            return
+        if not self._rate_limiter.ready():
+            return
+        self._write(next(self._spin_cycle))
+
+    def finish(self, final_status):
+        # type: (str) -> None
+        if self._finished:
+            return
+        self._write(final_status)
+        self._file.write("\n")
+        self._file.flush()
+        self._finished = True
+
+
+# Used for dumb terminals, non-interactive installs (no tty), etc.
+# We still print updates occasionally (once every 60 seconds by default) to
+# act as a keep-alive for systems like Travis-CI that take lack-of-output as
+# an indication that a task has frozen.
+class NonInteractiveSpinner(SpinnerInterface):
+    def __init__(self, message, min_update_interval_seconds=60):
+        # type: (str, float) -> None
+        self._message = message
+        self._finished = False
+        self._rate_limiter = RateLimiter(min_update_interval_seconds)
+        self._update("started")
+
+    def _update(self, status):
+        assert not self._finished
+        self._rate_limiter.reset()
+        logger.info("%s: %s", self._message, status)
+
+    def spin(self):
+        # type: () -> None
+        if self._finished:
+            return
+        if not self._rate_limiter.ready():
+            return
+        self._update("still running...")
+
+    def finish(self, final_status):
+        # type: (str) -> None
+        if self._finished:
+            return
+        self._update("finished with status '%s'" % (final_status,))
+        self._finished = True
+
+
+@contextlib.contextmanager
+def open_spinner(message):
+    # type: (str) -> Iterator[SpinnerInterface]
+    # Interactive spinner goes directly to sys.stdout rather than being routed
+    # through the logging system, but it acts like it has level INFO,
+    # i.e. it's only displayed if we're at level INFO or better.
+    # Non-interactive spinner goes through the logging system, so it is always
+    # in sync with logging configuration.
+    if sys.stdout.isatty() and logger.getEffectiveLevel() <= logging.INFO:
+        spinner = InteractiveSpinner(message)  # type: SpinnerInterface
+    else:
+        spinner = NonInteractiveSpinner(message)
+    try:
+        with hidden_cursor(sys.stdout):
+            yield spinner
+    except KeyboardInterrupt:
+        spinner.finish("canceled")
+        raise
+    except Exception:
+        spinner.finish("error")
+        raise
+    else:
+        spinner.finish("done")
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/utils/ui.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/utils/ui.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..afb9e302e0ad9c4607dea2ae6df40d54084f3fd6
GIT binary patch
literal 17200
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
U0bv0a9)2MaF+njdF(WZq04eiI(EtDd

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/vcs/__init__.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/vcs/__init__.py
new file mode 100644
index 0000000..6fca079
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/vcs/__init__.py
@@ -0,0 +1,604 @@
+"""Handles all VCS (version control) support"""
+from __future__ import absolute_import
+
+import errno
+import logging
+import os
+import shutil
+import sys
+
+from pip._vendor import pkg_resources
+from pip._vendor.six.moves.urllib import parse as urllib_parse
+
+from pip._internal.exceptions import BadCommand
+from pip._internal.utils.misc import (
+    ask_path_exists, backup_dir, call_subprocess, display_path, rmtree,
+)
+from pip._internal.utils.typing import MYPY_CHECK_RUNNING
+
+if MYPY_CHECK_RUNNING:
+    from typing import (
+        Any, Dict, Iterable, List, Mapping, Optional, Text, Tuple, Type
+    )
+    from pip._internal.utils.ui import SpinnerInterface
+
+    AuthInfo = Tuple[Optional[str], Optional[str]]
+
+__all__ = ['vcs']
+
+
+logger = logging.getLogger(__name__)
+
+
+def make_vcs_requirement_url(repo_url, rev, project_name, subdir=None):
+    """
+    Return the URL for a VCS requirement.
+
+    Args:
+      repo_url: the remote VCS url, with any needed VCS prefix (e.g. "git+").
+      project_name: the (unescaped) project name.
+    """
+    egg_project_name = pkg_resources.to_filename(project_name)
+    req = '{}@{}#egg={}'.format(repo_url, rev, egg_project_name)
+    if subdir:
+        req += '&subdirectory={}'.format(subdir)
+
+    return req
+
+
+class RemoteNotFoundError(Exception):
+    pass
+
+
+class RevOptions(object):
+
+    """
+    Encapsulates a VCS-specific revision to install, along with any VCS
+    install options.
+
+    Instances of this class should be treated as if immutable.
+    """
+
+    def __init__(
+        self,
+        vc_class,  # type: Type[VersionControl]
+        rev=None,  # type: Optional[str]
+        extra_args=None,  # type: Optional[List[str]]
+    ):
+        # type: (...) -> None
+        """
+        Args:
+          vc_class: a VersionControl subclass.
+          rev: the name of the revision to install.
+          extra_args: a list of extra options.
+        """
+        if extra_args is None:
+            extra_args = []
+
+        self.extra_args = extra_args
+        self.rev = rev
+        self.vc_class = vc_class
+
+    def __repr__(self):
+        return '<RevOptions {}: rev={!r}>'.format(self.vc_class.name, self.rev)
+
+    @property
+    def arg_rev(self):
+        # type: () -> Optional[str]
+        if self.rev is None:
+            return self.vc_class.default_arg_rev
+
+        return self.rev
+
+    def to_args(self):
+        # type: () -> List[str]
+        """
+        Return the VCS-specific command arguments.
+        """
+        args = []  # type: List[str]
+        rev = self.arg_rev
+        if rev is not None:
+            args += self.vc_class.get_base_rev_args(rev)
+        args += self.extra_args
+
+        return args
+
+    def to_display(self):
+        # type: () -> str
+        if not self.rev:
+            return ''
+
+        return ' (to revision {})'.format(self.rev)
+
+    def make_new(self, rev):
+        # type: (str) -> RevOptions
+        """
+        Make a copy of the current instance, but with a new rev.
+
+        Args:
+          rev: the name of the revision for the new object.
+        """
+        return self.vc_class.make_rev_options(rev, extra_args=self.extra_args)
+
+
+class VcsSupport(object):
+    _registry = {}  # type: Dict[str, Type[VersionControl]]
+    schemes = ['ssh', 'git', 'hg', 'bzr', 'sftp', 'svn']
+
+    def __init__(self):
+        # type: () -> None
+        # Register more schemes with urlparse for various version control
+        # systems
+        urllib_parse.uses_netloc.extend(self.schemes)
+        # Python >= 2.7.4, 3.3 doesn't have uses_fragment
+        if getattr(urllib_parse, 'uses_fragment', None):
+            urllib_parse.uses_fragment.extend(self.schemes)
+        super(VcsSupport, self).__init__()
+
+    def __iter__(self):
+        return self._registry.__iter__()
+
+    @property
+    def backends(self):
+        # type: () -> List[Type[VersionControl]]
+        return list(self._registry.values())
+
+    @property
+    def dirnames(self):
+        # type: () -> List[str]
+        return [backend.dirname for backend in self.backends]
+
+    @property
+    def all_schemes(self):
+        # type: () -> List[str]
+        schemes = []  # type: List[str]
+        for backend in self.backends:
+            schemes.extend(backend.schemes)
+        return schemes
+
+    def register(self, cls):
+        # type: (Type[VersionControl]) -> None
+        if not hasattr(cls, 'name'):
+            logger.warning('Cannot register VCS %s', cls.__name__)
+            return
+        if cls.name not in self._registry:
+            self._registry[cls.name] = cls
+            logger.debug('Registered VCS backend: %s', cls.name)
+
+    def unregister(self, cls=None, name=None):
+        # type: (Optional[Type[VersionControl]], Optional[str]) -> None
+        if name in self._registry:
+            del self._registry[name]
+        elif cls in self._registry.values():
+            del self._registry[cls.name]
+        else:
+            logger.warning('Cannot unregister because no class or name given')
+
+    def get_backend_type(self, location):
+        # type: (str) -> Optional[Type[VersionControl]]
+        """
+        Return the type of the version control backend if found at given
+        location, e.g. vcs.get_backend_type('/path/to/vcs/checkout')
+        """
+        for vc_type in self._registry.values():
+            if vc_type.controls_location(location):
+                logger.debug('Determine that %s uses VCS: %s',
+                             location, vc_type.name)
+                return vc_type
+        return None
+
+    def get_backend(self, name):
+        # type: (str) -> Optional[Type[VersionControl]]
+        name = name.lower()
+        if name in self._registry:
+            return self._registry[name]
+        return None
+
+
+vcs = VcsSupport()
+
+
+class VersionControl(object):
+    name = ''
+    dirname = ''
+    repo_name = ''
+    # List of supported schemes for this Version Control
+    schemes = ()  # type: Tuple[str, ...]
+    # Iterable of environment variable names to pass to call_subprocess().
+    unset_environ = ()  # type: Tuple[str, ...]
+    default_arg_rev = None  # type: Optional[str]
+
+    @classmethod
+    def should_add_vcs_url_prefix(cls, remote_url):
+        """
+        Return whether the vcs prefix (e.g. "git+") should be added to a
+        repository's remote url when used in a requirement.
+        """
+        return not remote_url.lower().startswith('{}:'.format(cls.name))
+
+    @classmethod
+    def get_subdirectory(cls, repo_dir):
+        """
+        Return the path to setup.py, relative to the repo root.
+        """
+        return None
+
+    @classmethod
+    def get_requirement_revision(cls, repo_dir):
+        """
+        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):
+        """
+        Return the requirement string to use to redownload the files
+        currently at the given repository directory.
+
+        Args:
+          project_name: the (unescaped) project name.
+
+        The return value has a form similar to the following:
+
+            {repository_url}@{revision}#egg={project_name}
+        """
+        repo_url = cls.get_remote_url(repo_dir)
+        if repo_url is None:
+            return None
+
+        if cls.should_add_vcs_url_prefix(repo_url):
+            repo_url = '{}+{}'.format(cls.name, repo_url)
+
+        revision = cls.get_requirement_revision(repo_dir)
+        subdir = cls.get_subdirectory(repo_dir)
+        req = make_vcs_requirement_url(repo_url, revision, project_name,
+                                       subdir=subdir)
+
+        return req
+
+    def __init__(self, url=None, *args, **kwargs):
+        self.url = url
+        super(VersionControl, self).__init__(*args, **kwargs)
+
+    @staticmethod
+    def get_base_rev_args(rev):
+        """
+        Return the base revision arguments for a vcs command.
+
+        Args:
+          rev: the name of a revision to install.  Cannot be None.
+        """
+        raise NotImplementedError
+
+    @classmethod
+    def make_rev_options(cls, rev=None, extra_args=None):
+        # type: (Optional[str], Optional[List[str]]) -> RevOptions
+        """
+        Return a RevOptions object.
+
+        Args:
+          rev: the name of a revision to install.
+          extra_args: a list of extra options.
+        """
+        return RevOptions(cls, rev, extra_args=extra_args)
+
+    @classmethod
+    def _is_local_repository(cls, repo):
+        # type: (str) -> bool
+        """
+           posix absolute paths start with os.path.sep,
+           win32 ones start with drive (like c:\\folder)
+        """
+        drive, tail = os.path.splitdrive(repo)
+        return repo.startswith(os.path.sep) or bool(drive)
+
+    def export(self, location):
+        """
+        Export the repository at the url to the destination location
+        i.e. only download the files, without vcs informations
+        """
+        raise NotImplementedError
+
+    @classmethod
+    def get_netloc_and_auth(cls, netloc, scheme):
+        """
+        Parse the repository URL's netloc, and return the new netloc to use
+        along with auth information.
+
+        Args:
+          netloc: the original repository URL netloc.
+          scheme: the repository URL's scheme without the vcs prefix.
+
+        This is mainly for the Subversion class to override, so that auth
+        information can be provided via the --username and --password options
+        instead of through the URL.  For other subclasses like Git without
+        such an option, auth information must stay in the URL.
+
+        Returns: (netloc, (username, password)).
+        """
+        return netloc, (None, None)
+
+    @classmethod
+    def get_url_rev_and_auth(cls, url):
+        # type: (str) -> Tuple[str, Optional[str], AuthInfo]
+        """
+        Parse the repository URL to use, and return the URL, revision,
+        and auth info to use.
+
+        Returns: (url, rev, (username, password)).
+        """
+        scheme, netloc, path, query, frag = urllib_parse.urlsplit(url)
+        if '+' not in scheme:
+            raise ValueError(
+                "Sorry, {!r} is a malformed VCS url. "
+                "The format is <vcs>+<protocol>://<url>, "
+                "e.g. svn+http://myrepo/svn/MyApp#egg=MyApp".format(url)
+            )
+        # Remove the vcs prefix.
+        scheme = scheme.split('+', 1)[1]
+        netloc, user_pass = cls.get_netloc_and_auth(netloc, scheme)
+        rev = None
+        if '@' in path:
+            path, rev = path.rsplit('@', 1)
+        url = urllib_parse.urlunsplit((scheme, netloc, path, query, ''))
+        return url, rev, user_pass
+
+    @staticmethod
+    def make_rev_args(username, password):
+        """
+        Return the RevOptions "extra arguments" to use in obtain().
+        """
+        return []
+
+    def get_url_rev_options(self, url):
+        # type: (str) -> Tuple[str, RevOptions]
+        """
+        Return the URL and RevOptions object to use in obtain() and in
+        some cases export(), as a tuple (url, rev_options).
+        """
+        url, rev, user_pass = self.get_url_rev_and_auth(url)
+        username, password = user_pass
+        extra_args = self.make_rev_args(username, password)
+        rev_options = self.make_rev_options(rev, extra_args=extra_args)
+
+        return url, rev_options
+
+    @staticmethod
+    def normalize_url(url):
+        # type: (str) -> str
+        """
+        Normalize a URL for comparison by unquoting it and removing any
+        trailing slash.
+        """
+        return urllib_parse.unquote(url).rstrip('/')
+
+    @classmethod
+    def compare_urls(cls, url1, url2):
+        # type: (str, str) -> bool
+        """
+        Compare two repo URLs for identity, ignoring incidental differences.
+        """
+        return (cls.normalize_url(url1) == cls.normalize_url(url2))
+
+    @classmethod
+    def fetch_new(cls, dest, url, rev_options):
+        """
+        Fetch a revision from a repository, in the case that this is the
+        first fetch from the repository.
+
+        Args:
+          dest: the directory to fetch the repository to.
+          rev_options: a RevOptions object.
+        """
+        raise NotImplementedError
+
+    def switch(self, dest, url, rev_options):
+        """
+        Switch the repo at ``dest`` to point to ``URL``.
+
+        Args:
+          rev_options: a RevOptions object.
+        """
+        raise NotImplementedError
+
+    def update(self, dest, url, rev_options):
+        """
+        Update an already-existing repo to the given ``rev_options``.
+
+        Args:
+          rev_options: a RevOptions object.
+        """
+        raise NotImplementedError
+
+    @classmethod
+    def is_commit_id_equal(cls, dest, name):
+        """
+        Return whether the id of the current commit equals the given name.
+
+        Args:
+          dest: the repository directory.
+          name: a string name.
+        """
+        raise NotImplementedError
+
+    def obtain(self, dest):
+        # type: (str) -> None
+        """
+        Install or update in editable mode the package represented by this
+        VersionControl object.
+
+        Args:
+          dest: the repository directory in which to install or update.
+        """
+        url, rev_options = self.get_url_rev_options(self.url)
+
+        if not os.path.exists(dest):
+            self.fetch_new(dest, url, rev_options)
+            return
+
+        rev_display = rev_options.to_display()
+        if self.is_repository_directory(dest):
+            existing_url = self.get_remote_url(dest)
+            if self.compare_urls(existing_url, url):
+                logger.debug(
+                    '%s in %s exists, and has correct URL (%s)',
+                    self.repo_name.title(),
+                    display_path(dest),
+                    url,
+                )
+                if not self.is_commit_id_equal(dest, rev_options.rev):
+                    logger.info(
+                        'Updating %s %s%s',
+                        display_path(dest),
+                        self.repo_name,
+                        rev_display,
+                    )
+                    self.update(dest, url, rev_options)
+                else:
+                    logger.info('Skipping because already up-to-date.')
+                return
+
+            logger.warning(
+                '%s %s in %s exists with URL %s',
+                self.name,
+                self.repo_name,
+                display_path(dest),
+                existing_url,
+            )
+            prompt = ('(s)witch, (i)gnore, (w)ipe, (b)ackup ',
+                      ('s', 'i', 'w', 'b'))
+        else:
+            logger.warning(
+                'Directory %s already exists, and is not a %s %s.',
+                dest,
+                self.name,
+                self.repo_name,
+            )
+            # https://github.com/python/mypy/issues/1174
+            prompt = ('(i)gnore, (w)ipe, (b)ackup ',  # type: ignore
+                      ('i', 'w', 'b'))
+
+        logger.warning(
+            'The plan is to install the %s repository %s',
+            self.name,
+            url,
+        )
+        response = ask_path_exists('What to do?  %s' % prompt[0], prompt[1])
+
+        if response == 'a':
+            sys.exit(-1)
+
+        if response == 'w':
+            logger.warning('Deleting %s', display_path(dest))
+            rmtree(dest)
+            self.fetch_new(dest, url, rev_options)
+            return
+
+        if response == 'b':
+            dest_dir = backup_dir(dest)
+            logger.warning(
+                'Backing up %s to %s', display_path(dest), dest_dir,
+            )
+            shutil.move(dest, dest_dir)
+            self.fetch_new(dest, url, rev_options)
+            return
+
+        # Do nothing if the response is "i".
+        if response == 's':
+            logger.info(
+                'Switching %s %s to %s%s',
+                self.repo_name,
+                display_path(dest),
+                url,
+                rev_display,
+            )
+            self.switch(dest, url, rev_options)
+
+    def unpack(self, location):
+        # type: (str) -> None
+        """
+        Clean up current location and download the url repository
+        (and vcs infos) into location
+        """
+        if os.path.exists(location):
+            rmtree(location)
+        self.obtain(location)
+
+    @classmethod
+    def get_remote_url(cls, location):
+        """
+        Return the url used at location
+
+        Raises RemoteNotFoundError if the repository does not have a remote
+        url configured.
+        """
+        raise NotImplementedError
+
+    @classmethod
+    def get_revision(cls, location):
+        """
+        Return the current commit id of the files at the given location.
+        """
+        raise NotImplementedError
+
+    @classmethod
+    def run_command(
+        cls,
+        cmd,  # type: List[str]
+        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]
+    ):
+        # type: (...) -> Optional[Text]
+        """
+        Run a VCS subcommand
+        This is simply a wrapper around call_subprocess that adds the VCS
+        command name, and checks that the VCS is available
+        """
+        cmd = [cls.name] + cmd
+        try:
+            return call_subprocess(cmd, show_stdout, cwd,
+                                   on_returncode=on_returncode,
+                                   extra_ok_returncodes=extra_ok_returncodes,
+                                   command_desc=command_desc,
+                                   extra_environ=extra_environ,
+                                   unset_environ=cls.unset_environ,
+                                   spinner=spinner)
+        except OSError as e:
+            # errno.ENOENT = no such file or directory
+            # In other words, the VCS executable isn't available
+            if e.errno == errno.ENOENT:
+                raise BadCommand(
+                    'Cannot find command %r - do you have '
+                    '%r installed and in your '
+                    'PATH?' % (cls.name, cls.name))
+            else:
+                raise  # re-raise exception if a different error occurred
+
+    @classmethod
+    def is_repository_directory(cls, path):
+        # type: (str) -> bool
+        """
+        Return whether a directory path is a repository directory.
+        """
+        logger.debug('Checking in %s for %s (%s)...',
+                     path, cls.dirname, cls.name)
+        return os.path.exists(os.path.join(path, cls.dirname))
+
+    @classmethod
+    def controls_location(cls, location):
+        # type: (str) -> bool
+        """
+        Check if a location is controlled by the vcs.
+        It is meant to be overridden to implement smarter detection
+        mechanisms for specific vcs.
+
+        This can do more than is_repository_directory() alone.  For example,
+        the Git override checks that Git is actually available.
+        """
+        return cls.is_repository_directory(location)
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/vcs/__init__.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/vcs/__init__.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..d545c5d2bd11a9bcc364930786c1f2f2b937ec23
GIT binary patch
literal 22654
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
bCN@R~W&tK?CQfF4W*z}C7BP1*FHU9v)xmV;

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/vcs/bazaar.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/vcs/bazaar.py
new file mode 100644
index 0000000..3587b3d
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/vcs/bazaar.py
@@ -0,0 +1,103 @@
+from __future__ import absolute_import
+
+import logging
+import os
+
+from pip._vendor.six.moves.urllib import parse as urllib_parse
+
+from pip._internal.download import path_to_url
+from pip._internal.utils.misc import display_path, rmtree
+from pip._internal.vcs import VersionControl, vcs
+
+logger = logging.getLogger(__name__)
+
+
+class Bazaar(VersionControl):
+    name = 'bzr'
+    dirname = '.bzr'
+    repo_name = 'branch'
+    schemes = (
+        'bzr', 'bzr+http', 'bzr+https', 'bzr+ssh', 'bzr+sftp', 'bzr+ftp',
+        'bzr+lp',
+    )
+
+    def __init__(self, url=None, *args, **kwargs):
+        super(Bazaar, self).__init__(url, *args, **kwargs)
+        # This is only needed for python <2.7.5
+        # Register lp but do not expose as a scheme to support bzr+lp.
+        if getattr(urllib_parse, 'uses_fragment', None):
+            urllib_parse.uses_fragment.extend(['lp'])
+
+    @staticmethod
+    def get_base_rev_args(rev):
+        return ['-r', rev]
+
+    def export(self, location):
+        """
+        Export the Bazaar repository at the url to the destination location
+        """
+        # Remove the location to make sure Bazaar can export it correctly
+        if os.path.exists(location):
+            rmtree(location)
+
+        url, rev_options = self.get_url_rev_options(self.url)
+        self.run_command(
+            ['export', location, url] + rev_options.to_args(),
+            show_stdout=False,
+        )
+
+    @classmethod
+    def fetch_new(cls, dest, url, rev_options):
+        rev_display = rev_options.to_display()
+        logger.info(
+            'Checking out %s%s to %s',
+            url,
+            rev_display,
+            display_path(dest),
+        )
+        cmd_args = ['branch', '-q'] + rev_options.to_args() + [url, dest]
+        cls.run_command(cmd_args)
+
+    def switch(self, dest, url, rev_options):
+        self.run_command(['switch', url], cwd=dest)
+
+    def update(self, dest, url, rev_options):
+        cmd_args = ['pull', '-q'] + rev_options.to_args()
+        self.run_command(cmd_args, cwd=dest)
+
+    @classmethod
+    def get_url_rev_and_auth(cls, url):
+        # hotfix the URL scheme after removing bzr+ from bzr+ssh:// readd it
+        url, rev, user_pass = super(Bazaar, cls).get_url_rev_and_auth(url)
+        if url.startswith('ssh://'):
+            url = 'bzr+' + url
+        return url, rev, user_pass
+
+    @classmethod
+    def get_remote_url(cls, location):
+        urls = cls.run_command(['info'], show_stdout=False, cwd=location)
+        for line in urls.splitlines():
+            line = line.strip()
+            for x in ('checkout of branch: ',
+                      'parent branch: '):
+                if line.startswith(x):
+                    repo = line.split(x)[1]
+                    if cls._is_local_repository(repo):
+                        return path_to_url(repo)
+                    return repo
+        return None
+
+    @classmethod
+    def get_revision(cls, location):
+        revision = cls.run_command(
+            ['revno'], show_stdout=False, cwd=location,
+        )
+        return revision.splitlines()[-1]
+
+    @classmethod
+    def is_commit_id_equal(cls, dest, name):
+        """Always assume the versions don't match"""
+        return False
+
+
+vcs.register(Bazaar)
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/vcs/bazaar.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/vcs/bazaar.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..873d5a69b82e5667acf203d7e9a46ad99ff97f76
GIT binary patch
literal 5100
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
GSOfqBXoR=`

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/vcs/git.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/vcs/git.py
new file mode 100644
index 0000000..35ea930
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/vcs/git.py
@@ -0,0 +1,362 @@
+from __future__ import absolute_import
+
+import logging
+import os.path
+import re
+
+from pip._vendor.packaging.version import parse as parse_version
+from pip._vendor.six.moves.urllib import parse as urllib_parse
+from pip._vendor.six.moves.urllib import request as urllib_request
+
+from pip._internal.exceptions import BadCommand
+from pip._internal.utils.compat import samefile
+from pip._internal.utils.misc import display_path, redact_password_from_url
+from pip._internal.utils.temp_dir import TempDirectory
+from pip._internal.vcs import RemoteNotFoundError, VersionControl, vcs
+
+urlsplit = urllib_parse.urlsplit
+urlunsplit = urllib_parse.urlunsplit
+
+
+logger = logging.getLogger(__name__)
+
+
+HASH_REGEX = re.compile('[a-fA-F0-9]{40}')
+
+
+def looks_like_hash(sha):
+    return bool(HASH_REGEX.match(sha))
+
+
+class Git(VersionControl):
+    name = 'git'
+    dirname = '.git'
+    repo_name = 'clone'
+    schemes = (
+        'git', 'git+http', 'git+https', 'git+ssh', 'git+git', 'git+file',
+    )
+    # Prevent the user's environment variables from interfering with pip:
+    # https://github.com/pypa/pip/issues/1130
+    unset_environ = ('GIT_DIR', 'GIT_WORK_TREE')
+    default_arg_rev = 'HEAD'
+
+    def __init__(self, url=None, *args, **kwargs):
+
+        # Works around an apparent Git bug
+        # (see https://article.gmane.org/gmane.comp.version-control.git/146500)
+        if url:
+            scheme, netloc, path, query, fragment = urlsplit(url)
+            if scheme.endswith('file'):
+                initial_slashes = path[:-len(path.lstrip('/'))]
+                newpath = (
+                    initial_slashes +
+                    urllib_request.url2pathname(path)
+                    .replace('\\', '/').lstrip('/')
+                )
+                url = urlunsplit((scheme, netloc, newpath, query, fragment))
+                after_plus = scheme.find('+') + 1
+                url = scheme[:after_plus] + urlunsplit(
+                    (scheme[after_plus:], netloc, newpath, query, fragment),
+                )
+
+        super(Git, self).__init__(url, *args, **kwargs)
+
+    @staticmethod
+    def get_base_rev_args(rev):
+        return [rev]
+
+    def get_git_version(self):
+        VERSION_PFX = 'git version '
+        version = self.run_command(['version'], show_stdout=False)
+        if version.startswith(VERSION_PFX):
+            version = version[len(VERSION_PFX):].split()[0]
+        else:
+            version = ''
+        # get first 3 positions of the git version because
+        # on windows it is x.y.z.windows.t, and this parses as
+        # LegacyVersion which always smaller than a Version.
+        version = '.'.join(version.split('.')[:3])
+        return parse_version(version)
+
+    @classmethod
+    def get_current_branch(cls, location):
+        """
+        Return the current branch, or None if HEAD isn't at a branch
+        (e.g. detached HEAD).
+        """
+        # git-symbolic-ref exits with empty stdout if "HEAD" is a detached
+        # HEAD rather than a symbolic ref.  In addition, the -q causes the
+        # command to exit with status code 1 instead of 128 in this case
+        # and to suppress the message to stderr.
+        args = ['symbolic-ref', '-q', 'HEAD']
+        output = cls.run_command(
+            args, extra_ok_returncodes=(1, ), show_stdout=False, cwd=location,
+        )
+        ref = output.strip()
+
+        if ref.startswith('refs/heads/'):
+            return ref[len('refs/heads/'):]
+
+        return None
+
+    def export(self, location):
+        """Export the Git repository at the url to the destination location"""
+        if not location.endswith('/'):
+            location = location + '/'
+
+        with TempDirectory(kind="export") as temp_dir:
+            self.unpack(temp_dir.path)
+            self.run_command(
+                ['checkout-index', '-a', '-f', '--prefix', location],
+                show_stdout=False, cwd=temp_dir.path
+            )
+
+    @classmethod
+    def get_revision_sha(cls, dest, rev):
+        """
+        Return (sha_or_none, is_branch), where sha_or_none is a commit hash
+        if the revision names a remote branch or tag, otherwise None.
+
+        Args:
+          dest: the repository directory.
+          rev: the revision name.
+        """
+        # Pass rev to pre-filter the list.
+        output = cls.run_command(['show-ref', rev], cwd=dest,
+                                 show_stdout=False, on_returncode='ignore')
+        refs = {}
+        for line in output.strip().splitlines():
+            try:
+                sha, ref = line.split()
+            except ValueError:
+                # Include the offending line to simplify troubleshooting if
+                # this error ever occurs.
+                raise ValueError('unexpected show-ref line: {!r}'.format(line))
+
+            refs[ref] = sha
+
+        branch_ref = 'refs/remotes/origin/{}'.format(rev)
+        tag_ref = 'refs/tags/{}'.format(rev)
+
+        sha = refs.get(branch_ref)
+        if sha is not None:
+            return (sha, True)
+
+        sha = refs.get(tag_ref)
+
+        return (sha, False)
+
+    @classmethod
+    def resolve_revision(cls, dest, url, rev_options):
+        """
+        Resolve a revision to a new RevOptions object with the SHA1 of the
+        branch, tag, or ref if found.
+
+        Args:
+          rev_options: a RevOptions object.
+        """
+        rev = rev_options.arg_rev
+        sha, is_branch = cls.get_revision_sha(dest, rev)
+
+        if sha is not None:
+            rev_options = rev_options.make_new(sha)
+            rev_options.branch_name = rev if is_branch else None
+
+            return rev_options
+
+        # Do not show a warning for the common case of something that has
+        # the form of a Git commit hash.
+        if not looks_like_hash(rev):
+            logger.warning(
+                "Did not find branch or tag '%s', assuming revision or ref.",
+                rev,
+            )
+
+        if not rev.startswith('refs/'):
+            return rev_options
+
+        # If it looks like a ref, we have to fetch it explicitly.
+        cls.run_command(
+            ['fetch', '-q', url] + rev_options.to_args(),
+            cwd=dest,
+        )
+        # Change the revision to the SHA of the ref we fetched
+        sha = cls.get_revision(dest, rev='FETCH_HEAD')
+        rev_options = rev_options.make_new(sha)
+
+        return rev_options
+
+    @classmethod
+    def is_commit_id_equal(cls, dest, name):
+        """
+        Return whether the current commit hash equals the given name.
+
+        Args:
+          dest: the repository directory.
+          name: a string name.
+        """
+        if not name:
+            # Then avoid an unnecessary subprocess call.
+            return False
+
+        return cls.get_revision(dest) == name
+
+    @classmethod
+    def fetch_new(cls, dest, url, rev_options):
+        rev_display = rev_options.to_display()
+        logger.info(
+            'Cloning %s%s to %s', redact_password_from_url(url),
+            rev_display, display_path(dest),
+        )
+        cls.run_command(['clone', '-q', url, dest])
+
+        if rev_options.rev:
+            # Then a specific revision was requested.
+            rev_options = cls.resolve_revision(dest, url, rev_options)
+            branch_name = getattr(rev_options, 'branch_name', None)
+            if branch_name is None:
+                # Only do a checkout if the current commit id doesn't match
+                # the requested revision.
+                if not cls.is_commit_id_equal(dest, rev_options.rev):
+                    cmd_args = ['checkout', '-q'] + rev_options.to_args()
+                    cls.run_command(cmd_args, cwd=dest)
+            elif cls.get_current_branch(dest) != branch_name:
+                # Then a specific branch was requested, and that branch
+                # is not yet checked out.
+                track_branch = 'origin/{}'.format(branch_name)
+                cmd_args = [
+                    'checkout', '-b', branch_name, '--track', track_branch,
+                ]
+                cls.run_command(cmd_args, cwd=dest)
+
+        #: repo may contain submodules
+        cls.update_submodules(dest)
+
+    def switch(self, dest, url, rev_options):
+        self.run_command(['config', 'remote.origin.url', url], cwd=dest)
+        cmd_args = ['checkout', '-q'] + rev_options.to_args()
+        self.run_command(cmd_args, cwd=dest)
+
+        self.update_submodules(dest)
+
+    def update(self, dest, url, rev_options):
+        # First fetch changes from the default remote
+        if self.get_git_version() >= parse_version('1.9.0'):
+            # fetch tags in addition to everything else
+            self.run_command(['fetch', '-q', '--tags'], cwd=dest)
+        else:
+            self.run_command(['fetch', '-q'], cwd=dest)
+        # Then reset to wanted revision (maybe even origin/master)
+        rev_options = self.resolve_revision(dest, url, rev_options)
+        cmd_args = ['reset', '--hard', '-q'] + rev_options.to_args()
+        self.run_command(cmd_args, cwd=dest)
+        #: update submodules
+        self.update_submodules(dest)
+
+    @classmethod
+    def get_remote_url(cls, location):
+        """
+        Return URL of the first remote encountered.
+
+        Raises RemoteNotFoundError if the repository does not have a remote
+        url configured.
+        """
+        # We need to pass 1 for extra_ok_returncodes since the command
+        # exits with return code 1 if there are no matching lines.
+        stdout = cls.run_command(
+            ['config', '--get-regexp', r'remote\..*\.url'],
+            extra_ok_returncodes=(1, ), show_stdout=False, cwd=location,
+        )
+        remotes = stdout.splitlines()
+        try:
+            found_remote = remotes[0]
+        except IndexError:
+            raise RemoteNotFoundError
+
+        for remote in remotes:
+            if remote.startswith('remote.origin.url '):
+                found_remote = remote
+                break
+        url = found_remote.split(' ')[1]
+        return url.strip()
+
+    @classmethod
+    def get_revision(cls, location, rev=None):
+        if rev is None:
+            rev = 'HEAD'
+        current_rev = cls.run_command(
+            ['rev-parse', rev], show_stdout=False, cwd=location,
+        )
+        return current_rev.strip()
+
+    @classmethod
+    def get_subdirectory(cls, location):
+        # find the repo root
+        git_dir = cls.run_command(['rev-parse', '--git-dir'],
+                                  show_stdout=False, cwd=location).strip()
+        if not os.path.isabs(git_dir):
+            git_dir = os.path.join(location, git_dir)
+        root_dir = os.path.join(git_dir, '..')
+        # find setup.py
+        orig_location = location
+        while not os.path.exists(os.path.join(location, 'setup.py')):
+            last_location = location
+            location = os.path.dirname(location)
+            if location == last_location:
+                # We've traversed up to the root of the filesystem without
+                # finding setup.py
+                logger.warning(
+                    "Could not find setup.py for directory %s (tried all "
+                    "parent directories)",
+                    orig_location,
+                )
+                return None
+        # relative path of setup.py to repo root
+        if samefile(root_dir, location):
+            return None
+        return os.path.relpath(location, root_dir)
+
+    @classmethod
+    def get_url_rev_and_auth(cls, url):
+        """
+        Prefixes stub URLs like 'user@hostname:user/repo.git' with 'ssh://'.
+        That's required because although they use SSH they sometimes don't
+        work with a ssh:// scheme (e.g. GitHub). But we need a scheme for
+        parsing. Hence we remove it again afterwards and return it as a stub.
+        """
+        if '://' not in url:
+            assert 'file:' not in url
+            url = url.replace('git+', 'git+ssh://')
+            url, rev, user_pass = super(Git, cls).get_url_rev_and_auth(url)
+            url = url.replace('ssh://', '')
+        else:
+            url, rev, user_pass = super(Git, cls).get_url_rev_and_auth(url)
+
+        return url, rev, user_pass
+
+    @classmethod
+    def update_submodules(cls, location):
+        if not os.path.exists(os.path.join(location, '.gitmodules')):
+            return
+        cls.run_command(
+            ['submodule', 'update', '--init', '--recursive', '-q'],
+            cwd=location,
+        )
+
+    @classmethod
+    def controls_location(cls, location):
+        if super(Git, cls).controls_location(location):
+            return True
+        try:
+            r = cls.run_command(['rev-parse'],
+                                cwd=location,
+                                show_stdout=False,
+                                on_returncode='ignore')
+            return not r
+        except BadCommand:
+            logger.debug("could not determine if %s is under git control "
+                         "because git is not available", location)
+            return False
+
+
+vcs.register(Git)
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/vcs/git.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/vcs/git.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..af119eca8a32470083f903a6a80998d13406ac9f
GIT binary patch
literal 12424
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
X3NXqraWZl;^E2}^bFzs2XYc_4Q?>2u

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/vcs/mercurial.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/vcs/mercurial.py
new file mode 100644
index 0000000..81edc4a
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/vcs/mercurial.py
@@ -0,0 +1,105 @@
+from __future__ import absolute_import
+
+import logging
+import os
+
+from pip._vendor.six.moves import configparser
+
+from pip._internal.download import path_to_url
+from pip._internal.utils.misc import display_path
+from pip._internal.utils.temp_dir import TempDirectory
+from pip._internal.vcs import VersionControl, vcs
+
+logger = logging.getLogger(__name__)
+
+
+class Mercurial(VersionControl):
+    name = 'hg'
+    dirname = '.hg'
+    repo_name = 'clone'
+    schemes = ('hg', 'hg+http', 'hg+https', 'hg+ssh', 'hg+static-http')
+
+    @staticmethod
+    def get_base_rev_args(rev):
+        return [rev]
+
+    def export(self, location):
+        """Export the Hg repository at the url to the destination location"""
+        with TempDirectory(kind="export") as temp_dir:
+            self.unpack(temp_dir.path)
+
+            self.run_command(
+                ['archive', location], show_stdout=False, cwd=temp_dir.path
+            )
+
+    @classmethod
+    def fetch_new(cls, dest, url, rev_options):
+        rev_display = rev_options.to_display()
+        logger.info(
+            'Cloning hg %s%s to %s',
+            url,
+            rev_display,
+            display_path(dest),
+        )
+        cls.run_command(['clone', '--noupdate', '-q', url, dest])
+        cmd_args = ['update', '-q'] + rev_options.to_args()
+        cls.run_command(cmd_args, cwd=dest)
+
+    def switch(self, dest, url, rev_options):
+        repo_config = os.path.join(dest, self.dirname, 'hgrc')
+        config = configparser.SafeConfigParser()
+        try:
+            config.read(repo_config)
+            config.set('paths', 'default', url)
+            with open(repo_config, 'w') as config_file:
+                config.write(config_file)
+        except (OSError, configparser.NoSectionError) as exc:
+            logger.warning(
+                'Could not switch Mercurial repository to %s: %s', url, exc,
+            )
+        else:
+            cmd_args = ['update', '-q'] + rev_options.to_args()
+            self.run_command(cmd_args, cwd=dest)
+
+    def update(self, dest, url, rev_options):
+        self.run_command(['pull', '-q'], cwd=dest)
+        cmd_args = ['update', '-q'] + rev_options.to_args()
+        self.run_command(cmd_args, cwd=dest)
+
+    @classmethod
+    def get_remote_url(cls, location):
+        url = cls.run_command(
+            ['showconfig', 'paths.default'],
+            show_stdout=False, cwd=location).strip()
+        if cls._is_local_repository(url):
+            url = path_to_url(url)
+        return url.strip()
+
+    @classmethod
+    def get_revision(cls, location):
+        """
+        Return the repository-local changeset revision number, as an integer.
+        """
+        current_revision = cls.run_command(
+            ['parents', '--template={rev}'],
+            show_stdout=False, cwd=location).strip()
+        return current_revision
+
+    @classmethod
+    def get_requirement_revision(cls, location):
+        """
+        Return the changeset identification hash, as a 40-character
+        hexadecimal string
+        """
+        current_rev_hash = cls.run_command(
+            ['parents', '--template={node}'],
+            show_stdout=False, cwd=location).strip()
+        return current_rev_hash
+
+    @classmethod
+    def is_commit_id_equal(cls, dest, name):
+        """Always assume the versions don't match"""
+        return False
+
+
+vcs.register(Mercurial)
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/vcs/mercurial.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/vcs/mercurial.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..293b15640de87d76f52d81edda286c1d487ea62a
GIT binary patch
literal 5223
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
J@iU7>0sun<x;p>>

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/vcs/subversion.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/vcs/subversion.py
new file mode 100644
index 0000000..01bb161
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/vcs/subversion.py
@@ -0,0 +1,234 @@
+from __future__ import absolute_import
+
+import logging
+import os
+import re
+
+from pip._internal.utils.logging import indent_log
+from pip._internal.utils.misc import (
+    display_path, rmtree, split_auth_from_netloc,
+)
+from pip._internal.utils.typing import MYPY_CHECK_RUNNING
+from pip._internal.vcs import VersionControl, vcs
+
+_svn_xml_url_re = re.compile('url="([^"]+)"')
+_svn_rev_re = re.compile(r'committed-rev="(\d+)"')
+_svn_info_xml_rev_re = re.compile(r'\s*revision="(\d+)"')
+_svn_info_xml_url_re = re.compile(r'<url>(.*)</url>')
+
+
+if MYPY_CHECK_RUNNING:
+    from typing import Optional, Tuple
+
+logger = logging.getLogger(__name__)
+
+
+class Subversion(VersionControl):
+    name = 'svn'
+    dirname = '.svn'
+    repo_name = 'checkout'
+    schemes = ('svn', 'svn+ssh', 'svn+http', 'svn+https', 'svn+svn')
+
+    @classmethod
+    def should_add_vcs_url_prefix(cls, remote_url):
+        return True
+
+    @staticmethod
+    def get_base_rev_args(rev):
+        return ['-r', rev]
+
+    def get_vcs_version(self):
+        # type: () -> Optional[Tuple[int, ...]]
+        """Return the version of the currently installed Subversion client.
+
+        :return: A tuple containing the parts of the version information or
+            ``None`` if the version returned from ``svn`` could not be parsed.
+        :raises: BadCommand: If ``svn`` is not installed.
+        """
+        # Example versions:
+        #   svn, version 1.10.3 (r1842928)
+        #      compiled Feb 25 2019, 14:20:39 on x86_64-apple-darwin17.0.0
+        #   svn, version 1.7.14 (r1542130)
+        #      compiled Mar 28 2018, 08:49:13 on x86_64-pc-linux-gnu
+        version_prefix = 'svn, version '
+        version = self.run_command(['--version'], show_stdout=False)
+        if not version.startswith(version_prefix):
+            return None
+
+        version = version[len(version_prefix):].split()[0]
+        version_list = version.split('.')
+        try:
+            parsed_version = tuple(map(int, version_list))
+        except ValueError:
+            return None
+
+        if not parsed_version:
+            return None
+
+        return parsed_version
+
+    def export(self, location):
+        """Export the svn repository at the url to the destination location"""
+        url, rev_options = self.get_url_rev_options(self.url)
+
+        logger.info('Exporting svn repository %s to %s', url, location)
+        with indent_log():
+            if os.path.exists(location):
+                # Subversion doesn't like to check out over an existing
+                # directory --force fixes this, but was only added in svn 1.5
+                rmtree(location)
+            cmd_args = ['export'] + rev_options.to_args() + [url, location]
+            self.run_command(cmd_args, show_stdout=False)
+
+    @classmethod
+    def fetch_new(cls, dest, url, rev_options):
+        rev_display = rev_options.to_display()
+        logger.info(
+            'Checking out %s%s to %s',
+            url,
+            rev_display,
+            display_path(dest),
+        )
+        cmd_args = ['checkout', '-q'] + rev_options.to_args() + [url, dest]
+        cls.run_command(cmd_args)
+
+    def switch(self, dest, url, rev_options):
+        cmd_args = ['switch'] + rev_options.to_args() + [url, dest]
+        self.run_command(cmd_args)
+
+    def update(self, dest, url, rev_options):
+        cmd_args = ['update'] + rev_options.to_args() + [dest]
+        self.run_command(cmd_args)
+
+    @classmethod
+    def get_revision(cls, location):
+        """
+        Return the maximum revision for all files under a given location
+        """
+        # Note: taken from setuptools.command.egg_info
+        revision = 0
+
+        for base, dirs, files in os.walk(location):
+            if cls.dirname not in dirs:
+                dirs[:] = []
+                continue    # no sense walking uncontrolled subdirs
+            dirs.remove(cls.dirname)
+            entries_fn = os.path.join(base, cls.dirname, 'entries')
+            if not os.path.exists(entries_fn):
+                # FIXME: should we warn?
+                continue
+
+            dirurl, localrev = cls._get_svn_url_rev(base)
+
+            if base == location:
+                base = dirurl + '/'   # save the root url
+            elif not dirurl or not dirurl.startswith(base):
+                dirs[:] = []
+                continue    # not part of the same svn tree, skip it
+            revision = max(revision, localrev)
+        return revision
+
+    @classmethod
+    def get_netloc_and_auth(cls, netloc, scheme):
+        """
+        This override allows the auth information to be passed to svn via the
+        --username and --password options instead of via the URL.
+        """
+        if scheme == 'ssh':
+            # The --username and --password options can't be used for
+            # svn+ssh URLs, so keep the auth information in the URL.
+            return super(Subversion, cls).get_netloc_and_auth(netloc, scheme)
+
+        return split_auth_from_netloc(netloc)
+
+    @classmethod
+    def get_url_rev_and_auth(cls, url):
+        # hotfix the URL scheme after removing svn+ from svn+ssh:// readd it
+        url, rev, user_pass = super(Subversion, cls).get_url_rev_and_auth(url)
+        if url.startswith('ssh://'):
+            url = 'svn+' + url
+        return url, rev, user_pass
+
+    @staticmethod
+    def make_rev_args(username, password):
+        extra_args = []
+        if username:
+            extra_args += ['--username', username]
+        if password:
+            extra_args += ['--password', password]
+
+        return extra_args
+
+    @classmethod
+    def get_remote_url(cls, location):
+        # In cases where the source is in a subdirectory, not alongside
+        # setup.py we have to look up in the location until we find a real
+        # setup.py
+        orig_location = location
+        while not os.path.exists(os.path.join(location, 'setup.py')):
+            last_location = location
+            location = os.path.dirname(location)
+            if location == last_location:
+                # We've traversed up to the root of the filesystem without
+                # finding setup.py
+                logger.warning(
+                    "Could not find setup.py for directory %s (tried all "
+                    "parent directories)",
+                    orig_location,
+                )
+                return None
+
+        return cls._get_svn_url_rev(location)[0]
+
+    @classmethod
+    def _get_svn_url_rev(cls, location):
+        from pip._internal.exceptions import InstallationError
+
+        entries_path = os.path.join(location, cls.dirname, 'entries')
+        if os.path.exists(entries_path):
+            with open(entries_path) as f:
+                data = f.read()
+        else:  # subversion >= 1.7 does not have the 'entries' file
+            data = ''
+
+        if (data.startswith('8') or
+                data.startswith('9') or
+                data.startswith('10')):
+            data = list(map(str.splitlines, data.split('\n\x0c\n')))
+            del data[0][0]  # get rid of the '8'
+            url = data[0][3]
+            revs = [int(d[9]) for d in data if len(d) > 9 and d[9]] + [0]
+        elif data.startswith('<?xml'):
+            match = _svn_xml_url_re.search(data)
+            if not match:
+                raise ValueError('Badly formatted data: %r' % data)
+            url = match.group(1)    # get repository URL
+            revs = [int(m.group(1)) for m in _svn_rev_re.finditer(data)] + [0]
+        else:
+            try:
+                # subversion >= 1.7
+                xml = cls.run_command(
+                    ['info', '--xml', location],
+                    show_stdout=False,
+                )
+                url = _svn_info_xml_url_re.search(xml).group(1)
+                revs = [
+                    int(m.group(1)) for m in _svn_info_xml_rev_re.finditer(xml)
+                ]
+            except InstallationError:
+                url, revs = None, []
+
+        if revs:
+            rev = max(revs)
+        else:
+            rev = 0
+
+        return url, rev
+
+    @classmethod
+    def is_commit_id_equal(cls, dest, name):
+        """Always assume the versions don't match"""
+        return False
+
+
+vcs.register(Subversion)
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/vcs/subversion.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/vcs/subversion.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..246a0b63afef4391f758c79aecbec1e966410628
GIT binary patch
literal 8821
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
IerB-?0FV^s4gdfE

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/wheel.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/wheel.py
new file mode 100644
index 0000000..1bdbe93
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/wheel.py
@@ -0,0 +1,1098 @@
+"""
+Support for installing and building the "wheel" binary package format.
+"""
+from __future__ import absolute_import
+
+import collections
+import compileall
+import csv
+import hashlib
+import logging
+import os.path
+import re
+import shutil
+import stat
+import sys
+import warnings
+from base64 import urlsafe_b64encode
+from email.parser import Parser
+
+from pip._vendor import pkg_resources
+from pip._vendor.distlib.scripts import ScriptMaker
+from pip._vendor.packaging.utils import canonicalize_name
+from pip._vendor.six import StringIO
+
+from pip._internal import pep425tags
+from pip._internal.download import path_to_url, unpack_url
+from pip._internal.exceptions import (
+    InstallationError, InvalidWheelFilename, UnsupportedWheel,
+)
+from pip._internal.locations import (
+    PIP_DELETE_MARKER_FILENAME, distutils_scheme,
+)
+from pip._internal.models.link import Link
+from pip._internal.utils.logging import indent_log
+from pip._internal.utils.misc import (
+    LOG_DIVIDER, call_subprocess, captured_stdout, ensure_dir,
+    format_command_args, read_chunks,
+)
+from pip._internal.utils.setuptools_build import SETUPTOOLS_SHIM
+from pip._internal.utils.temp_dir import TempDirectory
+from pip._internal.utils.typing import MYPY_CHECK_RUNNING
+from pip._internal.utils.ui import open_spinner
+
+if MYPY_CHECK_RUNNING:
+    from typing import (
+        Dict, List, Optional, Sequence, Mapping, Tuple, IO, Text, Any, Iterable
+    )
+    from pip._vendor.packaging.requirements import Requirement
+    from pip._internal.req.req_install import InstallRequirement
+    from pip._internal.download import PipSession
+    from pip._internal.index import FormatControl, PackageFinder
+    from pip._internal.operations.prepare import (
+        RequirementPreparer
+    )
+    from pip._internal.cache import WheelCache
+    from pip._internal.pep425tags import Pep425Tag
+
+    InstalledCSVRow = Tuple[str, ...]
+
+
+VERSION_COMPATIBLE = (1, 0)
+
+
+logger = logging.getLogger(__name__)
+
+
+def normpath(src, p):
+    return os.path.relpath(src, p).replace(os.path.sep, '/')
+
+
+def rehash(path, blocksize=1 << 20):
+    # type: (str, int) -> Tuple[str, str]
+    """Return (hash, length) for path using hashlib.sha256()"""
+    h = hashlib.sha256()
+    length = 0
+    with open(path, 'rb') as f:
+        for block in read_chunks(f, size=blocksize):
+            length += len(block)
+            h.update(block)
+    digest = 'sha256=' + urlsafe_b64encode(
+        h.digest()
+    ).decode('latin1').rstrip('=')
+    # unicode/str python2 issues
+    return (digest, str(length))  # type: ignore
+
+
+def open_for_csv(name, mode):
+    # type: (str, Text) -> IO
+    if sys.version_info[0] < 3:
+        nl = {}  # type: Dict[str, Any]
+        bin = 'b'
+    else:
+        nl = {'newline': ''}  # type: Dict[str, Any]
+        bin = ''
+    return open(name, mode + bin, **nl)
+
+
+def replace_python_tag(wheelname, new_tag):
+    # type: (str, str) -> str
+    """Replace the Python tag in a wheel file name with a new value.
+    """
+    parts = wheelname.split('-')
+    parts[-3] = new_tag
+    return '-'.join(parts)
+
+
+def fix_script(path):
+    # type: (str) -> Optional[bool]
+    """Replace #!python with #!/path/to/python
+    Return True if file was changed."""
+    # XXX RECORD hashes will need to be updated
+    if os.path.isfile(path):
+        with open(path, 'rb') as script:
+            firstline = script.readline()
+            if not firstline.startswith(b'#!python'):
+                return False
+            exename = sys.executable.encode(sys.getfilesystemencoding())
+            firstline = b'#!' + exename + os.linesep.encode("ascii")
+            rest = script.read()
+        with open(path, 'wb') as script:
+            script.write(firstline)
+            script.write(rest)
+        return True
+    return None
+
+
+dist_info_re = re.compile(r"""^(?P<namever>(?P<name>.+?)(-(?P<ver>.+?))?)
+                                \.dist-info$""", re.VERBOSE)
+
+
+def root_is_purelib(name, wheeldir):
+    # type: (str, str) -> bool
+    """
+    Return True if the extracted wheel in wheeldir should go into purelib.
+    """
+    name_folded = name.replace("-", "_")
+    for item in os.listdir(wheeldir):
+        match = dist_info_re.match(item)
+        if match and match.group('name') == name_folded:
+            with open(os.path.join(wheeldir, item, 'WHEEL')) as wheel:
+                for line in wheel:
+                    line = line.lower().rstrip()
+                    if line == "root-is-purelib: true":
+                        return True
+    return False
+
+
+def get_entrypoints(filename):
+    # type: (str) -> Tuple[Dict[str, str], Dict[str, str]]
+    if not os.path.exists(filename):
+        return {}, {}
+
+    # This is done because you can pass a string to entry_points wrappers which
+    # means that they may or may not be valid INI files. The attempt here is to
+    # strip leading and trailing whitespace in order to make them valid INI
+    # files.
+    with open(filename) as fp:
+        data = StringIO()
+        for line in fp:
+            data.write(line.strip())
+            data.write("\n")
+        data.seek(0)
+
+    # get the entry points and then the script names
+    entry_points = pkg_resources.EntryPoint.parse_map(data)
+    console = entry_points.get('console_scripts', {})
+    gui = entry_points.get('gui_scripts', {})
+
+    def _split_ep(s):
+        """get the string representation of EntryPoint, remove space and split
+        on '='"""
+        return str(s).replace(" ", "").split("=")
+
+    # convert the EntryPoint objects into strings with module:function
+    console = dict(_split_ep(v) for v in console.values())
+    gui = dict(_split_ep(v) for v in gui.values())
+    return console, gui
+
+
+def message_about_scripts_not_on_PATH(scripts):
+    # type: (Sequence[str]) -> Optional[str]
+    """Determine if any scripts are not on PATH and format a warning.
+
+    Returns a warning message if one or more scripts are not on PATH,
+    otherwise None.
+    """
+    if not scripts:
+        return None
+
+    # Group scripts by the path they were installed in
+    grouped_by_dir = collections.defaultdict(set)  # type: Dict[str, set]
+    for destfile in scripts:
+        parent_dir = os.path.dirname(destfile)
+        script_name = os.path.basename(destfile)
+        grouped_by_dir[parent_dir].add(script_name)
+
+    # We don't want to warn for directories that are on PATH.
+    not_warn_dirs = [
+        os.path.normcase(i).rstrip(os.sep) for i in
+        os.environ.get("PATH", "").split(os.pathsep)
+    ]
+    # If an executable sits with sys.executable, we don't warn for it.
+    #     This covers the case of venv invocations without activating the venv.
+    not_warn_dirs.append(os.path.normcase(os.path.dirname(sys.executable)))
+    warn_for = {
+        parent_dir: scripts for parent_dir, scripts in grouped_by_dir.items()
+        if os.path.normcase(parent_dir) not in not_warn_dirs
+    }
+    if not warn_for:
+        return None
+
+    # Format a message
+    msg_lines = []
+    for parent_dir, scripts in warn_for.items():
+        sorted_scripts = sorted(scripts)  # type: List[str]
+        if len(sorted_scripts) == 1:
+            start_text = "script {} is".format(sorted_scripts[0])
+        else:
+            start_text = "scripts {} are".format(
+                ", ".join(sorted_scripts[:-1]) + " and " + sorted_scripts[-1]
+            )
+
+        msg_lines.append(
+            "The {} installed in '{}' which is not on PATH."
+            .format(start_text, parent_dir)
+        )
+
+    last_line_fmt = (
+        "Consider adding {} to PATH or, if you prefer "
+        "to suppress this warning, use --no-warn-script-location."
+    )
+    if len(msg_lines) == 1:
+        msg_lines.append(last_line_fmt.format("this directory"))
+    else:
+        msg_lines.append(last_line_fmt.format("these directories"))
+
+    # Returns the formatted multiline message
+    return "\n".join(msg_lines)
+
+
+def sorted_outrows(outrows):
+    # type: (Iterable[InstalledCSVRow]) -> List[InstalledCSVRow]
+    """
+    Return the given rows of a RECORD file in sorted order.
+
+    Each row is a 3-tuple (path, hash, size) and corresponds to a record of
+    a RECORD file (see PEP 376 and PEP 427 for details).  For the rows
+    passed to this function, the size can be an integer as an int or string,
+    or the empty string.
+    """
+    # Normally, there should only be one row per path, in which case the
+    # second and third elements don't come into play when sorting.
+    # However, in cases in the wild where a path might happen to occur twice,
+    # we don't want the sort operation to trigger an error (but still want
+    # determinism).  Since the third element can be an int or string, we
+    # coerce each element to a string to avoid a TypeError in this case.
+    # For additional background, see--
+    # https://github.com/pypa/pip/issues/5868
+    return sorted(outrows, key=lambda row: tuple(str(x) for x in row))
+
+
+def get_csv_rows_for_installed(
+    old_csv_rows,  # type: Iterable[List[str]]
+    installed,  # type: Dict[str, str]
+    changed,  # type: set
+    generated,  # type: List[str]
+    lib_dir,  # type: str
+):
+    # type: (...) -> List[InstalledCSVRow]
+    """
+    :param installed: A map from archive RECORD path to installation RECORD
+        path.
+    """
+    installed_rows = []  # type: List[InstalledCSVRow]
+    for row in old_csv_rows:
+        if len(row) > 3:
+            logger.warning(
+                'RECORD line has more than three elements: {}'.format(row)
+            )
+        # Make a copy because we are mutating the row.
+        row = list(row)
+        old_path = row[0]
+        new_path = installed.pop(old_path, old_path)
+        row[0] = new_path
+        if new_path in changed:
+            digest, length = rehash(new_path)
+            row[1] = digest
+            row[2] = length
+        installed_rows.append(tuple(row))
+    for f in generated:
+        digest, length = rehash(f)
+        installed_rows.append((normpath(f, lib_dir), digest, str(length)))
+    for f in installed:
+        installed_rows.append((installed[f], '', ''))
+    return installed_rows
+
+
+def move_wheel_files(
+    name,  # type: str
+    req,  # type: Requirement
+    wheeldir,  # type: str
+    user=False,  # type: bool
+    home=None,  # type: Optional[str]
+    root=None,  # type: Optional[str]
+    pycompile=True,  # type: bool
+    scheme=None,  # type: Optional[Mapping[str, str]]
+    isolated=False,  # type: bool
+    prefix=None,  # type: Optional[str]
+    warn_script_location=True  # type: bool
+):
+    # type: (...) -> None
+    """Install a wheel"""
+    # TODO: Investigate and break this up.
+    # TODO: Look into moving this into a dedicated class for representing an
+    #       installation.
+
+    if not scheme:
+        scheme = distutils_scheme(
+            name, user=user, home=home, root=root, isolated=isolated,
+            prefix=prefix,
+        )
+
+    if root_is_purelib(name, wheeldir):
+        lib_dir = scheme['purelib']
+    else:
+        lib_dir = scheme['platlib']
+
+    info_dir = []  # type: List[str]
+    data_dirs = []
+    source = wheeldir.rstrip(os.path.sep) + os.path.sep
+
+    # Record details of the files moved
+    #   installed = files copied from the wheel to the destination
+    #   changed = files changed while installing (scripts #! line typically)
+    #   generated = files newly generated during the install (script wrappers)
+    installed = {}  # type: Dict[str, str]
+    changed = set()
+    generated = []  # type: List[str]
+
+    # Compile all of the pyc files that we're going to be installing
+    if pycompile:
+        with captured_stdout() as stdout:
+            with warnings.catch_warnings():
+                warnings.filterwarnings('ignore')
+                compileall.compile_dir(source, force=True, quiet=True)
+        logger.debug(stdout.getvalue())
+
+    def record_installed(srcfile, destfile, modified=False):
+        """Map archive RECORD paths to installation RECORD paths."""
+        oldpath = normpath(srcfile, wheeldir)
+        newpath = normpath(destfile, lib_dir)
+        installed[oldpath] = newpath
+        if modified:
+            changed.add(destfile)
+
+    def clobber(source, dest, is_base, fixer=None, filter=None):
+        ensure_dir(dest)  # common for the 'include' path
+
+        for dir, subdirs, files in os.walk(source):
+            basedir = dir[len(source):].lstrip(os.path.sep)
+            destdir = os.path.join(dest, basedir)
+            if is_base and basedir.split(os.path.sep, 1)[0].endswith('.data'):
+                continue
+            for s in subdirs:
+                destsubdir = os.path.join(dest, basedir, s)
+                if is_base and basedir == '' and destsubdir.endswith('.data'):
+                    data_dirs.append(s)
+                    continue
+                elif (is_base and
+                        s.endswith('.dist-info') and
+                        canonicalize_name(s).startswith(
+                            canonicalize_name(req.name))):
+                    assert not info_dir, ('Multiple .dist-info directories: ' +
+                                          destsubdir + ', ' +
+                                          ', '.join(info_dir))
+                    info_dir.append(destsubdir)
+            for f in files:
+                # Skip unwanted files
+                if filter and filter(f):
+                    continue
+                srcfile = os.path.join(dir, f)
+                destfile = os.path.join(dest, basedir, f)
+                # directory creation is lazy and after the file filtering above
+                # to ensure we don't install empty dirs; empty dirs can't be
+                # uninstalled.
+                ensure_dir(destdir)
+
+                # copyfile (called below) truncates the destination if it
+                # exists and then writes the new contents. This is fine in most
+                # cases, but can cause a segfault if pip has loaded a shared
+                # object (e.g. from pyopenssl through its vendored urllib3)
+                # Since the shared object is mmap'd an attempt to call a
+                # symbol in it will then cause a segfault. Unlinking the file
+                # allows writing of new contents while allowing the process to
+                # continue to use the old copy.
+                if os.path.exists(destfile):
+                    os.unlink(destfile)
+
+                # We use copyfile (not move, copy, or copy2) to be extra sure
+                # that we are not moving directories over (copyfile fails for
+                # directories) as well as to ensure that we are not copying
+                # over any metadata because we want more control over what
+                # metadata we actually copy over.
+                shutil.copyfile(srcfile, destfile)
+
+                # Copy over the metadata for the file, currently this only
+                # includes the atime and mtime.
+                st = os.stat(srcfile)
+                if hasattr(os, "utime"):
+                    os.utime(destfile, (st.st_atime, st.st_mtime))
+
+                # If our file is executable, then make our destination file
+                # executable.
+                if os.access(srcfile, os.X_OK):
+                    st = os.stat(srcfile)
+                    permissions = (
+                        st.st_mode | stat.S_IXUSR | stat.S_IXGRP | stat.S_IXOTH
+                    )
+                    os.chmod(destfile, permissions)
+
+                changed = False
+                if fixer:
+                    changed = fixer(destfile)
+                record_installed(srcfile, destfile, changed)
+
+    clobber(source, lib_dir, True)
+
+    assert info_dir, "%s .dist-info directory not found" % req
+
+    # Get the defined entry points
+    ep_file = os.path.join(info_dir[0], 'entry_points.txt')
+    console, gui = get_entrypoints(ep_file)
+
+    def is_entrypoint_wrapper(name):
+        # EP, EP.exe and EP-script.py are scripts generated for
+        # entry point EP by setuptools
+        if name.lower().endswith('.exe'):
+            matchname = name[:-4]
+        elif name.lower().endswith('-script.py'):
+            matchname = name[:-10]
+        elif name.lower().endswith(".pya"):
+            matchname = name[:-4]
+        else:
+            matchname = name
+        # Ignore setuptools-generated scripts
+        return (matchname in console or matchname in gui)
+
+    for datadir in data_dirs:
+        fixer = None
+        filter = None
+        for subdir in os.listdir(os.path.join(wheeldir, datadir)):
+            fixer = None
+            if subdir == 'scripts':
+                fixer = fix_script
+                filter = is_entrypoint_wrapper
+            source = os.path.join(wheeldir, datadir, subdir)
+            dest = scheme[subdir]
+            clobber(source, dest, False, fixer=fixer, filter=filter)
+
+    maker = ScriptMaker(None, scheme['scripts'])
+
+    # Ensure old scripts are overwritten.
+    # See https://github.com/pypa/pip/issues/1800
+    maker.clobber = True
+
+    # Ensure we don't generate any variants for scripts because this is almost
+    # never what somebody wants.
+    # See https://bitbucket.org/pypa/distlib/issue/35/
+    maker.variants = {''}
+
+    # This is required because otherwise distlib creates scripts that are not
+    # executable.
+    # See https://bitbucket.org/pypa/distlib/issue/32/
+    maker.set_mode = True
+
+    # Simplify the script and fix the fact that the default script swallows
+    # every single stack trace.
+    # See https://bitbucket.org/pypa/distlib/issue/34/
+    # See https://bitbucket.org/pypa/distlib/issue/33/
+    def _get_script_text(entry):
+        if entry.suffix is None:
+            raise InstallationError(
+                "Invalid script entry point: %s for req: %s - A callable "
+                "suffix is required. Cf https://packaging.python.org/en/"
+                "latest/distributing.html#console-scripts for more "
+                "information." % (entry, req)
+            )
+        return maker.script_template % {
+            "module": entry.prefix,
+            "import_name": entry.suffix.split(".")[0],
+            "func": entry.suffix,
+        }
+    # ignore type, because mypy disallows assigning to a method,
+    # see https://github.com/python/mypy/issues/2427
+    maker._get_script_text = _get_script_text  # type: ignore
+    maker.script_template = r"""# -*- coding: utf-8 -*-
+import re
+import sys
+
+from %(module)s import %(import_name)s
+
+if __name__ == '__main__':
+    sys.argv[0] = re.sub(r'(-script\.pyw?|\.exe)?$', '', sys.argv[0])
+    sys.exit(%(func)s())
+"""
+
+    # Special case pip and setuptools to generate versioned wrappers
+    #
+    # The issue is that some projects (specifically, pip and setuptools) use
+    # code in setup.py to create "versioned" entry points - pip2.7 on Python
+    # 2.7, pip3.3 on Python 3.3, etc. But these entry points are baked into
+    # the wheel metadata at build time, and so if the wheel is installed with
+    # a *different* version of Python the entry points will be wrong. The
+    # correct fix for this is to enhance the metadata to be able to describe
+    # such versioned entry points, but that won't happen till Metadata 2.0 is
+    # available.
+    # In the meantime, projects using versioned entry points will either have
+    # incorrect versioned entry points, or they will not be able to distribute
+    # "universal" wheels (i.e., they will need a wheel per Python version).
+    #
+    # Because setuptools and pip are bundled with _ensurepip and virtualenv,
+    # we need to use universal wheels. So, as a stopgap until Metadata 2.0, we
+    # override the versioned entry points in the wheel and generate the
+    # correct ones. This code is purely a short-term measure until Metadata 2.0
+    # is available.
+    #
+    # To add the level of hack in this section of code, in order to support
+    # ensurepip this code will look for an ``ENSUREPIP_OPTIONS`` environment
+    # variable which will control which version scripts get installed.
+    #
+    # ENSUREPIP_OPTIONS=altinstall
+    #   - Only pipX.Y and easy_install-X.Y will be generated and installed
+    # ENSUREPIP_OPTIONS=install
+    #   - pipX.Y, pipX, easy_install-X.Y will be generated and installed. Note
+    #     that this option is technically if ENSUREPIP_OPTIONS is set and is
+    #     not altinstall
+    # DEFAULT
+    #   - The default behavior is to install pip, pipX, pipX.Y, easy_install
+    #     and easy_install-X.Y.
+    pip_script = console.pop('pip', None)
+    if pip_script:
+        if "ENSUREPIP_OPTIONS" not in os.environ:
+            spec = 'pip = ' + pip_script
+            generated.extend(maker.make(spec))
+
+        if os.environ.get("ENSUREPIP_OPTIONS", "") != "altinstall":
+            spec = 'pip%s = %s' % (sys.version[:1], pip_script)
+            generated.extend(maker.make(spec))
+
+        spec = 'pip%s = %s' % (sys.version[:3], pip_script)
+        generated.extend(maker.make(spec))
+        # Delete any other versioned pip entry points
+        pip_ep = [k for k in console if re.match(r'pip(\d(\.\d)?)?$', k)]
+        for k in pip_ep:
+            del console[k]
+    easy_install_script = console.pop('easy_install', None)
+    if easy_install_script:
+        if "ENSUREPIP_OPTIONS" not in os.environ:
+            spec = 'easy_install = ' + easy_install_script
+            generated.extend(maker.make(spec))
+
+        spec = 'easy_install-%s = %s' % (sys.version[:3], easy_install_script)
+        generated.extend(maker.make(spec))
+        # Delete any other versioned easy_install entry points
+        easy_install_ep = [
+            k for k in console if re.match(r'easy_install(-\d\.\d)?$', k)
+        ]
+        for k in easy_install_ep:
+            del console[k]
+
+    # Generate the console and GUI entry points specified in the wheel
+    if len(console) > 0:
+        generated_console_scripts = maker.make_multiple(
+            ['%s = %s' % kv for kv in console.items()]
+        )
+        generated.extend(generated_console_scripts)
+
+        if warn_script_location:
+            msg = message_about_scripts_not_on_PATH(generated_console_scripts)
+            if msg is not None:
+                logger.warning(msg)
+
+    if len(gui) > 0:
+        generated.extend(
+            maker.make_multiple(
+                ['%s = %s' % kv for kv in gui.items()],
+                {'gui': True}
+            )
+        )
+
+    # Record pip as the installer
+    installer = os.path.join(info_dir[0], 'INSTALLER')
+    temp_installer = os.path.join(info_dir[0], 'INSTALLER.pip')
+    with open(temp_installer, 'wb') as installer_file:
+        installer_file.write(b'pip\n')
+    shutil.move(temp_installer, installer)
+    generated.append(installer)
+
+    # Record details of all files installed
+    record = os.path.join(info_dir[0], 'RECORD')
+    temp_record = os.path.join(info_dir[0], 'RECORD.pip')
+    with open_for_csv(record, 'r') as record_in:
+        with open_for_csv(temp_record, 'w+') as record_out:
+            reader = csv.reader(record_in)
+            outrows = get_csv_rows_for_installed(
+                reader, installed=installed, changed=changed,
+                generated=generated, lib_dir=lib_dir,
+            )
+            writer = csv.writer(record_out)
+            # Sort to simplify testing.
+            for row in sorted_outrows(outrows):
+                writer.writerow(row)
+    shutil.move(temp_record, record)
+
+
+def wheel_version(source_dir):
+    # type: (Optional[str]) -> Optional[Tuple[int, ...]]
+    """
+    Return the Wheel-Version of an extracted wheel, if possible.
+
+    Otherwise, return None if we couldn't parse / extract it.
+    """
+    try:
+        dist = [d for d in pkg_resources.find_on_path(None, source_dir)][0]
+
+        wheel_data = dist.get_metadata('WHEEL')
+        wheel_data = Parser().parsestr(wheel_data)
+
+        version = wheel_data['Wheel-Version'].strip()
+        version = tuple(map(int, version.split('.')))
+        return version
+    except Exception:
+        return None
+
+
+def check_compatibility(version, name):
+    # type: (Optional[Tuple[int, ...]], str) -> None
+    """
+    Raises errors or warns if called with an incompatible Wheel-Version.
+
+    Pip should refuse to install a Wheel-Version that's a major series
+    ahead of what it's compatible with (e.g 2.0 > 1.1); and warn when
+    installing a version only minor version ahead (e.g 1.2 > 1.1).
+
+    version: a 2-tuple representing a Wheel-Version (Major, Minor)
+    name: name of wheel or package to raise exception about
+
+    :raises UnsupportedWheel: when an incompatible Wheel-Version is given
+    """
+    if not version:
+        raise UnsupportedWheel(
+            "%s is in an unsupported or invalid wheel" % name
+        )
+    if version[0] > VERSION_COMPATIBLE[0]:
+        raise UnsupportedWheel(
+            "%s's Wheel-Version (%s) is not compatible with this version "
+            "of pip" % (name, '.'.join(map(str, version)))
+        )
+    elif version > VERSION_COMPATIBLE:
+        logger.warning(
+            'Installing from a newer Wheel-Version (%s)',
+            '.'.join(map(str, version)),
+        )
+
+
+class Wheel(object):
+    """A wheel file"""
+
+    # TODO: Maybe move the class into the models sub-package
+    # TODO: Maybe move the install code into this class
+
+    wheel_file_re = re.compile(
+        r"""^(?P<namever>(?P<name>.+?)-(?P<ver>.*?))
+        ((-(?P<build>\d[^-]*?))?-(?P<pyver>.+?)-(?P<abi>.+?)-(?P<plat>.+?)
+        \.whl|\.dist-info)$""",
+        re.VERBOSE
+    )
+
+    def __init__(self, filename):
+        # type: (str) -> None
+        """
+        :raises InvalidWheelFilename: when the filename is invalid for a wheel
+        """
+        wheel_info = self.wheel_file_re.match(filename)
+        if not wheel_info:
+            raise InvalidWheelFilename(
+                "%s is not a valid wheel filename." % filename
+            )
+        self.filename = filename
+        self.name = wheel_info.group('name').replace('_', '-')
+        # we'll assume "_" means "-" due to wheel naming scheme
+        # (https://github.com/pypa/pip/issues/1150)
+        self.version = wheel_info.group('ver').replace('_', '-')
+        self.build_tag = wheel_info.group('build')
+        self.pyversions = wheel_info.group('pyver').split('.')
+        self.abis = wheel_info.group('abi').split('.')
+        self.plats = wheel_info.group('plat').split('.')
+
+        # All the tag combinations from this file
+        self.file_tags = {
+            (x, y, z) for x in self.pyversions
+            for y in self.abis for z in self.plats
+        }
+
+    def support_index_min(self, tags=None):
+        # type: (Optional[List[Pep425Tag]]) -> Optional[int]
+        """
+        Return the lowest index that one of the wheel's file_tag combinations
+        achieves in the supported_tags list e.g. if there are 8 supported tags,
+        and one of the file tags is first in the list, then return 0.  Returns
+        None is the wheel is not supported.
+        """
+        if tags is None:  # for mock
+            tags = pep425tags.get_supported()
+        indexes = [tags.index(c) for c in self.file_tags if c in tags]
+        return min(indexes) if indexes else None
+
+    def supported(self, tags=None):
+        # type: (Optional[List[Pep425Tag]]) -> bool
+        """Is this wheel supported on this system?"""
+        if tags is None:  # for mock
+            tags = pep425tags.get_supported()
+        return bool(set(tags).intersection(self.file_tags))
+
+
+def _contains_egg_info(
+        s, _egg_info_re=re.compile(r'([a-z0-9_.]+)-([a-z0-9_.!+-]+)', re.I)):
+    """Determine whether the string looks like an egg_info.
+
+    :param s: The string to parse. E.g. foo-2.1
+    """
+    return bool(_egg_info_re.search(s))
+
+
+def should_use_ephemeral_cache(
+    req,  # type: InstallRequirement
+    format_control,  # type: FormatControl
+    autobuilding,  # type: bool
+    cache_available  # type: bool
+):
+    # type: (...) -> Optional[bool]
+    """
+    Return whether to build an InstallRequirement object using the
+    ephemeral cache.
+
+    :param cache_available: whether a cache directory is available for the
+        autobuilding=True case.
+
+    :return: True or False to build the requirement with ephem_cache=True
+        or False, respectively; or None not to build the requirement.
+    """
+    if req.constraint:
+        return None
+    if req.is_wheel:
+        if not autobuilding:
+            logger.info(
+                'Skipping %s, due to already being wheel.', req.name,
+            )
+        return None
+    if not autobuilding:
+        return False
+
+    if req.editable or not req.source_dir:
+        return None
+
+    if req.link and not req.link.is_artifact:
+        # VCS checkout. Build wheel just for this run.
+        return True
+
+    if "binary" not in format_control.get_allowed_formats(
+            canonicalize_name(req.name)):
+        logger.info(
+            "Skipping bdist_wheel for %s, due to binaries "
+            "being disabled for it.", req.name,
+        )
+        return None
+
+    link = req.link
+    base, ext = link.splitext()
+    if cache_available and _contains_egg_info(base):
+        return False
+
+    # Otherwise, build the wheel just for this run using the ephemeral
+    # cache since we are either in the case of e.g. a local directory, or
+    # no cache directory is available to use.
+    return True
+
+
+def format_command_result(
+    command_args,  # type: List[str]
+    command_output,  # type: str
+):
+    # type: (...) -> str
+    """
+    Format command information for logging.
+    """
+    command_desc = format_command_args(command_args)
+    text = 'Command arguments: {}\n'.format(command_desc)
+
+    if not command_output:
+        text += 'Command output: None'
+    elif logger.getEffectiveLevel() > logging.DEBUG:
+        text += 'Command output: [use --verbose to show]'
+    else:
+        if not command_output.endswith('\n'):
+            command_output += '\n'
+        text += 'Command output:\n{}{}'.format(command_output, LOG_DIVIDER)
+
+    return text
+
+
+def get_legacy_build_wheel_path(
+    names,  # type: List[str]
+    temp_dir,  # type: str
+    req,  # type: InstallRequirement
+    command_args,  # type: List[str]
+    command_output,  # type: str
+):
+    # type: (...) -> Optional[str]
+    """
+    Return the path to the wheel in the temporary build directory.
+    """
+    # Sort for determinism.
+    names = sorted(names)
+    if not names:
+        msg = (
+            'Legacy build of wheel for {!r} created no files.\n'
+        ).format(req.name)
+        msg += format_command_result(command_args, command_output)
+        logger.warning(msg)
+        return None
+
+    if len(names) > 1:
+        msg = (
+            'Legacy build of wheel for {!r} created more than one file.\n'
+            'Filenames (choosing first): {}\n'
+        ).format(req.name, names)
+        msg += format_command_result(command_args, command_output)
+        logger.warning(msg)
+
+    return os.path.join(temp_dir, names[0])
+
+
+class WheelBuilder(object):
+    """Build wheels from a RequirementSet."""
+
+    def __init__(
+        self,
+        finder,  # type: PackageFinder
+        preparer,  # type: RequirementPreparer
+        wheel_cache,  # type: WheelCache
+        build_options=None,  # type: Optional[List[str]]
+        global_options=None,  # type: Optional[List[str]]
+        no_clean=False  # type: bool
+    ):
+        # type: (...) -> None
+        self.finder = finder
+        self.preparer = preparer
+        self.wheel_cache = wheel_cache
+
+        self._wheel_dir = preparer.wheel_download_dir
+
+        self.build_options = build_options or []
+        self.global_options = global_options or []
+        self.no_clean = no_clean
+
+    def _build_one(self, req, output_dir, python_tag=None):
+        """Build one wheel.
+
+        :return: The filename of the built wheel, or None if the build failed.
+        """
+        # Install build deps into temporary directory (PEP 518)
+        with req.build_env:
+            return self._build_one_inside_env(req, output_dir,
+                                              python_tag=python_tag)
+
+    def _build_one_inside_env(self, req, output_dir, python_tag=None):
+        with TempDirectory(kind="wheel") as temp_dir:
+            if req.use_pep517:
+                builder = self._build_one_pep517
+            else:
+                builder = self._build_one_legacy
+            wheel_path = builder(req, temp_dir.path, python_tag=python_tag)
+            if wheel_path is not None:
+                wheel_name = os.path.basename(wheel_path)
+                dest_path = os.path.join(output_dir, wheel_name)
+                try:
+                    shutil.move(wheel_path, dest_path)
+                    logger.info('Stored in directory: %s', output_dir)
+                    return dest_path
+                except Exception:
+                    pass
+            # Ignore return, we can't do anything else useful.
+            self._clean_one(req)
+            return None
+
+    def _base_setup_args(self, req):
+        # NOTE: Eventually, we'd want to also -S to the flags here, when we're
+        # isolating. Currently, it breaks Python in virtualenvs, because it
+        # relies on site.py to find parts of the standard library outside the
+        # virtualenv.
+        return [
+            sys.executable, '-u', '-c',
+            SETUPTOOLS_SHIM % req.setup_py
+        ] + list(self.global_options)
+
+    def _build_one_pep517(self, req, tempd, python_tag=None):
+        """Build one InstallRequirement using the PEP 517 build process.
+
+        Returns path to wheel if successfully built. Otherwise, returns None.
+        """
+        assert req.metadata_directory is not None
+        if self.build_options:
+            # PEP 517 does not support --build-options
+            logger.error('Cannot build wheel for %s using PEP 517 when '
+                         '--build-options is present' % (req.name,))
+            return None
+        try:
+            req.spin_message = 'Building wheel for %s (PEP 517)' % (req.name,)
+            logger.debug('Destination directory: %s', tempd)
+            wheel_name = req.pep517_backend.build_wheel(
+                tempd,
+                metadata_directory=req.metadata_directory
+            )
+            if python_tag:
+                # General PEP 517 backends don't necessarily support
+                # a "--python-tag" option, so we rename the wheel
+                # file directly.
+                new_name = replace_python_tag(wheel_name, python_tag)
+                os.rename(
+                    os.path.join(tempd, wheel_name),
+                    os.path.join(tempd, new_name)
+                )
+                # Reassign to simplify the return at the end of function
+                wheel_name = new_name
+        except Exception:
+            logger.error('Failed building wheel for %s', req.name)
+            return None
+        return os.path.join(tempd, wheel_name)
+
+    def _build_one_legacy(self, req, tempd, python_tag=None):
+        """Build one InstallRequirement using the "legacy" build process.
+
+        Returns path to wheel if successfully built. Otherwise, returns None.
+        """
+        base_args = self._base_setup_args(req)
+
+        spin_message = 'Building wheel for %s (setup.py)' % (req.name,)
+        with open_spinner(spin_message) as spinner:
+            logger.debug('Destination directory: %s', tempd)
+            wheel_args = base_args + ['bdist_wheel', '-d', tempd] \
+                + self.build_options
+
+            if python_tag is not None:
+                wheel_args += ["--python-tag", python_tag]
+
+            try:
+                output = call_subprocess(wheel_args, cwd=req.setup_py_dir,
+                                         spinner=spinner)
+            except Exception:
+                spinner.finish("error")
+                logger.error('Failed building wheel for %s', req.name)
+                return None
+            names = os.listdir(tempd)
+            wheel_path = get_legacy_build_wheel_path(
+                names=names,
+                temp_dir=tempd,
+                req=req,
+                command_args=wheel_args,
+                command_output=output,
+            )
+            return wheel_path
+
+    def _clean_one(self, req):
+        base_args = self._base_setup_args(req)
+
+        logger.info('Running setup.py clean for %s', req.name)
+        clean_args = base_args + ['clean', '--all']
+        try:
+            call_subprocess(clean_args, cwd=req.source_dir)
+            return True
+        except Exception:
+            logger.error('Failed cleaning build dir for %s', req.name)
+            return False
+
+    def build(
+        self,
+        requirements,  # type: Iterable[InstallRequirement]
+        session,  # type: PipSession
+        autobuilding=False  # type: bool
+    ):
+        # type: (...) -> List[InstallRequirement]
+        """Build wheels.
+
+        :param unpack: If True, replace the sdist we built from with the
+            newly built wheel, in preparation for installation.
+        :return: True if all the wheels built correctly.
+        """
+        buildset = []
+        format_control = self.finder.format_control
+        # Whether a cache directory is available for autobuilding=True.
+        cache_available = bool(self._wheel_dir or self.wheel_cache.cache_dir)
+
+        for req in requirements:
+            ephem_cache = should_use_ephemeral_cache(
+                req, format_control=format_control, autobuilding=autobuilding,
+                cache_available=cache_available,
+            )
+            if ephem_cache is None:
+                continue
+
+            buildset.append((req, ephem_cache))
+
+        if not buildset:
+            return []
+
+        # Is any wheel build not using the ephemeral cache?
+        if any(not ephem_cache for _, ephem_cache in buildset):
+            have_directory_for_build = self._wheel_dir or (
+                autobuilding and self.wheel_cache.cache_dir
+            )
+            assert have_directory_for_build
+
+        # TODO by @pradyunsg
+        # Should break up this method into 2 separate methods.
+
+        # Build the wheels.
+        logger.info(
+            'Building wheels for collected packages: %s',
+            ', '.join([req.name for (req, _) in buildset]),
+        )
+        _cache = self.wheel_cache  # shorter name
+        with indent_log():
+            build_success, build_failure = [], []
+            for req, ephem in buildset:
+                python_tag = None
+                if autobuilding:
+                    python_tag = pep425tags.implementation_tag
+                    if ephem:
+                        output_dir = _cache.get_ephem_path_for_link(req.link)
+                    else:
+                        output_dir = _cache.get_path_for_link(req.link)
+                    try:
+                        ensure_dir(output_dir)
+                    except OSError as e:
+                        logger.warning("Building wheel for %s failed: %s",
+                                       req.name, e)
+                        build_failure.append(req)
+                        continue
+                else:
+                    output_dir = self._wheel_dir
+                wheel_file = self._build_one(
+                    req, output_dir,
+                    python_tag=python_tag,
+                )
+                if wheel_file:
+                    build_success.append(req)
+                    if autobuilding:
+                        # XXX: This is mildly duplicative with prepare_files,
+                        # but not close enough to pull out to a single common
+                        # method.
+                        # The code below assumes temporary source dirs -
+                        # prevent it doing bad things.
+                        if req.source_dir and not os.path.exists(os.path.join(
+                                req.source_dir, PIP_DELETE_MARKER_FILENAME)):
+                            raise AssertionError(
+                                "bad source dir - missing marker")
+                        # Delete the source we built the wheel from
+                        req.remove_temporary_source()
+                        # set the build directory again - name is known from
+                        # the work prepare_files did.
+                        req.source_dir = req.build_location(
+                            self.preparer.build_dir
+                        )
+                        # Update the link for this.
+                        req.link = Link(path_to_url(wheel_file))
+                        assert req.link.is_wheel
+                        # extract the wheel into the dir
+                        unpack_url(
+                            req.link, req.source_dir, None, False,
+                            session=session,
+                        )
+                else:
+                    build_failure.append(req)
+
+        # notify success/failure
+        if build_success:
+            logger.info(
+                'Successfully built %s',
+                ' '.join([req.name for req in build_success]),
+            )
+        if build_failure:
+            logger.info(
+                'Failed to build %s',
+                ' '.join([req.name for req in build_failure]),
+            )
+        # Return a list of requirements that failed to build
+        return build_failure
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/wheel.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_internal/wheel.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..4328374c535991f2571774a788312de1a2e8cf26
GIT binary patch
literal 32820
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
TaEfrsiP=hXaGG(7b1DD;&NTDv

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/__init__.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/__init__.py
new file mode 100644
index 0000000..c1d9508
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/__init__.py
@@ -0,0 +1,109 @@
+"""
+pip._vendor is for vendoring dependencies of pip to prevent needing pip to
+depend on something external.
+
+Files inside of pip._vendor should be considered immutable and should only be
+updated to versions from upstream.
+"""
+from __future__ import absolute_import
+
+import glob
+import os.path
+import sys
+
+# Downstream redistributors which have debundled our dependencies should also
+# patch this value to be true. This will trigger the additional patching
+# to cause things like "six" to be available as pip.
+DEBUNDLED = False
+
+# By default, look in this directory for a bunch of .whl files which we will
+# add to the beginning of sys.path before attempting to import anything. This
+# is done to support downstream re-distributors like Debian and Fedora who
+# wish to create their own Wheels for our dependencies to aid in debundling.
+WHEEL_DIR = os.path.abspath(os.path.dirname(__file__))
+
+
+# Define a small helper function to alias our vendored modules to the real ones
+# if the vendored ones do not exist. This idea of this was taken from
+# https://github.com/kennethreitz/requests/pull/2567.
+def vendored(modulename):
+    vendored_name = "{0}.{1}".format(__name__, modulename)
+
+    try:
+        __import__(modulename, globals(), locals(), level=0)
+    except ImportError:
+        # We can just silently allow import failures to pass here. If we
+        # got to this point it means that ``import pip._vendor.whatever``
+        # failed and so did ``import whatever``. Since we're importing this
+        # upfront in an attempt to alias imports, not erroring here will
+        # just mean we get a regular import error whenever pip *actually*
+        # tries to import one of these modules to use it, which actually
+        # gives us a better error message than we would have otherwise
+        # gotten.
+        pass
+    else:
+        sys.modules[vendored_name] = sys.modules[modulename]
+        base, head = vendored_name.rsplit(".", 1)
+        setattr(sys.modules[base], head, sys.modules[modulename])
+
+
+# If we're operating in a debundled setup, then we want to go ahead and trigger
+# the aliasing of our vendored libraries as well as looking for wheels to add
+# to our sys.path. This will cause all of this code to be a no-op typically
+# however downstream redistributors can enable it in a consistent way across
+# all platforms.
+if DEBUNDLED:
+    # Actually look inside of WHEEL_DIR to find .whl files and add them to the
+    # front of our sys.path.
+    sys.path[:] = glob.glob(os.path.join(WHEEL_DIR, "*.whl")) + sys.path
+
+    # Actually alias all of our vendored dependencies.
+    vendored("cachecontrol")
+    vendored("colorama")
+    vendored("distlib")
+    vendored("distro")
+    vendored("html5lib")
+    vendored("lockfile")
+    vendored("six")
+    vendored("six.moves")
+    vendored("six.moves.urllib")
+    vendored("six.moves.urllib.parse")
+    vendored("packaging")
+    vendored("packaging.version")
+    vendored("packaging.specifiers")
+    vendored("pep517")
+    vendored("pkg_resources")
+    vendored("progress")
+    vendored("pytoml")
+    vendored("retrying")
+    vendored("requests")
+    vendored("requests.exceptions")
+    vendored("requests.packages")
+    vendored("requests.packages.urllib3")
+    vendored("requests.packages.urllib3._collections")
+    vendored("requests.packages.urllib3.connection")
+    vendored("requests.packages.urllib3.connectionpool")
+    vendored("requests.packages.urllib3.contrib")
+    vendored("requests.packages.urllib3.contrib.ntlmpool")
+    vendored("requests.packages.urllib3.contrib.pyopenssl")
+    vendored("requests.packages.urllib3.exceptions")
+    vendored("requests.packages.urllib3.fields")
+    vendored("requests.packages.urllib3.filepost")
+    vendored("requests.packages.urllib3.packages")
+    vendored("requests.packages.urllib3.packages.ordered_dict")
+    vendored("requests.packages.urllib3.packages.six")
+    vendored("requests.packages.urllib3.packages.ssl_match_hostname")
+    vendored("requests.packages.urllib3.packages.ssl_match_hostname."
+             "_implementation")
+    vendored("requests.packages.urllib3.poolmanager")
+    vendored("requests.packages.urllib3.request")
+    vendored("requests.packages.urllib3.response")
+    vendored("requests.packages.urllib3.util")
+    vendored("requests.packages.urllib3.util.connection")
+    vendored("requests.packages.urllib3.util.request")
+    vendored("requests.packages.urllib3.util.response")
+    vendored("requests.packages.urllib3.util.retry")
+    vendored("requests.packages.urllib3.util.ssl_")
+    vendored("requests.packages.urllib3.util.timeout")
+    vendored("requests.packages.urllib3.util.url")
+    vendored("urllib3")
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/__init__.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/__init__.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..9a90c772266effb98c4ba72d32facb210031e074
GIT binary patch
literal 3389
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

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/appdirs.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/appdirs.py
new file mode 100644
index 0000000..2bd3911
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/appdirs.py
@@ -0,0 +1,604 @@
+#!/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_info__ = (1, 4, 3)
+__version__ = '.'.join(map(str, __version_info__))
+
+
+import sys
+import os
+
+PY3 = sys.version_info[0] == 3
+
+if PY3:
+    unicode = str
+
+if sys.platform.startswith('java'):
+    import platform
+    os_name = platform.java_ver()[3][0]
+    if os_name.startswith('Windows'): # "Windows XP", "Windows 7", etc.
+        system = 'win32'
+    elif os_name.startswith('Mac'): # "Mac OS X", etc.
+        system = 'darwin'
+    else: # "Linux", "SunOS", "FreeBSD", etc.
+        # Setting this to "linux2" is not ideal, but only Windows or Mac
+        # are actually checked for and the rest of the module expects
+        # *sys.platform* style strings.
+        system = 'linux2'
+else:
+    system = sys.platform
+
+
+
+def user_data_dir(appname=None, appauthor=None, version=None, roaming=False):
+    r"""Return full path to the user-specific data dir for this application.
+
+        "appname" is the name of application.
+            If None, just the system directory is returned.
+        "appauthor" (only used on Windows) is the name of the
+            appauthor or distributing body for this application. Typically
+            it is the owning company name. This falls back to appname. You may
+            pass False to disable it.
+        "version" is an optional version path element to append to the
+            path. You might want to use this if you want multiple versions
+            of your app to be able to run independently. If used, this
+            would typically be "<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>
+        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.sep.join([x, appname]) for x in pathlist]
+
+        if multipath:
+            path = os.pathsep.join(pathlist)
+        else:
+            path = pathlist[0]
+        return path
+
+    if appname and version:
+        path = os.path.join(path, version)
+    return path
+
+
+def user_config_dir(appname=None, appauthor=None, version=None, roaming=False):
+    r"""Return full path to the user-specific config dir for this application.
+
+        "appname" is the name of application.
+            If None, just the system directory is returned.
+        "appauthor" (only used on Windows) is the name of the
+            appauthor or distributing body for this application. Typically
+            it is the owning company name. This falls back to appname. You may
+            pass False to disable it.
+        "version" is an optional version path element to append to the
+            path. You might want to use this if you want multiple versions
+            of your app to be able to run independently. If used, this
+            would typically be "<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
+
+
+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
+        # only first, if multipath is False
+        path = os.getenv('XDG_CONFIG_DIRS', '/etc/xdg')
+        pathlist = [os.path.expanduser(x.rstrip(os.sep)) for x in path.split(os.pathsep)]
+        if appname:
+            if version:
+                appname = os.path.join(appname, version)
+            pathlist = [os.sep.join([x, appname]) for x in pathlist]
+
+        if multipath:
+            path = os.pathsep.join(pathlist)
+        else:
+            path = pathlist[0]
+    return path
+
+
+def user_cache_dir(appname=None, appauthor=None, version=None, opinion=True):
+    r"""Return full path to the user-specific cache dir for this application.
+
+        "appname" is the name of application.
+            If None, just the system directory is returned.
+        "appauthor" (only used on Windows) is the name of the
+            appauthor or distributing body for this application. Typically
+            it is the owning company name. This falls back to appname. You may
+            pass False to disable it.
+        "version" is an optional version path element to append to the
+            path. You might want to use this if you want multiple versions
+            of your app to be able to run independently. If used, this
+            would typically be "<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"))
+        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
+
+
+#---- 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/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/appdirs.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/appdirs.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..bd1ae6b56e2db9f379675cc7f6694df3f48c8429
GIT binary patch
literal 23990
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

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/cachecontrol/__init__.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/cachecontrol/__init__.py
new file mode 100644
index 0000000..8fdee66
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/cachecontrol/__init__.py
@@ -0,0 +1,11 @@
+"""CacheControl import Interface.
+
+Make it easy to import from cachecontrol without long namespaces.
+"""
+__author__ = "Eric Larson"
+__email__ = "eric@ionrock.org"
+__version__ = "0.12.5"
+
+from .wrapper import CacheControl
+from .adapter import CacheControlAdapter
+from .controller import CacheController
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/cachecontrol/__init__.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/cachecontrol/__init__.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..f08d60aa3317716c0514f4a574e231765e121e37
GIT binary patch
literal 630
zcmZSn%**AGdLky70ScHH7#JKF7#NCu7#J8*7#N}$7*ZG+q8J%cm>8m%7*d!SqL>*{
zSQt`R8FE+{a#<OoSQ!{Wd^Uz0HilewhA4IjpPeCxgCUobA&QfMF@=L6Sc4N}Y7zqj
zgL7hXMyhjuUP)1YjzVT`L4Hw*f@fYyYEfEZa;hE|mv3TrszPRoLTX}hr9w$QOi5Z%
zey&0?NN+M!Z+T`(Mt*6DLQZ~Ox<X!JZfbEsVsdJ+9#=6p0|SF=QD(A&PhwGVeqONv
z0|P^9QD(A3W`15#esZ>6eo=Zc8v_G_fu5m}o@pi{0|SEwh$!Jfb09=i7){hMC9$9+
zwFn}~k0zOuTI8p}#lXN&!p^|J5FekCpBx`w0uqRiPb@9T$S;bIF9C%{e0*wdVrEW!
zd<n?C@$qG;Ma7x<dGYaJjpap&1qG=^L7<2M3nW4;4FbCpWE?aca#D+eK+&cFQi&jn
zOBfg!^b3kI%Mwdc^~(~A^waWlQc{bG^^;Qc%afAwa!qrKjSQ2_)2q@gOfAZDvZ~As
zKp;I&KSaMEvp_d9uec;JCr8(<%)`?-03-y)@nxxbDfvbE$Z??`AD@|*SrQ+wS5R5P
e!N9;^lbfGXnv-hB0*ZA|pt3Q7A(H^303!fIETN?U

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/cachecontrol/_cmd.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/cachecontrol/_cmd.py
new file mode 100644
index 0000000..f1e0ad9
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/cachecontrol/_cmd.py
@@ -0,0 +1,57 @@
+import logging
+
+from pip._vendor import requests
+
+from pip._vendor.cachecontrol.adapter import CacheControlAdapter
+from pip._vendor.cachecontrol.cache import DictCache
+from pip._vendor.cachecontrol.controller import logger
+
+from argparse import ArgumentParser
+
+
+def setup_logging():
+    logger.setLevel(logging.DEBUG)
+    handler = logging.StreamHandler()
+    logger.addHandler(handler)
+
+
+def get_session():
+    adapter = CacheControlAdapter(
+        DictCache(), cache_etags=True, serializer=None, heuristic=None
+    )
+    sess = requests.Session()
+    sess.mount("http://", adapter)
+    sess.mount("https://", adapter)
+
+    sess.cache_controller = adapter.controller
+    return sess
+
+
+def get_args():
+    parser = ArgumentParser()
+    parser.add_argument("url", help="The URL to try and cache")
+    return parser.parse_args()
+
+
+def main(args=None):
+    args = get_args()
+    sess = get_session()
+
+    # Make a request to get a response
+    resp = sess.get(args.url)
+
+    # Turn on logging
+    setup_logging()
+
+    # try setting the cache
+    sess.cache_controller.cache_response(resp.request, resp.raw)
+
+    # Now try to get it
+    if sess.cache_controller.cached_request(resp.request):
+        print("Cached!")
+    else:
+        print("Not cached :(")
+
+
+if __name__ == "__main__":
+    main()
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/cachecontrol/_cmd.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/cachecontrol/_cmd.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..ceada47bebd287ca629de8aa2f89a25c93a0dada
GIT binary patch
literal 2288
zcmZSn%**AGdLky70ScHH7#JKF7#ND@GB7ZtFfgPrGUPBYL_ye03^|Mpxl9aEObm=5
zIcA0&W`<lAhA0*YpM@cZl_8gnA&L#cXJyD?XUOGXh~j|o*%)#-8FIN8qPQ3sQ`i|=
z7#O0s8B#dF3?7CQPB4QPWM>K&LklBA6hA|%07D8lLpBpb(M*O^euicS2F5(FtAaIn
z7#J8b|NsC0-%o>)fq|ifgMopeD7COOwYa1hA|lMdz~G#ioRR9BpI1_ppW~R4SWuE$
z1d-%qU|?{`OfCT{fC#ZMFfiogr>Db|@G&qjI2NUs=BDPA1SA#}rxt<331k~6oSZ@7
zqzkf|fgy{Lp@fMci<zOBk%1A!Vgb3emVu#!fgy{Pp@so0k;1?b47SQo17ueaGe|SY
z-NmUTKB;A?IVJ2+CuHWOm#~6d=;{>eUc$@3zz|$gl$x09k(if~lUh{5#lXOjn34kJ
zg3Sc$&49>jfT9yj6c;csFz6Q)WtJtDr0SO?7U`$u=cJ?-73(LZ=$9uY<>i{@78@BR
znWtB!TbNpu=VVox8Gt}~o_>gaL1uw&W?pegVor{(TbYNaaR5jNjN{8v^HTDQ^pimW
zoD2zI{rKeE6up8<u!D<JOG*pkLE)L1mkx@oVvwI17zG%47{TEP3PX_R!QmJS3JL~>
z5=KzCrGP^-g$bMjnL%VTBQq#4SwMl=%)n5~$WX(`kj2K3!U7IkCI&_*pB2t$V8~(z
zsfy<Sk-^{)_bcIMU|;|{IX<-{F})ZZkj1G*nTa`>RjEZKpj45OT3VD@T#}hw42q46
zl9B=|ef?sPOF`^nD}8+pkg_09ItT)JqJ)Kkfgz-*G!@M7%g;*<0);;~LV{C^i!<}{
zz>%4oUz%3}wh<a$pqLbZI|w1D0X7w6dm<#sf(<TCEiMMfDVP|Thy?{-dTL2L$Ss-q
zc|xEp0Lmr|jLeL3OgxMNi~>y1=miB2C}6<Rs|JZ)P}DJiVknCdoXwdSQb1XTk+Ft>
zA&UtV^}!k-J$@yitWjE&1NL}EYED711SpI%QWZjjd=yIZ6-tUK6%zAO6u@z*0a6_V
z(pbU+$r$m8(0mIH?gCKe1qne522er-ixq)`5=;zCc!E+DC_EF3(u?IlfeCUN10yG+
zFk><(06`uDVQ?U3AqOHPr$93T6F5vkLCH|d#83h*e84$^6_iP8n7~<qi6M)Fp&6Q0
zSQ)Z786XnPj0{DIpy+V-$YW(lVPbIi02fpsd;P$909;0<C>HZFFfjP#mp}qNMZro#
zgNuQIAxIWPh=Uvl(vqH95(J8@AW&Kf5&;Q=QV2Mr;)_y?3-a@dQ^9!yT3UnSx+t-{
z1g<P49x4TnSa2Eu1yGO}$S_be7o`>#fMX3z3{2F4+>x7@nWqAZHc&1GMH?rx5HmZo
zB(o?Z2NSqPijN1WiI3M11O*Z(cELqZL1uv-v;>8e6$%Ut3`l}{;NXIm2zt;`09@jf
zfRYJLm0)d<LP;5)iBOYsQi~9kP-0O!I8%T#5+wFOkqU`kkOzZQLE#TdvhneGiMgrq
w@!;S`5CantAP3px=BJeAq}qY<Ofe{#@GuE534n_u0cK7%P99D+9uXc!0QAiiG5`Po

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/cachecontrol/adapter.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/cachecontrol/adapter.py
new file mode 100644
index 0000000..780eb28
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/cachecontrol/adapter.py
@@ -0,0 +1,133 @@
+import types
+import functools
+import zlib
+
+from pip._vendor.requests.adapters import HTTPAdapter
+
+from .controller import CacheController
+from .cache import DictCache
+from .filewrapper import CallbackFileWrapper
+
+
+class CacheControlAdapter(HTTPAdapter):
+    invalidating_methods = {"PUT", "DELETE"}
+
+    def __init__(
+        self,
+        cache=None,
+        cache_etags=True,
+        controller_class=None,
+        serializer=None,
+        heuristic=None,
+        cacheable_methods=None,
+        *args,
+        **kw
+    ):
+        super(CacheControlAdapter, self).__init__(*args, **kw)
+        self.cache = cache or DictCache()
+        self.heuristic = heuristic
+        self.cacheable_methods = cacheable_methods or ("GET",)
+
+        controller_factory = controller_class or CacheController
+        self.controller = controller_factory(
+            self.cache, cache_etags=cache_etags, serializer=serializer
+        )
+
+    def send(self, request, cacheable_methods=None, **kw):
+        """
+        Send a request. Use the request information to see if it
+        exists in the cache and cache the response if we need to and can.
+        """
+        cacheable = cacheable_methods or self.cacheable_methods
+        if request.method in cacheable:
+            try:
+                cached_response = self.controller.cached_request(request)
+            except zlib.error:
+                cached_response = None
+            if cached_response:
+                return self.build_response(request, cached_response, from_cache=True)
+
+            # check for etags and add headers if appropriate
+            request.headers.update(self.controller.conditional_headers(request))
+
+        resp = super(CacheControlAdapter, self).send(request, **kw)
+
+        return resp
+
+    def build_response(
+        self, request, response, from_cache=False, cacheable_methods=None
+    ):
+        """
+        Build a response by making a request or using the cache.
+
+        This will end up calling send and returning a potentially
+        cached response
+        """
+        cacheable = cacheable_methods or self.cacheable_methods
+        if not from_cache and request.method in cacheable:
+            # Check for any heuristics that might update headers
+            # before trying to cache.
+            if self.heuristic:
+                response = self.heuristic.apply(response)
+
+            # apply any expiration heuristics
+            if response.status == 304:
+                # We must have sent an ETag request. This could mean
+                # that we've been expired already or that we simply
+                # have an etag. In either case, we want to try and
+                # update the cache if that is the case.
+                cached_response = self.controller.update_cached_response(
+                    request, response
+                )
+
+                if cached_response is not response:
+                    from_cache = True
+
+                # We are done with the server response, read a
+                # possible response body (compliant servers will
+                # not return one, but we cannot be 100% sure) and
+                # release the connection back to the pool.
+                response.read(decode_content=False)
+                response.release_conn()
+
+                response = cached_response
+
+            # We always cache the 301 responses
+            elif response.status == 301:
+                self.controller.cache_response(request, response)
+            else:
+                # Wrap the response file with a wrapper that will cache the
+                #   response when the stream has been consumed.
+                response._fp = CallbackFileWrapper(
+                    response._fp,
+                    functools.partial(
+                        self.controller.cache_response, request, response
+                    ),
+                )
+                if response.chunked:
+                    super_update_chunk_length = response._update_chunk_length
+
+                    def _update_chunk_length(self):
+                        super_update_chunk_length()
+                        if self.chunk_left == 0:
+                            self._fp._close()
+
+                    response._update_chunk_length = types.MethodType(
+                        _update_chunk_length, response
+                    )
+
+        resp = super(CacheControlAdapter, self).build_response(request, response)
+
+        # See if we should invalidate the cache.
+        if request.method in self.invalidating_methods and resp.ok:
+            cache_url = self.controller.cache_url(request.url)
+            self.cache.delete(cache_url)
+
+        # Give the request a from_cache attr to let people use it
+        resp.from_cache = from_cache
+
+        return resp
+
+    def close(self):
+        self.cache.close()
+        super(CacheControlAdapter, self).close()
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/cachecontrol/adapter.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/cachecontrol/adapter.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..d79c831608b5e294b894da8b084614a97a017341
GIT binary patch
literal 4045
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

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/cachecontrol/cache.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/cachecontrol/cache.py
new file mode 100644
index 0000000..94e0773
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/cachecontrol/cache.py
@@ -0,0 +1,39 @@
+"""
+The cache object API for implementing caches. The default is a thread
+safe in-memory dictionary.
+"""
+from threading import Lock
+
+
+class BaseCache(object):
+
+    def get(self, key):
+        raise NotImplementedError()
+
+    def set(self, key, value):
+        raise NotImplementedError()
+
+    def delete(self, key):
+        raise NotImplementedError()
+
+    def close(self):
+        pass
+
+
+class DictCache(BaseCache):
+
+    def __init__(self, init_dict=None):
+        self.lock = Lock()
+        self.data = init_dict or {}
+
+    def get(self, key):
+        return self.data.get(key, None)
+
+    def set(self, key, value):
+        with self.lock:
+            self.data.update({key: value})
+
+    def delete(self, key):
+        with self.lock:
+            if key in self.data:
+                self.data.pop(key)
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/cachecontrol/cache.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/cachecontrol/cache.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..987160b095b8cf2f9c3349ebc9acfabffc401eee
GIT binary patch
literal 2923
zcmZSn%**AGdLky70ScHI7#JKF7#ND(7#J8*7#N}$7*ZG+QkWQW7#VVz7^0XM7*m)T
zQkfaj7#UJn7+M$@ni&`(qgWVHSQ%1Tz@lt$QC5Z&c7|XL4v=|C3=9lhAsML($%)As
zsS5c?S*gh-3XTDu3TgR83YobDIjOm+c_o>7=@1pgdI})bDXD3Rr8y-EnZ*i;3MCmu
zsfj6E#ffRD3YmGjxv9DNMU@IEnaL%Y`FV*&m3my6|NsC0uffQ`z)-@%z`)>>pPXI7
z$-uzilvteV46+#RQIHxZki&Es7#LC+7@`<K-fdw3c`=0%<b^0^kiS79EDR~kU=db^
zpkNJ<!O2Vv3=AL)GR7HX3@^w|aA-7vO$r9P!VgTA2s1D+_~n;)!hD&U;#yRcU!(yt
z0qoG?)SR>uP}pauR%(Ev0!$PaGB7ac7ZhcdC6=V>mn9bIr{(9Qq!tzHC#C3@Cne?O
zn&uW8877&hSEXB+T9oHxRhb!pKzg2jh<-t4fo^7AaY<rMj;>poho^A>NC=GM%Tn`F
z@{9Dragm&#S5lOp1L5cuRD#`+o?5~M@)pR242;Pjr-3k0-VFk2(f}zB0u!JBD`90|
zU?@w>DNP0Y3``85_li?XKoM39aw!8NX|W0M9!Mv`dtm>7i2?Ey8z{S`=A@RS3Lr%r
zD7s)6oJv7ak;1?LOPt`822ud_3E2H$Vt_mWN+ZcR`NgTA`~r;|4Uo@DKt)J=d|qO1
zYJ5C6VaCVj=BJeAq{hbwfpi72GcYg&fm8*7vOCxl2x4Ho69fuakdul*1RE14GYEo<
zBbUtN64c@dl$^lDkv^h0VgZ*(j0~WH2vQ=kz)B=mSc$|2Dv>}T08hgplfZE;4=<5w
z7#QLi8EP0A3Pc$)85lrZCXm^%WB|^kptJxki*i7PCODxamL!6UC~)ckJ3KQlvm_o=
z;0|=)LQ@3TJ@JyDBoA^i10xS2GlP5u4hT?cs$pQrVqnMuhe8SiLo*XR4}g>f@qv;L
zC>X&Z;Fq75itu<4$mD_cFF2LUg8T`JU!)Qll(xXW)Mfz3Y!(AUzYGH-$iIvXSxgL>
zj0`nQptv_{W@KOtPhnsPj6f;@z`h3+h2S740cEz*f|SIPRJ8It2qZJ$fdI<o3ZOs$
zMF|5V7b3Dj&I1R786p_e85nCAL8(29ks+Inp-2bH&H{%AC^+&M7zl+3D1Zv`3kF+q
z07bhBC?r502ZaPbqn`#Sc!EIHb`UoxJqv;eP;~%KJcuF^5shHh0F{nB3=9n7ARmCd
z!p6kI!pY3Z;s+`2K^}>ZPsvY?j|Ue!kcMAoUV0F?lmht~(tre)u|XiCz+OQR1LG-h
WsbmAGne0Gmv>4=6HbwzvF@6B|)}Ge@

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/cachecontrol/caches/__init__.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/cachecontrol/caches/__init__.py
new file mode 100644
index 0000000..0e1658f
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/cachecontrol/caches/__init__.py
@@ -0,0 +1,2 @@
+from .file_cache import FileCache  # noqa
+from .redis_cache import RedisCache  # noqa
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/cachecontrol/caches/__init__.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/cachecontrol/caches/__init__.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..c2d55f8a7466d17672bdc4689265012431df0117
GIT binary patch
literal 329
zcmZSn%**AGdLky70ScHH7#JKF7#NCG7#J8*7#LC*8FCmHav2$-7#SErd?tn*CWc&Q
zhA3tR#uR3TU=0=q28K*V1_lNV5K+R(z`)>^nUm_An4FOc5#nNCU<gW0$t(to`GIwm
zfCSSrb5i4zK?;LF)|YTIFfbH>6hZ|-25Nw05JYh`0|SG8K~ZK|Vo9ogSz?iXT7FJS
zYEiL%Qi^_gQc_;7X>PHRVUl@zRl0?#MR`tEm6-tur03~}=oe%b=w{{>mn7!o=(?48
zcp3+QgupnyEHy7BzepeKoaFqxlA`<^2&Y&-K0Y%qvm`!Vub{GogMop;CO1E&G$+*#
M<i281hzT$P01W<3&;S4c

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/cachecontrol/caches/file_cache.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/cachecontrol/caches/file_cache.py
new file mode 100644
index 0000000..1ba0080
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/cachecontrol/caches/file_cache.py
@@ -0,0 +1,146 @@
+import hashlib
+import os
+from textwrap import dedent
+
+from ..cache import BaseCache
+from ..controller import CacheController
+
+try:
+    FileNotFoundError
+except NameError:
+    # py2.X
+    FileNotFoundError = (IOError, OSError)
+
+
+def _secure_open_write(filename, fmode):
+    # We only want to write to this file, so open it in write only mode
+    flags = os.O_WRONLY
+
+    # os.O_CREAT | os.O_EXCL will fail if the file already exists, so we only
+    #  will open *new* files.
+    # We specify this because we want to ensure that the mode we pass is the
+    # mode of the file.
+    flags |= os.O_CREAT | os.O_EXCL
+
+    # Do not follow symlinks to prevent someone from making a symlink that
+    # we follow and insecurely open a cache file.
+    if hasattr(os, "O_NOFOLLOW"):
+        flags |= os.O_NOFOLLOW
+
+    # On Windows we'll mark this file as binary
+    if hasattr(os, "O_BINARY"):
+        flags |= os.O_BINARY
+
+    # Before we open our file, we want to delete any existing file that is
+    # there
+    try:
+        os.remove(filename)
+    except (IOError, OSError):
+        # The file must not exist already, so we can just skip ahead to opening
+        pass
+
+    # Open our file, the use of os.O_CREAT | os.O_EXCL will ensure that if a
+    # race condition happens between the os.remove and this line, that an
+    # error will be raised. Because we utilize a lockfile this should only
+    # happen if someone is attempting to attack us.
+    fd = os.open(filename, flags, fmode)
+    try:
+        return os.fdopen(fd, "wb")
+
+    except:
+        # An error occurred wrapping our FD in a file object
+        os.close(fd)
+        raise
+
+
+class FileCache(BaseCache):
+
+    def __init__(
+        self,
+        directory,
+        forever=False,
+        filemode=0o0600,
+        dirmode=0o0700,
+        use_dir_lock=None,
+        lock_class=None,
+    ):
+
+        if use_dir_lock is not None and lock_class is not None:
+            raise ValueError("Cannot use use_dir_lock and lock_class together")
+
+        try:
+            from pip._vendor.lockfile import LockFile
+            from pip._vendor.lockfile.mkdirlockfile import MkdirLockFile
+        except ImportError:
+            notice = dedent(
+                """
+            NOTE: In order to use the FileCache you must have
+            lockfile installed. You can install it via pip:
+              pip install lockfile
+            """
+            )
+            raise ImportError(notice)
+
+        else:
+            if use_dir_lock:
+                lock_class = MkdirLockFile
+
+            elif lock_class is None:
+                lock_class = LockFile
+
+        self.directory = directory
+        self.forever = forever
+        self.filemode = filemode
+        self.dirmode = dirmode
+        self.lock_class = lock_class
+
+    @staticmethod
+    def encode(x):
+        return hashlib.sha224(x.encode()).hexdigest()
+
+    def _fn(self, name):
+        # NOTE: This method should not change as some may depend on it.
+        #       See: https://github.com/ionrock/cachecontrol/issues/63
+        hashed = self.encode(name)
+        parts = list(hashed[:5]) + [hashed]
+        return os.path.join(self.directory, *parts)
+
+    def get(self, key):
+        name = self._fn(key)
+        try:
+            with open(name, "rb") as fh:
+                return fh.read()
+
+        except FileNotFoundError:
+            return None
+
+    def set(self, key, value):
+        name = self._fn(key)
+
+        # Make sure the directory exists
+        try:
+            os.makedirs(os.path.dirname(name), self.dirmode)
+        except (IOError, OSError):
+            pass
+
+        with self.lock_class(name) as lock:
+            # Write our actual file
+            with _secure_open_write(lock.path, self.filemode) as fh:
+                fh.write(value)
+
+    def delete(self, key):
+        name = self._fn(key)
+        if not self.forever:
+            try:
+                os.remove(name)
+            except FileNotFoundError:
+                pass
+
+
+def url_to_file_path(url, filecache):
+    """Return the file cache path based on the URL.
+
+    This does not ensure the file exists!
+    """
+    key = CacheController.cache_url(url)
+    return filecache._fn(key)
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/cachecontrol/caches/file_cache.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/cachecontrol/caches/file_cache.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..9d01cd3bc884328ce23b84330134bed7ad2388f7
GIT binary patch
literal 4755
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

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/cachecontrol/caches/redis_cache.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/cachecontrol/caches/redis_cache.py
new file mode 100644
index 0000000..ed705ce
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/cachecontrol/caches/redis_cache.py
@@ -0,0 +1,33 @@
+from __future__ import division
+
+from datetime import datetime
+from pip._vendor.cachecontrol.cache import BaseCache
+
+
+class RedisCache(BaseCache):
+
+    def __init__(self, conn):
+        self.conn = conn
+
+    def get(self, key):
+        return self.conn.get(key)
+
+    def set(self, key, value, expires=None):
+        if not expires:
+            self.conn.set(key, value)
+        else:
+            expires = expires - datetime.utcnow()
+            self.conn.setex(key, int(expires.total_seconds()), value)
+
+    def delete(self, key):
+        self.conn.delete(key)
+
+    def clear(self):
+        """Helper for clearing all the keys in a database. Use with
+        caution!"""
+        for key in self.conn.keys():
+            self.conn.delete(key)
+
+    def close(self):
+        """Redis uses connection pooling, no need to close the connection."""
+        pass
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/cachecontrol/caches/redis_cache.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/cachecontrol/caches/redis_cache.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..ab84b3c99c258b637da2028775bceadf079cf6a7
GIT binary patch
literal 2500
zcmZSn%**AGdLky70ScHI7#JKB7#NDZ7#J8*7#LC*8FCmHav2$-7#SErd?tn*CWc%l
zhA1WopP3<tnIV^jA&P~8F@=R8m4zXVks*bZp@o5=nSmiPij^USjUiZroq>TN^Z)<<
z|1}sH7#K=8K&EGwWfo`V=OKwCmZX+s=B7eKI2jlioDz#uofDHYQcJiP7#M<5Q!<Oe
zT)2CgK#D-_b!1>*NM!&yGlc<Uc@z`K?JW!pQOqD0q%bkGFfxE#!wi;XV@P2EGuWYy
zjpASkf;cl7WF`zdgUse-U|^_WWT;_ahzAEsFxY{9V6udTfq@}8KQB)Mqy@|?PR&UR
z0tst?0u@XY*D)|K=ob`amL-;?>X#)J>8IuAq@)%V>nEk?mnS9V<(lRe8yO~<r&pz0
zm|B$QWL23NfIxbleu#cSW`S;IUU5lcPL8fynTMxw07wXo<I7U>Qu2%RlR<%$oS#=x
zl%E6P6zdm(f-4>@qgPM~4)gf<%)HE!_;^kR28LpggBchxy(<9nE(1dr149-g$luM3
z3@{&qw1B-<0!k?9sU=`v2eE?U6eN<JS_$?qm>2|}4g#e+9wg6#q6LP*aT^5kEHgu~
z3@CcxUanzcXl7zy%rj!BVP+^{V#s0!rDlm*W|%4#P{5S1f~2$9KyuBD3?NO+;9LO<
zE|Ber;3`fn2?D2nHU<WU(vsx7{PGe|$Q7rSq*j0fG&8TH1eDlH@=FqP;)_$0^Yc=Q
zH9+nK2XPQ6+kmx{CFYc-mVk^;ttiMWN-YKlIG7j=p$<x3{Gd<=IhcWwjZutA082s>
z0fjwkLIagCu+T#!Hc)`2q~@fSq$1KAI55CI1`~t9+n|gi2J$w@<qV9;pvVR>K{*4Q
z*z_0}7%J3ZX^0V&Zd_u;7-|_|LQJ4!)y&AiSSY{{o&w5uApOOj3=9k&sW}CyMG9&8
zMGDC|sfk6IdFcv?IXMa?8L0}{sg=bFnRyC{3Mq*tiAjmYsd@^b#i<JAnI#!q3Q&-o
zSXz>qpQq@j0dfx{S%Q)lNOKU#>4Q0J!KohXZ%I%9gWS!)ECvZ;P%wiqIEX<qh=8+)
z)fx(=#i_*#pmI7j859Z%1^M|onR)3t3VHbod8w%>3MKgp$vOGOso(%bDAe-<CogbW
z56*-TE~sQ51W67WEcwN$@}OV=B^CxIKMhV$c?`;X@$q?yxvBB-;Oa9zJ~uz5G$%Da
zJ_wYdz-1%2!t%?{OAP|)0VjhXAyA+RGcYh9yb5Lw0{;eqk}jy&D+U$nY)qWYoXkAz
zoXnhTei|S@LH(IlT2fjB@+T;oAZ4x`0|P@rW`Q2G!qfv-i_i)a!U+O}9@qk~ZxO^G
Z@He>fwt+;S9Vo3AgM2H%B)}-Z3;<i`S8o6S

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/cachecontrol/compat.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/cachecontrol/compat.py
new file mode 100644
index 0000000..33b5aed
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/cachecontrol/compat.py
@@ -0,0 +1,29 @@
+try:
+    from urllib.parse import urljoin
+except ImportError:
+    from urlparse import urljoin
+
+
+try:
+    import cPickle as pickle
+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:
+    from pip._vendor.requests.packages.urllib3.response import HTTPResponse
+except ImportError:
+    from pip._vendor.urllib3.response import HTTPResponse
+
+try:
+    from pip._vendor.requests.packages.urllib3.util import is_fp_closed
+except ImportError:
+    from pip._vendor.urllib3.util import is_fp_closed
+
+# Replicate some six behaviour
+try:
+    text_type = unicode
+except NameError:
+    text_type = str
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/cachecontrol/compat.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/cachecontrol/compat.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..9e45ed86ed2c7a74a42f0cfa8fc71739f4d7f349
GIT binary patch
literal 849
zcmZSn%**AGdLky70SZ_d7#JKF7#NBf7#SEUMHo^T7*ZG+au^tL85yD&85qO!6d71j
znHaLU7>djp7#SI%3YcLE@)#K+Dh0s$m>6<c7@}Ai!t-R|deUKfm>6<cL6Ttg5PO&z
za@ZJh*%_kPQSF%z)5FY=!vRx(q>qImhm#?fiy?{&Ro``(J{E=?ZkPhFJ}!n-9)>7h
zhVVRb29{Jluy1~YRHyQTgh6Ujm>7aJK%tTO|NsC08jK7K3?=Lg3=E}3Ia&Fcd43QP
z9tH*mkC2dnpw!}m{Ji2+glJ}Qd|E+#a!!76YKn#cNH<7rX;Ds2W|Ce(Vo`Bw5Gcq?
zxEUB2JaY^3i%MLJit>v}I3RX_Re&u_4#-T-&Pgp{V_;w?fH3vI%mTgmvedkk{35-g
z)WXu#;*w&$g2d$P#Prl+J%~NVdPPuo1%cf!gQgE%Rf!gw0^A0dmSpAxF@d}#fu;v$
zC`bj^1EqPH$@wX%C7dADsTC#hC6xsbo?l{aD#X{!pd?pPqyY*N1W{bXz`&qiP?TAg
zSdyw=mRO{pmY<W7T2!o`l%ijrl$4iinp<pSm}H(_m2P2bQJ#}kWo7^Z>3RAg`URN<
zx|w;!C5bsXx^872p2h(nAuxspoPKg*az<)$eqKpYevW=}er`cxiC#e^I1X%b^HWN5
pQtdziSFFasz`)EX!pO@g!pzJlz{txezzXFvL1|`YMlMEPMgW9`$$J0*

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/cachecontrol/controller.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/cachecontrol/controller.py
new file mode 100644
index 0000000..1b2b943
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/cachecontrol/controller.py
@@ -0,0 +1,367 @@
+"""
+The httplib2 algorithms ported for use with requests.
+"""
+import logging
+import re
+import calendar
+import time
+from email.utils import parsedate_tz
+
+from pip._vendor.requests.structures import CaseInsensitiveDict
+
+from .cache import DictCache
+from .serialize import Serializer
+
+
+logger = logging.getLogger(__name__)
+
+URI = re.compile(r"^(([^:/?#]+):)?(//([^/?#]*))?([^?#]*)(\?([^#]*))?(#(.*))?")
+
+
+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)
+    """
+    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.
+    """
+
+    def __init__(
+        self, cache=None, cache_etags=True, serializer=None, status_codes=None
+    ):
+        self.cache = cache or DictCache()
+        self.cache_etags = cache_etags
+        self.serializer = serializer or Serializer()
+        self.cacheable_status_codes = status_codes or (200, 203, 300, 301)
+
+    @classmethod
+    def _urlnorm(cls, uri):
+        """Normalize the URL to create a safe key for the cache"""
+        (scheme, authority, path, query, fragment) = parse_uri(uri)
+        if not scheme or not authority:
+            raise Exception("Only absolute URIs are allowed. uri = %s" % uri)
+
+        scheme = scheme.lower()
+        authority = authority.lower()
+
+        if not path:
+            path = "/"
+
+        # Could do syntax based normalization of the URI before
+        # computing the digest. See Section 6.2.2 of Std 66.
+        request_uri = query and "?".join([path, query]) or path
+        defrag_uri = scheme + "://" + authority + request_uri
+
+        return defrag_uri
+
+    @classmethod
+    def cache_url(cls, uri):
+        return cls._urlnorm(uri)
+
+    def parse_cache_control(self, headers):
+        known_directives = {
+            # https://tools.ietf.org/html/rfc7234#section-5.2
+            "max-age": (int, True),
+            "max-stale": (int, False),
+            "min-fresh": (int, True),
+            "no-cache": (None, False),
+            "no-store": (None, False),
+            "no-transform": (None, False),
+            "only-if-cached": (None, False),
+            "must-revalidate": (None, False),
+            "public": (None, False),
+            "private": (None, False),
+            "proxy-revalidate": (None, False),
+            "s-maxage": (int, True),
+        }
+
+        cc_headers = headers.get("cache-control", headers.get("Cache-Control", ""))
+
+        retval = {}
+
+        for cc_directive in cc_headers.split(","):
+            if not cc_directive.strip():
+                continue
+
+            parts = cc_directive.split("=", 1)
+            directive = parts[0].strip()
+
+            try:
+                typ, required = known_directives[directive]
+            except KeyError:
+                logger.debug("Ignoring unknown cache-control directive: %s", directive)
+                continue
+
+            if not typ or not required:
+                retval[directive] = None
+            if typ:
+                try:
+                    retval[directive] = typ(parts[1].strip())
+                except IndexError:
+                    if required:
+                        logger.debug(
+                            "Missing value for cache-control " "directive: %s",
+                            directive,
+                        )
+                except ValueError:
+                    logger.debug(
+                        "Invalid value for cache-control directive " "%s, must be %s",
+                        directive,
+                        typ.__name__,
+                    )
+
+        return retval
+
+    def cached_request(self, request):
+        """
+        Return a cached response if it exists in the cache, otherwise
+        return False.
+        """
+        cache_url = self.cache_url(request.url)
+        logger.debug('Looking up "%s" in the cache', cache_url)
+        cc = self.parse_cache_control(request.headers)
+
+        # Bail out if the request insists on fresh data
+        if "no-cache" in cc:
+            logger.debug('Request header has "no-cache", cache bypassed')
+            return False
+
+        if "max-age" in cc and cc["max-age"] == 0:
+            logger.debug('Request header has "max_age" as 0, cache bypassed')
+            return False
+
+        # Request allows serving from the cache, let's see if we find something
+        cache_data = self.cache.get(cache_url)
+        if cache_data is None:
+            logger.debug("No cache entry available")
+            return False
+
+        # Check whether it can be deserialized
+        resp = self.serializer.loads(request, cache_data)
+        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
+        # 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:
+            msg = (
+                'Returning cached "301 Moved Permanently" response '
+                "(ignoring date and etag information)"
+            )
+            logger.debug(msg)
+            return resp
+
+        headers = CaseInsensitiveDict(resp.headers)
+        if not headers or "date" not in headers:
+            if "etag" not in headers:
+                # Without date or etag, the cached response can never be used
+                # and should be deleted.
+                logger.debug("Purging cached response: no date or etag")
+                self.cache.delete(cache_url)
+            logger.debug("Ignoring cached response: no date")
+            return False
+
+        now = time.time()
+        date = calendar.timegm(parsedate_tz(headers["date"]))
+        current_age = max(0, now - date)
+        logger.debug("Current age based on date: %i", current_age)
+
+        # TODO: There is an assumption that the result will be a
+        #       urllib3 response object. This may not be best since we
+        #       could probably avoid instantiating or constructing the
+        #       response until we know we need it.
+        resp_cc = self.parse_cache_control(headers)
+
+        # determine freshness
+        freshness_lifetime = 0
+
+        # Check the max-age pragma in the cache control header
+        if "max-age" in resp_cc:
+            freshness_lifetime = resp_cc["max-age"]
+            logger.debug("Freshness lifetime from max-age: %i", freshness_lifetime)
+
+        # If there isn't a max-age, check for an expires header
+        elif "expires" in headers:
+            expires = parsedate_tz(headers["expires"])
+            if expires is not None:
+                expire_time = calendar.timegm(expires) - date
+                freshness_lifetime = max(0, expire_time)
+                logger.debug("Freshness lifetime from expires: %i", freshness_lifetime)
+
+        # Determine if we are setting freshness limit in the
+        # request. Note, this overrides what was in the response.
+        if "max-age" in cc:
+            freshness_lifetime = cc["max-age"]
+            logger.debug(
+                "Freshness lifetime from request max-age: %i", freshness_lifetime
+            )
+
+        if "min-fresh" in cc:
+            min_fresh = cc["min-fresh"]
+            # adjust our current age by our min fresh
+            current_age += min_fresh
+            logger.debug("Adjusted current age from min-fresh: %i", current_age)
+
+        # Return entry if it is fresh enough
+        if freshness_lifetime > current_age:
+            logger.debug('The response is "fresh", returning cached response')
+            logger.debug("%i > %i", freshness_lifetime, current_age)
+            return resp
+
+        # we're not fresh. If we don't have an Etag, clear it out
+        if "etag" not in headers:
+            logger.debug('The cached response is "stale" with no etag, purging')
+            self.cache.delete(cache_url)
+
+        # return the original handler
+        return False
+
+    def conditional_headers(self, request):
+        cache_url = self.cache_url(request.url)
+        resp = self.serializer.loads(request, self.cache.get(cache_url))
+        new_headers = {}
+
+        if resp:
+            headers = CaseInsensitiveDict(resp.headers)
+
+            if "etag" in headers:
+                new_headers["If-None-Match"] = headers["ETag"]
+
+            if "last-modified" in headers:
+                new_headers["If-Modified-Since"] = headers["Last-Modified"]
+
+        return new_headers
+
+    def cache_response(self, request, response, body=None, status_codes=None):
+        """
+        Algorithm for caching requests.
+
+        This assumes a requests Response object.
+        """
+        # From httplib2: Don't cache 206's since we aren't going to
+        #                handle byte range requests
+        cacheable_status_codes = status_codes or self.cacheable_status_codes
+        if response.status not in cacheable_status_codes:
+            logger.debug(
+                "Status code %s not in %s", response.status, cacheable_status_codes
+            )
+            return
+
+        response_headers = CaseInsensitiveDict(response.headers)
+
+        # If we've been given a body, our response has a Content-Length, that
+        # Content-Length is valid then we can check to see if the body we've
+        # been given matches the expected size, and if it doesn't we'll just
+        # skip trying to cache it.
+        if (
+            body is not None
+            and "content-length" in response_headers
+            and response_headers["content-length"].isdigit()
+            and int(response_headers["content-length"]) != len(body)
+        ):
+            return
+
+        cc_req = self.parse_cache_control(request.headers)
+        cc = self.parse_cache_control(response_headers)
+
+        cache_url = self.cache_url(request.url)
+        logger.debug('Updating cache with response from "%s"', cache_url)
+
+        # Delete it from the cache if we happen to have it stored there
+        no_store = False
+        if "no-store" in cc:
+            no_store = True
+            logger.debug('Response header has "no-store"')
+        if "no-store" in cc_req:
+            no_store = True
+            logger.debug('Request header has "no-store"')
+        if no_store and self.cache.get(cache_url):
+            logger.debug('Purging existing cache entry to honor "no-store"')
+            self.cache.delete(cache_url)
+        if no_store:
+            return
+
+        # If we've been given an etag, then keep the response
+        if self.cache_etags and "etag" in response_headers:
+            logger.debug("Caching due to etag")
+            self.cache.set(
+                cache_url, self.serializer.dumps(request, response, body=body)
+            )
+
+        # 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 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:
+            # 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)
+                )
+
+            # 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)
+                    )
+
+    def update_cached_response(self, request, response):
+        """On a 304 we will get a new set of headers that we want to
+        update our cached value with, assuming we have one.
+
+        This should only ever be called when we've sent an ETag and
+        gotten a 304 as the response.
+        """
+        cache_url = self.cache_url(request.url)
+
+        cached_response = self.serializer.loads(request, self.cache.get(cache_url))
+
+        if not cached_response:
+            # we didn't have a cached response
+            return response
+
+        # Lets update our headers with the headers from the new request:
+        # http://tools.ietf.org/html/draft-ietf-httpbis-p4-conditional-26#section-4.1
+        #
+        # The server isn't supposed to send headers that would make
+        # the cached body invalid. But... just in case, we'll be sure
+        # to strip out ones we know that might be problmatic due to
+        # typical assumptions.
+        excluded_headers = ["content-length"]
+
+        cached_response.headers.update(
+            dict(
+                (k, v)
+                for k, v in response.headers.items()
+                if k.lower() not in excluded_headers
+            )
+        )
+
+        # we want a 200 b/c we have content via the cache
+        cached_response.status = 200
+
+        # update our cache
+        self.cache.set(cache_url, self.serializer.dumps(request, cached_response))
+
+        return cached_response
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/cachecontrol/controller.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/cachecontrol/controller.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..667a185c7c2b6d52e1d510676b6029d5b0f55b60
GIT binary patch
literal 10121
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

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/cachecontrol/filewrapper.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/cachecontrol/filewrapper.py
new file mode 100644
index 0000000..30ed4c5
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/cachecontrol/filewrapper.py
@@ -0,0 +1,80 @@
+from io import BytesIO
+
+
+class CallbackFileWrapper(object):
+    """
+    Small wrapper around a fp object which will tee everything read into a
+    buffer, and when that file is closed it will execute a callback with the
+    contents of that buffer.
+
+    All attributes are proxied to the underlying file object.
+
+    This class uses members with a double underscore (__) leading prefix so as
+    not to accidentally shadow an attribute.
+    """
+
+    def __init__(self, fp, callback):
+        self.__buf = BytesIO()
+        self.__fp = fp
+        self.__callback = callback
+
+    def __getattr__(self, name):
+        # The vaguaries of garbage collection means that self.__fp is
+        # not always set.  By using __getattribute__ and the private
+        # name[0] allows looking up the attribute value and raising an
+        # AttributeError when it doesn't exist. This stop thigns from
+        # infinitely recursing calls to getattr in the case where
+        # self.__fp hasn't been set.
+        #
+        # [0] https://docs.python.org/2/reference/expressions.html#atom-identifiers
+        fp = self.__getattribute__("_CallbackFileWrapper__fp")
+        return getattr(fp, name)
+
+    def __is_fp_closed(self):
+        try:
+            return self.__fp.fp is None
+
+        except AttributeError:
+            pass
+
+        try:
+            return self.__fp.closed
+
+        except AttributeError:
+            pass
+
+        # We just don't cache it then.
+        # TODO: Add some logging here...
+        return False
+
+    def _close(self):
+        if self.__callback:
+            self.__callback(self.__buf.getvalue())
+
+        # We assign this to None here, because otherwise we can get into
+        # really tricky problems where the CPython interpreter dead locks
+        # because the callback is holding a reference to something which
+        # has a __del__ method. Setting this to None breaks the cycle
+        # and allows the garbage collector to do it's thing normally.
+        self.__callback = None
+
+    def read(self, amt=None):
+        data = self.__fp.read(amt)
+        self.__buf.write(data)
+        if self.__is_fp_closed():
+            self._close()
+
+        return data
+
+    def _safe_read(self, amt):
+        data = self.__fp._safe_read(amt)
+        if amt == 2 and data == b"\r\n":
+            # urllib executes this read to toss the CRLF at the end
+            # of the chunk.
+            return data
+
+        self.__buf.write(data)
+        if self.__is_fp_closed():
+            self._close()
+
+        return data
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/cachecontrol/filewrapper.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/cachecontrol/filewrapper.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..a8445222354764eeb5ecf492a7e0883f3bf734fd
GIT binary patch
literal 3043
zcmZSn%**AGdLky70ScHI7#JKF7#NDR7#J8*7#LC*8FCmHav2$-7#SE-m>5!-7}6LS
zQkWT97#Nxv7$T#X8B$mnf;Ctf7#K4D|NsAAgOP!Op@f}*fx)S=B(>PnzeJdUfx$U3
zCnqT}IomBWCpEk%v7jKe2yP`4NG-@pcLoNAR0fbuDGUrzOdz{k7#Kh{FoCR#Vu9Kl
z#R{?$B*n&%!p@Mw%Fx2d5XHfe!Uk5x$q*E*!2vR`jFEwXOF=<FAviZNCr6<iVzEME
zQGRJ&ibA47T7g1-QdVkmi9&fsW^#r?d1g+ILP=_>LTXuRQDsR+W?s5NQEFm}LS|k`
zzCt3{sHD=gwA3OUg~YrRh4PHlJcW{s#1e(H%$!t(%wmP)oc!X{6ot$Zh*_x>smY}!
zsS1e-$<P2$D9<d(P$<br1sj%}pI4HaS5mByp9V1pV!9p|Sk^HoM<KDKq$o3~v?R4y
zA+ab`p`a+gA~Q8bp(Gz<hC*pxN@`I~CCHs%7eIUi)gF=oc2Ht*u|jEaYOz9YYHm_$
zQ8B~?i3%zCrAaxd5F?6{^NUgyG~(km6>?G&Q$Xew6s4wRRwxwbD<l?!U6Yqz0<tzS
zIXN>WHLoNwC#O=OI3qD7zg!_P58+Ndu;OG;Is#!(<T``mLJ5>Cz-gw2fgzrep@xwG
z#9(5mVFELlL8&bmoO=8;SQr=>f<P&<M3RAlAs$QWiH}bzO)HVWDVtVMB8O8F78x2K
z7nXo5D^ATxD*?GRt)K*ybl@sLj?e%R#pMhP4EhB{nPrJ3srqG!Mfz#^IVq_{#rjDp
z`sGPUdAX*!#YTon=IK@G7N!>EIayU^1|X20ryrtUkXfLcnO6)7HC?wd4^QI&kPsNh
zm!;;V<QM5DCnjg4f)YegevUpUHlfK?ub>j_r1<#Eyv&mLcmYsovVok$$iv9Vm<)0?
z$R8jK4rv(%22hA*firJ2BSS3{LkS}|m>C(GnHYjKKsx+_K<dHF5|D}U@#(20@Wd7$
z56;0*A#gASfpR!Ftnw0bQ-eSb0EY{h7|_7s2E{YX`SJ0hpzs03DFY`zV=|~T0%4Hr
z!J*^Fz`#%`0u7)nMo_BD=3od8&l6-|DPd;F=3*#PXJBMx%wuGTsN{pGV?kBn2~$zR
z$^c8Vpb!BEDmZMwA?25!ms-Ndz`)=L%f+rmMfpV~Af=F!q6FkFx5S*{RB*}%2QoNB
z!Nh<DE6CmP@tMW(X$A2R$0~wCRtTK(m>ETwco|ukm>Ky%Gz&bOL1_yd&ie3FSfm6E
z#To{NEJlVbCQ!xE%*eo)2d-g2r2v=#3rJAh1%U~WVc@i%o?23tm{Xb>#LK|IFz7-G
z6rGSDG6IDVh|9pp$tcMV&zm5RfJ4O|9x7SjA`p^2K>@?Wki`tjq@aKS@mWBjRAdbf
zI#v)H6kIi+><dcHei|TKz{w4q(m=IT5XcsAf+{b{EJ-Z^mAKf8PUJ`p0#(mQIUH0h
zB<7ZYO-)HGNdzZEFfov+F-U}gfx#9Ox?JG&C&Vbg$iv9Xgc-uo*h82R)SAd<VkpuB
z1#$`#1DqWU3T^D6AC4vTLE+<<2@2|B5W&lZ6cZq~#TO^0rN+bKBM4L+1&M*`Gt__%
z5(kNaDll;1f{6hQVNgx$3JPIR#%Ev@Vw7NJVS<FRp9aWh;G7sA4=VoS<4Zsy@$tF&
zDWy57(CQ*SJ|#anK0XLkfd=t_ya)F;IOBpNF$iQ2*tZB`K>ZEMPN34J802p@E;c4k
zR!$yHK~8QS4oE`;+%Cw>hqOmP*$&dm3Ib_F_yNosNRNP{#|9E1b|ANb)29G40LLfg
A?*IS*

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/cachecontrol/heuristics.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/cachecontrol/heuristics.py
new file mode 100644
index 0000000..6c0e979
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/cachecontrol/heuristics.py
@@ -0,0 +1,135 @@
+import calendar
+import time
+
+from email.utils import formatdate, parsedate, parsedate_tz
+
+from datetime import datetime, timedelta
+
+TIME_FMT = "%a, %d %b %Y %H:%M:%S GMT"
+
+
+def expire_after(delta, date=None):
+    date = date or datetime.utcnow()
+    return date + delta
+
+
+def datetime_to_header(dt):
+    return formatdate(calendar.timegm(dt.timetuple()))
+
+
+class BaseHeuristic(object):
+
+    def warning(self, response):
+        """
+        Return a valid 1xx warning header value describing the cache
+        adjustments.
+
+        The response is provided too allow warnings like 113
+        http://tools.ietf.org/html/rfc7234#section-5.5.4 where we need
+        to explicitly say response is over 24 hours old.
+        """
+        return '110 - "Response is Stale"'
+
+    def update_headers(self, response):
+        """Update the response headers with any new headers.
+
+        NOTE: This SHOULD always include some Warning header to
+              signify that the response was cached by the client, not
+              by way of the provided headers.
+        """
+        return {}
+
+    def apply(self, response):
+        updated_headers = self.update_headers(response)
+
+        if updated_headers:
+            response.headers.update(updated_headers)
+            warning_header_value = self.warning(response)
+            if warning_header_value is not None:
+                response.headers.update({"Warning": warning_header_value})
+
+        return response
+
+
+class OneDayCache(BaseHeuristic):
+    """
+    Cache the response by providing an expires 1 day in the
+    future.
+    """
+
+    def update_headers(self, response):
+        headers = {}
+
+        if "expires" not in response.headers:
+            date = parsedate(response.headers["date"])
+            expires = expire_after(timedelta(days=1), date=datetime(*date[:6]))
+            headers["expires"] = datetime_to_header(expires)
+            headers["cache-control"] = "public"
+        return headers
+
+
+class ExpiresAfter(BaseHeuristic):
+    """
+    Cache **all** requests for a defined time period.
+    """
+
+    def __init__(self, **kw):
+        self.delta = timedelta(**kw)
+
+    def update_headers(self, response):
+        expires = expire_after(self.delta)
+        return {"expires": datetime_to_header(expires), "cache-control": "public"}
+
+    def warning(self, response):
+        tmpl = "110 - Automatically cached for %s. Response might be stale"
+        return tmpl % self.delta
+
+
+class LastModified(BaseHeuristic):
+    """
+    If there is no Expires header already, fall back on Last-Modified
+    using the heuristic from
+    http://tools.ietf.org/html/rfc7234#section-4.2.2
+    to calculate a reasonable value.
+
+    Firefox also does something like this per
+    https://developer.mozilla.org/en-US/docs/Web/HTTP/Caching_FAQ
+    http://lxr.mozilla.org/mozilla-release/source/netwerk/protocol/http/nsHttpResponseHead.cpp#397
+    Unlike mozilla we limit this to 24-hr.
+    """
+    cacheable_by_default_statuses = {
+        200, 203, 204, 206, 300, 301, 404, 405, 410, 414, 501
+    }
+
+    def update_headers(self, resp):
+        headers = resp.headers
+
+        if "expires" in headers:
+            return {}
+
+        if "cache-control" in headers and headers["cache-control"] != "public":
+            return {}
+
+        if resp.status not in self.cacheable_by_default_statuses:
+            return {}
+
+        if "date" not in headers or "last-modified" not in headers:
+            return {}
+
+        date = calendar.timegm(parsedate_tz(headers["date"]))
+        last_modified = parsedate(headers["last-modified"])
+        if date is None or last_modified is None:
+            return {}
+
+        now = time.time()
+        current_age = max(0, now - date)
+        delta = date - calendar.timegm(last_modified)
+        freshness_lifetime = max(0, min(delta / 10, 24 * 3600))
+        if freshness_lifetime <= current_age:
+            return {}
+
+        expires = date + freshness_lifetime
+        return {"expires": time.strftime(TIME_FMT, time.gmtime(expires))}
+
+    def warning(self, resp):
+        return None
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/cachecontrol/heuristics.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/cachecontrol/heuristics.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..be56432f614dc5681af3c00830fde00c2359abcb
GIT binary patch
literal 6673
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
I35p2<01$dZn*aa+

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/cachecontrol/serialize.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/cachecontrol/serialize.py
new file mode 100644
index 0000000..ec43ff2
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/cachecontrol/serialize.py
@@ -0,0 +1,186 @@
+import base64
+import io
+import json
+import zlib
+
+from pip._vendor import msgpack
+from pip._vendor.requests.structures import CaseInsensitiveDict
+
+from .compat import HTTPResponse, pickle, text_type
+
+
+def _b64_decode_bytes(b):
+    return base64.b64decode(b.encode("ascii"))
+
+
+def _b64_decode_str(s):
+    return _b64_decode_bytes(s).decode("utf8")
+
+
+class Serializer(object):
+
+    def dumps(self, request, response, body=None):
+        response_headers = CaseInsensitiveDict(response.headers)
+
+        if body is None:
+            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
+        #       Python 2.x these objects are unicode and not str, even when
+        #       they contain only ascii. The problem here is that msgpack
+        #       understands the difference between unicode and bytes and we
+        #       have it set to differentiate between them, however Python 2
+        #       doesn't know the difference. Forcing these to unicode will be
+        #       enough to have msgpack know the difference.
+        data = {
+            u"response": {
+                u"body": body,
+                u"headers": dict(
+                    (text_type(k), text_type(v)) for k, v in response.headers.items()
+                ),
+                u"status": response.status,
+                u"version": response.version,
+                u"reason": text_type(response.reason),
+                u"strict": response.strict,
+                u"decode_content": response.decode_content,
+            }
+        }
+
+        # Construct our vary headers
+        data[u"vary"] = {}
+        if u"vary" in response_headers:
+            varied_headers = response_headers[u"vary"].split(",")
+            for header in varied_headers:
+                header = text_type(header).strip()
+                header_value = request.headers.get(header, None)
+                if header_value is not None:
+                    header_value = text_type(header_value)
+                data[u"vary"][header] = header_value
+
+        return b",".join([b"cc=4", msgpack.dumps(data, use_bin_type=True)])
+
+    def loads(self, request, data):
+        # Short circuit if we've been given an empty set of data
+        if not data:
+            return
+
+        # Determine what version of the serializer the data was serialized
+        # with
+        try:
+            ver, data = data.split(b",", 1)
+        except ValueError:
+            ver = b"cc=0"
+
+        # Make sure that our "ver" is actually a version and isn't a false
+        # positive from a , being in the data stream.
+        if ver[:3] != b"cc=":
+            data = ver + data
+            ver = b"cc=0"
+
+        # Get the version number out of the cc=N
+        ver = ver.split(b"=", 1)[-1].decode("ascii")
+
+        # Dispatch to the actual load method for the given version
+        try:
+            return getattr(self, "_loads_v{}".format(ver))(request, data)
+
+        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):
+        """Verify our vary headers match and construct a real urllib3
+        HTTPResponse object.
+        """
+        # Special case the '*' Vary value as it means we cannot actually
+        # determine if the cached response is suitable for this request.
+        if "*" in cached.get("vary", {}):
+            return
+
+        # Ensure that the Vary headers for the cached response match our
+        # request
+        for header, value in cached.get("vary", {}).items():
+            if request.headers.get(header, None) != value:
+                return
+
+        body_raw = cached["response"].pop("body")
+
+        headers = CaseInsensitiveDict(data=cached["response"]["headers"])
+        if headers.get("transfer-encoding", "") == "chunked":
+            headers.pop("transfer-encoding")
+
+        cached["response"]["headers"] = headers
+
+        try:
+            body = io.BytesIO(body_raw)
+        except TypeError:
+            # This can happen if cachecontrol serialized to v1 format (pickle)
+            # using Python 2. A Python 2 str(byte string) will be unpickled as
+            # a Python 3 str (unicode string), which will cause the above to
+            # fail with:
+            #
+            #     TypeError: 'str' does not support the buffer interface
+            body = io.BytesIO(body_raw.encode("utf8"))
+
+        return HTTPResponse(body=body, preload_content=False, **cached["response"])
+
+    def _loads_v0(self, request, data):
+        # 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):
+        try:
+            cached = pickle.loads(data)
+        except ValueError:
+            return
+
+        return self.prepare_response(request, cached)
+
+    def _loads_v2(self, request, data):
+        try:
+            cached = json.loads(zlib.decompress(data).decode("utf8"))
+        except (ValueError, zlib.error):
+            return
+
+        # We need to decode the items that we've base64 encoded
+        cached["response"]["body"] = _b64_decode_bytes(cached["response"]["body"])
+        cached["response"]["headers"] = dict(
+            (_b64_decode_str(k), _b64_decode_str(v))
+            for k, v in cached["response"]["headers"].items()
+        )
+        cached["response"]["reason"] = _b64_decode_str(cached["response"]["reason"])
+        cached["vary"] = dict(
+            (_b64_decode_str(k), _b64_decode_str(v) if v is not None else v)
+            for k, v in cached["vary"].items()
+        )
+
+        return self.prepare_response(request, cached)
+
+    def _loads_v3(self, request, data):
+        # 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):
+        try:
+            cached = msgpack.loads(data, encoding="utf-8")
+        except ValueError:
+            return
+
+        return self.prepare_response(request, cached)
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/cachecontrol/serialize.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/cachecontrol/serialize.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..8a2151d8962058b8b3dabcea0df60386b661f811
GIT binary patch
literal 6411
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
Zpt7PERA2Hif+3RtqX3f(Gbalt3jlt7bua(`

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/cachecontrol/wrapper.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/cachecontrol/wrapper.py
new file mode 100644
index 0000000..265bfc8
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/cachecontrol/wrapper.py
@@ -0,0 +1,29 @@
+from .adapter import CacheControlAdapter
+from .cache import DictCache
+
+
+def CacheControl(
+    sess,
+    cache=None,
+    cache_etags=True,
+    serializer=None,
+    heuristic=None,
+    controller_class=None,
+    adapter_class=None,
+    cacheable_methods=None,
+):
+
+    cache = cache or DictCache()
+    adapter_class = adapter_class or CacheControlAdapter
+    adapter = adapter_class(
+        cache,
+        cache_etags=cache_etags,
+        serializer=serializer,
+        heuristic=heuristic,
+        controller_class=controller_class,
+        cacheable_methods=cacheable_methods,
+    )
+    sess.mount("http://", adapter)
+    sess.mount("https://", adapter)
+
+    return sess
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/cachecontrol/wrapper.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/cachecontrol/wrapper.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..fb4ea0bc39a8bf001f191675f06f49fa848c7d9f
GIT binary patch
literal 906
zcmZSn%**AGdLky70SY)67#JKF7#ND37#J8*7#LC*8FCmHav2$-7#SErd?tn*CWc&Q
zhA3tR#uOHYR91!*7F5K{(8A6T#Rd`#)?j5|V8~=-U|`Sy5hcP53=GbR$r-86`FSNp
z`8kd$i3KI8MG#3&1_lO~%;XZVf@F|OKq5RKEg%<VGB7aIFftVIFqAMbG&3;NGBVV#
zF%(EJlrS>XvVqt&j3D>cFfpVsG1M?Kq%bqofZbNZ%8<g!P{Yp9%*a~H!BE4%kj2E1
z!p2a;!O+aazzF5DBk_YZK-T+}a5FG4B!k==pIVZbUR=Tja!6`XW@1ieRccWQ$bA{9
zrA3*=C7H=30wBc@f90eW#V6+^78jQYf&@V(Bqrsg#^<J%WaOt57qc@kFl3aJ6j<r&
z7lUj9v5T$r^);9o7#M;;K@|jwkP=Yv<>r^>m1uyhDq#UzUtA0p2fHhX38Vq63nUo?
z(on+7z`&3Q30a6Mg4h@s7)n5vLWMOzrh|#%Vg?2V{eq&*vc!^9{j$U&{j~g?l+>bP
z{iGEA@}#7^T+`fQBf})~^s00VQ;YJPtSU1D5J=C{5795kEYQu&D=taQ$<cKy^YAnd
z011I{d|7H<N`8?(*qO<YV9_rxN-QWyEz&EfECI(WC}5yT0p#*x36Q(E`5Ac_nHkyO
zkdsM(QGm%$1LT1qP?UfJCkPZI;IIORi(h_TDwq*cRGJzDG9Bzc1TkPf1x2t;ZhlH>
UPO2R!YKuV$MSxL&m6;I%0SIl#V*mgE

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/certifi/__init__.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/certifi/__init__.py
new file mode 100644
index 0000000..632db8e
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/certifi/__init__.py
@@ -0,0 +1,3 @@
+from .core import where
+
+__version__ = "2019.03.09"
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/certifi/__init__.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/certifi/__init__.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..8f4d3a2d3dd693087f2df3a6a43e27250e0b061e
GIT binary patch
literal 287
zcmZSn%**AGdLky70ScHH7#JKF7#NDB7#J8*7#LC*8FCmHav2$-7#SE-m>8m%7*d!S
zf;Cte7#K1c85kHeKtu^E0|P^OMru)NF&6^^gOP!urJjMYo`I#G1~UT#LkUQAa(+>2
z5XhDiZUzR1`1rEaqT<Z_y!dzxkRXC6&Szj?&@U*;EK4j&)h|md(of6JNl7g#)=x^&
zFHcI!%Qej{HZn{yPp?Y1FtsSp$*M9l0D<&8{Sf_v%mUrayyB9?oE%-ZG7nGV0FV$E
z$Cst%rQ{dsC#M#bWTs{6$H!;pWtPOp>lIX%a4;}1*yQG?l;)(`fjm?U3I_ou0PAf+
A2mk;8

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/certifi/__main__.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/certifi/__main__.py
new file mode 100644
index 0000000..ae2aff5
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/certifi/__main__.py
@@ -0,0 +1,2 @@
+from pip._vendor.certifi import where
+print(where())
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/certifi/__main__.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/certifi/__main__.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..ea962588d90f0aa7bb437d925690292e6b3f3449
GIT binary patch
literal 273
zcmZSn%**AGdLky70ScHH7#JKF7#NCW7#J8*7#LC*8FCmHav2$-7#SE-85x=x7~DNl
zm>7aJm>C!tGXMYo|6hZVfq|ifm4ShwJR`Lz)lUOtMu{*314BV(fnI!BYF<iykzR6Y
zQAuW6W)R384OF5ypMilvzo00yEU_e2zbvsxKP^8eCAFwnKPg4OJSizJ*EF}-$S}z~
zy(-<p)S^5mtIEs(1k&^LL-Y$W3v@H{ic1o6a&+CwJUop9Ktf;)wOb!*w|;zlZenI$
ee7s&kWeEoZ1A|R&eoARhsvXD!#UNJ;FaiMLmqio+

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/certifi/cacert.pem b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/certifi/cacert.pem
new file mode 100644
index 0000000..84636dd
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/certifi/cacert.pem
@@ -0,0 +1,4658 @@
+
+# Issuer: CN=GlobalSign Root CA O=GlobalSign nv-sa OU=Root CA
+# Subject: CN=GlobalSign Root CA O=GlobalSign nv-sa OU=Root CA
+# Label: "GlobalSign Root CA"
+# Serial: 4835703278459707669005204
+# MD5 Fingerprint: 3e:45:52:15:09:51:92:e1:b7:5d:37:9f:b1:87:29:8a
+# SHA1 Fingerprint: b1:bc:96:8b:d4:f4:9d:62:2a:a8:9a:81:f2:15:01:52:a4:1d:82:9c
+# SHA256 Fingerprint: eb:d4:10:40:e4:bb:3e:c7:42:c9:e3:81:d3:1e:f2:a4:1a:48:b6:68:5c:96:e7:ce:f3:c1:df:6c:d4:33:1c:99
+-----BEGIN CERTIFICATE-----
+MIIDdTCCAl2gAwIBAgILBAAAAAABFUtaw5QwDQYJKoZIhvcNAQEFBQAwVzELMAkG
+A1UEBhMCQkUxGTAXBgNVBAoTEEdsb2JhbFNpZ24gbnYtc2ExEDAOBgNVBAsTB1Jv
+b3QgQ0ExGzAZBgNVBAMTEkdsb2JhbFNpZ24gUm9vdCBDQTAeFw05ODA5MDExMjAw
+MDBaFw0yODAxMjgxMjAwMDBaMFcxCzAJBgNVBAYTAkJFMRkwFwYDVQQKExBHbG9i
+YWxTaWduIG52LXNhMRAwDgYDVQQLEwdSb290IENBMRswGQYDVQQDExJHbG9iYWxT
+aWduIFJvb3QgQ0EwggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIBAQDaDuaZ
+jc6j40+Kfvvxi4Mla+pIH/EqsLmVEQS98GPR4mdmzxzdzxtIK+6NiY6arymAZavp
+xy0Sy6scTHAHoT0KMM0VjU/43dSMUBUc71DuxC73/OlS8pF94G3VNTCOXkNz8kHp
+1Wrjsok6Vjk4bwY8iGlbKk3Fp1S4bInMm/k8yuX9ifUSPJJ4ltbcdG6TRGHRjcdG
+snUOhugZitVtbNV4FpWi6cgKOOvyJBNPc1STE4U6G7weNLWLBYy5d4ux2x8gkasJ
+U26Qzns3dLlwR5EiUWMWea6xrkEmCMgZK9FGqkjWZCrXgzT/LCrBbBlDSgeF59N8
+9iFo7+ryUp9/k5DPAgMBAAGjQjBAMA4GA1UdDwEB/wQEAwIBBjAPBgNVHRMBAf8E
+BTADAQH/MB0GA1UdDgQWBBRge2YaRQ2XyolQL30EzTSo//z9SzANBgkqhkiG9w0B
+AQUFAAOCAQEA1nPnfE920I2/7LqivjTFKDK1fPxsnCwrvQmeU79rXqoRSLblCKOz
+yj1hTdNGCbM+w6DjY1Ub8rrvrTnhQ7k4o+YviiY776BQVvnGCv04zcQLcFGUl5gE
+38NflNUVyRRBnMRddWQVDf9VMOyGj/8N7yy5Y0b2qvzfvGn9LhJIZJrglfCm7ymP
+AbEVtQwdpf5pLGkkeB6zpxxxYu7KyJesF12KwvhHhm4qxFYxldBniYUr+WymXUad
+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=VeriSign Class 3 Public Primary Certification Authority - G3 O=VeriSign, Inc. OU=VeriSign Trust Network/(c) 1999 VeriSign, Inc. - For authorized use only
+# Subject: CN=VeriSign Class 3 Public Primary Certification Authority - G3 O=VeriSign, Inc. OU=VeriSign Trust Network/(c) 1999 VeriSign, Inc. - For authorized use only
+# Label: "Verisign Class 3 Public Primary Certification Authority - G3"
+# Serial: 206684696279472310254277870180966723415
+# MD5 Fingerprint: cd:68:b6:a7:c7:c4:ce:75:e0:1d:4f:57:44:61:92:09
+# SHA1 Fingerprint: 13:2d:0d:45:53:4b:69:97:cd:b2:d5:c3:39:e2:55:76:60:9b:5c:c6
+# SHA256 Fingerprint: eb:04:cf:5e:b1:f3:9a:fa:76:2f:2b:b1:20:f2:96:cb:a5:20:c1:b9:7d:b1:58:95:65:b8:1c:b9:a1:7b:72:44
+-----BEGIN CERTIFICATE-----
+MIIEGjCCAwICEQCbfgZJoz5iudXukEhxKe9XMA0GCSqGSIb3DQEBBQUAMIHKMQsw
+CQYDVQQGEwJVUzEXMBUGA1UEChMOVmVyaVNpZ24sIEluYy4xHzAdBgNVBAsTFlZl
+cmlTaWduIFRydXN0IE5ldHdvcmsxOjA4BgNVBAsTMShjKSAxOTk5IFZlcmlTaWdu
+LCBJbmMuIC0gRm9yIGF1dGhvcml6ZWQgdXNlIG9ubHkxRTBDBgNVBAMTPFZlcmlT
+aWduIENsYXNzIDMgUHVibGljIFByaW1hcnkgQ2VydGlmaWNhdGlvbiBBdXRob3Jp
+dHkgLSBHMzAeFw05OTEwMDEwMDAwMDBaFw0zNjA3MTYyMzU5NTlaMIHKMQswCQYD
+VQQGEwJVUzEXMBUGA1UEChMOVmVyaVNpZ24sIEluYy4xHzAdBgNVBAsTFlZlcmlT
+aWduIFRydXN0IE5ldHdvcmsxOjA4BgNVBAsTMShjKSAxOTk5IFZlcmlTaWduLCBJ
+bmMuIC0gRm9yIGF1dGhvcml6ZWQgdXNlIG9ubHkxRTBDBgNVBAMTPFZlcmlTaWdu
+IENsYXNzIDMgUHVibGljIFByaW1hcnkgQ2VydGlmaWNhdGlvbiBBdXRob3JpdHkg
+LSBHMzCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBAMu6nFL8eB8aHm8b
+N3O9+MlrlBIwT/A2R/XQkQr1F8ilYcEWQE37imGQ5XYgwREGfassbqb1EUGO+i2t
+KmFZpGcmTNDovFJbcCAEWNF6yaRpvIMXZK0Fi7zQWM6NjPXr8EJJC52XJ2cybuGu
+kxUccLwgTS8Y3pKI6GyFVxEa6X7jJhFUokWWVYPKMIno3Nij7SqAP395ZVc+FSBm
+CC+Vk7+qRy+oRpfwEuL+wgorUeZ25rdGt+INpsyow0xZVYnm6FNcHOqd8GIWC6fJ
+Xwzw3sJ2zq/3avL6QaaiMxTJ5Xpj055iN9WFZZ4O5lMkdBteHRJTW8cs54NJOxWu
+imi5V5cCAwEAATANBgkqhkiG9w0BAQUFAAOCAQEAERSWwauSCPc/L8my/uRan2Te
+2yFPhpk0djZX3dAVL8WtfxUfN2JzPtTnX84XA9s1+ivbrmAJXx5fj267Cz3qWhMe
+DGBvtcC1IyIuBwvLqXTLR7sdwdela8wv0kL9Sd2nic9TutoAWii/gt/4uhMdUIaC
+/Y4wjylGsB49Ndo4YhYYSq3mtlFs3q9i6wHQHiT+eo8SGhJouPtmmRQURVyu565p
+F4ErWjfJXir0xuKhXFSbplQAz/DxwceYMBo7Nhbbo27q/a2ywtrvAkcTisDxszGt
+TxzhT5yvDwyd93gN2PQ1VoDat20Xj50egWTh/sVFuq1ruQp6Tk9LhO5L8X3dEQ==
+-----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"
+# Serial: 946069240
+# MD5 Fingerprint: ee:29:31:bc:32:7e:9a:e6:e8:b5:f7:51:b4:34:71:90
+# SHA1 Fingerprint: 50:30:06:09:1d:97:d4:f5:ae:39:f7:cb:e7:92:7d:7d:65:2d:34:31
+# SHA256 Fingerprint: 6d:c4:71:72:e0:1c:bc:b0:bf:62:58:0d:89:5f:e2:b8:ac:9a:d4:f8:73:80:1e:0c:10:b9:c8:37:d2:1e:b1:77
+-----BEGIN CERTIFICATE-----
+MIIEKjCCAxKgAwIBAgIEOGPe+DANBgkqhkiG9w0BAQUFADCBtDEUMBIGA1UEChML
+RW50cnVzdC5uZXQxQDA+BgNVBAsUN3d3dy5lbnRydXN0Lm5ldC9DUFNfMjA0OCBp
+bmNvcnAuIGJ5IHJlZi4gKGxpbWl0cyBsaWFiLikxJTAjBgNVBAsTHChjKSAxOTk5
+IEVudHJ1c3QubmV0IExpbWl0ZWQxMzAxBgNVBAMTKkVudHJ1c3QubmV0IENlcnRp
+ZmljYXRpb24gQXV0aG9yaXR5ICgyMDQ4KTAeFw05OTEyMjQxNzUwNTFaFw0yOTA3
+MjQxNDE1MTJaMIG0MRQwEgYDVQQKEwtFbnRydXN0Lm5ldDFAMD4GA1UECxQ3d3d3
+LmVudHJ1c3QubmV0L0NQU18yMDQ4IGluY29ycC4gYnkgcmVmLiAobGltaXRzIGxp
+YWIuKTElMCMGA1UECxMcKGMpIDE5OTkgRW50cnVzdC5uZXQgTGltaXRlZDEzMDEG
+A1UEAxMqRW50cnVzdC5uZXQgQ2VydGlmaWNhdGlvbiBBdXRob3JpdHkgKDIwNDgp
+MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEArU1LqRKGsuqjIAcVFmQq
+K0vRvwtKTY7tgHalZ7d4QMBzQshowNtTK91euHaYNZOLGp18EzoOH1u3Hs/lJBQe
+sYGpjX24zGtLA/ECDNyrpUAkAH90lKGdCCmziAv1h3edVc3kw37XamSrhRSGlVuX
+MlBvPci6Zgzj/L24ScF2iUkZ/cCovYmjZy/Gn7xxGWC4LeksyZB2ZnuU4q941mVT
+XTzWnLLPKQP5L6RQstRIzgUyVYr9smRMDuSYB3Xbf9+5CFVghTAp+XtIpGmG4zU/
+HoZdenoVve8AjhUiVBcAkCaTvA5JaJG/+EfTnZVCwQ5N328mz8MYIWJmQ3DW1cAH
+4QIDAQABo0IwQDAOBgNVHQ8BAf8EBAMCAQYwDwYDVR0TAQH/BAUwAwEB/zAdBgNV
+HQ4EFgQUVeSB0RGAvtiJuQijMfmhJAkWuXAwDQYJKoZIhvcNAQEFBQADggEBADub
+j1abMOdTmXx6eadNl9cZlZD7Bh/KM3xGY4+WZiT6QBshJ8rmcnPyT/4xmf3IDExo
+U8aAghOY+rat2l098c5u9hURlIIM7j+VrxGrD9cv3h8Dj1csHsm7mhpElesYT6Yf
+zX1XEC+bBAlahLVu2B064dae0Wx5XnkcFMXj0EyTO2U87d89vqbllRrDtRnDvV5b
+u/8j72gZyxKTJ1wDLW8w0B62GqzeWvfRqqgnpv55gcR5mTNXuhKwqeBCbJPKVt7+
+bYQLCIt+jerXmCHG8+c8eS9enNFMFY3h7CI3zJpDC5fcgJCNs2ebb0gIFVbPv/Er
+fF6adulZkMV8gzURZVE=
+-----END CERTIFICATE-----
+
+# Issuer: CN=Baltimore CyberTrust Root O=Baltimore OU=CyberTrust
+# Subject: CN=Baltimore CyberTrust Root O=Baltimore OU=CyberTrust
+# Label: "Baltimore CyberTrust Root"
+# Serial: 33554617
+# MD5 Fingerprint: ac:b6:94:a5:9c:17:e0:d7:91:52:9b:b1:97:06:a6:e4
+# SHA1 Fingerprint: d4:de:20:d0:5e:66:fc:53:fe:1a:50:88:2c:78:db:28:52:ca:e4:74
+# SHA256 Fingerprint: 16:af:57:a9:f6:76:b0:ab:12:60:95:aa:5e:ba:de:f2:2a:b3:11:19:d6:44:ac:95:cd:4b:93:db:f3:f2:6a:eb
+-----BEGIN CERTIFICATE-----
+MIIDdzCCAl+gAwIBAgIEAgAAuTANBgkqhkiG9w0BAQUFADBaMQswCQYDVQQGEwJJ
+RTESMBAGA1UEChMJQmFsdGltb3JlMRMwEQYDVQQLEwpDeWJlclRydXN0MSIwIAYD
+VQQDExlCYWx0aW1vcmUgQ3liZXJUcnVzdCBSb290MB4XDTAwMDUxMjE4NDYwMFoX
+DTI1MDUxMjIzNTkwMFowWjELMAkGA1UEBhMCSUUxEjAQBgNVBAoTCUJhbHRpbW9y
+ZTETMBEGA1UECxMKQ3liZXJUcnVzdDEiMCAGA1UEAxMZQmFsdGltb3JlIEN5YmVy
+VHJ1c3QgUm9vdDCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBAKMEuyKr
+mD1X6CZymrV51Cni4eiVgLGw41uOKymaZN+hXe2wCQVt2yguzmKiYv60iNoS6zjr
+IZ3AQSsBUnuId9Mcj8e6uYi1agnnc+gRQKfRzMpijS3ljwumUNKoUMMo6vWrJYeK
+mpYcqWe4PwzV9/lSEy/CG9VwcPCPwBLKBsua4dnKM3p31vjsufFoREJIE9LAwqSu
+XmD+tqYF/LTdB1kC1FkYmGP1pWPgkAx9XbIGevOF6uvUA65ehD5f/xXtabz5OTZy
+dc93Uk3zyZAsuT3lySNTPx8kmCFcB5kpvcY67Oduhjprl3RjM71oGDHweI12v/ye
+jl0qhqdNkNwnGjkCAwEAAaNFMEMwHQYDVR0OBBYEFOWdWTCCR1jMrPoIVDaGezq1
+BE3wMBIGA1UdEwEB/wQIMAYBAf8CAQMwDgYDVR0PAQH/BAQDAgEGMA0GCSqGSIb3
+DQEBBQUAA4IBAQCFDF2O5G9RaEIFoN27TyclhAO992T9Ldcw46QQF+vaKSm2eT92
+9hkTI7gQCvlYpNRhcL0EYWoSihfVCr3FvDB81ukMJY2GQE/szKN+OMY3EU/t3Wgx
+jkzSswF07r51XgdIGn9w/xZchMB5hbgF/X++ZRGjD8ACtPhSNzkE1akxehi/oCr0
+Epn3o0WC4zxe9Z2etciefC7IpJ5OCBRLbf1wbWsaY71k5h+3zvDyny67G7fyUIhz
+ksLi4xaNmjICq44Y3ekQEe5+NauQrz4wlHrQMz2nZQ/1/I6eYs9HRCwBXbsdtTLS
+R9I4LtD+gdwyah617jzV/OeBHRnDJELqYzmp
+-----END CERTIFICATE-----
+
+# Issuer: CN=AddTrust External CA Root O=AddTrust AB OU=AddTrust External TTP Network
+# Subject: CN=AddTrust External CA Root O=AddTrust AB OU=AddTrust External TTP Network
+# Label: "AddTrust External Root"
+# Serial: 1
+# MD5 Fingerprint: 1d:35:54:04:85:78:b0:3f:42:42:4d:bf:20:73:0a:3f
+# SHA1 Fingerprint: 02:fa:f3:e2:91:43:54:68:60:78:57:69:4d:f5:e4:5b:68:85:18:68
+# SHA256 Fingerprint: 68:7f:a4:51:38:22:78:ff:f0:c8:b1:1f:8d:43:d5:76:67:1c:6e:b2:bc:ea:b4:13:fb:83:d9:65:d0:6d:2f:f2
+-----BEGIN CERTIFICATE-----
+MIIENjCCAx6gAwIBAgIBATANBgkqhkiG9w0BAQUFADBvMQswCQYDVQQGEwJTRTEU
+MBIGA1UEChMLQWRkVHJ1c3QgQUIxJjAkBgNVBAsTHUFkZFRydXN0IEV4dGVybmFs
+IFRUUCBOZXR3b3JrMSIwIAYDVQQDExlBZGRUcnVzdCBFeHRlcm5hbCBDQSBSb290
+MB4XDTAwMDUzMDEwNDgzOFoXDTIwMDUzMDEwNDgzOFowbzELMAkGA1UEBhMCU0Ux
+FDASBgNVBAoTC0FkZFRydXN0IEFCMSYwJAYDVQQLEx1BZGRUcnVzdCBFeHRlcm5h
+bCBUVFAgTmV0d29yazEiMCAGA1UEAxMZQWRkVHJ1c3QgRXh0ZXJuYWwgQ0EgUm9v
+dDCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBALf3GjPm8gAELTngTlvt
+H7xsD821+iO2zt6bETOXpClMfZOfvUq8k+0DGuOPz+VtUFrWlymUWoCwSXrbLpX9
+uMq/NzgtHj6RQa1wVsfwTz/oMp50ysiQVOnGXw94nZpAPA6sYapeFI+eh6FqUNzX
+mk6vBbOmcZSccbNQYArHE504B4YCqOmoaSYYkKtMsE8jqzpPhNjfzp/haW+710LX
+a0Tkx63ubUFfclpxCDezeWWkWaCUN/cALw3CknLa0Dhy2xSoRcRdKn23tNbE7qzN
+E0S3ySvdQwAl+mG5aWpYIxG3pzOPVnVZ9c0p10a3CitlttNCbxWyuHv77+ldU9U0
+WicCAwEAAaOB3DCB2TAdBgNVHQ4EFgQUrb2YejS0Jvf6xCZU7wO94CTLVBowCwYD
+VR0PBAQDAgEGMA8GA1UdEwEB/wQFMAMBAf8wgZkGA1UdIwSBkTCBjoAUrb2YejS0
+Jvf6xCZU7wO94CTLVBqhc6RxMG8xCzAJBgNVBAYTAlNFMRQwEgYDVQQKEwtBZGRU
+cnVzdCBBQjEmMCQGA1UECxMdQWRkVHJ1c3QgRXh0ZXJuYWwgVFRQIE5ldHdvcmsx
+IjAgBgNVBAMTGUFkZFRydXN0IEV4dGVybmFsIENBIFJvb3SCAQEwDQYJKoZIhvcN
+AQEFBQADggEBALCb4IUlwtYj4g+WBpKdQZic2YR5gdkeWxQHIzZlj7DYd7usQWxH
+YINRsPkyPef89iYTx4AWpb9a/IfPeHmJIZriTAcKhjW88t5RxNKWt9x+Tu5w/Rw5
+6wwCURQtjr0W4MHfRnXnJK3s9EK0hZNwEGe6nQY1ShjTK3rMUUKhemPR5ruhxSvC
+Nr4TDea9Y355e6cJDUCrat2PisP29owaQgVR1EX1n6diIWgVIEM8med8vSTYqZEX
+c4g/VhsxOBi0cQ+azcgOno4uG+GMmIPLHzHxREzGBHNJdmAPx/i9F4BrLunMTA5a
+mnkPIAou1Z5jJh5VkpTYghdae9C8x49OhgQ=
+-----END CERTIFICATE-----
+
+# Issuer: CN=Entrust Root Certification Authority O=Entrust, Inc. OU=www.entrust.net/CPS is incorporated by reference/(c) 2006 Entrust, Inc.
+# Subject: CN=Entrust Root Certification Authority O=Entrust, Inc. OU=www.entrust.net/CPS is incorporated by reference/(c) 2006 Entrust, Inc.
+# Label: "Entrust Root Certification Authority"
+# Serial: 1164660820
+# MD5 Fingerprint: d6:a5:c3:ed:5d:dd:3e:00:c1:3d:87:92:1f:1d:3f:e4
+# SHA1 Fingerprint: b3:1e:b1:b7:40:e3:6c:84:02:da:dc:37:d4:4d:f5:d4:67:49:52:f9
+# SHA256 Fingerprint: 73:c1:76:43:4f:1b:c6:d5:ad:f4:5b:0e:76:e7:27:28:7c:8d:e5:76:16:c1:e6:e6:14:1a:2b:2c:bc:7d:8e:4c
+-----BEGIN CERTIFICATE-----
+MIIEkTCCA3mgAwIBAgIERWtQVDANBgkqhkiG9w0BAQUFADCBsDELMAkGA1UEBhMC
+VVMxFjAUBgNVBAoTDUVudHJ1c3QsIEluYy4xOTA3BgNVBAsTMHd3dy5lbnRydXN0
+Lm5ldC9DUFMgaXMgaW5jb3Jwb3JhdGVkIGJ5IHJlZmVyZW5jZTEfMB0GA1UECxMW
+KGMpIDIwMDYgRW50cnVzdCwgSW5jLjEtMCsGA1UEAxMkRW50cnVzdCBSb290IENl
+cnRpZmljYXRpb24gQXV0aG9yaXR5MB4XDTA2MTEyNzIwMjM0MloXDTI2MTEyNzIw
+NTM0MlowgbAxCzAJBgNVBAYTAlVTMRYwFAYDVQQKEw1FbnRydXN0LCBJbmMuMTkw
+NwYDVQQLEzB3d3cuZW50cnVzdC5uZXQvQ1BTIGlzIGluY29ycG9yYXRlZCBieSBy
+ZWZlcmVuY2UxHzAdBgNVBAsTFihjKSAyMDA2IEVudHJ1c3QsIEluYy4xLTArBgNV
+BAMTJEVudHJ1c3QgUm9vdCBDZXJ0aWZpY2F0aW9uIEF1dGhvcml0eTCCASIwDQYJ
+KoZIhvcNAQEBBQADggEPADCCAQoCggEBALaVtkNC+sZtKm9I35RMOVcF7sN5EUFo
+Nu3s/poBj6E4KPz3EEZmLk0eGrEaTsbRwJWIsMn/MYszA9u3g3s+IIRe7bJWKKf4
+4LlAcTfFy0cOlypowCKVYhXbR9n10Cv/gkvJrT7eTNuQgFA/CYqEAOwwCj0Yzfv9
+KlmaI5UXLEWeH25DeW0MXJj+SKfFI0dcXv1u5x609mhF0YaDW6KKjbHjKYD+JXGI
+rb68j6xSlkuqUY3kEzEZ6E5Nn9uss2rVvDlUccp6en+Q3X0dgNmBu1kmwhH+5pPi
+94DkZfs0Nw4pgHBNrziGLp5/V6+eF67rHMsoIV+2HNjnogQi+dPa2MsCAwEAAaOB
+sDCBrTAOBgNVHQ8BAf8EBAMCAQYwDwYDVR0TAQH/BAUwAwEB/zArBgNVHRAEJDAi
+gA8yMDA2MTEyNzIwMjM0MlqBDzIwMjYxMTI3MjA1MzQyWjAfBgNVHSMEGDAWgBRo
+kORnpKZTgMeGZqTx90tD+4S9bTAdBgNVHQ4EFgQUaJDkZ6SmU4DHhmak8fdLQ/uE
+vW0wHQYJKoZIhvZ9B0EABBAwDhsIVjcuMTo0LjADAgSQMA0GCSqGSIb3DQEBBQUA
+A4IBAQCT1DCw1wMgKtD5Y+iRDAUgqV8ZyntyTtSx29CW+1RaGSwMCPeyvIWonX9t
+O1KzKtvn1ISMY/YPyyYBkVBs9F8U4pN0wBOeMDpQ47RgxRzwIkSNcUesyBrJ6Zua
+AGAT/3B+XxFNSRuzFVJ7yVTav52Vr2ua2J7p8eRDjeIRRDq/r72DQnNSi6q7pynP
+9WQcCk3RvKqsnyrQ/39/2n3qse0wJcGE2jTSW3iDVuycNsMm4hH2Z0kdkquM++v/
+eu6FSqdQgPCnXEqULl8FmTxSQeDNtGPPAUO6nIPcj2A781q0tHuu2guQOHXvgR1m
+0vdXcDazv/wor3ElhVsT/h5/WrQ8
+-----END CERTIFICATE-----
+
+# Issuer: CN=GeoTrust Global CA O=GeoTrust Inc.
+# Subject: CN=GeoTrust Global CA O=GeoTrust Inc.
+# Label: "GeoTrust Global CA"
+# Serial: 144470
+# MD5 Fingerprint: f7:75:ab:29:fb:51:4e:b7:77:5e:ff:05:3c:99:8e:f5
+# SHA1 Fingerprint: de:28:f4:a4:ff:e5:b9:2f:a3:c5:03:d1:a3:49:a7:f9:96:2a:82:12
+# SHA256 Fingerprint: ff:85:6a:2d:25:1d:cd:88:d3:66:56:f4:50:12:67:98:cf:ab:aa:de:40:79:9c:72:2d:e4:d2:b5:db:36:a7:3a
+-----BEGIN CERTIFICATE-----
+MIIDVDCCAjygAwIBAgIDAjRWMA0GCSqGSIb3DQEBBQUAMEIxCzAJBgNVBAYTAlVT
+MRYwFAYDVQQKEw1HZW9UcnVzdCBJbmMuMRswGQYDVQQDExJHZW9UcnVzdCBHbG9i
+YWwgQ0EwHhcNMDIwNTIxMDQwMDAwWhcNMjIwNTIxMDQwMDAwWjBCMQswCQYDVQQG
+EwJVUzEWMBQGA1UEChMNR2VvVHJ1c3QgSW5jLjEbMBkGA1UEAxMSR2VvVHJ1c3Qg
+R2xvYmFsIENBMIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEA2swYYzD9
+9BcjGlZ+W988bDjkcbd4kdS8odhM+KhDtgPpTSEHCIjaWC9mOSm9BXiLnTjoBbdq
+fnGk5sRgprDvgOSJKA+eJdbtg/OtppHHmMlCGDUUna2YRpIuT8rxh0PBFpVXLVDv
+iS2Aelet8u5fa9IAjbkU+BQVNdnARqN7csiRv8lVK83Qlz6cJmTM386DGXHKTubU
+1XupGc1V3sjs0l44U+VcT4wt/lAjNvxm5suOpDkZALeVAjmRCw7+OC7RHQWa9k0+
+bw8HHa8sHo9gOeL6NlMTOdReJivbPagUvTLrGAMoUgRx5aszPeE4uwc2hGKceeoW
+MPRfwCvocWvk+QIDAQABo1MwUTAPBgNVHRMBAf8EBTADAQH/MB0GA1UdDgQWBBTA
+ephojYn7qwVkDBF9qn1luMrMTjAfBgNVHSMEGDAWgBTAephojYn7qwVkDBF9qn1l
+uMrMTjANBgkqhkiG9w0BAQUFAAOCAQEANeMpauUvXVSOKVCUn5kaFOSPeCpilKIn
+Z57QzxpeR+nBsqTP3UEaBU6bS+5Kb1VSsyShNwrrZHYqLizz/Tt1kL/6cdjHPTfS
+tQWVYrmm3ok9Nns4d0iXrKYgjy6myQzCsplFAMfOEVEiIuCl6rYVSAlk6l5PdPcF
+PseKUgzbFbS9bZvlxrFUaKnjaZC2mqUPuLk/IH2uSrW4nOQdtqvmlKXBx4Ot2/Un
+hw4EbNX/3aBd7YdStysVAq45pmp06drE57xNNB6pXE0zX5IJL4hmXXeXxx12E6nV
+5fEWCRE11azbJHFwLJhWC9kXtNHjUStedejV0NxPNO3CBWaAocvmMw==
+-----END CERTIFICATE-----
+
+# Issuer: CN=GeoTrust Universal CA O=GeoTrust Inc.
+# Subject: CN=GeoTrust Universal CA O=GeoTrust Inc.
+# Label: "GeoTrust Universal CA"
+# Serial: 1
+# MD5 Fingerprint: 92:65:58:8b:a2:1a:31:72:73:68:5c:b4:a5:7a:07:48
+# SHA1 Fingerprint: e6:21:f3:35:43:79:05:9a:4b:68:30:9d:8a:2f:74:22:15:87:ec:79
+# SHA256 Fingerprint: a0:45:9b:9f:63:b2:25:59:f5:fa:5d:4c:6d:b3:f9:f7:2f:f1:93:42:03:35:78:f0:73:bf:1d:1b:46:cb:b9:12
+-----BEGIN CERTIFICATE-----
+MIIFaDCCA1CgAwIBAgIBATANBgkqhkiG9w0BAQUFADBFMQswCQYDVQQGEwJVUzEW
+MBQGA1UEChMNR2VvVHJ1c3QgSW5jLjEeMBwGA1UEAxMVR2VvVHJ1c3QgVW5pdmVy
+c2FsIENBMB4XDTA0MDMwNDA1MDAwMFoXDTI5MDMwNDA1MDAwMFowRTELMAkGA1UE
+BhMCVVMxFjAUBgNVBAoTDUdlb1RydXN0IEluYy4xHjAcBgNVBAMTFUdlb1RydXN0
+IFVuaXZlcnNhbCBDQTCCAiIwDQYJKoZIhvcNAQEBBQADggIPADCCAgoCggIBAKYV
+VaCjxuAfjJ0hUNfBvitbtaSeodlyWL0AG0y/YckUHUWCq8YdgNY96xCcOq9tJPi8
+cQGeBvV8Xx7BDlXKg5pZMK4ZyzBIle0iN430SppyZj6tlcDgFgDgEB8rMQ7XlFTT
+QjOgNB0eRXbdT8oYN+yFFXoZCPzVx5zw8qkuEKmS5j1YPakWaDwvdSEYfyh3peFh
+F7em6fgemdtzbvQKoiFs7tqqhZJmr/Z6a4LauiIINQ/PQvE1+mrufislzDoR5G2v
+c7J2Ha3QsnhnGqQ5HFELZ1aD/ThdDc7d8Lsrlh/eezJS/R27tQahsiFepdaVaH/w
+mZ7cRQg+59IJDTWU3YBOU5fXtQlEIGQWFwMCTFMNaN7VqnJNk22CDtucvc+081xd
+VHppCZbW2xHBjXWotM85yM48vCR85mLK4b19p71XZQvk/iXttmkQ3CgaRr0BHdCX
+teGYO8A3ZNY9lO4L4fUorgtWv3GLIylBjobFS1J72HGrH4oVpjuDWtdYAVHGTEHZ
+f9hBZ3KiKN9gg6meyHv8U3NyWfWTehd2Ds735VzZC1U0oqpbtWpU5xPKV+yXbfRe
+Bi9Fi1jUIxaS5BZuKGNZMN9QAZxjiRqf2xeUgnA3wySemkfWWspOqGmJch+RbNt+
+nhutxx9z3SxPGWX9f5NAEC7S8O08ni4oPmkmM8V7AgMBAAGjYzBhMA8GA1UdEwEB
+/wQFMAMBAf8wHQYDVR0OBBYEFNq7LqqwDLiIJlF0XG0D08DYj3rWMB8GA1UdIwQY
+MBaAFNq7LqqwDLiIJlF0XG0D08DYj3rWMA4GA1UdDwEB/wQEAwIBhjANBgkqhkiG
+9w0BAQUFAAOCAgEAMXjmx7XfuJRAyXHEqDXsRh3ChfMoWIawC/yOsjmPRFWrZIRc
+aanQmjg8+uUfNeVE44B5lGiku8SfPeE0zTBGi1QrlaXv9z+ZhP015s8xxtxqv6fX
+IwjhmF7DWgh2qaavdy+3YL1ERmrvl/9zlcGO6JP7/TG37FcREUWbMPEaiDnBTzyn
+ANXH/KttgCJwpQzgXQQpAvvLoJHRfNbDflDVnVi+QTjruXU8FdmbyUqDWcDaU/0z
+uzYYm4UPFd3uLax2k7nZAY1IEKj79TiG8dsKxr2EoyNB3tZ3b4XUhRxQ4K5RirqN
+Pnbiucon8l+f725ZDQbYKxek0nxru18UGkiPGkzns0ccjkxFKyDuSN/n3QmOGKja
+QI2SJhFTYXNd673nxE0pN2HrrDktZy4W1vUAg4WhzH92xH3kt0tm7wNFYGm2DFKW
+koRepqO1pD4r2czYG0eq8kTaT/kD6PAUyz/zg97QwVTjt+gKN02LIFkDMBmhLMi9
+ER/frslKxfMnZmaGrGiR/9nmUxwPi1xpZQomyB40w11Re9epnAahNt3ViZS82eQt
+DF4JbAiXfKM9fJP/P6EUp8+1Xevb2xzEdt+Iub1FBZUbrvxGakyvSOPOrg/Sfuvm
+bJxPgWp6ZKy7PtXny3YuxadIwVyQD8vIP/rmMuGNG2+k5o7Y+SlIis5z/iw=
+-----END CERTIFICATE-----
+
+# Issuer: CN=GeoTrust Universal CA 2 O=GeoTrust Inc.
+# Subject: CN=GeoTrust Universal CA 2 O=GeoTrust Inc.
+# Label: "GeoTrust Universal CA 2"
+# Serial: 1
+# MD5 Fingerprint: 34:fc:b8:d0:36:db:9e:14:b3:c2:f2:db:8f:e4:94:c7
+# SHA1 Fingerprint: 37:9a:19:7b:41:85:45:35:0c:a6:03:69:f3:3c:2e:af:47:4f:20:79
+# SHA256 Fingerprint: a0:23:4f:3b:c8:52:7c:a5:62:8e:ec:81:ad:5d:69:89:5d:a5:68:0d:c9:1d:1c:b8:47:7f:33:f8:78:b9:5b:0b
+-----BEGIN CERTIFICATE-----
+MIIFbDCCA1SgAwIBAgIBATANBgkqhkiG9w0BAQUFADBHMQswCQYDVQQGEwJVUzEW
+MBQGA1UEChMNR2VvVHJ1c3QgSW5jLjEgMB4GA1UEAxMXR2VvVHJ1c3QgVW5pdmVy
+c2FsIENBIDIwHhcNMDQwMzA0MDUwMDAwWhcNMjkwMzA0MDUwMDAwWjBHMQswCQYD
+VQQGEwJVUzEWMBQGA1UEChMNR2VvVHJ1c3QgSW5jLjEgMB4GA1UEAxMXR2VvVHJ1
+c3QgVW5pdmVyc2FsIENBIDIwggIiMA0GCSqGSIb3DQEBAQUAA4ICDwAwggIKAoIC
+AQCzVFLByT7y2dyxUxpZKeexw0Uo5dfR7cXFS6GqdHtXr0om/Nj1XqduGdt0DE81
+WzILAePb63p3NeqqWuDW6KFXlPCQo3RWlEQwAx5cTiuFJnSCegx2oG9NzkEtoBUG
+FF+3Qs17j1hhNNwqCPkuwwGmIkQcTAeC5lvO0Ep8BNMZcyfwqph/Lq9O64ceJHdq
+XbboW0W63MOhBW9Wjo8QJqVJwy7XQYci4E+GymC16qFjwAGXEHm9ADwSbSsVsaxL
+se4YuU6W3Nx2/zu+z18DwPw76L5GG//aQMJS9/7jOvdqdzXQ2o3rXhhqMcceujwb
+KNZrVMaqW9eiLBsZzKIC9ptZvTdrhrVtgrrY6slWvKk2WP0+GfPtDCapkzj4T8Fd
+IgbQl+rhrcZV4IErKIM6+vR7IVEAvlI4zs1meaj0gVbi0IMJR1FbUGrP20gaXT73
+y/Zl92zxlfgCOzJWgjl6W70viRu/obTo/3+NjN8D8WBOWBFM66M/ECuDmgFz2ZRt
+hAAnZqzwcEAJQpKtT5MNYQlRJNiS1QuUYbKHsu3/mjX/hVTK7URDrBs8FmtISgoc
+QIgfksILAAX/8sgCSqSqqcyZlpwvWOB94b67B9xfBHJcMTTD7F8t4D1kkCLm0ey4
+Lt1ZrtmhN79UNdxzMk+MBB4zsslG8dhcyFVQyWi9qLo2CQIDAQABo2MwYTAPBgNV
+HRMBAf8EBTADAQH/MB0GA1UdDgQWBBR281Xh+qQ2+/CfXGJx7Tz0RzgQKzAfBgNV
+HSMEGDAWgBR281Xh+qQ2+/CfXGJx7Tz0RzgQKzAOBgNVHQ8BAf8EBAMCAYYwDQYJ
+KoZIhvcNAQEFBQADggIBAGbBxiPz2eAubl/oz66wsCVNK/g7WJtAJDday6sWSf+z
+dXkzoS9tcBc0kf5nfo/sm+VegqlVHy/c1FEHEv6sFj4sNcZj/NwQ6w2jqtB8zNHQ
+L1EuxBRa3ugZ4T7GzKQp5y6EqgYweHZUcyiYWTjgAA1i00J9IZ+uPTqM1fp3DRgr
+Fg5fNuH8KrUwJM/gYwx7WBr+mbpCErGR9Hxo4sjoryzqyX6uuyo9DRXcNJW2GHSo
+ag/HtPQTxORb7QrSpJdMKu0vbBKJPfEncKpqA1Ihn0CoZ1Dy81of398j9tx4TuaY
+T1U6U+Pv8vSfx3zYWK8pIpe44L2RLrB27FcRz+8pRPPphXpgY+RdM4kX2TGq2tbz
+GDVyz4crL2MjhF2EjD9XoIj8mZEoJmmZ1I+XRL6O1UixpCgp8RW04eWe3fiPpm8m
+1wk8OhwRDqZsN/etRIcsKMfYdIKz0G9KV7s1KSegi+ghp4dkNl3M2Basx7InQJJV
+OCiNUW7dFGdTbHFcJoRNdVq2fmBWqU2t+5sel/MN2dKXVHfaPRK34B7vCAas+YWH
+6aLcr34YEoP9VhdBLtUpgn2Z9DH2canPLAEnpQW5qrJITirvn5NSUZU8UnOOVkwX
+QMAJKOSLakhT2+zNVVXxxvjpoixMptEmX36vWkzaH6byHCx+rgIW0lbQL1dTR+iS
+-----END CERTIFICATE-----
+
+# Issuer: CN=AAA Certificate Services O=Comodo CA Limited
+# Subject: CN=AAA Certificate Services O=Comodo CA Limited
+# Label: "Comodo AAA Services root"
+# Serial: 1
+# MD5 Fingerprint: 49:79:04:b0:eb:87:19:ac:47:b0:bc:11:51:9b:74:d0
+# SHA1 Fingerprint: d1:eb:23:a4:6d:17:d6:8f:d9:25:64:c2:f1:f1:60:17:64:d8:e3:49
+# SHA256 Fingerprint: d7:a7:a0:fb:5d:7e:27:31:d7:71:e9:48:4e:bc:de:f7:1d:5f:0c:3e:0a:29:48:78:2b:c8:3e:e0:ea:69:9e:f4
+-----BEGIN CERTIFICATE-----
+MIIEMjCCAxqgAwIBAgIBATANBgkqhkiG9w0BAQUFADB7MQswCQYDVQQGEwJHQjEb
+MBkGA1UECAwSR3JlYXRlciBNYW5jaGVzdGVyMRAwDgYDVQQHDAdTYWxmb3JkMRow
+GAYDVQQKDBFDb21vZG8gQ0EgTGltaXRlZDEhMB8GA1UEAwwYQUFBIENlcnRpZmlj
+YXRlIFNlcnZpY2VzMB4XDTA0MDEwMTAwMDAwMFoXDTI4MTIzMTIzNTk1OVowezEL
+MAkGA1UEBhMCR0IxGzAZBgNVBAgMEkdyZWF0ZXIgTWFuY2hlc3RlcjEQMA4GA1UE
+BwwHU2FsZm9yZDEaMBgGA1UECgwRQ29tb2RvIENBIExpbWl0ZWQxITAfBgNVBAMM
+GEFBQSBDZXJ0aWZpY2F0ZSBTZXJ2aWNlczCCASIwDQYJKoZIhvcNAQEBBQADggEP
+ADCCAQoCggEBAL5AnfRu4ep2hxxNRUSOvkbIgwadwSr+GB+O5AL686tdUIoWMQua
+BtDFcCLNSS1UY8y2bmhGC1Pqy0wkwLxyTurxFa70VJoSCsN6sjNg4tqJVfMiWPPe
+3M/vg4aijJRPn2jymJBGhCfHdr/jzDUsi14HZGWCwEiwqJH5YZ92IFCokcdmtet4
+YgNW8IoaE+oxox6gmf049vYnMlhvB/VruPsUK6+3qszWY19zjNoFmag4qMsXeDZR
+rOme9Hg6jc8P2ULimAyrL58OAd7vn5lJ8S3frHRNG5i1R8XlKdH5kBjHYpy+g8cm
+ez6KJcfA3Z3mNWgQIJ2P2N7Sw4ScDV7oL8kCAwEAAaOBwDCBvTAdBgNVHQ4EFgQU
+oBEKIz6W8Qfs4q8p74Klf9AwpLQwDgYDVR0PAQH/BAQDAgEGMA8GA1UdEwEB/wQF
+MAMBAf8wewYDVR0fBHQwcjA4oDagNIYyaHR0cDovL2NybC5jb21vZG9jYS5jb20v
+QUFBQ2VydGlmaWNhdGVTZXJ2aWNlcy5jcmwwNqA0oDKGMGh0dHA6Ly9jcmwuY29t
+b2RvLm5ldC9BQUFDZXJ0aWZpY2F0ZVNlcnZpY2VzLmNybDANBgkqhkiG9w0BAQUF
+AAOCAQEACFb8AvCb6P+k+tZ7xkSAzk/ExfYAWMymtrwUSWgEdujm7l3sAg9g1o1Q
+GE8mTgHj5rCl7r+8dFRBv/38ErjHT1r0iWAFf2C3BUrz9vHCv8S5dIa2LX1rzNLz
+Rt0vxuBqw8M0Ayx9lt1awg6nCpnBBYurDC/zXDrPbDdVCYfeU0BsWO/8tqtlbgT2
+G9w84FoVxp7Z8VlIMCFlA2zs6SFz7JsDoeA3raAVGI/6ugLOpyypEBMs1OUIJqsi
+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"
+# Serial: 1289
+# MD5 Fingerprint: 5e:39:7b:dd:f8:ba:ec:82:e9:ac:62:ba:0c:54:00:2b
+# SHA1 Fingerprint: ca:3a:fb:cf:12:40:36:4b:44:b2:16:20:88:80:48:39:19:93:7c:f7
+# SHA256 Fingerprint: 85:a0:dd:7d:d7:20:ad:b7:ff:05:f8:3d:54:2b:20:9d:c7:ff:45:28:f7:d6:77:b1:83:89:fe:a5:e5:c4:9e:86
+-----BEGIN CERTIFICATE-----
+MIIFtzCCA5+gAwIBAgICBQkwDQYJKoZIhvcNAQEFBQAwRTELMAkGA1UEBhMCQk0x
+GTAXBgNVBAoTEFF1b1ZhZGlzIExpbWl0ZWQxGzAZBgNVBAMTElF1b1ZhZGlzIFJv
+b3QgQ0EgMjAeFw0wNjExMjQxODI3MDBaFw0zMTExMjQxODIzMzNaMEUxCzAJBgNV
+BAYTAkJNMRkwFwYDVQQKExBRdW9WYWRpcyBMaW1pdGVkMRswGQYDVQQDExJRdW9W
+YWRpcyBSb290IENBIDIwggIiMA0GCSqGSIb3DQEBAQUAA4ICDwAwggIKAoICAQCa
+GMpLlA0ALa8DKYrwD4HIrkwZhR0In6spRIXzL4GtMh6QRr+jhiYaHv5+HBg6XJxg
+Fyo6dIMzMH1hVBHL7avg5tKifvVrbxi3Cgst/ek+7wrGsxDp3MJGF/hd/aTa/55J
+WpzmM+Yklvc/ulsrHHo1wtZn/qtmUIttKGAr79dgw8eTvI02kfN/+NsRE8Scd3bB
+rrcCaoF6qUWD4gXmuVbBlDePSHFjIuwXZQeVikvfj8ZaCuWw419eaxGrDPmF60Tp
++ARz8un+XJiM9XOva7R+zdRcAitMOeGylZUtQofX1bOQQ7dsE/He3fbE+Ik/0XX1
+ksOR1YqI0JDs3G3eicJlcZaLDQP9nL9bFqyS2+r+eXyt66/3FsvbzSUr5R/7mp/i
+Ucw6UwxI5g69ybR2BlLmEROFcmMDBOAENisgGQLodKcftslWZvB1JdxnwQ5hYIiz
+PtGo/KPaHbDRsSNU30R2be1B2MGyIrZTHN81Hdyhdyox5C315eXbyOD/5YDXC2Og
+/zOhD7osFRXql7PSorW+8oyWHhqPHWykYTe5hnMz15eWniN9gqRMgeKh0bpnX5UH
+oycR7hYQe7xFSkyyBNKr79X9DFHOUGoIMfmR2gyPZFwDwzqLID9ujWc9Otb+fVuI
+yV77zGHcizN300QyNQliBJIWENieJ0f7OyHj+OsdWwIDAQABo4GwMIGtMA8GA1Ud
+EwEB/wQFMAMBAf8wCwYDVR0PBAQDAgEGMB0GA1UdDgQWBBQahGK8SEwzJQTU7tD2
+A8QZRtGUazBuBgNVHSMEZzBlgBQahGK8SEwzJQTU7tD2A8QZRtGUa6FJpEcwRTEL
+MAkGA1UEBhMCQk0xGTAXBgNVBAoTEFF1b1ZhZGlzIExpbWl0ZWQxGzAZBgNVBAMT
+ElF1b1ZhZGlzIFJvb3QgQ0EgMoICBQkwDQYJKoZIhvcNAQEFBQADggIBAD4KFk2f
+BluornFdLwUvZ+YTRYPENvbzwCYMDbVHZF34tHLJRqUDGCdViXh9duqWNIAXINzn
+g/iN/Ae42l9NLmeyhP3ZRPx3UIHmfLTJDQtyU/h2BwdBR5YM++CCJpNVjP4iH2Bl
+fF/nJrP3MpCYUNQ3cVX2kiF495V5+vgtJodmVjB3pjd4M1IQWK4/YY7yarHvGH5K
+WWPKjaJW1acvvFYfzznB4vsKqBUsfU16Y8Zsl0Q80m/DShcK+JDSV6IZUaUtl0Ha
+B0+pUNqQjZRG4T7wlP0QADj1O+hA4bRuVhogzG9Yje0uRY/W6ZM/57Es3zrWIozc
+hLsib9D45MY56QSIPMO661V6bYCZJPVsAfv4l7CUW+v90m/xd2gNNWQjrLhVoQPR
+TUIZ3Ph1WVaj+ahJefivDrkRoHy3au000LYmYjgahwz46P0u05B/B5EqHdZ+XIWD
+mbA4CD/pXvk1B+TJYm5Xf6dQlfe6yJvmjqIBxdZmv3lh8zwc4bmCXF2gw+nYSL0Z
+ohEUGW6yhhtoPkg3Goi3XZZenMfvJ2II4pEZXNLxId26F0KCl3GBUzGpn/Z9Yr9y
+4aOTHcyKJloJONDO1w2AFrR4pTqHTI2KpdVGl/IsELm8VCLAAVBpQ570su9t+Oza
+8eOx79+Rj1QqCyXBJhnEUhAFZdWCEOrCMc0u
+-----END CERTIFICATE-----
+
+# Issuer: CN=QuoVadis Root CA 3 O=QuoVadis Limited
+# Subject: CN=QuoVadis Root CA 3 O=QuoVadis Limited
+# Label: "QuoVadis Root CA 3"
+# Serial: 1478
+# MD5 Fingerprint: 31:85:3c:62:94:97:63:b9:aa:fd:89:4e:af:6f:e0:cf
+# SHA1 Fingerprint: 1f:49:14:f7:d8:74:95:1d:dd:ae:02:c0:be:fd:3a:2d:82:75:51:85
+# SHA256 Fingerprint: 18:f1:fc:7f:20:5d:f8:ad:dd:eb:7f:e0:07:dd:57:e3:af:37:5a:9c:4d:8d:73:54:6b:f4:f1:fe:d1:e1:8d:35
+-----BEGIN CERTIFICATE-----
+MIIGnTCCBIWgAwIBAgICBcYwDQYJKoZIhvcNAQEFBQAwRTELMAkGA1UEBhMCQk0x
+GTAXBgNVBAoTEFF1b1ZhZGlzIExpbWl0ZWQxGzAZBgNVBAMTElF1b1ZhZGlzIFJv
+b3QgQ0EgMzAeFw0wNjExMjQxOTExMjNaFw0zMTExMjQxOTA2NDRaMEUxCzAJBgNV
+BAYTAkJNMRkwFwYDVQQKExBRdW9WYWRpcyBMaW1pdGVkMRswGQYDVQQDExJRdW9W
+YWRpcyBSb290IENBIDMwggIiMA0GCSqGSIb3DQEBAQUAA4ICDwAwggIKAoICAQDM
+V0IWVJzmmNPTTe7+7cefQzlKZbPoFog02w1ZkXTPkrgEQK0CSzGrvI2RaNggDhoB
+4hp7Thdd4oq3P5kazethq8Jlph+3t723j/z9cI8LoGe+AaJZz3HmDyl2/7FWeUUr
+H556VOijKTVopAFPD6QuN+8bv+OPEKhyq1hX51SGyMnzW9os2l2ObjyjPtr7guXd
+8lyyBTNvijbO0BNO/79KDDRMpsMhvVAEVeuxu537RR5kFd5VAYwCdrXLoT9Cabwv
+vWhDFlaJKjdhkf2mrk7AyxRllDdLkgbvBNDInIjbC3uBr7E9KsRlOni27tyAsdLT
+mZw67mtaa7ONt9XOnMK+pUsvFrGeaDsGb659n/je7Mwpp5ijJUMv7/FfJuGITfhe
+btfZFG4ZM2mnO4SJk8RTVROhUXhA+LjJou57ulJCg54U7QVSWllWp5f8nT8KKdjc
+T5EOE7zelaTfi5m+rJsziO+1ga8bxiJTyPbH7pcUsMV8eFLI8M5ud2CEpukqdiDt
+WAEXMJPpGovgc2PZapKUSU60rUqFxKMiMPwJ7Wgic6aIDFUhWMXhOp8q3crhkODZ
+c6tsgLjoC2SToJyMGf+z0gzskSaHirOi4XCPLArlzW1oUevaPwV/izLmE1xr/l9A
+4iLItLRkT9a6fUg+qGkM17uGcclzuD87nSVL2v9A6wIDAQABo4IBlTCCAZEwDwYD
+VR0TAQH/BAUwAwEB/zCB4QYDVR0gBIHZMIHWMIHTBgkrBgEEAb5YAAMwgcUwgZMG
+CCsGAQUFBwICMIGGGoGDQW55IHVzZSBvZiB0aGlzIENlcnRpZmljYXRlIGNvbnN0
+aXR1dGVzIGFjY2VwdGFuY2Ugb2YgdGhlIFF1b1ZhZGlzIFJvb3QgQ0EgMyBDZXJ0
+aWZpY2F0ZSBQb2xpY3kgLyBDZXJ0aWZpY2F0aW9uIFByYWN0aWNlIFN0YXRlbWVu
+dC4wLQYIKwYBBQUHAgEWIWh0dHA6Ly93d3cucXVvdmFkaXNnbG9iYWwuY29tL2Nw
+czALBgNVHQ8EBAMCAQYwHQYDVR0OBBYEFPLAE+CCQz777i9nMpY1XNu4ywLQMG4G
+A1UdIwRnMGWAFPLAE+CCQz777i9nMpY1XNu4ywLQoUmkRzBFMQswCQYDVQQGEwJC
+TTEZMBcGA1UEChMQUXVvVmFkaXMgTGltaXRlZDEbMBkGA1UEAxMSUXVvVmFkaXMg
+Um9vdCBDQSAzggIFxjANBgkqhkiG9w0BAQUFAAOCAgEAT62gLEz6wPJv92ZVqyM0
+7ucp2sNbtrCD2dDQ4iH782CnO11gUyeim/YIIirnv6By5ZwkajGxkHon24QRiSem
+d1o417+shvzuXYO8BsbRd2sPbSQvS3pspweWyuOEn62Iix2rFo1bZhfZFvSLgNLd
++LJ2w/w4E6oM3kJpK27zPOuAJ9v1pkQNn1pVWQvVDVJIxa6f8i+AxeoyUDUSly7B
+4f/xI4hROJ/yZlZ25w9Rl6VSDE1JUZU2Pb+iSwwQHYaZTKrzchGT5Or2m9qoXadN
+t54CrnMAyNojA+j56hl0YgCUyyIgvpSnWbWCar6ZeXqp8kokUvd0/bpO5qgdAm6x
+DYBEwa7TIzdfu4V8K5Iu6H6li92Z4b8nby1dqnuH/grdS/yO9SbkbnBCbjPsMZ57
+k8HkyWkaPcBrTiJt7qtYTcbQQcEr6k8Sh17rRdhs9ZgC06DYVYoGmRmioHfRMJ6s
+zHXug/WwYjnPbFfiTNKRCw51KBuav/0aQ/HKd/s7j2G4aSgWQgRecCocIdiP4b0j
+Wy10QJLZYxkNc91pvGJHvOB0K7Lrfb5BG7XARsWhIstfTsEokt4YutUqKLsRixeT
+mJlglFwjz1onl14LBQaTNx47aTbrqZ5hHY8y2o4M1nQ+ewkk2gF3R8Q7zTSMmfXK
+4SVhM7JZG+Ju1zdXtg2pEto=
+-----END CERTIFICATE-----
+
+# Issuer: O=SECOM Trust.net OU=Security Communication RootCA1
+# Subject: O=SECOM Trust.net OU=Security Communication RootCA1
+# Label: "Security Communication Root CA"
+# Serial: 0
+# MD5 Fingerprint: f1:bc:63:6a:54:e0:b5:27:f5:cd:e7:1a:e3:4d:6e:4a
+# SHA1 Fingerprint: 36:b1:2b:49:f9:81:9e:d7:4c:9e:bc:38:0f:c6:56:8f:5d:ac:b2:f7
+# SHA256 Fingerprint: e7:5e:72:ed:9f:56:0e:ec:6e:b4:80:00:73:a4:3f:c3:ad:19:19:5a:39:22:82:01:78:95:97:4a:99:02:6b:6c
+-----BEGIN CERTIFICATE-----
+MIIDWjCCAkKgAwIBAgIBADANBgkqhkiG9w0BAQUFADBQMQswCQYDVQQGEwJKUDEY
+MBYGA1UEChMPU0VDT00gVHJ1c3QubmV0MScwJQYDVQQLEx5TZWN1cml0eSBDb21t
+dW5pY2F0aW9uIFJvb3RDQTEwHhcNMDMwOTMwMDQyMDQ5WhcNMjMwOTMwMDQyMDQ5
+WjBQMQswCQYDVQQGEwJKUDEYMBYGA1UEChMPU0VDT00gVHJ1c3QubmV0MScwJQYD
+VQQLEx5TZWN1cml0eSBDb21tdW5pY2F0aW9uIFJvb3RDQTEwggEiMA0GCSqGSIb3
+DQEBAQUAA4IBDwAwggEKAoIBAQCzs/5/022x7xZ8V6UMbXaKL0u/ZPtM7orw8yl8
+9f/uKuDp6bpbZCKamm8sOiZpUQWZJtzVHGpxxpp9Hp3dfGzGjGdnSj74cbAZJ6kJ
+DKaVv0uMDPpVmDvY6CKhS3E4eayXkmmziX7qIWgGmBSWh9JhNrxtJ1aeV+7AwFb9
+Ms+k2Y7CI9eNqPPYJayX5HA49LY6tJ07lyZDo6G8SVlyTCMwhwFY9k6+HGhWZq/N
+QV3Is00qVUarH9oe4kA92819uZKAnDfdDJZkndwi92SL32HeFZRSFaB9UslLqCHJ
+xrHty8OVYNEP8Ktw+N/LTX7s1vqr2b1/VPKl6Xn62dZ2JChzAgMBAAGjPzA9MB0G
+A1UdDgQWBBSgc0mZaNyFW2XjmygvV5+9M7wHSDALBgNVHQ8EBAMCAQYwDwYDVR0T
+AQH/BAUwAwEB/zANBgkqhkiG9w0BAQUFAAOCAQEAaECpqLvkT115swW1F7NgE+vG
+kl3g0dNq/vu+m22/xwVtWSDEHPC32oRYAmP6SBbvT6UL90qY8j+eG61Ha2POCEfr
+Uj94nK9NrvjVT8+amCoQQTlSxN3Zmw7vkwGusi7KaEIkQmywszo+zenaSMQVy+n5
+Bw+SUEmK3TGXX8npN6o7WWWXlDLJs58+OmJYxUmtYg5xpTKqL8aJdkNAExNnPaJU
+JRDL8Try2frbSVa7pv6nQTXD4IhhyYjH3zYQIphZ6rBK+1YWc26sTfcioU+tHXot
+RSflMMFe8toTyyVCUZVHA4xsIcx0Qu1T/zOLjw9XARYvz6buyXAiFL39vmwLAw==
+-----END CERTIFICATE-----
+
+# Issuer: CN=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"
+# Serial: 107108908803651509692980124233745014957
+# MD5 Fingerprint: a1:0b:44:b3:ca:10:d8:00:6e:9d:0f:d8:0f:92:0a:d1
+# SHA1 Fingerprint: b8:01:86:d1:eb:9c:86:a5:41:04:cf:30:54:f3:4c:52:b7:e5:58:c6
+# SHA256 Fingerprint: ce:cd:dc:90:50:99:d8:da:df:c5:b1:d2:09:b7:37:cb:e2:c1:8c:fb:2c:10:c0:ff:0b:cf:0d:32:86:fc:1a:a2
+-----BEGIN CERTIFICATE-----
+MIIEMDCCAxigAwIBAgIQUJRs7Bjq1ZxN1ZfvdY+grTANBgkqhkiG9w0BAQUFADCB
+gjELMAkGA1UEBhMCVVMxHjAcBgNVBAsTFXd3dy54cmFtcHNlY3VyaXR5LmNvbTEk
+MCIGA1UEChMbWFJhbXAgU2VjdXJpdHkgU2VydmljZXMgSW5jMS0wKwYDVQQDEyRY
+UmFtcCBHbG9iYWwgQ2VydGlmaWNhdGlvbiBBdXRob3JpdHkwHhcNMDQxMTAxMTcx
+NDA0WhcNMzUwMTAxMDUzNzE5WjCBgjELMAkGA1UEBhMCVVMxHjAcBgNVBAsTFXd3
+dy54cmFtcHNlY3VyaXR5LmNvbTEkMCIGA1UEChMbWFJhbXAgU2VjdXJpdHkgU2Vy
+dmljZXMgSW5jMS0wKwYDVQQDEyRYUmFtcCBHbG9iYWwgQ2VydGlmaWNhdGlvbiBB
+dXRob3JpdHkwggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIBAQCYJB69FbS6
+38eMpSe2OAtp87ZOqCwuIR1cRN8hXX4jdP5efrRKt6atH67gBhbim1vZZ3RrXYCP
+KZ2GG9mcDZhtdhAoWORlsH9KmHmf4MMxfoArtYzAQDsRhtDLooY2YKTVMIJt2W7Q
+DxIEM5dfT2Fa8OT5kavnHTu86M/0ay00fOJIYRyO82FEzG+gSqmUsE3a56k0enI4
+qEHMPJQRfevIpoy3hsvKMzvZPTeL+3o+hiznc9cKV6xkmxnr9A8ECIqsAxcZZPRa
+JSKNNCyy9mgdEm3Tih4U2sSPpuIjhdV6Db1q4Ons7Be7QhtnqiXtRYMh/MHJfNVi
+PvryxS3T/dRlAgMBAAGjgZ8wgZwwEwYJKwYBBAGCNxQCBAYeBABDAEEwCwYDVR0P
+BAQDAgGGMA8GA1UdEwEB/wQFMAMBAf8wHQYDVR0OBBYEFMZPoj0GY4QJnM5i5ASs
+jVy16bYbMDYGA1UdHwQvMC0wK6ApoCeGJWh0dHA6Ly9jcmwueHJhbXBzZWN1cml0
+eS5jb20vWEdDQS5jcmwwEAYJKwYBBAGCNxUBBAMCAQEwDQYJKoZIhvcNAQEFBQAD
+ggEBAJEVOQMBG2f7Shz5CmBbodpNl2L5JFMn14JkTpAuw0kbK5rc/Kh4ZzXxHfAR
+vbdI4xD2Dd8/0sm2qlWkSLoC295ZLhVbO50WfUfXN+pfTXYSNrsf16GBBEYgoyxt
+qZ4Bfj8pzgCT3/3JknOJiWSe5yvkHJEs0rnOfc5vMZnT5r7SHpDwCRR5XCOrTdLa
+IR9NmXmd4c8nnxCbHIgNsIpkQTG4DmyQJKSbXHGPurt+HBvbaoAPIbzp26a3QPSy
+i6mx5O+aGtA9aZnuqCij4Tyz8LIRnM98QObd50N9otg6tamN8jSZxNQQ4Qb9CYQQ
+O+7ETPTsJ3xCwnR8gooJybQDJbw=
+-----END CERTIFICATE-----
+
+# Issuer: O=The Go Daddy Group, Inc. OU=Go Daddy Class 2 Certification Authority
+# Subject: O=The Go Daddy Group, Inc. OU=Go Daddy Class 2 Certification Authority
+# Label: "Go Daddy Class 2 CA"
+# Serial: 0
+# MD5 Fingerprint: 91:de:06:25:ab:da:fd:32:17:0c:bb:25:17:2a:84:67
+# SHA1 Fingerprint: 27:96:ba:e6:3f:18:01:e2:77:26:1b:a0:d7:77:70:02:8f:20:ee:e4
+# SHA256 Fingerprint: c3:84:6b:f2:4b:9e:93:ca:64:27:4c:0e:c6:7c:1e:cc:5e:02:4f:fc:ac:d2:d7:40:19:35:0e:81:fe:54:6a:e4
+-----BEGIN CERTIFICATE-----
+MIIEADCCAuigAwIBAgIBADANBgkqhkiG9w0BAQUFADBjMQswCQYDVQQGEwJVUzEh
+MB8GA1UEChMYVGhlIEdvIERhZGR5IEdyb3VwLCBJbmMuMTEwLwYDVQQLEyhHbyBE
+YWRkeSBDbGFzcyAyIENlcnRpZmljYXRpb24gQXV0aG9yaXR5MB4XDTA0MDYyOTE3
+MDYyMFoXDTM0MDYyOTE3MDYyMFowYzELMAkGA1UEBhMCVVMxITAfBgNVBAoTGFRo
+ZSBHbyBEYWRkeSBHcm91cCwgSW5jLjExMC8GA1UECxMoR28gRGFkZHkgQ2xhc3Mg
+MiBDZXJ0aWZpY2F0aW9uIEF1dGhvcml0eTCCASAwDQYJKoZIhvcNAQEBBQADggEN
+ADCCAQgCggEBAN6d1+pXGEmhW+vXX0iG6r7d/+TvZxz0ZWizV3GgXne77ZtJ6XCA
+PVYYYwhv2vLM0D9/AlQiVBDYsoHUwHU9S3/Hd8M+eKsaA7Ugay9qK7HFiH7Eux6w
+wdhFJ2+qN1j3hybX2C32qRe3H3I2TqYXP2WYktsqbl2i/ojgC95/5Y0V4evLOtXi
+EqITLdiOr18SPaAIBQi2XKVlOARFmR6jYGB0xUGlcmIbYsUfb18aQr4CUWWoriMY
+avx4A6lNf4DD+qta/KFApMoZFv6yyO9ecw3ud72a9nmYvLEHZ6IVDd2gWMZEewo+
+YihfukEHU1jPEX44dMX4/7VpkI+EdOqXG68CAQOjgcAwgb0wHQYDVR0OBBYEFNLE
+sNKR1EwRcbNhyz2h/t2oatTjMIGNBgNVHSMEgYUwgYKAFNLEsNKR1EwRcbNhyz2h
+/t2oatTjoWekZTBjMQswCQYDVQQGEwJVUzEhMB8GA1UEChMYVGhlIEdvIERhZGR5
+IEdyb3VwLCBJbmMuMTEwLwYDVQQLEyhHbyBEYWRkeSBDbGFzcyAyIENlcnRpZmlj
+YXRpb24gQXV0aG9yaXR5ggEAMAwGA1UdEwQFMAMBAf8wDQYJKoZIhvcNAQEFBQAD
+ggEBADJL87LKPpH8EsahB4yOd6AzBhRckB4Y9wimPQoZ+YeAEW5p5JYXMP80kWNy
+OO7MHAGjHZQopDH2esRU1/blMVgDoszOYtuURXO1v0XJJLXVggKtI3lpjbi2Tc7P
+TMozI+gciKqdi0FuFskg5YmezTvacPd+mSYgFFQlq25zheabIZ0KbIIOqPjCDPoQ
+HmyW74cNxA9hi63ugyuV+I6ShHI56yDqg+2DzZduCLzrTia2cyvk0/ZM/iZx4mER
+dEr/VxqHD3VILs9RaRegAhJhldXRQLIQTO7ErBBDpqWeCtWVYpoNz4iCxTIM5Cuf
+ReYNnyicsbkqWletNw+vHX/bvZ8=
+-----END CERTIFICATE-----
+
+# Issuer: O=Starfield Technologies, Inc. OU=Starfield Class 2 Certification Authority
+# Subject: O=Starfield Technologies, Inc. OU=Starfield Class 2 Certification Authority
+# Label: "Starfield Class 2 CA"
+# Serial: 0
+# MD5 Fingerprint: 32:4a:4b:bb:c8:63:69:9b:be:74:9a:c6:dd:1d:46:24
+# SHA1 Fingerprint: ad:7e:1c:28:b0:64:ef:8f:60:03:40:20:14:c3:d0:e3:37:0e:b5:8a
+# SHA256 Fingerprint: 14:65:fa:20:53:97:b8:76:fa:a6:f0:a9:95:8e:55:90:e4:0f:cc:7f:aa:4f:b7:c2:c8:67:75:21:fb:5f:b6:58
+-----BEGIN CERTIFICATE-----
+MIIEDzCCAvegAwIBAgIBADANBgkqhkiG9w0BAQUFADBoMQswCQYDVQQGEwJVUzEl
+MCMGA1UEChMcU3RhcmZpZWxkIFRlY2hub2xvZ2llcywgSW5jLjEyMDAGA1UECxMp
+U3RhcmZpZWxkIENsYXNzIDIgQ2VydGlmaWNhdGlvbiBBdXRob3JpdHkwHhcNMDQw
+NjI5MTczOTE2WhcNMzQwNjI5MTczOTE2WjBoMQswCQYDVQQGEwJVUzElMCMGA1UE
+ChMcU3RhcmZpZWxkIFRlY2hub2xvZ2llcywgSW5jLjEyMDAGA1UECxMpU3RhcmZp
+ZWxkIENsYXNzIDIgQ2VydGlmaWNhdGlvbiBBdXRob3JpdHkwggEgMA0GCSqGSIb3
+DQEBAQUAA4IBDQAwggEIAoIBAQC3Msj+6XGmBIWtDBFk385N78gDGIc/oav7PKaf
+8MOh2tTYbitTkPskpD6E8J7oX+zlJ0T1KKY/e97gKvDIr1MvnsoFAZMej2YcOadN
++lq2cwQlZut3f+dZxkqZJRRU6ybH838Z1TBwj6+wRir/resp7defqgSHo9T5iaU0
+X9tDkYI22WY8sbi5gv2cOj4QyDvvBmVmepsZGD3/cVE8MC5fvj13c7JdBmzDI1aa
+K4UmkhynArPkPw2vCHmCuDY96pzTNbO8acr1zJ3o/WSNF4Azbl5KXZnJHoe0nRrA
+1W4TNSNe35tfPe/W93bC6j67eA0cQmdrBNj41tpvi/JEoAGrAgEDo4HFMIHCMB0G
+A1UdDgQWBBS/X7fRzt0fhvRbVazc1xDCDqmI5zCBkgYDVR0jBIGKMIGHgBS/X7fR
+zt0fhvRbVazc1xDCDqmI56FspGowaDELMAkGA1UEBhMCVVMxJTAjBgNVBAoTHFN0
+YXJmaWVsZCBUZWNobm9sb2dpZXMsIEluYy4xMjAwBgNVBAsTKVN0YXJmaWVsZCBD
+bGFzcyAyIENlcnRpZmljYXRpb24gQXV0aG9yaXR5ggEAMAwGA1UdEwQFMAMBAf8w
+DQYJKoZIhvcNAQEFBQADggEBAAWdP4id0ckaVaGsafPzWdqbAYcaT1epoXkJKtv3
+L7IezMdeatiDh6GX70k1PncGQVhiv45YuApnP+yz3SFmH8lU+nLMPUxA2IGvd56D
+eruix/U0F47ZEUD0/CwqTRV/p2JdLiXTAAsgGh1o+Re49L2L7ShZ3U0WixeDyLJl
+xy16paq8U4Zt3VekyvggQQto8PT7dL5WXXp59fkdheMtlb71cZBDzI0fmgAKhynp
+VSJYACPq4xJDKVtHCN2MQWplBqjlIapBtJUhlbl90TSrE9atvNziPTnNvT51cKEY
+WQPJIrSPnNVeKtelttQKbfi3QBFGmh95DmK/D5fs4C8fF5Q=
+-----END CERTIFICATE-----
+
+# Issuer: O=Government Root Certification Authority
+# Subject: O=Government Root Certification Authority
+# Label: "Taiwan GRCA"
+# Serial: 42023070807708724159991140556527066870
+# MD5 Fingerprint: 37:85:44:53:32:45:1f:20:f0:f3:95:e1:25:c4:43:4e
+# SHA1 Fingerprint: f4:8b:11:bf:de:ab:be:94:54:20:71:e6:41:de:6b:be:88:2b:40:b9
+# SHA256 Fingerprint: 76:00:29:5e:ef:e8:5b:9e:1f:d6:24:db:76:06:2a:aa:ae:59:81:8a:54:d2:77:4c:d4:c0:b2:c0:11:31:e1:b3
+-----BEGIN CERTIFICATE-----
+MIIFcjCCA1qgAwIBAgIQH51ZWtcvwgZEpYAIaeNe9jANBgkqhkiG9w0BAQUFADA/
+MQswCQYDVQQGEwJUVzEwMC4GA1UECgwnR292ZXJubWVudCBSb290IENlcnRpZmlj
+YXRpb24gQXV0aG9yaXR5MB4XDTAyMTIwNTEzMjMzM1oXDTMyMTIwNTEzMjMzM1ow
+PzELMAkGA1UEBhMCVFcxMDAuBgNVBAoMJ0dvdmVybm1lbnQgUm9vdCBDZXJ0aWZp
+Y2F0aW9uIEF1dGhvcml0eTCCAiIwDQYJKoZIhvcNAQEBBQADggIPADCCAgoCggIB
+AJoluOzMonWoe/fOW1mKydGGEghU7Jzy50b2iPN86aXfTEc2pBsBHH8eV4qNw8XR
+IePaJD9IK/ufLqGU5ywck9G/GwGHU5nOp/UKIXZ3/6m3xnOUT0b3EEk3+qhZSV1q
+gQdW8or5BtD3cCJNtLdBuTK4sfCxw5w/cP1T3YGq2GN49thTbqGsaoQkclSGxtKy
+yhwOeYHWtXBiCAEuTk8O1RGvqa/lmr/czIdtJuTJV6L7lvnM4T9TjGxMfptTCAts
+F/tnyMKtsc2AtJfcdgEWFelq16TheEfOhtX7MfP6Mb40qij7cEwdScevLJ1tZqa2
+jWR+tSBqnTuBto9AAGdLiYa4zGX+FVPpBMHWXx1E1wovJ5pGfaENda1UhhXcSTvx
+ls4Pm6Dso3pdvtUqdULle96ltqqvKKyskKw4t9VoNSZ63Pc78/1Fm9G7Q3hub/FC
+VGqY8A2tl+lSXunVanLeavcbYBT0peS2cWeqH+riTcFCQP5nRhc4L0c/cZyu5SHK
+YS1tB6iEfC3uUSXxY5Ce/eFXiGvviiNtsea9P63RPZYLhY3Naye7twWb7LuRqQoH
+EgKXTiCQ8P8NHuJBO9NAOueNXdpm5AKwB1KYXA6OM5zCppX7VRluTI6uSw+9wThN
+Xo+EHWbNxWCWtFJaBYmOlXqYwZE8lSOyDvR5tMl8wUohAgMBAAGjajBoMB0GA1Ud
+DgQWBBTMzO/MKWCkO7GStjz6MmKPrCUVOzAMBgNVHRMEBTADAQH/MDkGBGcqBwAE
+MTAvMC0CAQAwCQYFKw4DAhoFADAHBgVnKgMAAAQUA5vwIhP/lSg209yewDL7MTqK
+UWUwDQYJKoZIhvcNAQEFBQADggIBAECASvomyc5eMN1PhnR2WPWus4MzeKR6dBcZ
+TulStbngCnRiqmjKeKBMmo4sIy7VahIkv9Ro04rQ2JyftB8M3jh+Vzj8jeJPXgyf
+qzvS/3WXy6TjZwj/5cAWtUgBfen5Cv8b5Wppv3ghqMKnI6mGq3ZW6A4M9hPdKmaK
+ZEk9GhiHkASfQlK3T8v+R0F2Ne//AHY2RTKbxkaFXeIksB7jSJaYV0eUVXoPQbFE
+JPPB/hprv4j9wabak2BegUqZIJxIZhm1AHlUD7gsL0u8qV1bYH+Mh6XgUmMqvtg7
+hUAV/h62ZT/FS9p+tXo1KaMuephgIqP0fSdOLeq0dDzpD6QzDxARvBMB1uUO07+1
+EqLhRSPAzAhuYbeJq4PjJB7mXQfnHyA+z2fI56wwbSdLaG5LKlwCCDTb+HbkZ6Mm
+nD+iMsJKxYEYMRBWqoTvLQr/uB930r+lWKBi5NdLkXWNiYCYfm3LU05er/ayl4WX
+udpVBrkk7tfGOB5jGxI7leFYrPLfhNVfmS8NVVvmONsuP3LpSIXLuykTjx44Vbnz
+ssQwmSNOXfJIoRIM3BKQCZBUkQM8R+XVyWXgt0t97EfTsws+rZ7QdAAO671RrcDe
+LMDDav7v3Aun+kbfYNucpllQdSNpc5Oy+fwC00fmcc4QAu4njIT/rEUNE1yDMuAl
+pYYsfPQS
+-----END CERTIFICATE-----
+
+# Issuer: CN=DigiCert Assured ID Root CA O=DigiCert Inc OU=www.digicert.com
+# Subject: CN=DigiCert Assured ID Root CA O=DigiCert Inc OU=www.digicert.com
+# Label: "DigiCert Assured ID Root CA"
+# Serial: 17154717934120587862167794914071425081
+# MD5 Fingerprint: 87:ce:0b:7b:2a:0e:49:00:e1:58:71:9b:37:a8:93:72
+# SHA1 Fingerprint: 05:63:b8:63:0d:62:d7:5a:bb:c8:ab:1e:4b:df:b5:a8:99:b2:4d:43
+# SHA256 Fingerprint: 3e:90:99:b5:01:5e:8f:48:6c:00:bc:ea:9d:11:1e:e7:21:fa:ba:35:5a:89:bc:f1:df:69:56:1e:3d:c6:32:5c
+-----BEGIN CERTIFICATE-----
+MIIDtzCCAp+gAwIBAgIQDOfg5RfYRv6P5WD8G/AwOTANBgkqhkiG9w0BAQUFADBl
+MQswCQYDVQQGEwJVUzEVMBMGA1UEChMMRGlnaUNlcnQgSW5jMRkwFwYDVQQLExB3
+d3cuZGlnaWNlcnQuY29tMSQwIgYDVQQDExtEaWdpQ2VydCBBc3N1cmVkIElEIFJv
+b3QgQ0EwHhcNMDYxMTEwMDAwMDAwWhcNMzExMTEwMDAwMDAwWjBlMQswCQYDVQQG
+EwJVUzEVMBMGA1UEChMMRGlnaUNlcnQgSW5jMRkwFwYDVQQLExB3d3cuZGlnaWNl
+cnQuY29tMSQwIgYDVQQDExtEaWdpQ2VydCBBc3N1cmVkIElEIFJvb3QgQ0EwggEi
+MA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIBAQCtDhXO5EOAXLGH87dg+XESpa7c
+JpSIqvTO9SA5KFhgDPiA2qkVlTJhPLWxKISKityfCgyDF3qPkKyK53lTXDGEKvYP
+mDI2dsze3Tyoou9q+yHyUmHfnyDXH+Kx2f4YZNISW1/5WBg1vEfNoTb5a3/UsDg+
+wRvDjDPZ2C8Y/igPs6eD1sNuRMBhNZYW/lmci3Zt1/GiSw0r/wty2p5g0I6QNcZ4
+VYcgoc/lbQrISXwxmDNsIumH0DJaoroTghHtORedmTpyoeb6pNnVFzF1roV9Iq4/
+AUaG9ih5yLHa5FcXxH4cDrC0kqZWs72yl+2qp/C3xag/lRbQ/6GW6whfGHdPAgMB
+AAGjYzBhMA4GA1UdDwEB/wQEAwIBhjAPBgNVHRMBAf8EBTADAQH/MB0GA1UdDgQW
+BBRF66Kv9JLLgjEtUYunpyGd823IDzAfBgNVHSMEGDAWgBRF66Kv9JLLgjEtUYun
+pyGd823IDzANBgkqhkiG9w0BAQUFAAOCAQEAog683+Lt8ONyc3pklL/3cmbYMuRC
+dWKuh+vy1dneVrOfzM4UKLkNl2BcEkxY5NM9g0lFWJc1aRqoR+pWxnmrEthngYTf
+fwk8lOa4JiwgvT2zKIn3X/8i4peEH+ll74fg38FnSbNd67IJKusm7Xi+fT8r87cm
+NW1fiQG2SVufAQWbqz0lwcy2f8Lxb4bG+mRo64EtlOtCt/qMHt1i8b5QZ7dsvfPx
+H2sMNgcWfzd8qVttevESRmCD1ycEvkvOl77DZypoEd+A5wwzZr8TDRRu838fYxAe
++o0bJW1sj6W3YQGx0qMmoRBxna3iw/nDmVG3KwcIzi7mULKn+gpFL6Lw8g==
+-----END CERTIFICATE-----
+
+# Issuer: CN=DigiCert Global Root CA O=DigiCert Inc OU=www.digicert.com
+# Subject: CN=DigiCert Global Root CA O=DigiCert Inc OU=www.digicert.com
+# Label: "DigiCert Global Root CA"
+# Serial: 10944719598952040374951832963794454346
+# MD5 Fingerprint: 79:e4:a9:84:0d:7d:3a:96:d7:c0:4f:e2:43:4c:89:2e
+# SHA1 Fingerprint: a8:98:5d:3a:65:e5:e5:c4:b2:d7:d6:6d:40:c6:dd:2f:b1:9c:54:36
+# SHA256 Fingerprint: 43:48:a0:e9:44:4c:78:cb:26:5e:05:8d:5e:89:44:b4:d8:4f:96:62:bd:26:db:25:7f:89:34:a4:43:c7:01:61
+-----BEGIN CERTIFICATE-----
+MIIDrzCCApegAwIBAgIQCDvgVpBCRrGhdWrJWZHHSjANBgkqhkiG9w0BAQUFADBh
+MQswCQYDVQQGEwJVUzEVMBMGA1UEChMMRGlnaUNlcnQgSW5jMRkwFwYDVQQLExB3
+d3cuZGlnaWNlcnQuY29tMSAwHgYDVQQDExdEaWdpQ2VydCBHbG9iYWwgUm9vdCBD
+QTAeFw0wNjExMTAwMDAwMDBaFw0zMTExMTAwMDAwMDBaMGExCzAJBgNVBAYTAlVT
+MRUwEwYDVQQKEwxEaWdpQ2VydCBJbmMxGTAXBgNVBAsTEHd3dy5kaWdpY2VydC5j
+b20xIDAeBgNVBAMTF0RpZ2lDZXJ0IEdsb2JhbCBSb290IENBMIIBIjANBgkqhkiG
+9w0BAQEFAAOCAQ8AMIIBCgKCAQEA4jvhEXLeqKTTo1eqUKKPC3eQyaKl7hLOllsB
+CSDMAZOnTjC3U/dDxGkAV53ijSLdhwZAAIEJzs4bg7/fzTtxRuLWZscFs3YnFo97
+nh6Vfe63SKMI2tavegw5BmV/Sl0fvBf4q77uKNd0f3p4mVmFaG5cIzJLv07A6Fpt
+43C/dxC//AH2hdmoRBBYMql1GNXRor5H4idq9Joz+EkIYIvUX7Q6hL+hqkpMfT7P
+T19sdl6gSzeRntwi5m3OFBqOasv+zbMUZBfHWymeMr/y7vrTC0LUq7dBMtoM1O/4
+gdW7jVg/tRvoSSiicNoxBN33shbyTApOB6jtSj1etX+jkMOvJwIDAQABo2MwYTAO
+BgNVHQ8BAf8EBAMCAYYwDwYDVR0TAQH/BAUwAwEB/zAdBgNVHQ4EFgQUA95QNVbR
+TLtm8KPiGxvDl7I90VUwHwYDVR0jBBgwFoAUA95QNVbRTLtm8KPiGxvDl7I90VUw
+DQYJKoZIhvcNAQEFBQADggEBAMucN6pIExIK+t1EnE9SsPTfrgT1eXkIoyQY/Esr
+hMAtudXH/vTBH1jLuG2cenTnmCmrEbXjcKChzUyImZOMkXDiqw8cvpOp/2PV5Adg
+06O/nVsJ8dWO41P0jmP6P6fbtGbfYmbW0W5BjfIttep3Sp+dWOIrWcBAI+0tKIJF
+PnlUkiaY4IBIqDfv8NZ5YBberOgOzW6sRBc4L0na4UU+Krk2U886UAb3LujEV0ls
+YSEY1QSteDwsOoBrp+uvFRTp2InBuThs4pFsiv9kuXclVzDAGySj4dzp30d8tbQk
+CAUw7C29C79Fv1C5qfPrmAESrciIxpg0X40KPMbp1ZWVbd4=
+-----END CERTIFICATE-----
+
+# Issuer: CN=DigiCert High Assurance EV Root CA O=DigiCert Inc OU=www.digicert.com
+# Subject: CN=DigiCert High Assurance EV Root CA O=DigiCert Inc OU=www.digicert.com
+# Label: "DigiCert High Assurance EV Root CA"
+# Serial: 3553400076410547919724730734378100087
+# MD5 Fingerprint: d4:74:de:57:5c:39:b2:d3:9c:85:83:c5:c0:65:49:8a
+# SHA1 Fingerprint: 5f:b7:ee:06:33:e2:59:db:ad:0c:4c:9a:e6:d3:8f:1a:61:c7:dc:25
+# SHA256 Fingerprint: 74:31:e5:f4:c3:c1:ce:46:90:77:4f:0b:61:e0:54:40:88:3b:a9:a0:1e:d0:0b:a6:ab:d7:80:6e:d3:b1:18:cf
+-----BEGIN CERTIFICATE-----
+MIIDxTCCAq2gAwIBAgIQAqxcJmoLQJuPC3nyrkYldzANBgkqhkiG9w0BAQUFADBs
+MQswCQYDVQQGEwJVUzEVMBMGA1UEChMMRGlnaUNlcnQgSW5jMRkwFwYDVQQLExB3
+d3cuZGlnaWNlcnQuY29tMSswKQYDVQQDEyJEaWdpQ2VydCBIaWdoIEFzc3VyYW5j
+ZSBFViBSb290IENBMB4XDTA2MTExMDAwMDAwMFoXDTMxMTExMDAwMDAwMFowbDEL
+MAkGA1UEBhMCVVMxFTATBgNVBAoTDERpZ2lDZXJ0IEluYzEZMBcGA1UECxMQd3d3
+LmRpZ2ljZXJ0LmNvbTErMCkGA1UEAxMiRGlnaUNlcnQgSGlnaCBBc3N1cmFuY2Ug
+RVYgUm9vdCBDQTCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBAMbM5XPm
++9S75S0tMqbf5YE/yc0lSbZxKsPVlDRnogocsF9ppkCxxLeyj9CYpKlBWTrT3JTW
+PNt0OKRKzE0lgvdKpVMSOO7zSW1xkX5jtqumX8OkhPhPYlG++MXs2ziS4wblCJEM
+xChBVfvLWokVfnHoNb9Ncgk9vjo4UFt3MRuNs8ckRZqnrG0AFFoEt7oT61EKmEFB
+Ik5lYYeBQVCmeVyJ3hlKV9Uu5l0cUyx+mM0aBhakaHPQNAQTXKFx01p8VdteZOE3
+hzBWBOURtCmAEvF5OYiiAhF8J2a3iLd48soKqDirCmTCv2ZdlYTBoSUeh10aUAsg
+EsxBu24LUTi4S8sCAwEAAaNjMGEwDgYDVR0PAQH/BAQDAgGGMA8GA1UdEwEB/wQF
+MAMBAf8wHQYDVR0OBBYEFLE+w2kD+L9HAdSYJhoIAu9jZCvDMB8GA1UdIwQYMBaA
+FLE+w2kD+L9HAdSYJhoIAu9jZCvDMA0GCSqGSIb3DQEBBQUAA4IBAQAcGgaX3Nec
+nzyIZgYIVyHbIUf4KmeqvxgydkAQV8GK83rZEWWONfqe/EW1ntlMMUu4kehDLI6z
+eM7b41N5cdblIZQB2lWHmiRk9opmzN6cN82oNLFpmyPInngiK3BD41VHMWEZ71jF
+hS9OMPagMRYjyOfiZRYzy78aG6A9+MpeizGLYAiJLQwGXFK3xPkKmNEVX58Svnw2
+Yzi9RKR/5CYrCsSXaQ3pjOLAEFe4yHYSkVXySGnYvCoCWw9E1CAx2/S6cCZdkGCe
+vEsXCS+0yx5DaMkHJ8HSXPfqIbloEpw8nL+e/IBcm2PN7EeqJSdnoDfzAIJ9VNep
++OkuE6N36B9K
+-----END CERTIFICATE-----
+
+# Issuer: CN=Class 2 Primary CA O=Certplus
+# Subject: CN=Class 2 Primary CA O=Certplus
+# Label: "Certplus Class 2 Primary CA"
+# Serial: 177770208045934040241468760488327595043
+# MD5 Fingerprint: 88:2c:8c:52:b8:a2:3c:f3:f7:bb:03:ea:ae:ac:42:0b
+# SHA1 Fingerprint: 74:20:74:41:72:9c:dd:92:ec:79:31:d8:23:10:8d:c2:81:92:e2:bb
+# SHA256 Fingerprint: 0f:99:3c:8a:ef:97:ba:af:56:87:14:0e:d5:9a:d1:82:1b:b4:af:ac:f0:aa:9a:58:b5:d5:7a:33:8a:3a:fb:cb
+-----BEGIN CERTIFICATE-----
+MIIDkjCCAnqgAwIBAgIRAIW9S/PY2uNp9pTXX8OlRCMwDQYJKoZIhvcNAQEFBQAw
+PTELMAkGA1UEBhMCRlIxETAPBgNVBAoTCENlcnRwbHVzMRswGQYDVQQDExJDbGFz
+cyAyIFByaW1hcnkgQ0EwHhcNOTkwNzA3MTcwNTAwWhcNMTkwNzA2MjM1OTU5WjA9
+MQswCQYDVQQGEwJGUjERMA8GA1UEChMIQ2VydHBsdXMxGzAZBgNVBAMTEkNsYXNz
+IDIgUHJpbWFyeSBDQTCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBANxQ
+ltAS+DXSCHh6tlJw/W/uz7kRy1134ezpfgSN1sxvc0NXYKwzCkTsA18cgCSR5aiR
+VhKC9+Ar9NuuYS6JEI1rbLqzAr3VNsVINyPi8Fo3UjMXEuLRYE2+L0ER4/YXJQyL
+kcAbmXuZVg2v7tK8R1fjeUl7NIknJITesezpWE7+Tt9avkGtrAjFGA7v0lPubNCd
+EgETjdyAYveVqUSISnFOYFWe2yMZeVYHDD9jC1yw4r5+FfyUM1hBOHTE4Y+L3yas
+H7WLO7dDWWuwJKZtkIvEcupdM5i3y95ee++U8Rs+yskhwcWYAqqi9lt3m/V+llU0
+HGdpwPFC40es/CgcZlUCAwEAAaOBjDCBiTAPBgNVHRMECDAGAQH/AgEKMAsGA1Ud
+DwQEAwIBBjAdBgNVHQ4EFgQU43Mt38sOKAze3bOkynm4jrvoMIkwEQYJYIZIAYb4
+QgEBBAQDAgEGMDcGA1UdHwQwMC4wLKAqoCiGJmh0dHA6Ly93d3cuY2VydHBsdXMu
+Y29tL0NSTC9jbGFzczIuY3JsMA0GCSqGSIb3DQEBBQUAA4IBAQCnVM+IRBnL39R/
+AN9WM2K191EBkOvDP9GIROkkXe/nFL0gt5o8AP5tn9uQ3Nf0YtaLcF3n5QRIqWh8
+yfFC82x/xXp8HVGIutIKPidd3i1RTtMTZGnkLuPT55sJmabglZvOGtd/vjzOUrMR
+FcEPF80Du5wlFbqidon8BvEY0JNLDnyCt6X09l/+7UCmnYR0ObncHoUW2ikbhiMA
+ybuJfm6AiB4vFLQDJKgybwOaRywwvlbGp0ICcBvqQNi6BQNwB6SW//1IMwrh3KWB
+kJtN3X3n57LNXMhqlfil9o3EXXgIvnsG1knPGTZQIy4I5p4FTUcY1Rbpsda2ENW7
+l7+ijrRU
+-----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"
+# Serial: 13492815561806991280
+# MD5 Fingerprint: 24:77:d9:a8:91:d1:3b:fa:88:2d:c2:ff:f8:cd:33:93
+# SHA1 Fingerprint: d8:c5:38:8a:b7:30:1b:1b:6e:d4:7a:e6:45:25:3a:6f:9f:1a:27:61
+# SHA256 Fingerprint: 62:dd:0b:e9:b9:f5:0a:16:3e:a0:f8:e7:5c:05:3b:1e:ca:57:ea:55:c8:68:8f:64:7c:68:81:f2:c8:35:7b:95
+-----BEGIN CERTIFICATE-----
+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
+-----END CERTIFICATE-----
+
+# Issuer: CN=SwissSign Silver CA - G2 O=SwissSign AG
+# Subject: CN=SwissSign Silver CA - G2 O=SwissSign AG
+# Label: "SwissSign Silver CA - G2"
+# Serial: 5700383053117599563
+# MD5 Fingerprint: e0:06:a1:c9:7d:cf:c9:fc:0d:c0:56:75:96:d8:62:13
+# SHA1 Fingerprint: 9b:aa:e5:9f:56:ee:21:cb:43:5a:be:25:93:df:a7:f0:40:d1:1d:cb
+# SHA256 Fingerprint: be:6c:4d:a2:bb:b9:ba:59:b6:f3:93:97:68:37:42:46:c3:c0:05:99:3f:a9:8f:02:0d:1d:ed:be:d4:8a:81:d5
+-----BEGIN CERTIFICATE-----
+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
+-----END CERTIFICATE-----
+
+# Issuer: CN=GeoTrust Primary Certification Authority O=GeoTrust Inc.
+# Subject: CN=GeoTrust Primary Certification Authority O=GeoTrust Inc.
+# Label: "GeoTrust Primary Certification Authority"
+# Serial: 32798226551256963324313806436981982369
+# MD5 Fingerprint: 02:26:c3:01:5e:08:30:37:43:a9:d0:7d:cf:37:e6:bf
+# SHA1 Fingerprint: 32:3c:11:8e:1b:f7:b8:b6:52:54:e2:e2:10:0d:d6:02:90:37:f0:96
+# SHA256 Fingerprint: 37:d5:10:06:c5:12:ea:ab:62:64:21:f1:ec:8c:92:01:3f:c5:f8:2a:e9:8e:e5:33:eb:46:19:b8:de:b4:d0:6c
+-----BEGIN CERTIFICATE-----
+MIIDfDCCAmSgAwIBAgIQGKy1av1pthU6Y2yv2vrEoTANBgkqhkiG9w0BAQUFADBY
+MQswCQYDVQQGEwJVUzEWMBQGA1UEChMNR2VvVHJ1c3QgSW5jLjExMC8GA1UEAxMo
+R2VvVHJ1c3QgUHJpbWFyeSBDZXJ0aWZpY2F0aW9uIEF1dGhvcml0eTAeFw0wNjEx
+MjcwMDAwMDBaFw0zNjA3MTYyMzU5NTlaMFgxCzAJBgNVBAYTAlVTMRYwFAYDVQQK
+Ew1HZW9UcnVzdCBJbmMuMTEwLwYDVQQDEyhHZW9UcnVzdCBQcmltYXJ5IENlcnRp
+ZmljYXRpb24gQXV0aG9yaXR5MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKC
+AQEAvrgVe//UfH1nrYNke8hCUy3f9oQIIGHWAVlqnEQRr+92/ZV+zmEwu3qDXwK9
+AWbK7hWNb6EwnL2hhZ6UOvNWiAAxz9juapYC2e0DjPt1befquFUWBRaa9OBesYjA
+ZIVcFU2Ix7e64HXprQU9nceJSOC7KMgD4TCTZF5SwFlwIjVXiIrxlQqD17wxcwE0
+7e9GceBrAqg1cmuXm2bgyxx5X9gaBGgeRwLmnWDiNpcB3841kt++Z8dtd1k7j53W
+kBWUvEI0EME5+bEnPn7WinXFsq+W06Lem+SYvn3h6YGttm/81w7a4DSwDRp35+MI
+mO9Y+pyEtzavwt+s0vQQBnBxNQIDAQABo0IwQDAPBgNVHRMBAf8EBTADAQH/MA4G
+A1UdDwEB/wQEAwIBBjAdBgNVHQ4EFgQULNVQQZcVi/CPNmFbSvtr2ZnJM5IwDQYJ
+KoZIhvcNAQEFBQADggEBAFpwfyzdtzRP9YZRqSa+S7iq8XEN3GHHoOo0Hnp3DwQ1
+6CePbJC/kRYkRj5KTs4rFtULUh38H2eiAkUxT87z+gOneZ1TatnaYzr4gNfTmeGl
+4b7UVXGYNTq+k+qurUKykG/g/CFNNWMziUnWm07Kx+dOCQD32sfvmWKZd7aVIl6K
+oKv0uHiYyjgZmclynnjNS6yvGaBzEi38wkG6gZHaFloxt/m0cYASSJlyc1pZU8Fj
+UjPtp8nSOQJw+uCxQmYpqptR7TBUIhRf2asdweSU8Pj1K/fqynhG1riR/aYNKxoU
+AT6A8EKglQdebc3MS6RFjasS6LPeWuWgfOgPIh1a6Vk=
+-----END CERTIFICATE-----
+
+# Issuer: CN=thawte Primary Root CA O=thawte, Inc. OU=Certification Services Division/(c) 2006 thawte, Inc. - For authorized use only
+# Subject: CN=thawte Primary Root CA O=thawte, Inc. OU=Certification Services Division/(c) 2006 thawte, Inc. - For authorized use only
+# Label: "thawte Primary Root CA"
+# Serial: 69529181992039203566298953787712940909
+# MD5 Fingerprint: 8c:ca:dc:0b:22:ce:f5:be:72:ac:41:1a:11:a8:d8:12
+# SHA1 Fingerprint: 91:c6:d6:ee:3e:8a:c8:63:84:e5:48:c2:99:29:5c:75:6c:81:7b:81
+# SHA256 Fingerprint: 8d:72:2f:81:a9:c1:13:c0:79:1d:f1:36:a2:96:6d:b2:6c:95:0a:97:1d:b4:6b:41:99:f4:ea:54:b7:8b:fb:9f
+-----BEGIN CERTIFICATE-----
+MIIEIDCCAwigAwIBAgIQNE7VVyDV7exJ9C/ON9srbTANBgkqhkiG9w0BAQUFADCB
+qTELMAkGA1UEBhMCVVMxFTATBgNVBAoTDHRoYXd0ZSwgSW5jLjEoMCYGA1UECxMf
+Q2VydGlmaWNhdGlvbiBTZXJ2aWNlcyBEaXZpc2lvbjE4MDYGA1UECxMvKGMpIDIw
+MDYgdGhhd3RlLCBJbmMuIC0gRm9yIGF1dGhvcml6ZWQgdXNlIG9ubHkxHzAdBgNV
+BAMTFnRoYXd0ZSBQcmltYXJ5IFJvb3QgQ0EwHhcNMDYxMTE3MDAwMDAwWhcNMzYw
+NzE2MjM1OTU5WjCBqTELMAkGA1UEBhMCVVMxFTATBgNVBAoTDHRoYXd0ZSwgSW5j
+LjEoMCYGA1UECxMfQ2VydGlmaWNhdGlvbiBTZXJ2aWNlcyBEaXZpc2lvbjE4MDYG
+A1UECxMvKGMpIDIwMDYgdGhhd3RlLCBJbmMuIC0gRm9yIGF1dGhvcml6ZWQgdXNl
+IG9ubHkxHzAdBgNVBAMTFnRoYXd0ZSBQcmltYXJ5IFJvb3QgQ0EwggEiMA0GCSqG
+SIb3DQEBAQUAA4IBDwAwggEKAoIBAQCsoPD7gFnUnMekz52hWXMJEEUMDSxuaPFs
+W0hoSVk3/AszGcJ3f8wQLZU0HObrTQmnHNK4yZc2AreJ1CRfBsDMRJSUjQJib+ta
+3RGNKJpchJAQeg29dGYvajig4tVUROsdB58Hum/u6f1OCyn1PoSgAfGcq/gcfomk
+6KHYcWUNo1F77rzSImANuVud37r8UVsLr5iy6S7pBOhih94ryNdOwUxkHt3Ph1i6
+Sk/KaAcdHJ1KxtUvkcx8cXIcxcBn6zL9yZJclNqFwJu/U30rCfSMnZEfl2pSy94J
+NqR32HuHUETVPm4pafs5SSYeCaWAe0At6+gnhcn+Yf1+5nyXHdWdAgMBAAGjQjBA
+MA8GA1UdEwEB/wQFMAMBAf8wDgYDVR0PAQH/BAQDAgEGMB0GA1UdDgQWBBR7W0XP
+r87Lev0xkhpqtvNG61dIUDANBgkqhkiG9w0BAQUFAAOCAQEAeRHAS7ORtvzw6WfU
+DW5FvlXok9LOAz/t2iWwHVfLHjp2oEzsUHboZHIMpKnxuIvW1oeEuzLlQRHAd9mz
+YJ3rG9XRbkREqaYB7FViHXe4XI5ISXycO1cRrK1zN44veFyQaEfZYGDm/Ac9IiAX
+xPcW6cTYcvnIc3zfFi8VqT79aie2oetaupgf1eNNZAqdE8hhuvU5HIe6uL17In/2
+/qxAeeWsEG89jxt5dovEN7MhGITlNgDrYyCZuen+MwS7QcjBAvlEYyCegc5C09Y/
+LHbTY5xZ3Y+m4Q6gLkH3LpVHz7z9M/P2C2F+fpErgUfCJzDupxBdN49cOSvkBPB7
+jVaMaA==
+-----END CERTIFICATE-----
+
+# Issuer: CN=VeriSign Class 3 Public Primary Certification Authority - G5 O=VeriSign, Inc. OU=VeriSign Trust Network/(c) 2006 VeriSign, Inc. - For authorized use only
+# Subject: CN=VeriSign Class 3 Public Primary Certification Authority - G5 O=VeriSign, Inc. OU=VeriSign Trust Network/(c) 2006 VeriSign, Inc. - For authorized use only
+# Label: "VeriSign Class 3 Public Primary Certification Authority - G5"
+# Serial: 33037644167568058970164719475676101450
+# MD5 Fingerprint: cb:17:e4:31:67:3e:e2:09:fe:45:57:93:f3:0a:fa:1c
+# SHA1 Fingerprint: 4e:b6:d5:78:49:9b:1c:cf:5f:58:1e:ad:56:be:3d:9b:67:44:a5:e5
+# SHA256 Fingerprint: 9a:cf:ab:7e:43:c8:d8:80:d0:6b:26:2a:94:de:ee:e4:b4:65:99:89:c3:d0:ca:f1:9b:af:64:05:e4:1a:b7:df
+-----BEGIN CERTIFICATE-----
+MIIE0zCCA7ugAwIBAgIQGNrRniZ96LtKIVjNzGs7SjANBgkqhkiG9w0BAQUFADCB
+yjELMAkGA1UEBhMCVVMxFzAVBgNVBAoTDlZlcmlTaWduLCBJbmMuMR8wHQYDVQQL
+ExZWZXJpU2lnbiBUcnVzdCBOZXR3b3JrMTowOAYDVQQLEzEoYykgMjAwNiBWZXJp
+U2lnbiwgSW5jLiAtIEZvciBhdXRob3JpemVkIHVzZSBvbmx5MUUwQwYDVQQDEzxW
+ZXJpU2lnbiBDbGFzcyAzIFB1YmxpYyBQcmltYXJ5IENlcnRpZmljYXRpb24gQXV0
+aG9yaXR5IC0gRzUwHhcNMDYxMTA4MDAwMDAwWhcNMzYwNzE2MjM1OTU5WjCByjEL
+MAkGA1UEBhMCVVMxFzAVBgNVBAoTDlZlcmlTaWduLCBJbmMuMR8wHQYDVQQLExZW
+ZXJpU2lnbiBUcnVzdCBOZXR3b3JrMTowOAYDVQQLEzEoYykgMjAwNiBWZXJpU2ln
+biwgSW5jLiAtIEZvciBhdXRob3JpemVkIHVzZSBvbmx5MUUwQwYDVQQDEzxWZXJp
+U2lnbiBDbGFzcyAzIFB1YmxpYyBQcmltYXJ5IENlcnRpZmljYXRpb24gQXV0aG9y
+aXR5IC0gRzUwggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIBAQCvJAgIKXo1
+nmAMqudLO07cfLw8RRy7K+D+KQL5VwijZIUVJ/XxrcgxiV0i6CqqpkKzj/i5Vbex
+t0uz/o9+B1fs70PbZmIVYc9gDaTY3vjgw2IIPVQT60nKWVSFJuUrjxuf6/WhkcIz
+SdhDY2pSS9KP6HBRTdGJaXvHcPaz3BJ023tdS1bTlr8Vd6Gw9KIl8q8ckmcY5fQG
+BO+QueQA5N06tRn/Arr0PO7gi+s3i+z016zy9vA9r911kTMZHRxAy3QkGSGT2RT+
+rCpSx4/VBEnkjWNHiDxpg8v+R70rfk/Fla4OndTRQ8Bnc+MUCH7lP59zuDMKz10/
+NIeWiu5T6CUVAgMBAAGjgbIwga8wDwYDVR0TAQH/BAUwAwEB/zAOBgNVHQ8BAf8E
+BAMCAQYwbQYIKwYBBQUHAQwEYTBfoV2gWzBZMFcwVRYJaW1hZ2UvZ2lmMCEwHzAH
+BgUrDgMCGgQUj+XTGoasjY5rw8+AatRIGCx7GS4wJRYjaHR0cDovL2xvZ28udmVy
+aXNpZ24uY29tL3ZzbG9nby5naWYwHQYDVR0OBBYEFH/TZafC3ey78DAJ80M5+gKv
+MzEzMA0GCSqGSIb3DQEBBQUAA4IBAQCTJEowX2LP2BqYLz3q3JktvXf2pXkiOOzE
+p6B4Eq1iDkVwZMXnl2YtmAl+X6/WzChl8gGqCBpH3vn5fJJaCGkgDdk+bW48DW7Y
+5gaRQBi5+MHt39tBquCWIMnNZBU4gcmU7qKEKQsTb47bDN0lAtukixlE0kF6BWlK
+WE9gyn6CagsCqiUXObXbf+eEZSqVir2G3l6BFoMtEMze/aiCKm0oHw0LxOXnGiYZ
+4fQRbxC1lfznQgUy286dUV4otp6F01vvpX1FQHKOtw5rDgb7MzVIcbidJ4vEZV8N
+hnacRHr2lVz2XTIIM6RUthg/aFzyQkqFOFSDX9HoLPKsEdao7WNq
+-----END CERTIFICATE-----
+
+# Issuer: CN=SecureTrust CA O=SecureTrust Corporation
+# Subject: CN=SecureTrust CA O=SecureTrust Corporation
+# Label: "SecureTrust CA"
+# Serial: 17199774589125277788362757014266862032
+# MD5 Fingerprint: dc:32:c3:a7:6d:25:57:c7:68:09:9d:ea:2d:a9:a2:d1
+# SHA1 Fingerprint: 87:82:c6:c3:04:35:3b:cf:d2:96:92:d2:59:3e:7d:44:d9:34:ff:11
+# SHA256 Fingerprint: f1:c1:b5:0a:e5:a2:0d:d8:03:0e:c9:f6:bc:24:82:3d:d3:67:b5:25:57:59:b4:e7:1b:61:fc:e9:f7:37:5d:73
+-----BEGIN CERTIFICATE-----
+MIIDuDCCAqCgAwIBAgIQDPCOXAgWpa1Cf/DrJxhZ0DANBgkqhkiG9w0BAQUFADBI
+MQswCQYDVQQGEwJVUzEgMB4GA1UEChMXU2VjdXJlVHJ1c3QgQ29ycG9yYXRpb24x
+FzAVBgNVBAMTDlNlY3VyZVRydXN0IENBMB4XDTA2MTEwNzE5MzExOFoXDTI5MTIz
+MTE5NDA1NVowSDELMAkGA1UEBhMCVVMxIDAeBgNVBAoTF1NlY3VyZVRydXN0IENv
+cnBvcmF0aW9uMRcwFQYDVQQDEw5TZWN1cmVUcnVzdCBDQTCCASIwDQYJKoZIhvcN
+AQEBBQADggEPADCCAQoCggEBAKukgeWVzfX2FI7CT8rU4niVWJxB4Q2ZQCQXOZEz
+Zum+4YOvYlyJ0fwkW2Gz4BERQRwdbvC4u/jep4G6pkjGnx29vo6pQT64lO0pGtSO
+0gMdA+9tDWccV9cGrcrI9f4Or2YlSASWC12juhbDCE/RRvgUXPLIXgGZbf2IzIao
+wW8xQmxSPmjL8xk037uHGFaAJsTQ3MBv396gwpEWoGQRS0S8Hvbn+mPeZqx2pHGj
+7DaUaHp3pLHnDi+BeuK1cobvomuL8A/b01k/unK8RCSc43Oz969XL0Imnal0ugBS
+8kvNU3xHCzaFDmapCJcWNFfBZveA4+1wVMeT4C4oFVmHursCAwEAAaOBnTCBmjAT
+BgkrBgEEAYI3FAIEBh4EAEMAQTALBgNVHQ8EBAMCAYYwDwYDVR0TAQH/BAUwAwEB
+/zAdBgNVHQ4EFgQUQjK2FvoE/f5dS3rD/fdMQB1aQ68wNAYDVR0fBC0wKzApoCeg
+JYYjaHR0cDovL2NybC5zZWN1cmV0cnVzdC5jb20vU1RDQS5jcmwwEAYJKwYBBAGC
+NxUBBAMCAQAwDQYJKoZIhvcNAQEFBQADggEBADDtT0rhWDpSclu1pqNlGKa7UTt3
+6Z3q059c4EVlew3KW+JwULKUBRSuSceNQQcSc5R+DCMh/bwQf2AQWnL1mA6s7Ll/
+3XpvXdMc9P+IBWlCqQVxyLesJugutIxq/3HcuLHfmbx8IVQr5Fiiu1cprp6poxkm
+D5kuCLDv/WnPmRoJjeOnnyvJNjR7JLN4TJUXpAYmHrZkUjZfYGfZnMUFdAvnZyPS
+CPyI6a6Lf+Ew9Dd+/cYy2i2eRDAwbO4H3tI0/NL/QPZL9GZGBlSm8jIKYyYwa5vR
+3ItHuuG51WLQoqD0ZwV4KWMabwTW+MZMo5qxN7SN5ShLHZ4swrhovO0C7jE=
+-----END CERTIFICATE-----
+
+# Issuer: CN=Secure Global CA O=SecureTrust Corporation
+# Subject: CN=Secure Global CA O=SecureTrust Corporation
+# Label: "Secure Global CA"
+# Serial: 9751836167731051554232119481456978597
+# MD5 Fingerprint: cf:f4:27:0d:d4:ed:dc:65:16:49:6d:3d:da:bf:6e:de
+# SHA1 Fingerprint: 3a:44:73:5a:e5:81:90:1f:24:86:61:46:1e:3b:9c:c4:5f:f5:3a:1b
+# SHA256 Fingerprint: 42:00:f5:04:3a:c8:59:0e:bb:52:7d:20:9e:d1:50:30:29:fb:cb:d4:1c:a1:b5:06:ec:27:f1:5a:de:7d:ac:69
+-----BEGIN CERTIFICATE-----
+MIIDvDCCAqSgAwIBAgIQB1YipOjUiolN9BPI8PjqpTANBgkqhkiG9w0BAQUFADBK
+MQswCQYDVQQGEwJVUzEgMB4GA1UEChMXU2VjdXJlVHJ1c3QgQ29ycG9yYXRpb24x
+GTAXBgNVBAMTEFNlY3VyZSBHbG9iYWwgQ0EwHhcNMDYxMTA3MTk0MjI4WhcNMjkx
+MjMxMTk1MjA2WjBKMQswCQYDVQQGEwJVUzEgMB4GA1UEChMXU2VjdXJlVHJ1c3Qg
+Q29ycG9yYXRpb24xGTAXBgNVBAMTEFNlY3VyZSBHbG9iYWwgQ0EwggEiMA0GCSqG
+SIb3DQEBAQUAA4IBDwAwggEKAoIBAQCvNS7YrGxVaQZx5RNoJLNP2MwhR/jxYDiJ
+iQPpvepeRlMJ3Fz1Wuj3RSoC6zFh1ykzTM7HfAo3fg+6MpjhHZevj8fcyTiW89sa
+/FHtaMbQbqR8JNGuQsiWUGMu4P51/pinX0kuleM5M2SOHqRfkNJnPLLZ/kG5VacJ
+jnIFHovdRIWCQtBJwB1g8NEXLJXr9qXBkqPFwqcIYA1gBBCWeZ4WNOaptvolRTnI
+HmX5k/Wq8VLcmZg9pYYaDDUz+kulBAYVHDGA76oYa8J719rO+TMg1fW9ajMtgQT7
+sFzUnKPiXB3jqUJ1XnvUd+85VLrJChgbEplJL4hL/VBi0XPnj3pDAgMBAAGjgZ0w
+gZowEwYJKwYBBAGCNxQCBAYeBABDAEEwCwYDVR0PBAQDAgGGMA8GA1UdEwEB/wQF
+MAMBAf8wHQYDVR0OBBYEFK9EBMJBfkiD2045AuzshHrmzsmkMDQGA1UdHwQtMCsw
+KaAnoCWGI2h0dHA6Ly9jcmwuc2VjdXJldHJ1c3QuY29tL1NHQ0EuY3JsMBAGCSsG
+AQQBgjcVAQQDAgEAMA0GCSqGSIb3DQEBBQUAA4IBAQBjGghAfaReUw132HquHw0L
+URYD7xh8yOOvaliTFGCRsoTciE6+OYo68+aCiV0BN7OrJKQVDpI1WkpEXk5X+nXO
+H0jOZvQ8QCaSmGwb7iRGDBezUqXbpZGRzzfTb+cnCDpOGR86p1hcF895P4vkp9Mm
+I50mD1hp/Ed+stCNi5O/KU9DaXR2Z0vPB4zmAve14bRDtUstFJ/53CYNv6ZHdAbY
+iNE6KTCEztI5gGIbqMdXSbxqVVFnFUq+NQfk1XWYN3kwFNspnWzFacxHVaIw98xc
+f8LDmBxrThaA63p4ZUWiABqvDA1VZDRIuJK58bRQKfJPIx/abKwfROHdI3hRW8cW
+-----END CERTIFICATE-----
+
+# Issuer: CN=COMODO Certification Authority O=COMODO CA Limited
+# Subject: CN=COMODO Certification Authority O=COMODO CA Limited
+# Label: "COMODO Certification Authority"
+# Serial: 104350513648249232941998508985834464573
+# MD5 Fingerprint: 5c:48:dc:f7:42:72:ec:56:94:6d:1c:cc:71:35:80:75
+# SHA1 Fingerprint: 66:31:bf:9e:f7:4f:9e:b6:c9:d5:a6:0c:ba:6a:be:d1:f7:bd:ef:7b
+# SHA256 Fingerprint: 0c:2c:d6:3d:f7:80:6f:a3:99:ed:e8:09:11:6b:57:5b:f8:79:89:f0:65:18:f9:80:8c:86:05:03:17:8b:af:66
+-----BEGIN CERTIFICATE-----
+MIIEHTCCAwWgAwIBAgIQToEtioJl4AsC7j41AkblPTANBgkqhkiG9w0BAQUFADCB
+gTELMAkGA1UEBhMCR0IxGzAZBgNVBAgTEkdyZWF0ZXIgTWFuY2hlc3RlcjEQMA4G
+A1UEBxMHU2FsZm9yZDEaMBgGA1UEChMRQ09NT0RPIENBIExpbWl0ZWQxJzAlBgNV
+BAMTHkNPTU9ETyBDZXJ0aWZpY2F0aW9uIEF1dGhvcml0eTAeFw0wNjEyMDEwMDAw
+MDBaFw0yOTEyMzEyMzU5NTlaMIGBMQswCQYDVQQGEwJHQjEbMBkGA1UECBMSR3Jl
+YXRlciBNYW5jaGVzdGVyMRAwDgYDVQQHEwdTYWxmb3JkMRowGAYDVQQKExFDT01P
+RE8gQ0EgTGltaXRlZDEnMCUGA1UEAxMeQ09NT0RPIENlcnRpZmljYXRpb24gQXV0
+aG9yaXR5MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEA0ECLi3LjkRv3
+UcEbVASY06m/weaKXTuH+7uIzg3jLz8GlvCiKVCZrts7oVewdFFxze1CkU1B/qnI
+2GqGd0S7WWaXUF601CxwRM/aN5VCaTwwxHGzUvAhTaHYujl8HJ6jJJ3ygxaYqhZ8
+Q5sVW7euNJH+1GImGEaaP+vB+fGQV+useg2L23IwambV4EajcNxo2f8ESIl33rXp
++2dtQem8Ob0y2WIC8bGoPW43nOIv4tOiJovGuFVDiOEjPqXSJDlqR6sA1KGzqSX+
+DT+nHbrTUcELpNqsOO9VUCQFZUaTNE8tja3G1CEZ0o7KBWFxB3NH5YoZEr0ETc5O
+nKVIrLsm9wIDAQABo4GOMIGLMB0GA1UdDgQWBBQLWOWLxkwVN6RAqTCpIb5HNlpW
+/zAOBgNVHQ8BAf8EBAMCAQYwDwYDVR0TAQH/BAUwAwEB/zBJBgNVHR8EQjBAMD6g
+PKA6hjhodHRwOi8vY3JsLmNvbW9kb2NhLmNvbS9DT01PRE9DZXJ0aWZpY2F0aW9u
+QXV0aG9yaXR5LmNybDANBgkqhkiG9w0BAQUFAAOCAQEAPpiem/Yb6dc5t3iuHXIY
+SdOH5EOC6z/JqvWote9VfCFSZfnVDeFs9D6Mk3ORLgLETgdxb8CPOGEIqB6BCsAv
+IC9Bi5HcSEW88cbeunZrM8gALTFGTO3nnc+IlP8zwFboJIYmuNg4ON8qa90SzMc/
+RxdMosIGlgnW2/4/PEZB31jiVg88O8EckzXZOFKs7sjsLjBOlDW0JB9LeGna8gI4
+zJVSk/BwJVmcIGfE7vmLV2H0knZ9P4SNVbfo5azV8fUZVqZa+5Acr5Pr5RzUZ5dd
+BA6+C4OmF4O5MBKgxTMVBbkN+8cFduPYSo38NBejxiEovjBFMR7HeL5YYTisO+IB
+ZQ==
+-----END CERTIFICATE-----
+
+# Issuer: CN=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"
+# Serial: 41578283867086692638256921589707938090
+# MD5 Fingerprint: 7c:62:ff:74:9d:31:53:5e:68:4a:d5:78:aa:1e:bf:23
+# SHA1 Fingerprint: 9f:74:4e:9f:2b:4d:ba:ec:0f:31:2c:50:b6:56:3b:8e:2d:93:c3:11
+# SHA256 Fingerprint: 17:93:92:7a:06:14:54:97:89:ad:ce:2f:8f:34:f7:f0:b6:6d:0f:3a:e3:a3:b8:4d:21:ec:15:db:ba:4f:ad:c7
+-----BEGIN CERTIFICATE-----
+MIICiTCCAg+gAwIBAgIQH0evqmIAcFBUTAGem2OZKjAKBggqhkjOPQQDAzCBhTEL
+MAkGA1UEBhMCR0IxGzAZBgNVBAgTEkdyZWF0ZXIgTWFuY2hlc3RlcjEQMA4GA1UE
+BxMHU2FsZm9yZDEaMBgGA1UEChMRQ09NT0RPIENBIExpbWl0ZWQxKzApBgNVBAMT
+IkNPTU9ETyBFQ0MgQ2VydGlmaWNhdGlvbiBBdXRob3JpdHkwHhcNMDgwMzA2MDAw
+MDAwWhcNMzgwMTE4MjM1OTU5WjCBhTELMAkGA1UEBhMCR0IxGzAZBgNVBAgTEkdy
+ZWF0ZXIgTWFuY2hlc3RlcjEQMA4GA1UEBxMHU2FsZm9yZDEaMBgGA1UEChMRQ09N
+T0RPIENBIExpbWl0ZWQxKzApBgNVBAMTIkNPTU9ETyBFQ0MgQ2VydGlmaWNhdGlv
+biBBdXRob3JpdHkwdjAQBgcqhkjOPQIBBgUrgQQAIgNiAAQDR3svdcmCFYX7deSR
+FtSrYpn1PlILBs5BAH+X4QokPB0BBO490o0JlwzgdeT6+3eKKvUDYEs2ixYjFq0J
+cfRK9ChQtP6IHG4/bC8vCVlbpVsLM5niwz2J+Wos77LTBumjQjBAMB0GA1UdDgQW
+BBR1cacZSBm8nZ3qQUfflMRId5nTeTAOBgNVHQ8BAf8EBAMCAQYwDwYDVR0TAQH/
+BAUwAwEB/zAKBggqhkjOPQQDAwNoADBlAjEA7wNbeqy3eApyt4jf/7VGFAkK+qDm
+fQjGGoe9GKhzvSbKYAydzpmfz1wPMOG+FDHqAjAU9JM8SaczepBGR7NjfRObTrdv
+GDeAU/7dIOA1mjbRxwG55tzd8/8dLDoWV9mSOdY=
+-----END CERTIFICATE-----
+
+# Issuer: CN=OISTE WISeKey Global Root GA CA O=WISeKey OU=Copyright (c) 2005/OISTE Foundation Endorsed
+# Subject: CN=OISTE WISeKey Global Root GA CA O=WISeKey OU=Copyright (c) 2005/OISTE Foundation Endorsed
+# Label: "OISTE WISeKey Global Root GA CA"
+# Serial: 86718877871133159090080555911823548314
+# MD5 Fingerprint: bc:6c:51:33:a7:e9:d3:66:63:54:15:72:1b:21:92:93
+# SHA1 Fingerprint: 59:22:a1:e1:5a:ea:16:35:21:f8:98:39:6a:46:46:b0:44:1b:0f:a9
+# SHA256 Fingerprint: 41:c9:23:86:6a:b4:ca:d6:b7:ad:57:80:81:58:2e:02:07:97:a6:cb:df:4f:ff:78:ce:83:96:b3:89:37:d7:f5
+-----BEGIN CERTIFICATE-----
+MIID8TCCAtmgAwIBAgIQQT1yx/RrH4FDffHSKFTfmjANBgkqhkiG9w0BAQUFADCB
+ijELMAkGA1UEBhMCQ0gxEDAOBgNVBAoTB1dJU2VLZXkxGzAZBgNVBAsTEkNvcHly
+aWdodCAoYykgMjAwNTEiMCAGA1UECxMZT0lTVEUgRm91bmRhdGlvbiBFbmRvcnNl
+ZDEoMCYGA1UEAxMfT0lTVEUgV0lTZUtleSBHbG9iYWwgUm9vdCBHQSBDQTAeFw0w
+NTEyMTExNjAzNDRaFw0zNzEyMTExNjA5NTFaMIGKMQswCQYDVQQGEwJDSDEQMA4G
+A1UEChMHV0lTZUtleTEbMBkGA1UECxMSQ29weXJpZ2h0IChjKSAyMDA1MSIwIAYD
+VQQLExlPSVNURSBGb3VuZGF0aW9uIEVuZG9yc2VkMSgwJgYDVQQDEx9PSVNURSBX
+SVNlS2V5IEdsb2JhbCBSb290IEdBIENBMIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8A
+MIIBCgKCAQEAy0+zAJs9Nt350UlqaxBJH+zYK7LG+DKBKUOVTJoZIyEVRd7jyBxR
+VVuuk+g3/ytr6dTqvirdqFEr12bDYVxgAsj1znJ7O7jyTmUIms2kahnBAbtzptf2
+w93NvKSLtZlhuAGio9RN1AU9ka34tAhxZK9w8RxrfvbDd50kc3vkDIzh2TbhmYsF
+mQvtRTEJysIA2/dyoJaqlYfQjse2YXMNdmaM3Bu0Y6Kff5MTMPGhJ9vZ/yxViJGg
+4E8HsChWjBgbl0SOid3gF27nKu+POQoxhILYQBRJLnpB5Kf+42TMwVlxSywhp1t9
+4B3RLoGbw9ho972WG6xwsRYUC9tguSYBBQIDAQABo1EwTzALBgNVHQ8EBAMCAYYw
+DwYDVR0TAQH/BAUwAwEB/zAdBgNVHQ4EFgQUswN+rja8sHnR3JQmthG+IbJphpQw
+EAYJKwYBBAGCNxUBBAMCAQAwDQYJKoZIhvcNAQEFBQADggEBAEuh/wuHbrP5wUOx
+SPMowB0uyQlB+pQAHKSkq0lPjz0e701vvbyk9vImMMkQyh2I+3QZH4VFvbBsUfk2
+ftv1TDI6QU9bR8/oCy22xBmddMVHxjtqD6wU2zz0c5ypBd8A3HR4+vg1YFkCExh8
+vPtNsCBtQ7tgMHpnM1zFmdH4LTlSc/uMqpclXHLZCB6rTjzjgTGfA6b7wP4piFXa
+hNVQA7bihKOmNqoROgHhGEvWRGizPflTdISzRpFGlgC3gCy24eMQ4tui5yiPAZZi
+Fj4A4xylNoEYokxSdsARo27mHbrjWr42U8U+dY+GaSlYU7Wcu2+fXMUY7N0v4ZjJ
+/L7fCg0=
+-----END CERTIFICATE-----
+
+# Issuer: CN=Certigna O=Dhimyotis
+# Subject: CN=Certigna O=Dhimyotis
+# Label: "Certigna"
+# Serial: 18364802974209362175
+# MD5 Fingerprint: ab:57:a6:5b:7d:42:82:19:b5:d8:58:26:28:5e:fd:ff
+# SHA1 Fingerprint: b1:2e:13:63:45:86:a4:6f:1a:b2:60:68:37:58:2d:c4:ac:fd:94:97
+# SHA256 Fingerprint: e3:b6:a2:db:2e:d7:ce:48:84:2f:7a:c5:32:41:c7:b7:1d:54:14:4b:fb:40:c1:1f:3f:1d:0b:42:f5:ee:a1:2d
+-----BEGIN CERTIFICATE-----
+MIIDqDCCApCgAwIBAgIJAP7c4wEPyUj/MA0GCSqGSIb3DQEBBQUAMDQxCzAJBgNV
+BAYTAkZSMRIwEAYDVQQKDAlEaGlteW90aXMxETAPBgNVBAMMCENlcnRpZ25hMB4X
+DTA3MDYyOTE1MTMwNVoXDTI3MDYyOTE1MTMwNVowNDELMAkGA1UEBhMCRlIxEjAQ
+BgNVBAoMCURoaW15b3RpczERMA8GA1UEAwwIQ2VydGlnbmEwggEiMA0GCSqGSIb3
+DQEBAQUAA4IBDwAwggEKAoIBAQDIaPHJ1tazNHUmgh7stL7qXOEm7RFHYeGifBZ4
+QCHkYJ5ayGPhxLGWkv8YbWkj4Sti993iNi+RB7lIzw7sebYs5zRLcAglozyHGxny
+gQcPOJAZ0xH+hrTy0V4eHpbNgGzOOzGTtvKg0KmVEn2lmsxryIRWijOp5yIVUxbw
+zBfsV1/pogqYCd7jX5xv3EjjhQsVWqa6n6xI4wmy9/Qy3l40vhx4XUJbzg4ij02Q
+130yGLMLLGq/jj8UEYkgDncUtT2UCIf3JR7VsmAA7G8qKCVuKj4YYxclPz5EIBb2
+JsglrgVKtOdjLPOMFlN+XPsRGgjBRmKfIrjxwo1p3Po6WAbfAgMBAAGjgbwwgbkw
+DwYDVR0TAQH/BAUwAwEB/zAdBgNVHQ4EFgQUGu3+QTmQtCRZvgHyUtVF9lo53BEw
+ZAYDVR0jBF0wW4AUGu3+QTmQtCRZvgHyUtVF9lo53BGhOKQ2MDQxCzAJBgNVBAYT
+AkZSMRIwEAYDVQQKDAlEaGlteW90aXMxETAPBgNVBAMMCENlcnRpZ25hggkA/tzj
+AQ/JSP8wDgYDVR0PAQH/BAQDAgEGMBEGCWCGSAGG+EIBAQQEAwIABzANBgkqhkiG
+9w0BAQUFAAOCAQEAhQMeknH2Qq/ho2Ge6/PAD/Kl1NqV5ta+aDY9fm4fTIrv0Q8h
+bV6lUmPOEvjvKtpv6zf+EwLHyzs+ImvaYS5/1HI93TDhHkxAGYwP15zRgzB7mFnc
+fca5DClMoTOi62c6ZYTTluLtdkVwj7Ur3vkj1kluPBS1xp81HlDQwY9qcEQCYsuu
+HWhBp6pX6FOqB9IG9tUUBguRA3UsbHK1YZWaDYu5Def131TN3ubY1gkIl2PlwS6w
+t0QmwCbAr1UwnjvVNioZBPRcHv/PLLf/0P2HQBHVESO7SMAhqaQoLf0V+LBOK/Qw
+WyH8EZE0vkHve52Xdf+XlcCWWC/qu0bXu+TZLg==
+-----END CERTIFICATE-----
+
+# Issuer: CN=Deutsche Telekom Root CA 2 O=Deutsche Telekom AG OU=T-TeleSec Trust Center
+# Subject: CN=Deutsche Telekom Root CA 2 O=Deutsche Telekom AG OU=T-TeleSec Trust Center
+# Label: "Deutsche Telekom Root CA 2"
+# Serial: 38
+# MD5 Fingerprint: 74:01:4a:91:b1:08:c4:58:ce:47:cd:f0:dd:11:53:08
+# SHA1 Fingerprint: 85:a4:08:c0:9c:19:3e:5d:51:58:7d:cd:d6:13:30:fd:8c:de:37:bf
+# SHA256 Fingerprint: b6:19:1a:50:d0:c3:97:7f:7d:a9:9b:cd:aa:c8:6a:22:7d:ae:b9:67:9e:c7:0b:a3:b0:c9:d9:22:71:c1:70:d3
+-----BEGIN CERTIFICATE-----
+MIIDnzCCAoegAwIBAgIBJjANBgkqhkiG9w0BAQUFADBxMQswCQYDVQQGEwJERTEc
+MBoGA1UEChMTRGV1dHNjaGUgVGVsZWtvbSBBRzEfMB0GA1UECxMWVC1UZWxlU2Vj
+IFRydXN0IENlbnRlcjEjMCEGA1UEAxMaRGV1dHNjaGUgVGVsZWtvbSBSb290IENB
+IDIwHhcNOTkwNzA5MTIxMTAwWhcNMTkwNzA5MjM1OTAwWjBxMQswCQYDVQQGEwJE
+RTEcMBoGA1UEChMTRGV1dHNjaGUgVGVsZWtvbSBBRzEfMB0GA1UECxMWVC1UZWxl
+U2VjIFRydXN0IENlbnRlcjEjMCEGA1UEAxMaRGV1dHNjaGUgVGVsZWtvbSBSb290
+IENBIDIwggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIBAQCrC6M14IspFLEU
+ha88EOQ5bzVdSq7d6mGNlUn0b2SjGmBmpKlAIoTZ1KXleJMOaAGtuU1cOs7TuKhC
+QN/Po7qCWWqSG6wcmtoIKyUn+WkjR/Hg6yx6m/UTAtB+NHzCnjwAWav12gz1Mjwr
+rFDa1sPeg5TKqAyZMg4ISFZbavva4VhYAUlfckE8FQYBjl2tqriTtM2e66foai1S
+NNs671x1Udrb8zH57nGYMsRUFUQM+ZtV7a3fGAigo4aKSe5TBY8ZTNXeWHmb0moc
+QqvF1afPaA+W5OFhmHZhyJF81j4A4pFQh+GdCuatl9Idxjp9y7zaAzTVjlsB9WoH
+txa2bkp/AgMBAAGjQjBAMB0GA1UdDgQWBBQxw3kbuvVT1xfgiXotF2wKsyudMzAP
+BgNVHRMECDAGAQH/AgEFMA4GA1UdDwEB/wQEAwIBBjANBgkqhkiG9w0BAQUFAAOC
+AQEAlGRZrTlk5ynrE/5aw4sTV8gEJPB0d8Bg42f76Ymmg7+Wgnxu1MM9756Abrsp
+tJh6sTtU6zkXR34ajgv8HzFZMQSyzhfzLMdiNlXiItiJVbSYSKpk+tYcNthEeFpa
+IzpXl/V6ME+un2pMSyuOoAPjPuCp1NJ70rOo4nI8rZ7/gFnkm0W09juwzTkZmDLl
+6iFhkOQxIY40sfcvNUqFENrnijchvllj4PKFiDFT1FQUhXB59C4Gdyd1Lx+4ivn+
+xbrYNuSD7Odlt79jWvNGr4GUN9RBjNYj1h7P9WgbRGOiWrqnNVmh5XAFmw4jV5mU
+Cm26OWMohpLzGITY+9HPBVZkVw==
+-----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"
+# Serial: 28956088682735189655030529057352760477
+# MD5 Fingerprint: 1b:2e:00:ca:26:06:90:3d:ad:fe:6f:15:68:d3:6b:b3
+# SHA1 Fingerprint: 67:65:0d:f1:7e:8e:7e:5b:82:40:a4:f4:56:4b:cf:e2:3d:69:c6:f0
+# SHA256 Fingerprint: c0:a6:f4:dc:63:a2:4b:fd:cf:54:ef:2a:6a:08:2a:0a:72:de:35:80:3e:2f:f5:ff:52:7a:e5:d8:72:06:df:d5
+-----BEGIN CERTIFICATE-----
+MIIFsDCCA5igAwIBAgIQFci9ZUdcr7iXAF7kBtK8nTANBgkqhkiG9w0BAQUFADBe
+MQswCQYDVQQGEwJUVzEjMCEGA1UECgwaQ2h1bmdod2EgVGVsZWNvbSBDby4sIEx0
+ZC4xKjAoBgNVBAsMIWVQS0kgUm9vdCBDZXJ0aWZpY2F0aW9uIEF1dGhvcml0eTAe
+Fw0wNDEyMjAwMjMxMjdaFw0zNDEyMjAwMjMxMjdaMF4xCzAJBgNVBAYTAlRXMSMw
+IQYDVQQKDBpDaHVuZ2h3YSBUZWxlY29tIENvLiwgTHRkLjEqMCgGA1UECwwhZVBL
+SSBSb290IENlcnRpZmljYXRpb24gQXV0aG9yaXR5MIICIjANBgkqhkiG9w0BAQEF
+AAOCAg8AMIICCgKCAgEA4SUP7o3biDN1Z82tH306Tm2d0y8U82N0ywEhajfqhFAH
+SyZbCUNsIZ5qyNUD9WBpj8zwIuQf5/dqIjG3LBXy4P4AakP/h2XGtRrBp0xtInAh
+ijHyl3SJCRImHJ7K2RKilTza6We/CKBk49ZCt0Xvl/T29de1ShUCWH2YWEtgvM3X
+DZoTM1PRYfl61dd4s5oz9wCGzh1NlDivqOx4UXCKXBCDUSH3ET00hl7lSM2XgYI1
+TBnsZfZrxQWh7kcT1rMhJ5QQCtkkO7q+RBNGMD+XPNjX12ruOzjjK9SXDrkb5wdJ
+fzcq+Xd4z1TtW0ado4AOkUPB1ltfFLqfpo0kR0BZv3I4sjZsN/+Z0V0OWQqraffA
+sgRFelQArr5T9rXn4fg8ozHSqf4hUmTFpmfwdQcGlBSBVcYn5AGPF8Fqcde+S/uU
+WH1+ETOxQvdibBjWzwloPn9s9h6PYq2lY9sJpx8iQkEeb5mKPtf5P0B6ebClAZLS
+nT0IFaUQAS2zMnaolQ2zepr7BxB4EW/hj8e6DyUadCrlHJhBmd8hh+iVBmoKs2pH
+dmX2Os+PYhcZewoozRrSgx4hxyy/vv9haLdnG7t4TY3OZ+XkwY63I2binZB1NJip
+NiuKmpS5nezMirH4JYlcWrYvjB9teSSnUmjDhDXiZo1jDiVN1Rmy5nk3pyKdVDEC
+AwEAAaNqMGgwHQYDVR0OBBYEFB4M97Zn8uGSJglFwFU5Lnc/QkqiMAwGA1UdEwQF
+MAMBAf8wOQYEZyoHAAQxMC8wLQIBADAJBgUrDgMCGgUAMAcGBWcqAwAABBRFsMLH
+ClZ87lt4DJX5GFPBphzYEDANBgkqhkiG9w0BAQUFAAOCAgEACbODU1kBPpVJufGB
+uvl2ICO1J2B01GqZNF5sAFPZn/KmsSQHRGoqxqWOeBLoR9lYGxMqXnmbnwoqZ6Yl
+PwZpVnPDimZI+ymBV3QGypzqKOg4ZyYr8dW1P2WT+DZdjo2NQCCHGervJ8A9tDkP
+JXtoUHRVnAxZfVo9QZQlUgjgRywVMRnVvwdVxrsStZf0X4OFunHB2WyBEXYKCrC/
+gpf36j36+uwtqSiUO1bd0lEursC9CBWMd1I0ltabrNMdjmEPNXubrjlpC2JgQCA2
+j6/7Nu4tCEoduL+bXPjqpRugc6bY+G7gMwRfaKonh+3ZwZCc7b3jajWvY9+rGNm6
+5ulK6lCKD2GTHuItGeIwlDWSXQ62B68ZgI9HkFFLLk3dheLSClIKF5r8GrBQAuUB
+o2M3IUxExJtRmREOc5wGj1QupyheRDmHVi03vYVElOEMSyycw5KFNGHLD7ibSkNS
+/jQ6fbjpKdx2qcgw+BRxgMYeNkh0IkFch4LoGHGLQYlE535YW6i4jRPpp2zDR+2z
+Gp1iro2C6pSe3VkQw63d4k3jMdXH7OjysP6SHhYKGvzZ8/gntsm+HbRsZJB/9OTE
+W9c3rkIO3aQab3yIVMUWbuF6aC74Or8NpDyJO3inTmODBCEIZ43ygknQW/2xzQ+D
+hNQ+IIX3Sj0rnP0qCglN6oH4EZw=
+-----END CERTIFICATE-----
+
+# Issuer: O=certSIGN OU=certSIGN ROOT CA
+# Subject: O=certSIGN OU=certSIGN ROOT CA
+# Label: "certSIGN ROOT CA"
+# Serial: 35210227249154
+# MD5 Fingerprint: 18:98:c0:d6:e9:3a:fc:f9:b0:f5:0c:f7:4b:01:44:17
+# SHA1 Fingerprint: fa:b7:ee:36:97:26:62:fb:2d:b0:2a:f6:bf:03:fd:e8:7c:4b:2f:9b
+# SHA256 Fingerprint: ea:a9:62:c4:fa:4a:6b:af:eb:e4:15:19:6d:35:1c:cd:88:8d:4f:53:f3:fa:8a:e6:d7:c4:66:a9:4e:60:42:bb
+-----BEGIN CERTIFICATE-----
+MIIDODCCAiCgAwIBAgIGIAYFFnACMA0GCSqGSIb3DQEBBQUAMDsxCzAJBgNVBAYT
+AlJPMREwDwYDVQQKEwhjZXJ0U0lHTjEZMBcGA1UECxMQY2VydFNJR04gUk9PVCBD
+QTAeFw0wNjA3MDQxNzIwMDRaFw0zMTA3MDQxNzIwMDRaMDsxCzAJBgNVBAYTAlJP
+MREwDwYDVQQKEwhjZXJ0U0lHTjEZMBcGA1UECxMQY2VydFNJR04gUk9PVCBDQTCC
+ASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBALczuX7IJUqOtdu0KBuqV5Do
+0SLTZLrTk+jUrIZhQGpgV2hUhE28alQCBf/fm5oqrl0Hj0rDKH/v+yv6efHHrfAQ
+UySQi2bJqIirr1qjAOm+ukbuW3N7LBeCgV5iLKECZbO9xSsAfsT8AzNXDe3i+s5d
+RdY4zTW2ssHQnIFKquSyAVwdj1+ZxLGt24gh65AIgoDzMKND5pCCrlUoSe1b16kQ
+OA7+j0xbm0bqQfWwCHTD0IgztnzXdN/chNFDDnU5oSVAKOp4yw4sLjmdjItuFhwv
+JoIQ4uNllAoEwF73XVv4EOLQunpL+943AAAaWyjj0pxzPjKHmKHJUS/X3qwzs08C
+AwEAAaNCMEAwDwYDVR0TAQH/BAUwAwEB/zAOBgNVHQ8BAf8EBAMCAcYwHQYDVR0O
+BBYEFOCMm9slSbPxfIbWskKHC9BroNnkMA0GCSqGSIb3DQEBBQUAA4IBAQA+0hyJ
+LjX8+HXd5n9liPRyTMks1zJO890ZeUe9jjtbkw9QSSQTaxQGcu8J06Gh40CEyecY
+MnQ8SG4Pn0vU9x7Tk4ZkVJdjclDVVc/6IJMCopvDI5NOFlV2oHB5bc0hH88vLbwZ
+44gx+FkagQnIl6Z0x2DEW8xXjrJ1/RsCCdtZb3KTafcxQdaIOL+Hsr0Wefmq5L6I
+Jd1hJyMctTEHBDa0GpC9oHRxUIltvBTjD4au8as+x6AJzKNI0eDbZOeStc+vckNw
+i/nDhDwTqn6Sm1dTk/pwwpEOMfmbZ13pljheX7NzTogVZ96edhBiIL5VaZVDADlN
+9u6wWk5JRFRYX0KD
+-----END CERTIFICATE-----
+
+# Issuer: CN=GeoTrust Primary Certification Authority - G3 O=GeoTrust Inc. OU=(c) 2008 GeoTrust Inc. - For authorized use only
+# Subject: CN=GeoTrust Primary Certification Authority - G3 O=GeoTrust Inc. OU=(c) 2008 GeoTrust Inc. - For authorized use only
+# Label: "GeoTrust Primary Certification Authority - G3"
+# Serial: 28809105769928564313984085209975885599
+# MD5 Fingerprint: b5:e8:34:36:c9:10:44:58:48:70:6d:2e:83:d4:b8:05
+# SHA1 Fingerprint: 03:9e:ed:b8:0b:e7:a0:3c:69:53:89:3b:20:d2:d9:32:3a:4c:2a:fd
+# SHA256 Fingerprint: b4:78:b8:12:25:0d:f8:78:63:5c:2a:a7:ec:7d:15:5e:aa:62:5e:e8:29:16:e2:cd:29:43:61:88:6c:d1:fb:d4
+-----BEGIN CERTIFICATE-----
+MIID/jCCAuagAwIBAgIQFaxulBmyeUtB9iepwxgPHzANBgkqhkiG9w0BAQsFADCB
+mDELMAkGA1UEBhMCVVMxFjAUBgNVBAoTDUdlb1RydXN0IEluYy4xOTA3BgNVBAsT
+MChjKSAyMDA4IEdlb1RydXN0IEluYy4gLSBGb3IgYXV0aG9yaXplZCB1c2Ugb25s
+eTE2MDQGA1UEAxMtR2VvVHJ1c3QgUHJpbWFyeSBDZXJ0aWZpY2F0aW9uIEF1dGhv
+cml0eSAtIEczMB4XDTA4MDQwMjAwMDAwMFoXDTM3MTIwMTIzNTk1OVowgZgxCzAJ
+BgNVBAYTAlVTMRYwFAYDVQQKEw1HZW9UcnVzdCBJbmMuMTkwNwYDVQQLEzAoYykg
+MjAwOCBHZW9UcnVzdCBJbmMuIC0gRm9yIGF1dGhvcml6ZWQgdXNlIG9ubHkxNjA0
+BgNVBAMTLUdlb1RydXN0IFByaW1hcnkgQ2VydGlmaWNhdGlvbiBBdXRob3JpdHkg
+LSBHMzCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBANziXmJYHTNXOTIz
++uvLh4yn1ErdBojqZI4xmKU4kB6Yzy5jK/BGvESyiaHAKAxJcCGVn2TAppMSAmUm
+hsalifD614SgcK9PGpc/BkTVyetyEH3kMSj7HGHmKAdEc5IiaacDiGydY8hS2pgn
+5whMcD60yRLBxWeDXTPzAxHsatBT4tG6NmCUgLthY2xbF37fQJQeqw3CIShwiP/W
+JmxsYAQlTlV+fe+/lEjetx3dcI0FX4ilm/LC7urRQEFtYjgdVgbFA0dRIBn8exAL
+DmKudlW/X3e+PkkBUz2YJQN2JFodtNuJ6nnltrM7P7pMKEF/BqxqjsHQ9gUdfeZC
+huOl1UcCAwEAAaNCMEAwDwYDVR0TAQH/BAUwAwEB/zAOBgNVHQ8BAf8EBAMCAQYw
+HQYDVR0OBBYEFMR5yo6hTgMdHNxr2zFblD4/MH8tMA0GCSqGSIb3DQEBCwUAA4IB
+AQAtxRPPVoB7eni9n64smefv2t+UXglpp+duaIy9cr5HqQ6XErhK8WTTOd8lNNTB
+zU6B8A8ExCSzNJbGpqow32hhc9f5joWJ7w5elShKKiePEI4ufIbEAp7aDHdlDkQN
+kv39sxY2+hENHYwOB4lqKVb3cvTdFZx3NWZXqxNT2I7BQMXXExZacse3aQHEerGD
+AWh9jUGhlBjBJVz88P6DAod8DQ3PLghcSkANPuyBYeYk28rgDi0Hsj5W3I31QYUH
+SJsMC8tJP33st/3LjWeJGqvtux6jAAgIFyqCXDFdRootD4abdNlF+9RAsXqqaC2G
+spki4cErx5z481+oghLrGREt
+-----END CERTIFICATE-----
+
+# Issuer: CN=thawte Primary Root CA - G2 O=thawte, Inc. OU=(c) 2007 thawte, Inc. - For authorized use only
+# Subject: CN=thawte Primary Root CA - G2 O=thawte, Inc. OU=(c) 2007 thawte, Inc. - For authorized use only
+# Label: "thawte Primary Root CA - G2"
+# Serial: 71758320672825410020661621085256472406
+# MD5 Fingerprint: 74:9d:ea:60:24:c4:fd:22:53:3e:cc:3a:72:d9:29:4f
+# SHA1 Fingerprint: aa:db:bc:22:23:8f:c4:01:a1:27:bb:38:dd:f4:1d:db:08:9e:f0:12
+# SHA256 Fingerprint: a4:31:0d:50:af:18:a6:44:71:90:37:2a:86:af:af:8b:95:1f:fb:43:1d:83:7f:1e:56:88:b4:59:71:ed:15:57
+-----BEGIN CERTIFICATE-----
+MIICiDCCAg2gAwIBAgIQNfwmXNmET8k9Jj1Xm67XVjAKBggqhkjOPQQDAzCBhDEL
+MAkGA1UEBhMCVVMxFTATBgNVBAoTDHRoYXd0ZSwgSW5jLjE4MDYGA1UECxMvKGMp
+IDIwMDcgdGhhd3RlLCBJbmMuIC0gRm9yIGF1dGhvcml6ZWQgdXNlIG9ubHkxJDAi
+BgNVBAMTG3RoYXd0ZSBQcmltYXJ5IFJvb3QgQ0EgLSBHMjAeFw0wNzExMDUwMDAw
+MDBaFw0zODAxMTgyMzU5NTlaMIGEMQswCQYDVQQGEwJVUzEVMBMGA1UEChMMdGhh
+d3RlLCBJbmMuMTgwNgYDVQQLEy8oYykgMjAwNyB0aGF3dGUsIEluYy4gLSBGb3Ig
+YXV0aG9yaXplZCB1c2Ugb25seTEkMCIGA1UEAxMbdGhhd3RlIFByaW1hcnkgUm9v
+dCBDQSAtIEcyMHYwEAYHKoZIzj0CAQYFK4EEACIDYgAEotWcgnuVnfFSeIf+iha/
+BebfowJPDQfGAFG6DAJSLSKkQjnE/o/qycG+1E3/n3qe4rF8mq2nhglzh9HnmuN6
+papu+7qzcMBniKI11KOasf2twu8x+qi58/sIxpHR+ymVo0IwQDAPBgNVHRMBAf8E
+BTADAQH/MA4GA1UdDwEB/wQEAwIBBjAdBgNVHQ4EFgQUmtgAMADna3+FGO6Lts6K
+DPgR4bswCgYIKoZIzj0EAwMDaQAwZgIxAN344FdHW6fmCsO99YCKlzUNG4k8VIZ3
+KMqh9HneteY4sPBlcIx/AlTCv//YoT7ZzwIxAMSNlPzcU9LcnXgWHxUzI1NS41ox
+XZ3Krr0TKUQNJ1uo52icEvdYPy5yAlejj6EULg==
+-----END CERTIFICATE-----
+
+# Issuer: CN=thawte Primary Root CA - G3 O=thawte, Inc. OU=Certification Services Division/(c) 2008 thawte, Inc. - For authorized use only
+# Subject: CN=thawte Primary Root CA - G3 O=thawte, Inc. OU=Certification Services Division/(c) 2008 thawte, Inc. - For authorized use only
+# Label: "thawte Primary Root CA - G3"
+# Serial: 127614157056681299805556476275995414779
+# MD5 Fingerprint: fb:1b:5d:43:8a:94:cd:44:c6:76:f2:43:4b:47:e7:31
+# SHA1 Fingerprint: f1:8b:53:8d:1b:e9:03:b6:a6:f0:56:43:5b:17:15:89:ca:f3:6b:f2
+# SHA256 Fingerprint: 4b:03:f4:58:07:ad:70:f2:1b:fc:2c:ae:71:c9:fd:e4:60:4c:06:4c:f5:ff:b6:86:ba:e5:db:aa:d7:fd:d3:4c
+-----BEGIN CERTIFICATE-----
+MIIEKjCCAxKgAwIBAgIQYAGXt0an6rS0mtZLL/eQ+zANBgkqhkiG9w0BAQsFADCB
+rjELMAkGA1UEBhMCVVMxFTATBgNVBAoTDHRoYXd0ZSwgSW5jLjEoMCYGA1UECxMf
+Q2VydGlmaWNhdGlvbiBTZXJ2aWNlcyBEaXZpc2lvbjE4MDYGA1UECxMvKGMpIDIw
+MDggdGhhd3RlLCBJbmMuIC0gRm9yIGF1dGhvcml6ZWQgdXNlIG9ubHkxJDAiBgNV
+BAMTG3RoYXd0ZSBQcmltYXJ5IFJvb3QgQ0EgLSBHMzAeFw0wODA0MDIwMDAwMDBa
+Fw0zNzEyMDEyMzU5NTlaMIGuMQswCQYDVQQGEwJVUzEVMBMGA1UEChMMdGhhd3Rl
+LCBJbmMuMSgwJgYDVQQLEx9DZXJ0aWZpY2F0aW9uIFNlcnZpY2VzIERpdmlzaW9u
+MTgwNgYDVQQLEy8oYykgMjAwOCB0aGF3dGUsIEluYy4gLSBGb3IgYXV0aG9yaXpl
+ZCB1c2Ugb25seTEkMCIGA1UEAxMbdGhhd3RlIFByaW1hcnkgUm9vdCBDQSAtIEcz
+MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAsr8nLPvb2FvdeHsbnndm
+gcs+vHyu86YnmjSjaDFxODNi5PNxZnmxqWWjpYvVj2AtP0LMqmsywCPLLEHd5N/8
+YZzic7IilRFDGF/Eth9XbAoFWCLINkw6fKXRz4aviKdEAhN0cXMKQlkC+BsUa0Lf
+b1+6a4KinVvnSr0eAXLbS3ToO39/fR8EtCab4LRarEc9VbjXsCZSKAExQGbY2SS9
+9irY7CFJXJv2eul/VTV+lmuNk5Mny5K76qxAwJ/C+IDPXfRa3M50hqY+bAtTyr2S
+zhkGcuYMXDhpxwTWvGzOW/b3aJzcJRVIiKHpqfiYnODz1TEoYRFsZ5aNOZnLwkUk
+OQIDAQABo0IwQDAPBgNVHRMBAf8EBTADAQH/MA4GA1UdDwEB/wQEAwIBBjAdBgNV
+HQ4EFgQUrWyqlGCc7eT/+j4KdCtjA/e2Wb8wDQYJKoZIhvcNAQELBQADggEBABpA
+2JVlrAmSicY59BDlqQ5mU1143vokkbvnRFHfxhY0Cu9qRFHqKweKA3rD6z8KLFIW
+oCtDuSWQP3CpMyVtRRooOyfPqsMpQhvfO0zAMzRbQYi/aytlryjvsvXDqmbOe1bu
+t8jLZ8HJnBoYuMTDSQPxYA5QzUbF83d597YV4Djbxy8ooAw/dyZ02SUS2jHaGh7c
+KUGRIjxpp7sC8rZcJwOJ9Abqm+RyguOhCcHpABnTPtRwa7pxpqpYrvS76Wy274fM
+m7v/OeZWYdMKp8RcTGB7BXcmer/YB1IsYvdwY9k5vG8cwnncdimvzsUsZAReiDZu
+MdRAGmI0Nj81Aa6sY6A=
+-----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=VeriSign Class 3 Public Primary Certification Authority - G4 O=VeriSign, Inc. OU=VeriSign Trust Network/(c) 2007 VeriSign, Inc. - For authorized use only
+# Subject: CN=VeriSign Class 3 Public Primary Certification Authority - G4 O=VeriSign, Inc. OU=VeriSign Trust Network/(c) 2007 VeriSign, Inc. - For authorized use only
+# Label: "VeriSign Class 3 Public Primary Certification Authority - G4"
+# Serial: 63143484348153506665311985501458640051
+# MD5 Fingerprint: 3a:52:e1:e7:fd:6f:3a:e3:6f:f3:6f:99:1b:f9:22:41
+# SHA1 Fingerprint: 22:d5:d8:df:8f:02:31:d1:8d:f7:9d:b7:cf:8a:2d:64:c9:3f:6c:3a
+# SHA256 Fingerprint: 69:dd:d7:ea:90:bb:57:c9:3e:13:5d:c8:5e:a6:fc:d5:48:0b:60:32:39:bd:c4:54:fc:75:8b:2a:26:cf:7f:79
+-----BEGIN CERTIFICATE-----
+MIIDhDCCAwqgAwIBAgIQL4D+I4wOIg9IZxIokYesszAKBggqhkjOPQQDAzCByjEL
+MAkGA1UEBhMCVVMxFzAVBgNVBAoTDlZlcmlTaWduLCBJbmMuMR8wHQYDVQQLExZW
+ZXJpU2lnbiBUcnVzdCBOZXR3b3JrMTowOAYDVQQLEzEoYykgMjAwNyBWZXJpU2ln
+biwgSW5jLiAtIEZvciBhdXRob3JpemVkIHVzZSBvbmx5MUUwQwYDVQQDEzxWZXJp
+U2lnbiBDbGFzcyAzIFB1YmxpYyBQcmltYXJ5IENlcnRpZmljYXRpb24gQXV0aG9y
+aXR5IC0gRzQwHhcNMDcxMTA1MDAwMDAwWhcNMzgwMTE4MjM1OTU5WjCByjELMAkG
+A1UEBhMCVVMxFzAVBgNVBAoTDlZlcmlTaWduLCBJbmMuMR8wHQYDVQQLExZWZXJp
+U2lnbiBUcnVzdCBOZXR3b3JrMTowOAYDVQQLEzEoYykgMjAwNyBWZXJpU2lnbiwg
+SW5jLiAtIEZvciBhdXRob3JpemVkIHVzZSBvbmx5MUUwQwYDVQQDEzxWZXJpU2ln
+biBDbGFzcyAzIFB1YmxpYyBQcmltYXJ5IENlcnRpZmljYXRpb24gQXV0aG9yaXR5
+IC0gRzQwdjAQBgcqhkjOPQIBBgUrgQQAIgNiAASnVnp8Utpkmw4tXNherJI9/gHm
+GUo9FANL+mAnINmDiWn6VMaaGF5VKmTeBvaNSjutEDxlPZCIBIngMGGzrl0Bp3ve
+fLK+ymVhAIau2o970ImtTR1ZmkGxvEeA3J5iw/mjgbIwga8wDwYDVR0TAQH/BAUw
+AwEB/zAOBgNVHQ8BAf8EBAMCAQYwbQYIKwYBBQUHAQwEYTBfoV2gWzBZMFcwVRYJ
+aW1hZ2UvZ2lmMCEwHzAHBgUrDgMCGgQUj+XTGoasjY5rw8+AatRIGCx7GS4wJRYj
+aHR0cDovL2xvZ28udmVyaXNpZ24uY29tL3ZzbG9nby5naWYwHQYDVR0OBBYEFLMW
+kf3upm7ktS5Jj4d4gYDs5bG1MAoGCCqGSM49BAMDA2gAMGUCMGYhDBgmYFo4e1ZC
+4Kf8NoRRkSAsdk1DPcQdhCPQrNZ8NQbOzWm9kA3bbEhCHQ6qQgIxAJw9SDkjOVga
+FRJZap7v1VmyHVIsmXHNxynfGyphe3HR3vPA5Q06Sqotp9iGKt0uEA==
+-----END CERTIFICATE-----
+
+# Issuer: CN=NetLock Arany (Class Gold) F\u0151tan\xfas\xedtv\xe1ny O=NetLock Kft. OU=Tan\xfas\xedtv\xe1nykiad\xf3k (Certification Services)
+# Subject: CN=NetLock Arany (Class Gold) F\u0151tan\xfas\xedtv\xe1ny O=NetLock Kft. OU=Tan\xfas\xedtv\xe1nykiad\xf3k (Certification Services)
+# Label: "NetLock Arany (Class Gold) F\u0151tan\xfas\xedtv\xe1ny"
+# Serial: 80544274841616
+# MD5 Fingerprint: c5:a1:b7:ff:73:dd:d6:d7:34:32:18:df:fc:3c:ad:88
+# SHA1 Fingerprint: 06:08:3f:59:3f:15:a1:04:a0:69:a4:6b:a9:03:d0:06:b7:97:09:91
+# SHA256 Fingerprint: 6c:61:da:c3:a2:de:f0:31:50:6b:e0:36:d2:a6:fe:40:19:94:fb:d1:3d:f9:c8:d4:66:59:92:74:c4:46:ec:98
+-----BEGIN CERTIFICATE-----
+MIIEFTCCAv2gAwIBAgIGSUEs5AAQMA0GCSqGSIb3DQEBCwUAMIGnMQswCQYDVQQG
+EwJIVTERMA8GA1UEBwwIQnVkYXBlc3QxFTATBgNVBAoMDE5ldExvY2sgS2Z0LjE3
+MDUGA1UECwwuVGFuw7pzw610dsOhbnlraWFkw7NrIChDZXJ0aWZpY2F0aW9uIFNl
+cnZpY2VzKTE1MDMGA1UEAwwsTmV0TG9jayBBcmFueSAoQ2xhc3MgR29sZCkgRsWR
+dGFuw7pzw610dsOhbnkwHhcNMDgxMjExMTUwODIxWhcNMjgxMjA2MTUwODIxWjCB
+pzELMAkGA1UEBhMCSFUxETAPBgNVBAcMCEJ1ZGFwZXN0MRUwEwYDVQQKDAxOZXRM
+b2NrIEtmdC4xNzA1BgNVBAsMLlRhbsO6c8OtdHbDoW55a2lhZMOzayAoQ2VydGlm
+aWNhdGlvbiBTZXJ2aWNlcykxNTAzBgNVBAMMLE5ldExvY2sgQXJhbnkgKENsYXNz
+IEdvbGQpIEbFkXRhbsO6c8OtdHbDoW55MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8A
+MIIBCgKCAQEAxCRec75LbRTDofTjl5Bu0jBFHjzuZ9lk4BqKf8owyoPjIMHj9DrT
+lF8afFttvzBPhCf2nx9JvMaZCpDyD/V/Q4Q3Y1GLeqVw/HpYzY6b7cNGbIRwXdrz
+AZAj/E4wqX7hJ2Pn7WQ8oLjJM2P+FpD/sLj916jAwJRDC7bVWaaeVtAkH3B5r9s5
+VA1lddkVQZQBr17s9o3x/61k/iCa11zr/qYfCGSji3ZVrR47KGAuhyXoqq8fxmRG
+ILdwfzzeSNuWU7c5d+Qa4scWhHaXWy+7GRWF+GmF9ZmnqfI0p6m2pgP8b4Y9VHx2
+BJtr+UBdADTHLpl1neWIA6pN+APSQnbAGwIDAKiLo0UwQzASBgNVHRMBAf8ECDAG
+AQH/AgEEMA4GA1UdDwEB/wQEAwIBBjAdBgNVHQ4EFgQUzPpnk/C2uNClwB7zU/2M
+U9+D15YwDQYJKoZIhvcNAQELBQADggEBAKt/7hwWqZw8UQCgwBEIBaeZ5m8BiFRh
+bvG5GK1Krf6BQCOUL/t1fC8oS2IkgYIL9WHxHG64YTjrgfpioTtaYtOUZcTh5m2C
++C8lcLIhJsFyUR+MLMOEkMNaj7rP9KdlpeuY0fsFskZ1FSNqb4VjMIDw1Z4fKRzC
+bLBQWV2QWzuoDTDPv31/zvGdg73JRm4gpvlhUbohL3u+pRVjodSVh/GeufOJ8z2F
+uLjbvrW5KfnaNwUASZQDhETnv0Mxz3WLJdH0pmT1kvarBes96aULNmLazAZfNou2
+XjG4Kvte9nHfRCaexOYNkbQudZWAUWpLMKawYqGT8ZvYzsRjdT9ZR7E=
+-----END CERTIFICATE-----
+
+# Issuer: CN=Staat der Nederlanden Root CA - G2 O=Staat der Nederlanden
+# Subject: CN=Staat der Nederlanden Root CA - G2 O=Staat der Nederlanden
+# Label: "Staat der Nederlanden Root CA - G2"
+# Serial: 10000012
+# MD5 Fingerprint: 7c:a5:0f:f8:5b:9a:7d:6d:30:ae:54:5a:e3:42:a2:8a
+# SHA1 Fingerprint: 59:af:82:79:91:86:c7:b4:75:07:cb:cf:03:57:46:eb:04:dd:b7:16
+# SHA256 Fingerprint: 66:8c:83:94:7d:a6:3b:72:4b:ec:e1:74:3c:31:a0:e6:ae:d0:db:8e:c5:b3:1b:e3:77:bb:78:4f:91:b6:71:6f
+-----BEGIN CERTIFICATE-----
+MIIFyjCCA7KgAwIBAgIEAJiWjDANBgkqhkiG9w0BAQsFADBaMQswCQYDVQQGEwJO
+TDEeMBwGA1UECgwVU3RhYXQgZGVyIE5lZGVybGFuZGVuMSswKQYDVQQDDCJTdGFh
+dCBkZXIgTmVkZXJsYW5kZW4gUm9vdCBDQSAtIEcyMB4XDTA4MDMyNjExMTgxN1oX
+DTIwMDMyNTExMDMxMFowWjELMAkGA1UEBhMCTkwxHjAcBgNVBAoMFVN0YWF0IGRl
+ciBOZWRlcmxhbmRlbjErMCkGA1UEAwwiU3RhYXQgZGVyIE5lZGVybGFuZGVuIFJv
+b3QgQ0EgLSBHMjCCAiIwDQYJKoZIhvcNAQEBBQADggIPADCCAgoCggIBAMVZ5291
+qj5LnLW4rJ4L5PnZyqtdj7U5EILXr1HgO+EASGrP2uEGQxGZqhQlEq0i6ABtQ8Sp
+uOUfiUtnvWFI7/3S4GCI5bkYYCjDdyutsDeqN95kWSpGV+RLufg3fNU254DBtvPU
+Z5uW6M7XxgpT0GtJlvOjCwV3SPcl5XCsMBQgJeN/dVrlSPhOewMHBPqCYYdu8DvE
+pMfQ9XQ+pV0aCPKbJdL2rAQmPlU6Yiile7Iwr/g3wtG61jj99O9JMDeZJiFIhQGp
+5Rbn3JBV3w/oOM2ZNyFPXfUib2rFEhZgF1XyZWampzCROME4HYYEhLoaJXhena/M
+UGDWE4dS7WMfbWV9whUYdMrhfmQpjHLYFhN9C0lK8SgbIHRrxT3dsKpICT0ugpTN
+GmXZK4iambwYfp/ufWZ8Pr2UuIHOzZgweMFvZ9C+X+Bo7d7iscksWXiSqt8rYGPy
+5V6548r6f1CGPqI0GAwJaCgRHOThuVw+R7oyPxjMW4T182t0xHJ04eOLoEq9jWYv
+6q012iDTiIJh8BIitrzQ1aTsr1SIJSQ8p22xcik/Plemf1WvbibG/ufMQFxRRIEK
+eN5KzlW/HdXZt1bv8Hb/C3m1r737qWmRRpdogBQ2HbN/uymYNqUg+oJgYjOk7Na6
+B6duxc8UpufWkjTYgfX8HV2qXB72o007uPc5AgMBAAGjgZcwgZQwDwYDVR0TAQH/
+BAUwAwEB/zBSBgNVHSAESzBJMEcGBFUdIAAwPzA9BggrBgEFBQcCARYxaHR0cDov
+L3d3dy5wa2lvdmVyaGVpZC5ubC9wb2xpY2llcy9yb290LXBvbGljeS1HMjAOBgNV
+HQ8BAf8EBAMCAQYwHQYDVR0OBBYEFJFoMocVHYnitfGsNig0jQt8YojrMA0GCSqG
+SIb3DQEBCwUAA4ICAQCoQUpnKpKBglBu4dfYszk78wIVCVBR7y29JHuIhjv5tLyS
+CZa59sCrI2AGeYwRTlHSeYAz+51IvuxBQ4EffkdAHOV6CMqqi3WtFMTC6GY8ggen
+5ieCWxjmD27ZUD6KQhgpxrRW/FYQoAUXvQwjf/ST7ZwaUb7dRUG/kSS0H4zpX897
+IZmflZ85OkYcbPnNe5yQzSipx6lVu6xiNGI1E0sUOlWDuYaNkqbG9AclVMwWVxJK
+gnjIFNkXgiYtXSAfea7+1HAWFpWD2DU5/1JddRwWxRNVz0fMdWVSSt7wsKfkCpYL
++63C4iWEst3kvX5ZbJvw8NjnyvLplzh+ib7M+zkXYT9y2zqR2GUBGR2tUKRXCnxL
+vJxxcypFURmFzI79R6d0lR2o0a9OF7FpJsKqeFdbxU2n5Z4FF5TKsl+gSRiNNOkm
+bEgeqmiSBeGCc1qb3AdbCG19ndeNIdn8FCCqwkXfP+cAslHkwvgFuXkajDTznlvk
+N1trSt8sV4pAWja63XVECDdCcAz+3F4hoKOKwJCcaNpQ5kUQR3i2TtJlycM33+FC
+Y7BXN0Ute4qcvwXqZVUz9zkQxSgqIXobisQk+T8VyJoVIPVVYpbtbZNQvOSqeK3Z
+ywplh6ZmwcSBo3c6WB4L7oOLnR7SUqTMHW+wmG2UMbX4cQrcufx9MmDm66+KAQ==
+-----END CERTIFICATE-----
+
+# Issuer: CN=Hongkong Post Root CA 1 O=Hongkong Post
+# Subject: CN=Hongkong Post Root CA 1 O=Hongkong Post
+# Label: "Hongkong Post Root CA 1"
+# Serial: 1000
+# MD5 Fingerprint: a8:0d:6f:39:78:b9:43:6d:77:42:6d:98:5a:cc:23:ca
+# SHA1 Fingerprint: d6:da:a8:20:8d:09:d2:15:4d:24:b5:2f:cb:34:6e:b2:58:b2:8a:58
+# SHA256 Fingerprint: f9:e6:7d:33:6c:51:00:2a:c0:54:c6:32:02:2d:66:dd:a2:e7:e3:ff:f1:0a:d0:61:ed:31:d8:bb:b4:10:cf:b2
+-----BEGIN CERTIFICATE-----
+MIIDMDCCAhigAwIBAgICA+gwDQYJKoZIhvcNAQEFBQAwRzELMAkGA1UEBhMCSEsx
+FjAUBgNVBAoTDUhvbmdrb25nIFBvc3QxIDAeBgNVBAMTF0hvbmdrb25nIFBvc3Qg
+Um9vdCBDQSAxMB4XDTAzMDUxNTA1MTMxNFoXDTIzMDUxNTA0NTIyOVowRzELMAkG
+A1UEBhMCSEsxFjAUBgNVBAoTDUhvbmdrb25nIFBvc3QxIDAeBgNVBAMTF0hvbmdr
+b25nIFBvc3QgUm9vdCBDQSAxMIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKC
+AQEArP84tulmAknjorThkPlAj3n54r15/gK97iSSHSL22oVyaf7XPwnU3ZG1ApzQ
+jVrhVcNQhrkpJsLj2aDxaQMoIIBFIi1WpztUlVYiWR8o3x8gPW2iNr4joLFutbEn
+PzlTCeqrauh0ssJlXI6/fMN4hM2eFvz1Lk8gKgifd/PFHsSaUmYeSF7jEAaPIpjh
+ZY4bXSNmO7ilMlHIhqqhqZ5/dpTCpmy3QfDVyAY45tQM4vM7TG1QjMSDJ8EThFk9
+nnV0ttgCXjqQesBCNnLsak3c78QA3xMYV18meMjWCnl3v/evt3a5pQuEF10Q6m/h
+q5URX208o1xNg1vysxmKgIsLhwIDAQABoyYwJDASBgNVHRMBAf8ECDAGAQH/AgED
+MA4GA1UdDwEB/wQEAwIBxjANBgkqhkiG9w0BAQUFAAOCAQEADkbVPK7ih9legYsC
+mEEIjEy82tvuJxuC52pF7BaLT4Wg87JwvVqWuspube5Gi27nKi6Wsxkz67SfqLI3
+7piol7Yutmcn1KZJ/RyTZXaeQi/cImyaT/JaFTmxcdcrUehtHJjA2Sr0oYJ71clB
+oiMBdDhViw+5LmeiIAQ32pwL0xch4I+XeTRvhEgCIDMb5jREn5Fw9IBehEPCKdJs
+EhTkYY2sEJCehFC78JZvRZ+K88psT/oROhUVRsPNH4NbLUES7VBnQRM9IauUiqpO
+fMGx+6fWtScvl6tu4B3i0RwsH0Ti/L6RoZz71ilTc4afU9hDDl3WY4JxHYB0yvbi
+AmvZWg==
+-----END CERTIFICATE-----
+
+# Issuer: CN=SecureSign RootCA11 O=Japan Certification Services, Inc.
+# Subject: CN=SecureSign RootCA11 O=Japan Certification Services, Inc.
+# Label: "SecureSign RootCA11"
+# Serial: 1
+# MD5 Fingerprint: b7:52:74:e2:92:b4:80:93:f2:75:e4:cc:d7:f2:ea:26
+# SHA1 Fingerprint: 3b:c4:9f:48:f8:f3:73:a0:9c:1e:bd:f8:5b:b1:c3:65:c7:d8:11:b3
+# SHA256 Fingerprint: bf:0f:ee:fb:9e:3a:58:1a:d5:f9:e9:db:75:89:98:57:43:d2:61:08:5c:4d:31:4f:6f:5d:72:59:aa:42:16:12
+-----BEGIN CERTIFICATE-----
+MIIDbTCCAlWgAwIBAgIBATANBgkqhkiG9w0BAQUFADBYMQswCQYDVQQGEwJKUDEr
+MCkGA1UEChMiSmFwYW4gQ2VydGlmaWNhdGlvbiBTZXJ2aWNlcywgSW5jLjEcMBoG
+A1UEAxMTU2VjdXJlU2lnbiBSb290Q0ExMTAeFw0wOTA0MDgwNDU2NDdaFw0yOTA0
+MDgwNDU2NDdaMFgxCzAJBgNVBAYTAkpQMSswKQYDVQQKEyJKYXBhbiBDZXJ0aWZp
+Y2F0aW9uIFNlcnZpY2VzLCBJbmMuMRwwGgYDVQQDExNTZWN1cmVTaWduIFJvb3RD
+QTExMIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEA/XeqpRyQBTvLTJsz
+i1oURaTnkBbR31fSIRCkF/3frNYfp+TbfPfs37gD2pRY/V1yfIw/XwFndBWW4wI8
+h9uuywGOwvNmxoVF9ALGOrVisq/6nL+k5tSAMJjzDbaTj6nU2DbysPyKyiyhFTOV
+MdrAG/LuYpmGYz+/3ZMqg6h2uRMft85OQoWPIucuGvKVCbIFtUROd6EgvanyTgp9
+UK31BQ1FT0Zx/Sg+U/sE2C3XZR1KG/rPO7AxmjVuyIsG0wCR8pQIZUyxNAYAeoni
+8McDWc/V1uinMrPmmECGxc0nEovMe863ETxiYAcjPitAbpSACW22s293bzUIUPsC
+h8U+iQIDAQABo0IwQDAdBgNVHQ4EFgQUW/hNT7KlhtQ60vFjmqC+CfZXt94wDgYD
+VR0PAQH/BAQDAgEGMA8GA1UdEwEB/wQFMAMBAf8wDQYJKoZIhvcNAQEFBQADggEB
+AKChOBZmLqdWHyGcBvod7bkixTgm2E5P7KN/ed5GIaGHd48HCJqypMWvDzKYC3xm
+KbabfSVSSUOrTC4rbnpwrxYO4wJs+0LmGJ1F2FXI6Dvd5+H0LgscNFxsWEr7jIhQ
+X5Ucv+2rIrVls4W6ng+4reV6G4pQOh29Dbx7VFALuUKvVaAYga1lme++5Jy/xIWr
+QbJUb9wlze144o4MjQlJ3WN7WmmWAiGovVJZ6X01y8hSyn+B/tlr0/cR7SXf+Of5
+pPpyl4RTDaXQMhhRdlkUbA/r7F+AjHVDg8OFmP9Mni0N5HeDk061lgeLKBObjBmN
+QSdJQO7e5iNEOdyhIta6A/I=
+-----END CERTIFICATE-----
+
+# Issuer: CN=Microsec e-Szigno Root CA 2009 O=Microsec Ltd.
+# Subject: CN=Microsec e-Szigno Root CA 2009 O=Microsec Ltd.
+# Label: "Microsec e-Szigno Root CA 2009"
+# Serial: 14014712776195784473
+# MD5 Fingerprint: f8:49:f4:03:bc:44:2d:83:be:48:69:7d:29:64:fc:b1
+# SHA1 Fingerprint: 89:df:74:fe:5c:f4:0f:4a:80:f9:e3:37:7d:54:da:91:e1:01:31:8e
+# SHA256 Fingerprint: 3c:5f:81:fe:a5:fa:b8:2c:64:bf:a2:ea:ec:af:cd:e8:e0:77:fc:86:20:a7:ca:e5:37:16:3d:f3:6e:db:f3:78
+-----BEGIN CERTIFICATE-----
+MIIECjCCAvKgAwIBAgIJAMJ+QwRORz8ZMA0GCSqGSIb3DQEBCwUAMIGCMQswCQYD
+VQQGEwJIVTERMA8GA1UEBwwIQnVkYXBlc3QxFjAUBgNVBAoMDU1pY3Jvc2VjIEx0
+ZC4xJzAlBgNVBAMMHk1pY3Jvc2VjIGUtU3ppZ25vIFJvb3QgQ0EgMjAwOTEfMB0G
+CSqGSIb3DQEJARYQaW5mb0BlLXN6aWduby5odTAeFw0wOTA2MTYxMTMwMThaFw0y
+OTEyMzAxMTMwMThaMIGCMQswCQYDVQQGEwJIVTERMA8GA1UEBwwIQnVkYXBlc3Qx
+FjAUBgNVBAoMDU1pY3Jvc2VjIEx0ZC4xJzAlBgNVBAMMHk1pY3Jvc2VjIGUtU3pp
+Z25vIFJvb3QgQ0EgMjAwOTEfMB0GCSqGSIb3DQEJARYQaW5mb0BlLXN6aWduby5o
+dTCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBAOn4j/NjrdqG2KfgQvvP
+kd6mJviZpWNwrZuuyjNAfW2WbqEORO7hE52UQlKavXWFdCyoDh2Tthi3jCyoz/tc
+cbna7P7ofo/kLx2yqHWH2Leh5TvPmUpG0IMZfcChEhyVbUr02MelTTMuhTlAdX4U
+fIASmFDHQWe4oIBhVKZsTh/gnQ4H6cm6M+f+wFUoLAKApxn1ntxVUwOXewdI/5n7
+N4okxFnMUBBjjqqpGrCEGob5X7uxUG6k0QrM1XF+H6cbfPVTbiJfyyvm1HxdrtbC
+xkzlBQHZ7Vf8wSN5/PrIJIOV87VqUQHQd9bpEqH5GoP7ghu5sJf0dgYzQ0mg/wu1
++rUCAwEAAaOBgDB+MA8GA1UdEwEB/wQFMAMBAf8wDgYDVR0PAQH/BAQDAgEGMB0G
+A1UdDgQWBBTLD8bfQkPMPcu1SCOhGnqmKrs0aDAfBgNVHSMEGDAWgBTLD8bfQkPM
+Pcu1SCOhGnqmKrs0aDAbBgNVHREEFDASgRBpbmZvQGUtc3ppZ25vLmh1MA0GCSqG
+SIb3DQEBCwUAA4IBAQDJ0Q5eLtXMs3w+y/w9/w0olZMEyL/azXm4Q5DwpL7v8u8h
+mLzU1F0G9u5C7DBsoKqpyvGvivo/C3NqPuouQH4frlRheesuCDfXI/OMn74dseGk
+ddug4lQUsbocKaQY9hK6ohQU4zE1yED/t+AFdlfBHFny+L/k7SViXITwfn4fs775
+tyERzAMBVnCnEJIeGzSBHq2cGsMEPO0CYdYeBvNfOofyK/FFh+U9rNHHV4S9a67c
+2Pm2G2JwCz02yULyMtd6YebS2z3PyKnJm9zbWETXbzivf3jTo60adbocwTZ8jx5t
+HMN1Rq41Bab2XD0h7lbwyYIiLXpUq3DDfSJlgnCW
+-----END CERTIFICATE-----
+
+# Issuer: CN=GlobalSign O=GlobalSign OU=GlobalSign Root CA - R3
+# Subject: CN=GlobalSign O=GlobalSign OU=GlobalSign Root CA - R3
+# Label: "GlobalSign Root CA - R3"
+# Serial: 4835703278459759426209954
+# MD5 Fingerprint: c5:df:b8:49:ca:05:13:55:ee:2d:ba:1a:c3:3e:b0:28
+# SHA1 Fingerprint: d6:9b:56:11:48:f0:1c:77:c5:45:78:c1:09:26:df:5b:85:69:76:ad
+# SHA256 Fingerprint: cb:b5:22:d7:b7:f1:27:ad:6a:01:13:86:5b:df:1c:d4:10:2e:7d:07:59:af:63:5a:7c:f4:72:0d:c9:63:c5:3b
+-----BEGIN CERTIFICATE-----
+MIIDXzCCAkegAwIBAgILBAAAAAABIVhTCKIwDQYJKoZIhvcNAQELBQAwTDEgMB4G
+A1UECxMXR2xvYmFsU2lnbiBSb290IENBIC0gUjMxEzARBgNVBAoTCkdsb2JhbFNp
+Z24xEzARBgNVBAMTCkdsb2JhbFNpZ24wHhcNMDkwMzE4MTAwMDAwWhcNMjkwMzE4
+MTAwMDAwWjBMMSAwHgYDVQQLExdHbG9iYWxTaWduIFJvb3QgQ0EgLSBSMzETMBEG
+A1UEChMKR2xvYmFsU2lnbjETMBEGA1UEAxMKR2xvYmFsU2lnbjCCASIwDQYJKoZI
+hvcNAQEBBQADggEPADCCAQoCggEBAMwldpB5BngiFvXAg7aEyiie/QV2EcWtiHL8
+RgJDx7KKnQRfJMsuS+FggkbhUqsMgUdwbN1k0ev1LKMPgj0MK66X17YUhhB5uzsT
+gHeMCOFJ0mpiLx9e+pZo34knlTifBtc+ycsmWQ1z3rDI6SYOgxXG71uL0gRgykmm
+KPZpO/bLyCiR5Z2KYVc3rHQU3HTgOu5yLy6c+9C7v/U9AOEGM+iCK65TpjoWc4zd
+QQ4gOsC0p6Hpsk+QLjJg6VfLuQSSaGjlOCZgdbKfd/+RFO+uIEn8rUAVSNECMWEZ
+XriX7613t2Saer9fwRPvm2L7DWzgVGkWqQPabumDk3F2xmmFghcCAwEAAaNCMEAw
+DgYDVR0PAQH/BAQDAgEGMA8GA1UdEwEB/wQFMAMBAf8wHQYDVR0OBBYEFI/wS3+o
+LkUkrk1Q+mOai97i3Ru8MA0GCSqGSIb3DQEBCwUAA4IBAQBLQNvAUKr+yAzv95ZU
+RUm7lgAJQayzE4aGKAczymvmdLm6AC2upArT9fHxD4q/c2dKg8dEe3jgr25sbwMp
+jjM5RcOO5LlXbKr8EpbsU8Yt5CRsuZRj+9xTaGdWPoO4zzUhw8lo/s7awlOqzJCK
+6fBdRoyV3XpYKBovHd7NADdBj+1EbddTKJd+82cEHhXXipa0095MJ6RMG3NzdvQX
+mcIfeg7jLQitChws/zyrVQ4PkX4268NXSb7hLi18YIvDQVETI53O9zJrlAGomecs
+Mx86OyXShkDOOyyGeMlhLxS67ttVb9+E7gUJTb0o2HLO02JQZR7rkpeDMdmztcpH
+WD9f
+-----END CERTIFICATE-----
+
+# Issuer: CN=Autoridad de Certificacion Firmaprofesional CIF A62634068
+# Subject: CN=Autoridad de Certificacion Firmaprofesional CIF A62634068
+# Label: "Autoridad de Certificacion Firmaprofesional CIF A62634068"
+# Serial: 6047274297262753887
+# MD5 Fingerprint: 73:3a:74:7a:ec:bb:a3:96:a6:c2:e4:e2:c8:9b:c0:c3
+# SHA1 Fingerprint: ae:c5:fb:3f:c8:e1:bf:c4:e5:4f:03:07:5a:9a:e8:00:b7:f7:b6:fa
+# SHA256 Fingerprint: 04:04:80:28:bf:1f:28:64:d4:8f:9a:d4:d8:32:94:36:6a:82:88:56:55:3f:3b:14:30:3f:90:14:7f:5d:40:ef
+-----BEGIN CERTIFICATE-----
+MIIGFDCCA/ygAwIBAgIIU+w77vuySF8wDQYJKoZIhvcNAQEFBQAwUTELMAkGA1UE
+BhMCRVMxQjBABgNVBAMMOUF1dG9yaWRhZCBkZSBDZXJ0aWZpY2FjaW9uIEZpcm1h
+cHJvZmVzaW9uYWwgQ0lGIEE2MjYzNDA2ODAeFw0wOTA1MjAwODM4MTVaFw0zMDEy
+MzEwODM4MTVaMFExCzAJBgNVBAYTAkVTMUIwQAYDVQQDDDlBdXRvcmlkYWQgZGUg
+Q2VydGlmaWNhY2lvbiBGaXJtYXByb2Zlc2lvbmFsIENJRiBBNjI2MzQwNjgwggIi
+MA0GCSqGSIb3DQEBAQUAA4ICDwAwggIKAoICAQDKlmuO6vj78aI14H9M2uDDUtd9
+thDIAl6zQyrET2qyyhxdKJp4ERppWVevtSBC5IsP5t9bpgOSL/UR5GLXMnE42QQM
+cas9UX4PB99jBVzpv5RvwSmCwLTaUbDBPLutN0pcyvFLNg4kq7/DhHf9qFD0sefG
+L9ItWY16Ck6WaVICqjaY7Pz6FIMMNx/Jkjd/14Et5cS54D40/mf0PmbR0/RAz15i
+NA9wBj4gGFrO93IbJWyTdBSTo3OxDqqHECNZXyAFGUftaI6SEspd/NYrspI8IM/h
+X68gvqB2f3bl7BqGYTM+53u0P6APjqK5am+5hyZvQWyIplD9amML9ZMWGxmPsu2b
+m8mQ9QEM3xk9Dz44I8kvjwzRAv4bVdZO0I08r0+k8/6vKtMFnXkIoctXMbScyJCy
+Z/QYFpM6/EfY0XiWMR+6KwxfXZmtY4laJCB22N/9q06mIqqdXuYnin1oKaPnirja
+EbsXLZmdEyRG98Xi2J+Of8ePdG1asuhy9azuJBCtLxTa/y2aRnFHvkLfuwHb9H/T
+KI8xWVvTyQKmtFLKbpf7Q8UIJm+K9Lv9nyiqDdVF8xM6HdjAeI9BZzwelGSuewvF
+6NkBiDkal4ZkQdU7hwxu+g/GvUgUvzlN1J5Bto+WHWOWk9mVBngxaJ43BjuAiUVh
+OSPHG0SjFeUc+JIwuwIDAQABo4HvMIHsMBIGA1UdEwEB/wQIMAYBAf8CAQEwDgYD
+VR0PAQH/BAQDAgEGMB0GA1UdDgQWBBRlzeurNR4APn7VdMActHNHDhpkLzCBpgYD
+VR0gBIGeMIGbMIGYBgRVHSAAMIGPMC8GCCsGAQUFBwIBFiNodHRwOi8vd3d3LmZp
+cm1hcHJvZmVzaW9uYWwuY29tL2NwczBcBggrBgEFBQcCAjBQHk4AUABhAHMAZQBv
+ACAAZABlACAAbABhACAAQgBvAG4AYQBuAG8AdgBhACAANAA3ACAAQgBhAHIAYwBl
+AGwAbwBuAGEAIAAwADgAMAAxADcwDQYJKoZIhvcNAQEFBQADggIBABd9oPm03cXF
+661LJLWhAqvdpYhKsg9VSytXjDvlMd3+xDLx51tkljYyGOylMnfX40S2wBEqgLk9
+am58m9Ot/MPWo+ZkKXzR4Tgegiv/J2Wv+xYVxC5xhOW1//qkR71kMrv2JYSiJ0L1
+ILDCExARzRAVukKQKtJE4ZYm6zFIEv0q2skGz3QeqUvVhyj5eTSSPi5E6PaPT481
+PyWzOdxjKpBrIF/EUhJOlywqrJ2X3kjyo2bbwtKDlaZmp54lD+kLM5FlClrD2VQS
+3a/DTg4fJl4N3LON7NWBcN7STyQF82xO9UxJZo3R/9ILJUFI/lGExkKvgATP0H5k
+SeTy36LssUzAKh3ntLFlosS88Zj0qnAHY7S42jtM+kAiMFsRpvAFDsYCA0irhpuF
+3dvd6qJ2gHN99ZwExEWN57kci57q13XRcrHedUTnQn3iV2t93Jm8PYMo6oCTjcVM
+ZcFwgbg4/EMxsvYDNEeyrPsiBsse3RdHHF9mudMaotoRsaS8I8nkvof/uZS2+F0g
+StRf571oe2XyFR7SOqkt6dhrJKyXWERHrVkY8SFlcN7ONGCoQPHzPKTDKCOM/icz
+Q0CgFzzr6juwcqajuUpLXhZI9LK8yIySxZ2frHI2vDSANGupi5LAuBft7HZT9SQB
+jLMi6Et8Vcad+qMUu2WFbm5PEn4KPJ2V
+-----END CERTIFICATE-----
+
+# Issuer: CN=Izenpe.com O=IZENPE S.A.
+# Subject: CN=Izenpe.com O=IZENPE S.A.
+# Label: "Izenpe.com"
+# Serial: 917563065490389241595536686991402621
+# MD5 Fingerprint: a6:b0:cd:85:80:da:5c:50:34:a3:39:90:2f:55:67:73
+# SHA1 Fingerprint: 2f:78:3d:25:52:18:a7:4a:65:39:71:b5:2c:a2:9c:45:15:6f:e9:19
+# SHA256 Fingerprint: 25:30:cc:8e:98:32:15:02:ba:d9:6f:9b:1f:ba:1b:09:9e:2d:29:9e:0f:45:48:bb:91:4f:36:3b:c0:d4:53:1f
+-----BEGIN CERTIFICATE-----
+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
+-----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"
+# Serial: 0
+# MD5 Fingerprint: 80:3a:bc:22:c1:e6:fb:8d:9b:3b:27:4a:32:1b:9a:01
+# SHA1 Fingerprint: 47:be:ab:c9:22:ea:e8:0e:78:78:34:62:a7:9f:45:c2:54:fd:e6:8b
+# SHA256 Fingerprint: 45:14:0b:32:47:eb:9c:c8:c5:b4:f0:d7:b5:30:91:f7:32:92:08:9e:6e:5a:63:e2:74:9d:d3:ac:a9:19:8e:da
+-----BEGIN CERTIFICATE-----
+MIIDxTCCAq2gAwIBAgIBADANBgkqhkiG9w0BAQsFADCBgzELMAkGA1UEBhMCVVMx
+EDAOBgNVBAgTB0FyaXpvbmExEzARBgNVBAcTClNjb3R0c2RhbGUxGjAYBgNVBAoT
+EUdvRGFkZHkuY29tLCBJbmMuMTEwLwYDVQQDEyhHbyBEYWRkeSBSb290IENlcnRp
+ZmljYXRlIEF1dGhvcml0eSAtIEcyMB4XDTA5MDkwMTAwMDAwMFoXDTM3MTIzMTIz
+NTk1OVowgYMxCzAJBgNVBAYTAlVTMRAwDgYDVQQIEwdBcml6b25hMRMwEQYDVQQH
+EwpTY290dHNkYWxlMRowGAYDVQQKExFHb0RhZGR5LmNvbSwgSW5jLjExMC8GA1UE
+AxMoR28gRGFkZHkgUm9vdCBDZXJ0aWZpY2F0ZSBBdXRob3JpdHkgLSBHMjCCASIw
+DQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBAL9xYgjx+lk09xvJGKP3gElY6SKD
+E6bFIEMBO4Tx5oVJnyfq9oQbTqC023CYxzIBsQU+B07u9PpPL1kwIuerGVZr4oAH
+/PMWdYA5UXvl+TW2dE6pjYIT5LY/qQOD+qK+ihVqf94Lw7YZFAXK6sOoBJQ7Rnwy
+DfMAZiLIjWltNowRGLfTshxgtDj6AozO091GB94KPutdfMh8+7ArU6SSYmlRJQVh
+GkSBjCypQ5Yj36w6gZoOKcUcqeldHraenjAKOc7xiID7S13MMuyFYkMlNAJWJwGR
+tDtwKj9useiciAF9n9T521NtYJ2/LOdYq7hfRvzOxBsDPAnrSTFcaUaz4EcCAwEA
+AaNCMEAwDwYDVR0TAQH/BAUwAwEB/zAOBgNVHQ8BAf8EBAMCAQYwHQYDVR0OBBYE
+FDqahQcQZyi27/a9BUFuIMGU2g/eMA0GCSqGSIb3DQEBCwUAA4IBAQCZ21151fmX
+WWcDYfF+OwYxdS2hII5PZYe096acvNjpL9DbWu7PdIxztDhC2gV7+AJ1uP2lsdeu
+9tfeE8tTEH6KRtGX+rcuKxGrkLAngPnon1rpN5+r5N9ss4UXnT3ZJE95kTXWXwTr
+gIOrmgIttRD02JDHBHNA7XIloKmf7J6raBKZV8aPEjoJpL1E/QYVN8Gb5DKj7Tjo
+2GTzLH4U/ALqn83/B2gX2yKQOC16jdFU8WnjXzPKej17CuPKf1855eJ1usV2GDPO
+LPAvTK33sefOT6jEm0pUBsV/fdUID+Ic/n4XuKxe9tQWskMJDE32p2u0mYRlynqI
+4uJEvlz36hz1
+-----END CERTIFICATE-----
+
+# Issuer: CN=Starfield Root Certificate Authority - G2 O=Starfield Technologies, Inc.
+# Subject: CN=Starfield Root Certificate Authority - G2 O=Starfield Technologies, Inc.
+# Label: "Starfield Root Certificate Authority - G2"
+# Serial: 0
+# MD5 Fingerprint: d6:39:81:c6:52:7e:96:69:fc:fc:ca:66:ed:05:f2:96
+# SHA1 Fingerprint: b5:1c:06:7c:ee:2b:0c:3d:f8:55:ab:2d:92:f4:fe:39:d4:e7:0f:0e
+# SHA256 Fingerprint: 2c:e1:cb:0b:f9:d2:f9:e1:02:99:3f:be:21:51:52:c3:b2:dd:0c:ab:de:1c:68:e5:31:9b:83:91:54:db:b7:f5
+-----BEGIN CERTIFICATE-----
+MIID3TCCAsWgAwIBAgIBADANBgkqhkiG9w0BAQsFADCBjzELMAkGA1UEBhMCVVMx
+EDAOBgNVBAgTB0FyaXpvbmExEzARBgNVBAcTClNjb3R0c2RhbGUxJTAjBgNVBAoT
+HFN0YXJmaWVsZCBUZWNobm9sb2dpZXMsIEluYy4xMjAwBgNVBAMTKVN0YXJmaWVs
+ZCBSb290IENlcnRpZmljYXRlIEF1dGhvcml0eSAtIEcyMB4XDTA5MDkwMTAwMDAw
+MFoXDTM3MTIzMTIzNTk1OVowgY8xCzAJBgNVBAYTAlVTMRAwDgYDVQQIEwdBcml6
+b25hMRMwEQYDVQQHEwpTY290dHNkYWxlMSUwIwYDVQQKExxTdGFyZmllbGQgVGVj
+aG5vbG9naWVzLCBJbmMuMTIwMAYDVQQDEylTdGFyZmllbGQgUm9vdCBDZXJ0aWZp
+Y2F0ZSBBdXRob3JpdHkgLSBHMjCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoC
+ggEBAL3twQP89o/8ArFvW59I2Z154qK3A2FWGMNHttfKPTUuiUP3oWmb3ooa/RMg
+nLRJdzIpVv257IzdIvpy3Cdhl+72WoTsbhm5iSzchFvVdPtrX8WJpRBSiUZV9Lh1
+HOZ/5FSuS/hVclcCGfgXcVnrHigHdMWdSL5stPSksPNkN3mSwOxGXn/hbVNMYq/N
+Hwtjuzqd+/x5AJhhdM8mgkBj87JyahkNmcrUDnXMN/uLicFZ8WJ/X7NfZTD4p7dN
+dloedl40wOiWVpmKs/B/pM293DIxfJHP4F8R+GuqSVzRmZTRouNjWwl2tVZi4Ut0
+HZbUJtQIBFnQmA4O5t78w+wfkPECAwEAAaNCMEAwDwYDVR0TAQH/BAUwAwEB/zAO
+BgNVHQ8BAf8EBAMCAQYwHQYDVR0OBBYEFHwMMh+n2TB/xH1oo2Kooc6rB1snMA0G
+CSqGSIb3DQEBCwUAA4IBAQARWfolTwNvlJk7mh+ChTnUdgWUXuEok21iXQnCoKjU
+sHU48TRqneSfioYmUeYs0cYtbpUgSpIB7LiKZ3sx4mcujJUDJi5DnUox9g61DLu3
+4jd/IroAow57UvtruzvE03lRTs2Q9GcHGcg8RnoNAX3FWOdt5oUwF5okxBDgBPfg
+8n/Uqgr/Qh037ZTlZFkSIHc40zI+OIF1lnP6aI+xy84fxez6nH7PfrHxBy22/L/K
+pL/QlwVKvOoYKAKQvVR4CSFx09F9HdkWsKlhPdAKACL8x3vLCWRFCztAgfd9fDL1
+mMpYjn0q7pBZc2T5NnReJaH1ZgUufzkVqSr7UIuOhWn0
+-----END CERTIFICATE-----
+
+# Issuer: CN=Starfield Services Root Certificate Authority - G2 O=Starfield Technologies, Inc.
+# Subject: CN=Starfield Services Root Certificate Authority - G2 O=Starfield Technologies, Inc.
+# Label: "Starfield Services Root Certificate Authority - G2"
+# Serial: 0
+# MD5 Fingerprint: 17:35:74:af:7b:61:1c:eb:f4:f9:3c:e2:ee:40:f9:a2
+# SHA1 Fingerprint: 92:5a:8f:8d:2c:6d:04:e0:66:5f:59:6a:ff:22:d8:63:e8:25:6f:3f
+# SHA256 Fingerprint: 56:8d:69:05:a2:c8:87:08:a4:b3:02:51:90:ed:cf:ed:b1:97:4a:60:6a:13:c6:e5:29:0f:cb:2a:e6:3e:da:b5
+-----BEGIN CERTIFICATE-----
+MIID7zCCAtegAwIBAgIBADANBgkqhkiG9w0BAQsFADCBmDELMAkGA1UEBhMCVVMx
+EDAOBgNVBAgTB0FyaXpvbmExEzARBgNVBAcTClNjb3R0c2RhbGUxJTAjBgNVBAoT
+HFN0YXJmaWVsZCBUZWNobm9sb2dpZXMsIEluYy4xOzA5BgNVBAMTMlN0YXJmaWVs
+ZCBTZXJ2aWNlcyBSb290IENlcnRpZmljYXRlIEF1dGhvcml0eSAtIEcyMB4XDTA5
+MDkwMTAwMDAwMFoXDTM3MTIzMTIzNTk1OVowgZgxCzAJBgNVBAYTAlVTMRAwDgYD
+VQQIEwdBcml6b25hMRMwEQYDVQQHEwpTY290dHNkYWxlMSUwIwYDVQQKExxTdGFy
+ZmllbGQgVGVjaG5vbG9naWVzLCBJbmMuMTswOQYDVQQDEzJTdGFyZmllbGQgU2Vy
+dmljZXMgUm9vdCBDZXJ0aWZpY2F0ZSBBdXRob3JpdHkgLSBHMjCCASIwDQYJKoZI
+hvcNAQEBBQADggEPADCCAQoCggEBANUMOsQq+U7i9b4Zl1+OiFOxHz/Lz58gE20p
+OsgPfTz3a3Y4Y9k2YKibXlwAgLIvWX/2h/klQ4bnaRtSmpDhcePYLQ1Ob/bISdm2
+8xpWriu2dBTrz/sm4xq6HZYuajtYlIlHVv8loJNwU4PahHQUw2eeBGg6345AWh1K
+Ts9DkTvnVtYAcMtS7nt9rjrnvDH5RfbCYM8TWQIrgMw0R9+53pBlbQLPLJGmpufe
+hRhJfGZOozptqbXuNC66DQO4M99H67FrjSXZm86B0UVGMpZwh94CDklDhbZsc7tk
+6mFBrMnUVN+HL8cisibMn1lUaJ/8viovxFUcdUBgF4UCVTmLfwUCAwEAAaNCMEAw
+DwYDVR0TAQH/BAUwAwEB/zAOBgNVHQ8BAf8EBAMCAQYwHQYDVR0OBBYEFJxfAN+q
+AdcwKziIorhtSpzyEZGDMA0GCSqGSIb3DQEBCwUAA4IBAQBLNqaEd2ndOxmfZyMI
+bw5hyf2E3F/YNoHN2BtBLZ9g3ccaaNnRbobhiCPPE95Dz+I0swSdHynVv/heyNXB
+ve6SbzJ08pGCL72CQnqtKrcgfU28elUSwhXqvfdqlS5sdJ/PHLTyxQGjhdByPq1z
+qwubdQxtRbeOlKyWN7Wg0I8VRw7j6IPdj/3vQQF3zCepYoUz8jcI73HPdwbeyBkd
+iEDPfUYd/x7H4c7/I9vG+o1VTqkC50cRRj70/b17KSa7qWFiNyi2LSr2EIZkyXCn
+0q23KXB56jzaYyWf/Wi3MOxw+3WKt21gZ7IeyLnp2KhvAotnDU0mV3HaIPzBSlCN
+sSi6
+-----END CERTIFICATE-----
+
+# Issuer: CN=AffirmTrust Commercial O=AffirmTrust
+# Subject: CN=AffirmTrust Commercial O=AffirmTrust
+# Label: "AffirmTrust Commercial"
+# Serial: 8608355977964138876
+# MD5 Fingerprint: 82:92:ba:5b:ef:cd:8a:6f:a6:3d:55:f9:84:f6:d6:b7
+# SHA1 Fingerprint: f9:b5:b6:32:45:5f:9c:be:ec:57:5f:80:dc:e9:6e:2c:c7:b2:78:b7
+# SHA256 Fingerprint: 03:76:ab:1d:54:c5:f9:80:3c:e4:b2:e2:01:a0:ee:7e:ef:7b:57:b6:36:e8:a9:3c:9b:8d:48:60:c9:6f:5f:a7
+-----BEGIN CERTIFICATE-----
+MIIDTDCCAjSgAwIBAgIId3cGJyapsXwwDQYJKoZIhvcNAQELBQAwRDELMAkGA1UE
+BhMCVVMxFDASBgNVBAoMC0FmZmlybVRydXN0MR8wHQYDVQQDDBZBZmZpcm1UcnVz
+dCBDb21tZXJjaWFsMB4XDTEwMDEyOTE0MDYwNloXDTMwMTIzMTE0MDYwNlowRDEL
+MAkGA1UEBhMCVVMxFDASBgNVBAoMC0FmZmlybVRydXN0MR8wHQYDVQQDDBZBZmZp
+cm1UcnVzdCBDb21tZXJjaWFsMIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKC
+AQEA9htPZwcroRX1BiLLHwGy43NFBkRJLLtJJRTWzsO3qyxPxkEylFf6EqdbDuKP
+Hx6GGaeqtS25Xw2Kwq+FNXkyLbscYjfysVtKPcrNcV/pQr6U6Mje+SJIZMblq8Yr
+ba0F8PrVC8+a5fBQpIs7R6UjW3p6+DM/uO+Zl+MgwdYoic+U+7lF7eNAFxHUdPAL
+MeIrJmqbTFeurCA+ukV6BfO9m2kVrn1OIGPENXY6BwLJN/3HR+7o8XYdcxXyl6S1
+yHp52UKqK39c/s4mT6NmgTWvRLpUHhwwMmWd5jyTXlBOeuM61G7MGvv50jeuJCqr
+VwMiKA1JdX+3KNp1v47j3A55MQIDAQABo0IwQDAdBgNVHQ4EFgQUnZPGU4teyq8/
+nx4P5ZmVvCT2lI8wDwYDVR0TAQH/BAUwAwEB/zAOBgNVHQ8BAf8EBAMCAQYwDQYJ
+KoZIhvcNAQELBQADggEBAFis9AQOzcAN/wr91LoWXym9e2iZWEnStB03TX8nfUYG
+XUPGhi4+c7ImfU+TqbbEKpqrIZcUsd6M06uJFdhrJNTxFq7YpFzUf1GO7RgBsZNj
+vbz4YYCanrHOQnDiqX0GJX0nof5v7LMeJNrjS1UaADs1tDvZ110w/YETifLCBivt
+Z8SOyUOyXGsViQK8YvxO8rUzqrJv0wqiUOP2O+guRMLbZjipM1ZI8W0bM40NjD9g
+N53Tym1+NH4Nn3J2ixufcv1SNUFFApYvHLKac0khsUlHRUe072o0EclNmsxZt9YC
+nlpOZbWUrhvfKbAW8b8Angc6F2S1BLUjIZkKlTuXfO8=
+-----END CERTIFICATE-----
+
+# Issuer: CN=AffirmTrust Networking O=AffirmTrust
+# Subject: CN=AffirmTrust Networking O=AffirmTrust
+# Label: "AffirmTrust Networking"
+# Serial: 8957382827206547757
+# MD5 Fingerprint: 42:65:ca:be:01:9a:9a:4c:a9:8c:41:49:cd:c0:d5:7f
+# SHA1 Fingerprint: 29:36:21:02:8b:20:ed:02:f5:66:c5:32:d1:d6:ed:90:9f:45:00:2f
+# SHA256 Fingerprint: 0a:81:ec:5a:92:97:77:f1:45:90:4a:f3:8d:5d:50:9f:66:b5:e2:c5:8f:cd:b5:31:05:8b:0e:17:f3:f0:b4:1b
+-----BEGIN CERTIFICATE-----
+MIIDTDCCAjSgAwIBAgIIfE8EORzUmS0wDQYJKoZIhvcNAQEFBQAwRDELMAkGA1UE
+BhMCVVMxFDASBgNVBAoMC0FmZmlybVRydXN0MR8wHQYDVQQDDBZBZmZpcm1UcnVz
+dCBOZXR3b3JraW5nMB4XDTEwMDEyOTE0MDgyNFoXDTMwMTIzMTE0MDgyNFowRDEL
+MAkGA1UEBhMCVVMxFDASBgNVBAoMC0FmZmlybVRydXN0MR8wHQYDVQQDDBZBZmZp
+cm1UcnVzdCBOZXR3b3JraW5nMIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKC
+AQEAtITMMxcua5Rsa2FSoOujz3mUTOWUgJnLVWREZY9nZOIG41w3SfYvm4SEHi3y
+YJ0wTsyEheIszx6e/jarM3c1RNg1lho9Nuh6DtjVR6FqaYvZ/Ls6rnla1fTWcbua
+kCNrmreIdIcMHl+5ni36q1Mr3Lt2PpNMCAiMHqIjHNRqrSK6mQEubWXLviRmVSRL
+QESxG9fhwoXA3hA/Pe24/PHxI1Pcv2WXb9n5QHGNfb2V1M6+oF4nI979ptAmDgAp
+6zxG8D1gvz9Q0twmQVGeFDdCBKNwV6gbh+0t+nvujArjqWaJGctB+d1ENmHP4ndG
+yH329JKBNv3bNPFyfvMMFr20FQIDAQABo0IwQDAdBgNVHQ4EFgQUBx/S55zawm6i
+QLSwelAQUHTEyL0wDwYDVR0TAQH/BAUwAwEB/zAOBgNVHQ8BAf8EBAMCAQYwDQYJ
+KoZIhvcNAQEFBQADggEBAIlXshZ6qML91tmbmzTCnLQyFE2npN/svqe++EPbkTfO
+tDIuUFUaNU52Q3Eg75N3ThVwLofDwR1t3Mu1J9QsVtFSUzpE0nPIxBsFZVpikpzu
+QY0x2+c06lkh1QF612S4ZDnNye2v7UsDSKegmQGA3GWjNq5lWUhPgkvIZfFXHeVZ
+Lgo/bNjR9eUJtGxUAArgFU2HdW23WJZa3W3SAKD0m0i+wzekujbgfIeFlxoVot4u
+olu9rxj5kFDNcFn4J2dHy8egBzp90SxdbBk6ZrV9/ZFvgrG+CJPbFEfxojfHRZ48
+x3evZKiT3/Zpg4Jg8klCNO1aAFSFHBY2kgxc+qatv9s=
+-----END CERTIFICATE-----
+
+# Issuer: CN=AffirmTrust Premium O=AffirmTrust
+# Subject: CN=AffirmTrust Premium O=AffirmTrust
+# Label: "AffirmTrust Premium"
+# Serial: 7893706540734352110
+# MD5 Fingerprint: c4:5d:0e:48:b6:ac:28:30:4e:0a:bc:f9:38:16:87:57
+# SHA1 Fingerprint: d8:a6:33:2c:e0:03:6f:b1:85:f6:63:4f:7d:6a:06:65:26:32:28:27
+# SHA256 Fingerprint: 70:a7:3f:7f:37:6b:60:07:42:48:90:45:34:b1:14:82:d5:bf:0e:69:8e:cc:49:8d:f5:25:77:eb:f2:e9:3b:9a
+-----BEGIN CERTIFICATE-----
+MIIFRjCCAy6gAwIBAgIIbYwURrGmCu4wDQYJKoZIhvcNAQEMBQAwQTELMAkGA1UE
+BhMCVVMxFDASBgNVBAoMC0FmZmlybVRydXN0MRwwGgYDVQQDDBNBZmZpcm1UcnVz
+dCBQcmVtaXVtMB4XDTEwMDEyOTE0MTAzNloXDTQwMTIzMTE0MTAzNlowQTELMAkG
+A1UEBhMCVVMxFDASBgNVBAoMC0FmZmlybVRydXN0MRwwGgYDVQQDDBNBZmZpcm1U
+cnVzdCBQcmVtaXVtMIICIjANBgkqhkiG9w0BAQEFAAOCAg8AMIICCgKCAgEAxBLf
+qV/+Qd3d9Z+K4/as4Tx4mrzY8H96oDMq3I0gW64tb+eT2TZwamjPjlGjhVtnBKAQ
+JG9dKILBl1fYSCkTtuG+kU3fhQxTGJoeJKJPj/CihQvL9Cl/0qRY7iZNyaqoe5rZ
++jjeRFcV5fiMyNlI4g0WJx0eyIOFJbe6qlVBzAMiSy2RjYvmia9mx+n/K+k8rNrS
+s8PhaJyJ+HoAVt70VZVs+7pk3WKL3wt3MutizCaam7uqYoNMtAZ6MMgpv+0GTZe5
+HMQxK9VfvFMSF5yZVylmd2EhMQcuJUmdGPLu8ytxjLW6OQdJd/zvLpKQBY0tL3d7
+70O/Nbua2Plzpyzy0FfuKE4mX4+QaAkvuPjcBukumj5Rp9EixAqnOEhss/n/fauG
+V+O61oV4d7pD6kh/9ti+I20ev9E2bFhc8e6kGVQa9QPSdubhjL08s9NIS+LI+H+S
+qHZGnEJlPqQewQcDWkYtuJfzt9WyVSHvutxMAJf7FJUnM7/oQ0dG0giZFmA7mn7S
+5u046uwBHjxIVkkJx0w3AJ6IDsBz4W9m6XJHMD4Q5QsDyZpCAGzFlH5hxIrff4Ia
+C1nEWTJ3s7xgaVY5/bQGeyzWZDbZvUjthB9+pSKPKrhC9IK31FOQeE4tGv2Bb0TX
+OwF0lkLgAOIua+rF7nKsu7/+6qqo+Nz2snmKtmcCAwEAAaNCMEAwHQYDVR0OBBYE
+FJ3AZ6YMItkm9UWrpmVSESfYRaxjMA8GA1UdEwEB/wQFMAMBAf8wDgYDVR0PAQH/
+BAQDAgEGMA0GCSqGSIb3DQEBDAUAA4ICAQCzV00QYk465KzquByvMiPIs0laUZx2
+KI15qldGF9X1Uva3ROgIRL8YhNILgM3FEv0AVQVhh0HctSSePMTYyPtwni94loMg
+Nt58D2kTiKV1NpgIpsbfrM7jWNa3Pt668+s0QNiigfV4Py/VpfzZotReBA4Xrf5B
+8OWycvpEgjNC6C1Y91aMYj+6QrCcDFx+LmUmXFNPALJ4fqENmS2NuB2OosSw/WDQ
+MKSOyARiqcTtNd56l+0OOF6SL5Nwpamcb6d9Ex1+xghIsV5n61EIJenmJWtSKZGc
+0jlzCFfemQa0W50QBuHCAKi4HEoCChTQwUHK+4w1IX2COPKpVJEZNZOUbWo6xbLQ
+u4mGk+ibyQ86p3q4ofB4Rvr8Ny/lioTz3/4E2aFooC8k4gmVBtWVyuEklut89pMF
+u+1z6S3RdTnX5yTb2E5fQ4+e0BQ5v1VwSJlXMbSc7kqYA5YwH2AG7hsj/oFgIxpH
+YoWlzBk0gG+zrBrjn/B7SK3VAdlntqlyk+otZrWyuOQ9PLLvTIzq6we/qzWaVYa8
+GKa1qF60g2xraUDTn9zxw2lrueFtCfTxqlB2Cnp9ehehVZZCmTEJ3WARjQUwfuaO
+RtGdFNrHF+QFlozEJLUbzxQHskD4o55BhrwE0GuWyCqANP2/7waj3VjFhT0+j/6e
+KeC2uAloGRwYQw==
+-----END CERTIFICATE-----
+
+# Issuer: CN=AffirmTrust Premium ECC O=AffirmTrust
+# Subject: CN=AffirmTrust Premium ECC O=AffirmTrust
+# Label: "AffirmTrust Premium ECC"
+# Serial: 8401224907861490260
+# MD5 Fingerprint: 64:b0:09:55:cf:b1:d5:99:e2:be:13:ab:a6:5d:ea:4d
+# SHA1 Fingerprint: b8:23:6b:00:2f:1d:16:86:53:01:55:6c:11:a4:37:ca:eb:ff:c3:bb
+# SHA256 Fingerprint: bd:71:fd:f6:da:97:e4:cf:62:d1:64:7a:dd:25:81:b0:7d:79:ad:f8:39:7e:b4:ec:ba:9c:5e:84:88:82:14:23
+-----BEGIN CERTIFICATE-----
+MIIB/jCCAYWgAwIBAgIIdJclisc/elQwCgYIKoZIzj0EAwMwRTELMAkGA1UEBhMC
+VVMxFDASBgNVBAoMC0FmZmlybVRydXN0MSAwHgYDVQQDDBdBZmZpcm1UcnVzdCBQ
+cmVtaXVtIEVDQzAeFw0xMDAxMjkxNDIwMjRaFw00MDEyMzExNDIwMjRaMEUxCzAJ
+BgNVBAYTAlVTMRQwEgYDVQQKDAtBZmZpcm1UcnVzdDEgMB4GA1UEAwwXQWZmaXJt
+VHJ1c3QgUHJlbWl1bSBFQ0MwdjAQBgcqhkjOPQIBBgUrgQQAIgNiAAQNMF4bFZ0D
+0KF5Nbc6PJJ6yhUczWLznCZcBz3lVPqj1swS6vQUX+iOGasvLkjmrBhDeKzQN8O9
+ss0s5kfiGuZjuD0uL3jET9v0D6RoTFVya5UdThhClXjMNzyR4ptlKymjQjBAMB0G
+A1UdDgQWBBSaryl6wBE1NSZRMADDav5A1a7WPDAPBgNVHRMBAf8EBTADAQH/MA4G
+A1UdDwEB/wQEAwIBBjAKBggqhkjOPQQDAwNnADBkAjAXCfOHiFBar8jAQr9HX/Vs
+aobgxCd05DhT1wV/GzTjxi+zygk8N53X57hG8f2h4nECMEJZh0PUUd+60wkyWs6I
+flc9nF9Ca/UHLbXwgpP5WW+uZPpY5Yse42O+tYHNbwKMeQ==
+-----END CERTIFICATE-----
+
+# Issuer: CN=Certum Trusted Network CA O=Unizeto Technologies S.A. OU=Certum Certification Authority
+# Subject: CN=Certum Trusted Network CA O=Unizeto Technologies S.A. OU=Certum Certification Authority
+# Label: "Certum Trusted Network CA"
+# Serial: 279744
+# MD5 Fingerprint: d5:e9:81:40:c5:18:69:fc:46:2c:89:75:62:0f:aa:78
+# SHA1 Fingerprint: 07:e0:32:e0:20:b7:2c:3f:19:2f:06:28:a2:59:3a:19:a7:0f:06:9e
+# SHA256 Fingerprint: 5c:58:46:8d:55:f5:8e:49:7e:74:39:82:d2:b5:00:10:b6:d1:65:37:4a:cf:83:a7:d4:a3:2d:b7:68:c4:40:8e
+-----BEGIN CERTIFICATE-----
+MIIDuzCCAqOgAwIBAgIDBETAMA0GCSqGSIb3DQEBBQUAMH4xCzAJBgNVBAYTAlBM
+MSIwIAYDVQQKExlVbml6ZXRvIFRlY2hub2xvZ2llcyBTLkEuMScwJQYDVQQLEx5D
+ZXJ0dW0gQ2VydGlmaWNhdGlvbiBBdXRob3JpdHkxIjAgBgNVBAMTGUNlcnR1bSBU
+cnVzdGVkIE5ldHdvcmsgQ0EwHhcNMDgxMDIyMTIwNzM3WhcNMjkxMjMxMTIwNzM3
+WjB+MQswCQYDVQQGEwJQTDEiMCAGA1UEChMZVW5pemV0byBUZWNobm9sb2dpZXMg
+Uy5BLjEnMCUGA1UECxMeQ2VydHVtIENlcnRpZmljYXRpb24gQXV0aG9yaXR5MSIw
+IAYDVQQDExlDZXJ0dW0gVHJ1c3RlZCBOZXR3b3JrIENBMIIBIjANBgkqhkiG9w0B
+AQEFAAOCAQ8AMIIBCgKCAQEA4/t9o3K6wvDJFIf1awFO4W5AB7ptJ11/91sts1rH
+UV+rpDKmYYe2bg+G0jACl/jXaVehGDldamR5xgFZrDwxSjh80gTSSyjoIF87B6LM
+TXPb865Px1bVWqeWifrzq2jUI4ZZJ88JJ7ysbnKDHDBy3+Ci6dLhdHUZvSqeexVU
+BBvXQzmtVSjF4hq79MDkrjhJM8x2hZ85RdKknvISjFH4fOQtf/WsX+sWn7Et0brM
+kUJ3TCXJkDhv2/DM+44el1k+1WBO5gUo7Ul5E0u6SNsv+XLTOcr+H9g0cvW0QM8x
+AcPs3hEtF10fuFDRXhmnad4HMyjKUJX5p1TLVIZQRan5SQIDAQABo0IwQDAPBgNV
+HRMBAf8EBTADAQH/MB0GA1UdDgQWBBQIds3LB/8k9sXN7buQvOKEN0Z19zAOBgNV
+HQ8BAf8EBAMCAQYwDQYJKoZIhvcNAQEFBQADggEBAKaorSLOAT2mo/9i0Eidi15y
+sHhE49wcrwn9I0j6vSrEuVUEtRCjjSfeC4Jj0O7eDDd5QVsisrCaQVymcODU0HfL
+I9MA4GxWL+FpDQ3Zqr8hgVDZBqWo/5U30Kr+4rP1mS1FhIrlQgnXdAIv94nYmem8
+J9RHjboNRhx3zxSkHLmkMcScKHQDNP8zGSal6Q10tz6XxnboJ5ajZt3hrvJBW8qY
+VoNzcOSGGtIxQbovvi0TWnZvTuhOgQ4/WwMioBK+ZlgRSssDxLQqKi2WF+A5VLxI
+03YnnZotBqbJ7DnSq9ufmgsnAjUpsUCV5/nonFWIGUbWtzT1fs45mtk48VH3Tyw=
+-----END CERTIFICATE-----
+
+# Issuer: CN=TWCA Root Certification Authority O=TAIWAN-CA OU=Root CA
+# Subject: CN=TWCA Root Certification Authority O=TAIWAN-CA OU=Root CA
+# Label: "TWCA Root Certification Authority"
+# Serial: 1
+# MD5 Fingerprint: aa:08:8f:f6:f9:7b:b7:f2:b1:a7:1e:9b:ea:ea:bd:79
+# SHA1 Fingerprint: cf:9e:87:6d:d3:eb:fc:42:26:97:a3:b5:a3:7a:a0:76:a9:06:23:48
+# SHA256 Fingerprint: bf:d8:8f:e1:10:1c:41:ae:3e:80:1b:f8:be:56:35:0e:e9:ba:d1:a6:b9:bd:51:5e:dc:5c:6d:5b:87:11:ac:44
+-----BEGIN CERTIFICATE-----
+MIIDezCCAmOgAwIBAgIBATANBgkqhkiG9w0BAQUFADBfMQswCQYDVQQGEwJUVzES
+MBAGA1UECgwJVEFJV0FOLUNBMRAwDgYDVQQLDAdSb290IENBMSowKAYDVQQDDCFU
+V0NBIFJvb3QgQ2VydGlmaWNhdGlvbiBBdXRob3JpdHkwHhcNMDgwODI4MDcyNDMz
+WhcNMzAxMjMxMTU1OTU5WjBfMQswCQYDVQQGEwJUVzESMBAGA1UECgwJVEFJV0FO
+LUNBMRAwDgYDVQQLDAdSb290IENBMSowKAYDVQQDDCFUV0NBIFJvb3QgQ2VydGlm
+aWNhdGlvbiBBdXRob3JpdHkwggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIB
+AQCwfnK4pAOU5qfeCTiRShFAh6d8WWQUe7UREN3+v9XAu1bihSX0NXIP+FPQQeFE
+AcK0HMMxQhZHhTMidrIKbw/lJVBPhYa+v5guEGcevhEFhgWQxFnQfHgQsIBct+HH
+K3XLfJ+utdGdIzdjp9xCoi2SBBtQwXu4PhvJVgSLL1KbralW6cH/ralYhzC2gfeX
+RfwZVzsrb+RH9JlF/h3x+JejiB03HFyP4HYlmlD4oFT/RJB2I9IyxsOrBr/8+7/z
+rX2SYgJbKdM1o5OaQ2RgXbL6Mv87BK9NQGr5x+PvI/1ry+UPizgN7gr8/g+YnzAx
+3WxSZfmLgb4i4RxYA7qRG4kHAgMBAAGjQjBAMA4GA1UdDwEB/wQEAwIBBjAPBgNV
+HRMBAf8EBTADAQH/MB0GA1UdDgQWBBRqOFsmjd6LWvJPelSDGRjjCDWmujANBgkq
+hkiG9w0BAQUFAAOCAQEAPNV3PdrfibqHDAhUaiBQkr6wQT25JmSDCi/oQMCXKCeC
+MErJk/9q56YAf4lCmtYR5VPOL8zy2gXE/uJQxDqGfczafhAJO5I1KlOy/usrBdls
+XebQ79NqZp4VKIV66IIArB6nCWlWQtNoURi+VJq/REG6Sb4gumlc7rh3zc5sH62D
+lhh9DrUUOYTxKOkto557HnpyWoOzeW/vtPzQCqVYT0bf+215WfKEIlKuD8z7fDvn
+aspHYcN6+NOSBB+4IIThNlQWx0DeO4pz3N/GCUzf7Nr/1FNCocnyYh0igzyXxfkZ
+YiesZSLX0zzG5Y6yU8xJzrww/nsOM5D77dIUkR8Hrw==
+-----END CERTIFICATE-----
+
+# Issuer: O=SECOM Trust Systems CO.,LTD. OU=Security Communication RootCA2
+# Subject: O=SECOM Trust Systems CO.,LTD. OU=Security Communication RootCA2
+# Label: "Security Communication RootCA2"
+# Serial: 0
+# MD5 Fingerprint: 6c:39:7d:a4:0e:55:59:b2:3f:d6:41:b1:12:50:de:43
+# SHA1 Fingerprint: 5f:3b:8c:f2:f8:10:b3:7d:78:b4:ce:ec:19:19:c3:73:34:b9:c7:74
+# SHA256 Fingerprint: 51:3b:2c:ec:b8:10:d4:cd:e5:dd:85:39:1a:df:c6:c2:dd:60:d8:7b:b7:36:d2:b5:21:48:4a:a4:7a:0e:be:f6
+-----BEGIN CERTIFICATE-----
+MIIDdzCCAl+gAwIBAgIBADANBgkqhkiG9w0BAQsFADBdMQswCQYDVQQGEwJKUDEl
+MCMGA1UEChMcU0VDT00gVHJ1c3QgU3lzdGVtcyBDTy4sTFRELjEnMCUGA1UECxMe
+U2VjdXJpdHkgQ29tbXVuaWNhdGlvbiBSb290Q0EyMB4XDTA5MDUyOTA1MDAzOVoX
+DTI5MDUyOTA1MDAzOVowXTELMAkGA1UEBhMCSlAxJTAjBgNVBAoTHFNFQ09NIFRy
+dXN0IFN5c3RlbXMgQ08uLExURC4xJzAlBgNVBAsTHlNlY3VyaXR5IENvbW11bmlj
+YXRpb24gUm9vdENBMjCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBANAV
+OVKxUrO6xVmCxF1SrjpDZYBLx/KWvNs2l9amZIyoXvDjChz335c9S672XewhtUGr
+zbl+dp+++T42NKA7wfYxEUV0kz1XgMX5iZnK5atq1LXaQZAQwdbWQonCv/Q4EpVM
+VAX3NuRFg3sUZdbcDE3R3n4MqzvEFb46VqZab3ZpUql6ucjrappdUtAtCms1FgkQ
+hNBqyjoGADdH5H5XTz+L62e4iKrFvlNVspHEfbmwhRkGeC7bYRr6hfVKkaHnFtWO
+ojnflLhwHyg/i/xAXmODPIMqGplrz95Zajv8bxbXH/1KEOtOghY6rCcMU/Gt1SSw
+awNQwS08Ft1ENCcadfsCAwEAAaNCMEAwHQYDVR0OBBYEFAqFqXdlBZh8QIH4D5cs
+OPEK7DzPMA4GA1UdDwEB/wQEAwIBBjAPBgNVHRMBAf8EBTADAQH/MA0GCSqGSIb3
+DQEBCwUAA4IBAQBMOqNErLlFsceTfsgLCkLfZOoc7llsCLqJX2rKSpWeeo8HxdpF
+coJxDjrSzG+ntKEju/Ykn8sX/oymzsLS28yN/HH8AynBbF0zX2S2ZTuJbxh2ePXc
+okgfGT+Ok+vx+hfuzU7jBBJV1uXk3fs+BXziHV7Gp7yXT2g69ekuCkO2r1dcYmh8
+t/2jioSgrGK+KwmHNPBqAbubKVY8/gA3zyNs8U6qtnRGEmyR7jTV7JqR50S+kDFy
+1UkC9gLl9B/rfNmWVan/7Ir5mUf/NVoCqgTLiluHcSmRvaS0eg29mvVXIwAHIRc/
+SjnRBUkLp7Y3gaVdjKozXoEofKd9J+sAro03
+-----END CERTIFICATE-----
+
+# Issuer: CN=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"
+# Serial: 6271844772424770508
+# MD5 Fingerprint: 69:c1:0d:4f:07:a3:1b:c3:fe:56:3d:04:bc:11:f6:a6
+# SHA1 Fingerprint: f3:73:b3:87:06:5a:28:84:8a:f2:f3:4a:ce:19:2b:dd:c7:8e:9c:ac
+# SHA256 Fingerprint: 55:92:60:84:ec:96:3a:64:b9:6e:2a:be:01:ce:0b:a8:6a:64:fb:fe:bc:c7:aa:b5:af:c1:55:b3:7f:d7:60:66
+-----BEGIN CERTIFICATE-----
+MIIFuzCCA6OgAwIBAgIIVwoRl0LE48wwDQYJKoZIhvcNAQELBQAwazELMAkGA1UE
+BhMCSVQxDjAMBgNVBAcMBU1pbGFuMSMwIQYDVQQKDBpBY3RhbGlzIFMucC5BLi8w
+MzM1ODUyMDk2NzEnMCUGA1UEAwweQWN0YWxpcyBBdXRoZW50aWNhdGlvbiBSb290
+IENBMB4XDTExMDkyMjExMjIwMloXDTMwMDkyMjExMjIwMlowazELMAkGA1UEBhMC
+SVQxDjAMBgNVBAcMBU1pbGFuMSMwIQYDVQQKDBpBY3RhbGlzIFMucC5BLi8wMzM1
+ODUyMDk2NzEnMCUGA1UEAwweQWN0YWxpcyBBdXRoZW50aWNhdGlvbiBSb290IENB
+MIICIjANBgkqhkiG9w0BAQEFAAOCAg8AMIICCgKCAgEAp8bEpSmkLO/lGMWwUKNv
+UTufClrJwkg4CsIcoBh/kbWHuUA/3R1oHwiD1S0eiKD4j1aPbZkCkpAW1V8IbInX
+4ay8IMKx4INRimlNAJZaby/ARH6jDuSRzVju3PvHHkVH3Se5CAGfpiEd9UEtL0z9
+KK3giq0itFZljoZUj5NDKd45RnijMCO6zfB9E1fAXdKDa0hMxKufgFpbOr3JpyI/
+gCczWw63igxdBzcIy2zSekciRDXFzMwujt0q7bd9Zg1fYVEiVRvjRuPjPdA1Yprb
+rxTIW6HMiRvhMCb8oJsfgadHHwTrozmSBp+Z07/T6k9QnBn+locePGX2oxgkg4YQ
+51Q+qDp2JE+BIcXjDwL4k5RHILv+1A7TaLndxHqEguNTVHnd25zS8gebLra8Pu2F
+be8lEfKXGkJh90qX6IuxEAf6ZYGyojnP9zz/GPvG8VqLWeICrHuS0E4UT1lF9gxe
+KF+w6D9Fz8+vm2/7hNN3WpVvrJSEnu68wEqPSpP4RCHiMUVhUE4Q2OM1fEwZtN4F
+v6MGn8i1zeQf1xcGDXqVdFUNaBr8EBtiZJ1t4JWgw5QHVw0U5r0F+7if5t+L4sbn
+fpb2U8WANFAoWPASUHEXMLrmeGO89LKtmyuy/uE5jF66CyCU3nuDuP/jVo23Eek7
+jPKxwV2dpAtMK9myGPW1n0sCAwEAAaNjMGEwHQYDVR0OBBYEFFLYiDrIn3hm7Ynz
+ezhwlMkCAjbQMA8GA1UdEwEB/wQFMAMBAf8wHwYDVR0jBBgwFoAUUtiIOsifeGbt
+ifN7OHCUyQICNtAwDgYDVR0PAQH/BAQDAgEGMA0GCSqGSIb3DQEBCwUAA4ICAQAL
+e3KHwGCmSUyIWOYdiPcUZEim2FgKDk8TNd81HdTtBjHIgT5q1d07GjLukD0R0i70
+jsNjLiNmsGe+b7bAEzlgqqI0JZN1Ut6nna0Oh4lScWoWPBkdg/iaKWW+9D+a2fDz
+WochcYBNy+A4mz+7+uAwTc+G02UQGRjRlwKxK3JCaKygvU5a2hi/a5iB0P2avl4V
+SM0RFbnAKVy06Ij3Pjaut2L9HmLecHgQHEhb2rykOLpn7VU+Xlff1ANATIGk0k9j
+pwlCCRT8AKnCgHNPLsBA2RF7SOp6AsDT6ygBJlh0wcBzIm2Tlf05fbsq4/aC4yyX
+X04fkZT6/iyj2HYauE2yOE+b+h1IYHkm4vP9qdCa6HCPSXrW5b0KDtst842/6+Ok
+fcvHlXHo2qN8xcL4dJIEG4aspCJTQLas/kx2z/uUMsA1n3Y/buWQbqCmJqK4LL7R
+K4X9p2jIugErsWx0Hbhzlefut8cl8ABMALJ+tguLHPPAUJ4lueAI3jZm/zel0btU
+ZCzJJ7VLkn5l/9Mt4blOvH+kQSGQQXemOR/qnuOf0GZvBeyqdn6/axag67XH/JJU
+LysRJyU3eExRarDzzFhdFPFqSBX/wge2sY0PjlxQRrM9vwGYT7JZVEc+NHt4bVaT
+LnPqZih4zR0Uv6CPLy64Lo7yFIrM6bV8+2ydDKXhlg==
+-----END CERTIFICATE-----
+
+# Issuer: 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"
+# Serial: 2
+# MD5 Fingerprint: 46:a7:d2:fe:45:fb:64:5a:a8:59:90:9b:78:44:9b:29
+# SHA1 Fingerprint: 49:0a:75:74:de:87:0a:47:fe:58:ee:f6:c7:6b:eb:c6:0b:12:40:99
+# SHA256 Fingerprint: 9a:11:40:25:19:7c:5b:b9:5d:94:e6:3d:55:cd:43:79:08:47:b6:46:b2:3c:df:11:ad:a4:a0:0e:ff:15:fb:48
+-----BEGIN CERTIFICATE-----
+MIIFWTCCA0GgAwIBAgIBAjANBgkqhkiG9w0BAQsFADBOMQswCQYDVQQGEwJOTzEd
+MBsGA1UECgwUQnV5cGFzcyBBUy05ODMxNjMzMjcxIDAeBgNVBAMMF0J1eXBhc3Mg
+Q2xhc3MgMiBSb290IENBMB4XDTEwMTAyNjA4MzgwM1oXDTQwMTAyNjA4MzgwM1ow
+TjELMAkGA1UEBhMCTk8xHTAbBgNVBAoMFEJ1eXBhc3MgQVMtOTgzMTYzMzI3MSAw
+HgYDVQQDDBdCdXlwYXNzIENsYXNzIDIgUm9vdCBDQTCCAiIwDQYJKoZIhvcNAQEB
+BQADggIPADCCAgoCggIBANfHXvfBB9R3+0Mh9PT1aeTuMgHbo4Yf5FkNuud1g1Lr
+6hxhFUi7HQfKjK6w3Jad6sNgkoaCKHOcVgb/S2TwDCo3SbXlzwx87vFKu3MwZfPV
+L4O2fuPn9Z6rYPnT8Z2SdIrkHJasW4DptfQxh6NR/Md+oW+OU3fUl8FVM5I+GC91
+1K2GScuVr1QGbNgGE41b/+EmGVnAJLqBcXmQRFBoJJRfuLMR8SlBYaNByyM21cHx
+MlAQTn/0hpPshNOOvEu/XAFOBz3cFIqUCqTqc/sLUegTBxj6DvEr0VQVfTzh97QZ
+QmdiXnfgolXsttlpF9U6r0TtSsWe5HonfOV116rLJeffawrbD02TTqigzXsu8lkB
+arcNuAeBfos4GzjmCleZPe4h6KP1DBbdi+w0jpwqHAAVF41og9JwnxgIzRFo1clr
+Us3ERo/ctfPYV3Me6ZQ5BL/T3jjetFPsaRyifsSP5BtwrfKi+fv3FmRmaZ9JUaLi
+FRhnBkp/1Wy1TbMz4GHrXb7pmA8y1x1LPC5aAVKRCfLf6o3YBkBjqhHk/sM3nhRS
+P/TizPJhk9H9Z2vXUq6/aKtAQ6BXNVN48FP4YUIHZMbXb5tMOA1jrGKvNouicwoN
+9SG9dKpN6nIDSdvHXx1iY8f93ZHsM+71bbRuMGjeyNYmsHVee7QHIJihdjK4TWxP
+AgMBAAGjQjBAMA8GA1UdEwEB/wQFMAMBAf8wHQYDVR0OBBYEFMmAd+BikoL1Rpzz
+uvdMw964o605MA4GA1UdDwEB/wQEAwIBBjANBgkqhkiG9w0BAQsFAAOCAgEAU18h
+9bqwOlI5LJKwbADJ784g7wbylp7ppHR/ehb8t/W2+xUbP6umwHJdELFx7rxP462s
+A20ucS6vxOOto70MEae0/0qyexAQH6dXQbLArvQsWdZHEIjzIVEpMMpghq9Gqx3t
+OluwlN5E40EIosHsHdb9T7bWR9AUC8rmyrV7d35BH16Dx7aMOZawP5aBQW9gkOLo
++fsicdl9sz1Gv7SEr5AcD48Saq/v7h56rgJKihcrdv6sVIkkLE8/trKnToyokZf7
+KcZ7XC25y2a2t6hbElGFtQl+Ynhw/qlqYLYdDnkM/crqJIByw5c/8nerQyIKx+u2
+DISCLIBrQYoIwOula9+ZEsuK1V6ADJHgJgg2SMX6OBE1/yWDLfJ6v9r9jv6ly0Us
+H8SIU653DtmadsWOLB2jutXsMq7Aqqz30XpN69QH4kj3Io6wpJ9qzo6ysmD0oyLQ
+I+uUWnpp3Q+/QFesa1lQ2aOZ4W7+jQF5JyMV3pKdewlNWudLSDBaGOYKbeaP4NK7
+5t98biGCwWg5TbSYWGZizEqQXsP6JwSxeRV0mcy+rSDeJmAc61ZRpqPq5KM/p/9h
+3PFaTWwyI0PurKju7koSCTxdccK+efrCh2gdC/1cacwG0Jp9VJkqyTkaGa9LKkPz
+Y11aWOIv4x3kqdbQCtCev9eBCfHJxyYNrJgWVqA=
+-----END CERTIFICATE-----
+
+# Issuer: CN=Buypass Class 3 Root CA O=Buypass AS-983163327
+# Subject: CN=Buypass Class 3 Root CA O=Buypass AS-983163327
+# Label: "Buypass Class 3 Root CA"
+# Serial: 2
+# MD5 Fingerprint: 3d:3b:18:9e:2c:64:5a:e8:d5:88:ce:0e:f9:37:c2:ec
+# SHA1 Fingerprint: da:fa:f7:fa:66:84:ec:06:8f:14:50:bd:c7:c2:81:a5:bc:a9:64:57
+# SHA256 Fingerprint: ed:f7:eb:bc:a2:7a:2a:38:4d:38:7b:7d:40:10:c6:66:e2:ed:b4:84:3e:4c:29:b4:ae:1d:5b:93:32:e6:b2:4d
+-----BEGIN CERTIFICATE-----
+MIIFWTCCA0GgAwIBAgIBAjANBgkqhkiG9w0BAQsFADBOMQswCQYDVQQGEwJOTzEd
+MBsGA1UECgwUQnV5cGFzcyBBUy05ODMxNjMzMjcxIDAeBgNVBAMMF0J1eXBhc3Mg
+Q2xhc3MgMyBSb290IENBMB4XDTEwMTAyNjA4Mjg1OFoXDTQwMTAyNjA4Mjg1OFow
+TjELMAkGA1UEBhMCTk8xHTAbBgNVBAoMFEJ1eXBhc3MgQVMtOTgzMTYzMzI3MSAw
+HgYDVQQDDBdCdXlwYXNzIENsYXNzIDMgUm9vdCBDQTCCAiIwDQYJKoZIhvcNAQEB
+BQADggIPADCCAgoCggIBAKXaCpUWUOOV8l6ddjEGMnqb8RB2uACatVI2zSRHsJ8Y
+ZLya9vrVediQYkwiL944PdbgqOkcLNt4EemOaFEVcsfzM4fkoF0LXOBXByow9c3E
+N3coTRiR5r/VUv1xLXA+58bEiuPwKAv0dpihi4dVsjoT/Lc+JzeOIuOoTyrvYLs9
+tznDDgFHmV0ST9tD+leh7fmdvhFHJlsTmKtdFoqwNxxXnUX/iJY2v7vKB3tvh2PX
+0DJq1l1sDPGzbjniazEuOQAnFN44wOwZZoYS6J1yFhNkUsepNxz9gjDthBgd9K5c
+/3ATAOux9TN6S9ZV+AWNS2mw9bMoNlwUxFFzTWsL8TQH2xc519woe2v1n/MuwU8X
+KhDzzMro6/1rqy6any2CbgTUUgGTLT2G/H783+9CHaZr77kgxve9oKeV/afmiSTY
+zIw0bOIjL9kSGiG5VZFvC5F5GQytQIgLcOJ60g7YaEi7ghM5EFjp2CoHxhLbWNvS
+O1UQRwUVZ2J+GGOmRj8JDlQyXr8NYnon74Do29lLBlo3WiXQCBJ31G8JUJc9yB3D
+34xFMFbG02SrZvPAXpacw8Tvw3xrizp5f7NJzz3iiZ+gMEuFuZyUJHmPfWupRWgP
+K9Dx2hzLabjKSWJtyNBjYt1gD1iqj6G8BaVmos8bdrKEZLFMOVLAMLrwjEsCsLa3
+AgMBAAGjQjBAMA8GA1UdEwEB/wQFMAMBAf8wHQYDVR0OBBYEFEe4zf/lb+74suwv
+Tg75JbCOPGvDMA4GA1UdDwEB/wQEAwIBBjANBgkqhkiG9w0BAQsFAAOCAgEAACAj
+QTUEkMJAYmDv4jVM1z+s4jSQuKFvdvoWFqRINyzpkMLyPPgKn9iB5btb2iUspKdV
+cSQy9sgL8rxq+JOssgfCX5/bzMiKqr5qb+FJEMwx14C7u8jYog5kV+qi9cKpMRXS
+IGrs/CIBKM+GuIAeqcwRpTzyFrNHnfzSgCHEy9BHcEGhyoMZCCxt8l13nIoUE9Q2
+HJLw5QY33KbmkJs4j1xrG0aGQ0JfPgEHU1RdZX33inOhmlRaHylDFCfChQ+1iHsa
+O5S3HWCntZznKWlXWpuTekMwGwPXYshApqr8ZORK15FTAaggiG6cX0S5y2CBNOxv
+033aSF/rtJC8LakcC6wc1aJoIIAE1vyxjy+7SjENSoYc6+I2KSb12tjE8nVhz36u
+dmNKekBlk4f4HoCMhuWG1o8O/FMsYOgWYRqiPkN7zTlgVGr18okmAWiDSKIz6MkE
+kbIRNBE+6tBDGR8Dk5AM/1E9V/RBbuHLoL7ryWPNbczk+DaqaJ3tvV2XcEQNtg41
+3OEMXbugUZTLfhbrES+jkkXITHHZvMmZUldGL1DPvTVp9D0VzgalLA8+9oG6lLvD
+u79leNKGef9JOxqDDPDeeOzI8k1MGt6CKfjBWtrt7uYnXuhF0J0cUahoq0Tj0Itq
+4/g7u9xN12TyUb7mqqta6THuBrxzvxNiCp/HuZc=
+-----END CERTIFICATE-----
+
+# Issuer: CN=T-TeleSec GlobalRoot Class 3 O=T-Systems Enterprise Services GmbH OU=T-Systems Trust Center
+# Subject: CN=T-TeleSec GlobalRoot Class 3 O=T-Systems Enterprise Services GmbH OU=T-Systems Trust Center
+# Label: "T-TeleSec GlobalRoot Class 3"
+# Serial: 1
+# MD5 Fingerprint: ca:fb:40:a8:4e:39:92:8a:1d:fe:8e:2f:c4:27:ea:ef
+# SHA1 Fingerprint: 55:a6:72:3e:cb:f2:ec:cd:c3:23:74:70:19:9d:2a:be:11:e3:81:d1
+# SHA256 Fingerprint: fd:73:da:d3:1c:64:4f:f1:b4:3b:ef:0c:cd:da:96:71:0b:9c:d9:87:5e:ca:7e:31:70:7a:f3:e9:6d:52:2b:bd
+-----BEGIN CERTIFICATE-----
+MIIDwzCCAqugAwIBAgIBATANBgkqhkiG9w0BAQsFADCBgjELMAkGA1UEBhMCREUx
+KzApBgNVBAoMIlQtU3lzdGVtcyBFbnRlcnByaXNlIFNlcnZpY2VzIEdtYkgxHzAd
+BgNVBAsMFlQtU3lzdGVtcyBUcnVzdCBDZW50ZXIxJTAjBgNVBAMMHFQtVGVsZVNl
+YyBHbG9iYWxSb290IENsYXNzIDMwHhcNMDgxMDAxMTAyOTU2WhcNMzMxMDAxMjM1
+OTU5WjCBgjELMAkGA1UEBhMCREUxKzApBgNVBAoMIlQtU3lzdGVtcyBFbnRlcnBy
+aXNlIFNlcnZpY2VzIEdtYkgxHzAdBgNVBAsMFlQtU3lzdGVtcyBUcnVzdCBDZW50
+ZXIxJTAjBgNVBAMMHFQtVGVsZVNlYyBHbG9iYWxSb290IENsYXNzIDMwggEiMA0G
+CSqGSIb3DQEBAQUAA4IBDwAwggEKAoIBAQC9dZPwYiJvJK7genasfb3ZJNW4t/zN
+8ELg63iIVl6bmlQdTQyK9tPPcPRStdiTBONGhnFBSivwKixVA9ZIw+A5OO3yXDw/
+RLyTPWGrTs0NvvAgJ1gORH8EGoel15YUNpDQSXuhdfsaa3Ox+M6pCSzyU9XDFES4
+hqX2iys52qMzVNn6chr3IhUciJFrf2blw2qAsCTz34ZFiP0Zf3WHHx+xGwpzJFu5
+ZeAsVMhg02YXP+HMVDNzkQI6pn97djmiH5a2OK61yJN0HZ65tOVgnS9W0eDrXltM
+EnAMbEQgqxHY9Bn20pxSN+f6tsIxO0rUFJmtxxr1XV/6B7h8DR/Wgx6zAgMBAAGj
+QjBAMA8GA1UdEwEB/wQFMAMBAf8wDgYDVR0PAQH/BAQDAgEGMB0GA1UdDgQWBBS1
+A/d2O2GCahKqGFPrAyGUv/7OyjANBgkqhkiG9w0BAQsFAAOCAQEAVj3vlNW92nOy
+WL6ukK2YJ5f+AbGwUgC4TeQbIXQbfsDuXmkqJa9c1h3a0nnJ85cp4IaH3gRZD/FZ
+1GSFS5mvJQQeyUapl96Cshtwn5z2r3Ex3XsFpSzTucpH9sry9uetuUg/vBa3wW30
+6gmv7PO15wWeph6KU1HWk4HMdJP2udqmJQV0eVp+QD6CSyYRMG7hP0HHRwA11fXT
+91Q+gT3aSWqas+8QPebrb9HIIkfLzM8BMZLZGOMivgkeGj5asuRrDFR6fUNOuIml
+e9eiPZaGzPImNC1qkp2aGtAw4l1OBLBfiyB+d8E9lYLRRpo7PHi4b6HQDWSieB4p
+TpPDpFQUWw==
+-----END CERTIFICATE-----
+
+# Issuer: CN=EE Certification Centre Root CA O=AS Sertifitseerimiskeskus
+# Subject: CN=EE Certification Centre Root CA O=AS Sertifitseerimiskeskus
+# Label: "EE Certification Centre Root CA"
+# Serial: 112324828676200291871926431888494945866
+# MD5 Fingerprint: 43:5e:88:d4:7d:1a:4a:7e:fd:84:2e:52:eb:01:d4:6f
+# SHA1 Fingerprint: c9:a8:b9:e7:55:80:5e:58:e3:53:77:a7:25:eb:af:c3:7b:27:cc:d7
+# SHA256 Fingerprint: 3e:84:ba:43:42:90:85:16:e7:75:73:c0:99:2f:09:79:ca:08:4e:46:85:68:1f:f1:95:cc:ba:8a:22:9b:8a:76
+-----BEGIN CERTIFICATE-----
+MIIEAzCCAuugAwIBAgIQVID5oHPtPwBMyonY43HmSjANBgkqhkiG9w0BAQUFADB1
+MQswCQYDVQQGEwJFRTEiMCAGA1UECgwZQVMgU2VydGlmaXRzZWVyaW1pc2tlc2t1
+czEoMCYGA1UEAwwfRUUgQ2VydGlmaWNhdGlvbiBDZW50cmUgUm9vdCBDQTEYMBYG
+CSqGSIb3DQEJARYJcGtpQHNrLmVlMCIYDzIwMTAxMDMwMTAxMDMwWhgPMjAzMDEy
+MTcyMzU5NTlaMHUxCzAJBgNVBAYTAkVFMSIwIAYDVQQKDBlBUyBTZXJ0aWZpdHNl
+ZXJpbWlza2Vza3VzMSgwJgYDVQQDDB9FRSBDZXJ0aWZpY2F0aW9uIENlbnRyZSBS
+b290IENBMRgwFgYJKoZIhvcNAQkBFglwa2lAc2suZWUwggEiMA0GCSqGSIb3DQEB
+AQUAA4IBDwAwggEKAoIBAQDIIMDs4MVLqwd4lfNE7vsLDP90jmG7sWLqI9iroWUy
+euuOF0+W2Ap7kaJjbMeMTC55v6kF/GlclY1i+blw7cNRfdCT5mzrMEvhvH2/UpvO
+bntl8jixwKIy72KyaOBhU8E2lf/slLo2rpwcpzIP5Xy0xm90/XsY6KxX7QYgSzIw
+WFv9zajmofxwvI6Sc9uXp3whrj3B9UiHbCe9nyV0gVWw93X2PaRka9ZP585ArQ/d
+MtO8ihJTmMmJ+xAdTX7Nfh9WDSFwhfYggx/2uh8Ej+p3iDXE/+pOoYtNP2MbRMNE
+1CV2yreN1x5KZmTNXMWcg+HCCIia7E6j8T4cLNlsHaFLAgMBAAGjgYowgYcwDwYD
+VR0TAQH/BAUwAwEB/zAOBgNVHQ8BAf8EBAMCAQYwHQYDVR0OBBYEFBLyWj7qVhy/
+zQas8fElyalL1BSZMEUGA1UdJQQ+MDwGCCsGAQUFBwMCBggrBgEFBQcDAQYIKwYB
+BQUHAwMGCCsGAQUFBwMEBggrBgEFBQcDCAYIKwYBBQUHAwkwDQYJKoZIhvcNAQEF
+BQADggEBAHv25MANqhlHt01Xo/6tu7Fq1Q+e2+RjxY6hUFaTlrg4wCQiZrxTFGGV
+v9DHKpY5P30osxBAIWrEr7BSdxjhlthWXePdNl4dp1BUoMUq5KqMlIpPnTX/dqQG
+E5Gion0ARD9V04I8GtVbvFZMIi5GQ4okQC3zErg7cBqklrkar4dBGmoYDQZPxz5u
+uSlNDUmJEYcyW+ZLBMjkXOZ0c5RdFpgTlf7727FE5TpwrDdr5rMzcijJs1eg9gIW
+iAYLtqZLICjU3j2LrTcFU3T+bsy8QxdxXvnFzBqpYe73dgzzcvRyrc9yAjYHR8/v
+GVCJYMzpJJUPwssd8m92kMfMdcGWxZ0=
+-----END CERTIFICATE-----
+
+# Issuer: CN=D-TRUST Root Class 3 CA 2 2009 O=D-Trust GmbH
+# Subject: CN=D-TRUST Root Class 3 CA 2 2009 O=D-Trust GmbH
+# Label: "D-TRUST Root Class 3 CA 2 2009"
+# Serial: 623603
+# MD5 Fingerprint: cd:e0:25:69:8d:47:ac:9c:89:35:90:f7:fd:51:3d:2f
+# SHA1 Fingerprint: 58:e8:ab:b0:36:15:33:fb:80:f7:9b:1b:6d:29:d3:ff:8d:5f:00:f0
+# SHA256 Fingerprint: 49:e7:a4:42:ac:f0:ea:62:87:05:00:54:b5:25:64:b6:50:e4:f4:9e:42:e3:48:d6:aa:38:e0:39:e9:57:b1:c1
+-----BEGIN CERTIFICATE-----
+MIIEMzCCAxugAwIBAgIDCYPzMA0GCSqGSIb3DQEBCwUAME0xCzAJBgNVBAYTAkRF
+MRUwEwYDVQQKDAxELVRydXN0IEdtYkgxJzAlBgNVBAMMHkQtVFJVU1QgUm9vdCBD
+bGFzcyAzIENBIDIgMjAwOTAeFw0wOTExMDUwODM1NThaFw0yOTExMDUwODM1NTha
+ME0xCzAJBgNVBAYTAkRFMRUwEwYDVQQKDAxELVRydXN0IEdtYkgxJzAlBgNVBAMM
+HkQtVFJVU1QgUm9vdCBDbGFzcyAzIENBIDIgMjAwOTCCASIwDQYJKoZIhvcNAQEB
+BQADggEPADCCAQoCggEBANOySs96R+91myP6Oi/WUEWJNTrGa9v+2wBoqOADER03
+UAifTUpolDWzU9GUY6cgVq/eUXjsKj3zSEhQPgrfRlWLJ23DEE0NkVJD2IfgXU42
+tSHKXzlABF9bfsyjxiupQB7ZNoTWSPOSHjRGICTBpFGOShrvUD9pXRl/RcPHAY9R
+ySPocq60vFYJfxLLHLGvKZAKyVXMD9O0Gu1HNVpK7ZxzBCHQqr0ME7UAyiZsxGsM
+lFqVlNpQmvH/pStmMaTJOKDfHR+4CS7zp+hnUquVH+BGPtikw8paxTGA6Eian5Rp
+/hnd2HN8gcqW3o7tszIFZYQ05ub9VxC1X3a/L7AQDcUCAwEAAaOCARowggEWMA8G
+A1UdEwEB/wQFMAMBAf8wHQYDVR0OBBYEFP3aFMSfMN4hvR5COfyrYyNJ4PGEMA4G
+A1UdDwEB/wQEAwIBBjCB0wYDVR0fBIHLMIHIMIGAoH6gfIZ6bGRhcDovL2RpcmVj
+dG9yeS5kLXRydXN0Lm5ldC9DTj1ELVRSVVNUJTIwUm9vdCUyMENsYXNzJTIwMyUy
+MENBJTIwMiUyMDIwMDksTz1ELVRydXN0JTIwR21iSCxDPURFP2NlcnRpZmljYXRl
+cmV2b2NhdGlvbmxpc3QwQ6BBoD+GPWh0dHA6Ly93d3cuZC10cnVzdC5uZXQvY3Js
+L2QtdHJ1c3Rfcm9vdF9jbGFzc18zX2NhXzJfMjAwOS5jcmwwDQYJKoZIhvcNAQEL
+BQADggEBAH+X2zDI36ScfSF6gHDOFBJpiBSVYEQBrLLpME+bUMJm2H6NMLVwMeni
+acfzcNsgFYbQDfC+rAF1hM5+n02/t2A7nPPKHeJeaNijnZflQGDSNiH+0LS4F9p0
+o3/U37CYAqxva2ssJSRyoWXuJVrl5jLn8t+rSfrzkGkj2wTZ51xY/GXUl77M/C4K
+zCUqNQT4YJEVdT1B/yMfGchs64JTBKbkTCJNjYy6zltz7GRUUG3RnFX7acM2w4y8
+PIWmawomDeCTmGCufsYkl4phX5GOZpIJhzbNi5stPvZR1FDUWSi9g/LMKHtThm3Y
+Johw1+qRzT65ysCQblrGXnRl11z+o+I=
+-----END CERTIFICATE-----
+
+# Issuer: CN=D-TRUST Root Class 3 CA 2 EV 2009 O=D-Trust GmbH
+# Subject: CN=D-TRUST Root Class 3 CA 2 EV 2009 O=D-Trust GmbH
+# Label: "D-TRUST Root Class 3 CA 2 EV 2009"
+# Serial: 623604
+# MD5 Fingerprint: aa:c6:43:2c:5e:2d:cd:c4:34:c0:50:4f:11:02:4f:b6
+# SHA1 Fingerprint: 96:c9:1b:0b:95:b4:10:98:42:fa:d0:d8:22:79:fe:60:fa:b9:16:83
+# SHA256 Fingerprint: ee:c5:49:6b:98:8c:e9:86:25:b9:34:09:2e:ec:29:08:be:d0:b0:f3:16:c2:d4:73:0c:84:ea:f1:f3:d3:48:81
+-----BEGIN CERTIFICATE-----
+MIIEQzCCAyugAwIBAgIDCYP0MA0GCSqGSIb3DQEBCwUAMFAxCzAJBgNVBAYTAkRF
+MRUwEwYDVQQKDAxELVRydXN0IEdtYkgxKjAoBgNVBAMMIUQtVFJVU1QgUm9vdCBD
+bGFzcyAzIENBIDIgRVYgMjAwOTAeFw0wOTExMDUwODUwNDZaFw0yOTExMDUwODUw
+NDZaMFAxCzAJBgNVBAYTAkRFMRUwEwYDVQQKDAxELVRydXN0IEdtYkgxKjAoBgNV
+BAMMIUQtVFJVU1QgUm9vdCBDbGFzcyAzIENBIDIgRVYgMjAwOTCCASIwDQYJKoZI
+hvcNAQEBBQADggEPADCCAQoCggEBAJnxhDRwui+3MKCOvXwEz75ivJn9gpfSegpn
+ljgJ9hBOlSJzmY3aFS3nBfwZcyK3jpgAvDw9rKFs+9Z5JUut8Mxk2og+KbgPCdM0
+3TP1YtHhzRnp7hhPTFiu4h7WDFsVWtg6uMQYZB7jM7K1iXdODL/ZlGsTl28So/6Z
+qQTMFexgaDbtCHu39b+T7WYxg4zGcTSHThfqr4uRjRxWQa4iN1438h3Z0S0NL2lR
+p75mpoo6Kr3HGrHhFPC+Oh25z1uxav60sUYgovseO3Dvk5h9jHOW8sXvhXCtKSb8
+HgQ+HKDYD8tSg2J87otTlZCpV6LqYQXY+U3EJ/pure3511H3a6UCAwEAAaOCASQw
+ggEgMA8GA1UdEwEB/wQFMAMBAf8wHQYDVR0OBBYEFNOUikxiEyoZLsyvcop9Ntea
+HNxnMA4GA1UdDwEB/wQEAwIBBjCB3QYDVR0fBIHVMIHSMIGHoIGEoIGBhn9sZGFw
+Oi8vZGlyZWN0b3J5LmQtdHJ1c3QubmV0L0NOPUQtVFJVU1QlMjBSb290JTIwQ2xh
+c3MlMjAzJTIwQ0ElMjAyJTIwRVYlMjAyMDA5LE89RC1UcnVzdCUyMEdtYkgsQz1E
+RT9jZXJ0aWZpY2F0ZXJldm9jYXRpb25saXN0MEagRKBChkBodHRwOi8vd3d3LmQt
+dHJ1c3QubmV0L2NybC9kLXRydXN0X3Jvb3RfY2xhc3NfM19jYV8yX2V2XzIwMDku
+Y3JsMA0GCSqGSIb3DQEBCwUAA4IBAQA07XtaPKSUiO8aEXUHL7P+PPoeUSbrh/Yp
+3uDx1MYkCenBz1UbtDDZzhr+BlGmFaQt77JLvyAoJUnRpjZ3NOhk31KxEcdzes05
+nsKtjHEh8lprr988TlWvsoRlFIm5d8sqMb7Po23Pb0iUMkZv53GMoKaEGTcH8gNF
+CSuGdXzfX2lXANtu2KZyIktQ1HWYVt+3GP9DQ1CuekR78HlR10M9p9OB0/DJT7na
+xpeG0ILD5EJt/rDiZE4OJudANCa1CInXCGNjOCd1HjPqbqjdn5lPdE2BiYBL3ZqX
+KVwvvoFBuYz/6n1gBp7N1z3TLqMVvKjmJuVvw9y4AyHqnxbxLFS1
+-----END CERTIFICATE-----
+
+# Issuer: CN=CA Disig Root R2 O=Disig a.s.
+# Subject: CN=CA Disig Root R2 O=Disig a.s.
+# Label: "CA Disig Root R2"
+# Serial: 10572350602393338211
+# MD5 Fingerprint: 26:01:fb:d8:27:a7:17:9a:45:54:38:1a:43:01:3b:03
+# SHA1 Fingerprint: b5:61:eb:ea:a4:de:e4:25:4b:69:1a:98:a5:57:47:c2:34:c7:d9:71
+# SHA256 Fingerprint: e2:3d:4a:03:6d:7b:70:e9:f5:95:b1:42:20:79:d2:b9:1e:df:bb:1f:b6:51:a0:63:3e:aa:8a:9d:c5:f8:07:03
+-----BEGIN CERTIFICATE-----
+MIIFaTCCA1GgAwIBAgIJAJK4iNuwisFjMA0GCSqGSIb3DQEBCwUAMFIxCzAJBgNV
+BAYTAlNLMRMwEQYDVQQHEwpCcmF0aXNsYXZhMRMwEQYDVQQKEwpEaXNpZyBhLnMu
+MRkwFwYDVQQDExBDQSBEaXNpZyBSb290IFIyMB4XDTEyMDcxOTA5MTUzMFoXDTQy
+MDcxOTA5MTUzMFowUjELMAkGA1UEBhMCU0sxEzARBgNVBAcTCkJyYXRpc2xhdmEx
+EzARBgNVBAoTCkRpc2lnIGEucy4xGTAXBgNVBAMTEENBIERpc2lnIFJvb3QgUjIw
+ggIiMA0GCSqGSIb3DQEBAQUAA4ICDwAwggIKAoICAQCio8QACdaFXS1tFPbCw3Oe
+NcJxVX6B+6tGUODBfEl45qt5WDza/3wcn9iXAng+a0EE6UG9vgMsRfYvZNSrXaNH
+PWSb6WiaxswbP7q+sos0Ai6YVRn8jG+qX9pMzk0DIaPY0jSTVpbLTAwAFjxfGs3I
+x2ymrdMxp7zo5eFm1tL7A7RBZckQrg4FY8aAamkw/dLukO8NJ9+flXP04SXabBbe
+QTg06ov80egEFGEtQX6sx3dOy1FU+16SGBsEWmjGycT6txOgmLcRK7fWV8x8nhfR
+yyX+hk4kLlYMeE2eARKmK6cBZW58Yh2EhN/qwGu1pSqVg8NTEQxzHQuyRpDRQjrO
+QG6Vrf/GlK1ul4SOfW+eioANSW1z4nuSHsPzwfPrLgVv2RvPN3YEyLRa5Beny912
+H9AZdugsBbPWnDTYltxhh5EF5EQIM8HauQhl1K6yNg3ruji6DOWbnuuNZt2Zz9aJ
+QfYEkoopKW1rOhzndX0CcQ7zwOe9yxndnWCywmZgtrEE7snmhrmaZkCo5xHtgUUD
+i/ZnWejBBhG93c+AAk9lQHhcR1DIm+YfgXvkRKhbhZri3lrVx/k6RGZL5DJUfORs
+nLMOPReisjQS1n6yqEm70XooQL6iFh/f5DcfEXP7kAplQ6INfPgGAVUzfbANuPT1
+rqVCV3w2EYx7XsQDnYx5nQIDAQABo0IwQDAPBgNVHRMBAf8EBTADAQH/MA4GA1Ud
+DwEB/wQEAwIBBjAdBgNVHQ4EFgQUtZn4r7CU9eMg1gqtzk5WpC5uQu0wDQYJKoZI
+hvcNAQELBQADggIBACYGXnDnZTPIgm7ZnBc6G3pmsgH2eDtpXi/q/075KMOYKmFM
+tCQSin1tERT3nLXK5ryeJ45MGcipvXrA1zYObYVybqjGom32+nNjf7xueQgcnYqf
+GopTpti72TVVsRHFqQOzVju5hJMiXn7B9hJSi+osZ7z+Nkz1uM/Rs0mSO9MpDpkb
+lvdhuDvEK7Z4bLQjb/D907JedR+Zlais9trhxTF7+9FGs9K8Z7RiVLoJ92Owk6Ka
++elSLotgEqv89WBW7xBci8QaQtyDW2QOy7W81k/BfDxujRNt+3vrMNDcTa/F1bal
+TFtxyegxvug4BkihGuLq0t4SOVga/4AOgnXmt8kHbA7v/zjxmHHEt38OFdAlab0i
+nSvtBfZGR6ztwPDUO+Ls7pZbkBNOHlY667DvlruWIxG68kOGdGSVyCh13x01utI3
+gzhTODY7z2zp+WsO0PsE6E9312UBeIYMej4hYvF/Y3EMyZ9E26gnonW+boE+18Dr
+G5gPcFw0sorMwIUY6256s/daoQe/qUKS82Ail+QUoQebTnbAjn39pCXHR+3/H3Os
+zMOl6W8KjptlwlCFtaOgUxLMVYdh84GuEEZhvUQhuMI9dM9+JDX6HAcOmz0iyu8x
+L4ysEr3vQCj8KWefshNPZiTEUxnpHikV7+ZtsH8tZ/3zbBt1RqPlShfppNcL
+-----END CERTIFICATE-----
+
+# Issuer: CN=ACCVRAIZ1 O=ACCV OU=PKIACCV
+# Subject: CN=ACCVRAIZ1 O=ACCV OU=PKIACCV
+# Label: "ACCVRAIZ1"
+# Serial: 6828503384748696800
+# MD5 Fingerprint: d0:a0:5a:ee:05:b6:09:94:21:a1:7d:f1:b2:29:82:02
+# SHA1 Fingerprint: 93:05:7a:88:15:c6:4f:ce:88:2f:fa:91:16:52:28:78:bc:53:64:17
+# SHA256 Fingerprint: 9a:6e:c0:12:e1:a7:da:9d:be:34:19:4d:47:8a:d7:c0:db:18:22:fb:07:1d:f1:29:81:49:6e:d1:04:38:41:13
+-----BEGIN CERTIFICATE-----
+MIIH0zCCBbugAwIBAgIIXsO3pkN/pOAwDQYJKoZIhvcNAQEFBQAwQjESMBAGA1UE
+AwwJQUNDVlJBSVoxMRAwDgYDVQQLDAdQS0lBQ0NWMQ0wCwYDVQQKDARBQ0NWMQsw
+CQYDVQQGEwJFUzAeFw0xMTA1MDUwOTM3MzdaFw0zMDEyMzEwOTM3MzdaMEIxEjAQ
+BgNVBAMMCUFDQ1ZSQUlaMTEQMA4GA1UECwwHUEtJQUNDVjENMAsGA1UECgwEQUND
+VjELMAkGA1UEBhMCRVMwggIiMA0GCSqGSIb3DQEBAQUAA4ICDwAwggIKAoICAQCb
+qau/YUqXry+XZpp0X9DZlv3P4uRm7x8fRzPCRKPfmt4ftVTdFXxpNRFvu8gMjmoY
+HtiP2Ra8EEg2XPBjs5BaXCQ316PWywlxufEBcoSwfdtNgM3802/J+Nq2DoLSRYWo
+G2ioPej0RGy9ocLLA76MPhMAhN9KSMDjIgro6TenGEyxCQ0jVn8ETdkXhBilyNpA
+lHPrzg5XPAOBOp0KoVdDaaxXbXmQeOW1tDvYvEyNKKGno6e6Ak4l0Squ7a4DIrhr
+IA8wKFSVf+DuzgpmndFALW4ir50awQUZ0m/A8p/4e7MCQvtQqR0tkw8jq8bBD5L/
+0KIV9VMJcRz/RROE5iZe+OCIHAr8Fraocwa48GOEAqDGWuzndN9wrqODJerWx5eH
+k6fGioozl2A3ED6XPm4pFdahD9GILBKfb6qkxkLrQaLjlUPTAYVtjrs78yM2x/47
+4KElB0iryYl0/wiPgL/AlmXz7uxLaL2diMMxs0Dx6M/2OLuc5NF/1OVYm3z61PMO
+m3WR5LpSLhl+0fXNWhn8ugb2+1KoS5kE3fj5tItQo05iifCHJPqDQsGH+tUtKSpa
+cXpkatcnYGMN285J9Y0fkIkyF/hzQ7jSWpOGYdbhdQrqeWZ2iE9x6wQl1gpaepPl
+uUsXQA+xtrn13k/c4LOsOxFwYIRKQ26ZIMApcQrAZQIDAQABo4ICyzCCAscwfQYI
+KwYBBQUHAQEEcTBvMEwGCCsGAQUFBzAChkBodHRwOi8vd3d3LmFjY3YuZXMvZmls
+ZWFkbWluL0FyY2hpdm9zL2NlcnRpZmljYWRvcy9yYWl6YWNjdjEuY3J0MB8GCCsG
+AQUFBzABhhNodHRwOi8vb2NzcC5hY2N2LmVzMB0GA1UdDgQWBBTSh7Tj3zcnk1X2
+VuqB5TbMjB4/vTAPBgNVHRMBAf8EBTADAQH/MB8GA1UdIwQYMBaAFNKHtOPfNyeT
+VfZW6oHlNsyMHj+9MIIBcwYDVR0gBIIBajCCAWYwggFiBgRVHSAAMIIBWDCCASIG
+CCsGAQUFBwICMIIBFB6CARAAQQB1AHQAbwByAGkAZABhAGQAIABkAGUAIABDAGUA
+cgB0AGkAZgBpAGMAYQBjAGkA8wBuACAAUgBhAO0AegAgAGQAZQAgAGwAYQAgAEEA
+QwBDAFYAIAAoAEEAZwBlAG4AYwBpAGEAIABkAGUAIABUAGUAYwBuAG8AbABvAGcA
+7QBhACAAeQAgAEMAZQByAHQAaQBmAGkAYwBhAGMAaQDzAG4AIABFAGwAZQBjAHQA
+cgDzAG4AaQBjAGEALAAgAEMASQBGACAAUQA0ADYAMAAxADEANQA2AEUAKQAuACAA
+QwBQAFMAIABlAG4AIABoAHQAdABwADoALwAvAHcAdwB3AC4AYQBjAGMAdgAuAGUA
+czAwBggrBgEFBQcCARYkaHR0cDovL3d3dy5hY2N2LmVzL2xlZ2lzbGFjaW9uX2Mu
+aHRtMFUGA1UdHwROMEwwSqBIoEaGRGh0dHA6Ly93d3cuYWNjdi5lcy9maWxlYWRt
+aW4vQXJjaGl2b3MvY2VydGlmaWNhZG9zL3JhaXphY2N2MV9kZXIuY3JsMA4GA1Ud
+DwEB/wQEAwIBBjAXBgNVHREEEDAOgQxhY2N2QGFjY3YuZXMwDQYJKoZIhvcNAQEF
+BQADggIBAJcxAp/n/UNnSEQU5CmH7UwoZtCPNdpNYbdKl02125DgBS4OxnnQ8pdp
+D70ER9m+27Up2pvZrqmZ1dM8MJP1jaGo/AaNRPTKFpV8M9xii6g3+CfYCS0b78gU
+JyCpZET/LtZ1qmxNYEAZSUNUY9rizLpm5U9EelvZaoErQNV/+QEnWCzI7UiRfD+m
+AM/EKXMRNt6GGT6d7hmKG9Ww7Y49nCrADdg9ZuM8Db3VlFzi4qc1GwQA9j9ajepD
+vV+JHanBsMyZ4k0ACtrJJ1vnE5Bc5PUzolVt3OAJTS+xJlsndQAJxGJ3KQhfnlms
+tn6tn1QwIgPBHnFk/vk4CpYY3QIUrCPLBhwepH2NDd4nQeit2hW3sCPdK6jT2iWH
+7ehVRE2I9DZ+hJp4rPcOVkkO1jMl1oRQQmwgEh0q1b688nCBpHBgvgW1m54ERL5h
+I6zppSSMEYCUWqKiuUnSwdzRp+0xESyeGabu4VXhwOrPDYTkF7eifKXeVSUG7szA
+h1xA2syVP1XgNce4hL60Xc16gwFy7ofmXx2utYXGJt/mwZrpHgJHnyqobalbz+xF
+d3+YJ5oyXSrjhO7FmGYvliAd3djDJ9ew+f7Zfc3Qn48LFFhRny+Lwzgt3uiP1o2H
+pPVWQxaZLPSkVrQ0uGE3ycJYgBugl6H8WY3pEfbRD0tVNEYqi4Y7
+-----END CERTIFICATE-----
+
+# Issuer: CN=TWCA Global Root CA O=TAIWAN-CA OU=Root CA
+# Subject: CN=TWCA Global Root CA O=TAIWAN-CA OU=Root CA
+# Label: "TWCA Global Root CA"
+# Serial: 3262
+# MD5 Fingerprint: f9:03:7e:cf:e6:9e:3c:73:7a:2a:90:07:69:ff:2b:96
+# SHA1 Fingerprint: 9c:bb:48:53:f6:a4:f6:d3:52:a4:e8:32:52:55:60:13:f5:ad:af:65
+# SHA256 Fingerprint: 59:76:90:07:f7:68:5d:0f:cd:50:87:2f:9f:95:d5:75:5a:5b:2b:45:7d:81:f3:69:2b:61:0a:98:67:2f:0e:1b
+-----BEGIN CERTIFICATE-----
+MIIFQTCCAymgAwIBAgICDL4wDQYJKoZIhvcNAQELBQAwUTELMAkGA1UEBhMCVFcx
+EjAQBgNVBAoTCVRBSVdBTi1DQTEQMA4GA1UECxMHUm9vdCBDQTEcMBoGA1UEAxMT
+VFdDQSBHbG9iYWwgUm9vdCBDQTAeFw0xMjA2MjcwNjI4MzNaFw0zMDEyMzExNTU5
+NTlaMFExCzAJBgNVBAYTAlRXMRIwEAYDVQQKEwlUQUlXQU4tQ0ExEDAOBgNVBAsT
+B1Jvb3QgQ0ExHDAaBgNVBAMTE1RXQ0EgR2xvYmFsIFJvb3QgQ0EwggIiMA0GCSqG
+SIb3DQEBAQUAA4ICDwAwggIKAoICAQCwBdvI64zEbooh745NnHEKH1Jw7W2CnJfF
+10xORUnLQEK1EjRsGcJ0pDFfhQKX7EMzClPSnIyOt7h52yvVavKOZsTuKwEHktSz
+0ALfUPZVr2YOy+BHYC8rMjk1Ujoog/h7FsYYuGLWRyWRzvAZEk2tY/XTP3VfKfCh
+MBwqoJimFb3u/Rk28OKRQ4/6ytYQJ0lM793B8YVwm8rqqFpD/G2Gb3PpN0Wp8DbH
+zIh1HrtsBv+baz4X7GGqcXzGHaL3SekVtTzWoWH1EfcFbx39Eb7QMAfCKbAJTibc
+46KokWofwpFFiFzlmLhxpRUZyXx1EcxwdE8tmx2RRP1WKKD+u4ZqyPpcC1jcxkt2
+yKsi2XMPpfRaAok/T54igu6idFMqPVMnaR1sjjIsZAAmY2E2TqNGtz99sy2sbZCi
+laLOz9qC5wc0GZbpuCGqKX6mOL6OKUohZnkfs8O1CWfe1tQHRvMq2uYiN2DLgbYP
+oA/pyJV/v1WRBXrPPRXAb94JlAGD1zQbzECl8LibZ9WYkTunhHiVJqRaCPgrdLQA
+BDzfuBSO6N+pjWxnkjMdwLfS7JLIvgm/LCkFbwJrnu+8vyq8W8BQj0FwcYeyTbcE
+qYSjMq+u7msXi7Kx/mzhkIyIqJdIzshNy/MGz19qCkKxHh53L46g5pIOBvwFItIm
+4TFRfTLcDwIDAQABoyMwITAOBgNVHQ8BAf8EBAMCAQYwDwYDVR0TAQH/BAUwAwEB
+/zANBgkqhkiG9w0BAQsFAAOCAgEAXzSBdu+WHdXltdkCY4QWwa6gcFGn90xHNcgL
+1yg9iXHZqjNB6hQbbCEAwGxCGX6faVsgQt+i0trEfJdLjbDorMjupWkEmQqSpqsn
+LhpNgb+E1HAerUf+/UqdM+DyucRFCCEK2mlpc3INvjT+lIutwx4116KD7+U4x6WF
+H6vPNOw/KP4M8VeGTslV9xzU2KV9Bnpv1d8Q34FOIWWxtuEXeZVFBs5fzNxGiWNo
+RI2T9GRwoD2dKAXDOXC4Ynsg/eTb6QihuJ49CcdP+yz4k3ZB3lLg4VfSnQO8d57+
+nile98FRYB/e2guyLXW3Q0iT5/Z5xoRdgFlglPx4mI88k1HtQJAH32RjJMtOcQWh
+15QaiDLxInQirqWm2BJpTGCjAu4r7NRjkgtevi92a6O2JryPA9gK8kxkRr05YuWW
+6zRjESjMlfGt7+/cgFhI6Uu46mWs6fyAtbXIRfmswZ/ZuepiiI7E8UuDEq3mi4TW
+nsLrgxifarsbJGAzcMzs9zLzXNl5fe+epP7JI8Mk7hWSsT2RTyaGvWZzJBPqpK5j
+wa19hAM8EHiGG3njxPPyBJUgriOCxLM6AGK/5jYk4Ve6xx6QddVfP5VhK8E7zeWz
+aGHQRiapIVJpLesux+t3zqY6tQMzT3bR51xUAV3LePTJDL/PEo4XLSNolOer/qmy
+KwbQBM0=
+-----END CERTIFICATE-----
+
+# Issuer: CN=TeliaSonera Root CA v1 O=TeliaSonera
+# Subject: CN=TeliaSonera Root CA v1 O=TeliaSonera
+# Label: "TeliaSonera Root CA v1"
+# Serial: 199041966741090107964904287217786801558
+# MD5 Fingerprint: 37:41:49:1b:18:56:9a:26:f5:ad:c2:66:fb:40:a5:4c
+# SHA1 Fingerprint: 43:13:bb:96:f1:d5:86:9b:c1:4e:6a:92:f6:cf:f6:34:69:87:82:37
+# SHA256 Fingerprint: dd:69:36:fe:21:f8:f0:77:c1:23:a1:a5:21:c1:22:24:f7:22:55:b7:3e:03:a7:26:06:93:e8:a2:4b:0f:a3:89
+-----BEGIN CERTIFICATE-----
+MIIFODCCAyCgAwIBAgIRAJW+FqD3LkbxezmCcvqLzZYwDQYJKoZIhvcNAQEFBQAw
+NzEUMBIGA1UECgwLVGVsaWFTb25lcmExHzAdBgNVBAMMFlRlbGlhU29uZXJhIFJv
+b3QgQ0EgdjEwHhcNMDcxMDE4MTIwMDUwWhcNMzIxMDE4MTIwMDUwWjA3MRQwEgYD
+VQQKDAtUZWxpYVNvbmVyYTEfMB0GA1UEAwwWVGVsaWFTb25lcmEgUm9vdCBDQSB2
+MTCCAiIwDQYJKoZIhvcNAQEBBQADggIPADCCAgoCggIBAMK+6yfwIaPzaSZVfp3F
+VRaRXP3vIb9TgHot0pGMYzHw7CTww6XScnwQbfQ3t+XmfHnqjLWCi65ItqwA3GV1
+7CpNX8GH9SBlK4GoRz6JI5UwFpB/6FcHSOcZrr9FZ7E3GwYq/t75rH2D+1665I+X
+Z75Ljo1kB1c4VWk0Nj0TSO9P4tNmHqTPGrdeNjPUtAa9GAH9d4RQAEX1jF3oI7x+
+/jXh7VB7qTCNGdMJjmhnXb88lxhTuylixcpecsHHltTbLaC0H2kD7OriUPEMPPCs
+81Mt8Bz17Ww5OXOAFshSsCPN4D7c3TxHoLs1iuKYaIu+5b9y7tL6pe0S7fyYGKkm
+dtwoSxAgHNN/Fnct7W+A90m7UwW7XWjH1Mh1Fj+JWov3F0fUTPHSiXk+TT2YqGHe
+Oh7S+F4D4MHJHIzTjU3TlTazN19jY5szFPAtJmtTfImMMsJu7D0hADnJoWjiUIMu
+sDor8zagrC/kb2HCUQk5PotTubtn2txTuXZZNp1D5SDgPTJghSJRt8czu90VL6R4
+pgd7gUY2BIbdeTXHlSw7sKMXNeVzH7RcWe/a6hBle3rQf5+ztCo3O3CLm1u5K7fs
+slESl1MpWtTwEhDcTwK7EpIvYtQ/aUN8Ddb8WHUBiJ1YFkveupD/RwGJBmr2X7KQ
+arMCpgKIv7NHfirZ1fpoeDVNAgMBAAGjPzA9MA8GA1UdEwEB/wQFMAMBAf8wCwYD
+VR0PBAQDAgEGMB0GA1UdDgQWBBTwj1k4ALP1j5qWDNXr+nuqF+gTEjANBgkqhkiG
+9w0BAQUFAAOCAgEAvuRcYk4k9AwI//DTDGjkk0kiP0Qnb7tt3oNmzqjMDfz1mgbl
+dxSR651Be5kqhOX//CHBXfDkH1e3damhXwIm/9fH907eT/j3HEbAek9ALCI18Bmx
+0GtnLLCo4MBANzX2hFxc469CeP6nyQ1Q6g2EdvZR74NTxnr/DlZJLo961gzmJ1Tj
+TQpgcmLNkQfWpb/ImWvtxBnmq0wROMVvMeJuScg/doAmAyYp4Db29iBT4xdwNBed
+Y2gea+zDTYa4EzAvXUYNR0PVG6pZDrlcjQZIrXSHX8f8MVRBE+LHIQ6e4B4N4cB7
+Q4WQxYpYxmUKeFfyxiMPAdkgS94P+5KFdSpcc41teyWRyu5FrgZLAMzTsVlQ2jqI
+OylDRl6XK1TOU2+NSueW+r9xDkKLfP0ooNBIytrEgUy7onOTJsjrDNYmiLbAJM+7
+vVvrdX3pCI6GMyx5dwlppYn8s3CQh3aP0yK7Qs69cwsgJirQmz1wHiRszYd2qReW
+t88NkvuOGKmYSdGe/mBEciG5Ge3C9THxOUiIkCR1VBatzvT4aRRkOfujuLpwQMcn
+HL/EVlP6Y2XQ8xwOFvVrhlhNGNTkDY6lnVuR3HYkUD/GKvvZt5y11ubQ2egZixVx
+SK236thZiNSQvxaz2emsWWFUyBy6ysHK4bkgTI86k4mloMy/0/Z1pHWWbVY=
+-----END CERTIFICATE-----
+
+# Issuer: CN=E-Tugra Certification Authority O=E-Tu\u011fra EBG Bili\u015fim Teknolojileri ve Hizmetleri A.\u015e. OU=E-Tugra Sertifikasyon Merkezi
+# Subject: CN=E-Tugra Certification Authority O=E-Tu\u011fra EBG Bili\u015fim Teknolojileri ve Hizmetleri A.\u015e. OU=E-Tugra Sertifikasyon Merkezi
+# Label: "E-Tugra Certification Authority"
+# Serial: 7667447206703254355
+# MD5 Fingerprint: b8:a1:03:63:b0:bd:21:71:70:8a:6f:13:3a:bb:79:49
+# SHA1 Fingerprint: 51:c6:e7:08:49:06:6e:f3:92:d4:5c:a0:0d:6d:a3:62:8f:c3:52:39
+# SHA256 Fingerprint: b0:bf:d5:2b:b0:d7:d9:bd:92:bf:5d:4d:c1:3d:a2:55:c0:2c:54:2f:37:83:65:ea:89:39:11:f5:5e:55:f2:3c
+-----BEGIN CERTIFICATE-----
+MIIGSzCCBDOgAwIBAgIIamg+nFGby1MwDQYJKoZIhvcNAQELBQAwgbIxCzAJBgNV
+BAYTAlRSMQ8wDQYDVQQHDAZBbmthcmExQDA+BgNVBAoMN0UtVHXEn3JhIEVCRyBC
+aWxpxZ9pbSBUZWtub2xvamlsZXJpIHZlIEhpem1ldGxlcmkgQS7Fni4xJjAkBgNV
+BAsMHUUtVHVncmEgU2VydGlmaWthc3lvbiBNZXJrZXppMSgwJgYDVQQDDB9FLVR1
+Z3JhIENlcnRpZmljYXRpb24gQXV0aG9yaXR5MB4XDTEzMDMwNTEyMDk0OFoXDTIz
+MDMwMzEyMDk0OFowgbIxCzAJBgNVBAYTAlRSMQ8wDQYDVQQHDAZBbmthcmExQDA+
+BgNVBAoMN0UtVHXEn3JhIEVCRyBCaWxpxZ9pbSBUZWtub2xvamlsZXJpIHZlIEhp
+em1ldGxlcmkgQS7Fni4xJjAkBgNVBAsMHUUtVHVncmEgU2VydGlmaWthc3lvbiBN
+ZXJrZXppMSgwJgYDVQQDDB9FLVR1Z3JhIENlcnRpZmljYXRpb24gQXV0aG9yaXR5
+MIICIjANBgkqhkiG9w0BAQEFAAOCAg8AMIICCgKCAgEA4vU/kwVRHoViVF56C/UY
+B4Oufq9899SKa6VjQzm5S/fDxmSJPZQuVIBSOTkHS0vdhQd2h8y/L5VMzH2nPbxH
+D5hw+IyFHnSOkm0bQNGZDbt1bsipa5rAhDGvykPL6ys06I+XawGb1Q5KCKpbknSF
+Q9OArqGIW66z6l7LFpp3RMih9lRozt6Plyu6W0ACDGQXwLWTzeHxE2bODHnv0ZEo
+q1+gElIwcxmOj+GMB6LDu0rw6h8VqO4lzKRG+Bsi77MOQ7osJLjFLFzUHPhdZL3D
+k14opz8n8Y4e0ypQBaNV2cvnOVPAmJ6MVGKLJrD3fY185MaeZkJVgkfnsliNZvcH
+fC425lAcP9tDJMW/hkd5s3kc91r0E+xs+D/iWR+V7kI+ua2oMoVJl0b+SzGPWsut
+dEcf6ZG33ygEIqDUD13ieU/qbIWGvaimzuT6w+Gzrt48Ue7LE3wBf4QOXVGUnhMM
+ti6lTPk5cDZvlsouDERVxcr6XQKj39ZkjFqzAQqptQpHF//vkUAqjqFGOjGY5RH8
+zLtJVor8udBhmm9lbObDyz51Sf6Pp+KJxWfXnUYTTjF2OySznhFlhqt/7x3U+Lzn
+rFpct1pHXFXOVbQicVtbC/DP3KBhZOqp12gKY6fgDT+gr9Oq0n7vUaDmUStVkhUX
+U8u3Zg5mTPj5dUyQ5xJwx0UCAwEAAaNjMGEwHQYDVR0OBBYEFC7j27JJ0JxUeVz6
+Jyr+zE7S6E5UMA8GA1UdEwEB/wQFMAMBAf8wHwYDVR0jBBgwFoAULuPbsknQnFR5
+XPonKv7MTtLoTlQwDgYDVR0PAQH/BAQDAgEGMA0GCSqGSIb3DQEBCwUAA4ICAQAF
+Nzr0TbdF4kV1JI+2d1LoHNgQk2Xz8lkGpD4eKexd0dCrfOAKkEh47U6YA5n+KGCR
+HTAduGN8qOY1tfrTYXbm1gdLymmasoR6d5NFFxWfJNCYExL/u6Au/U5Mh/jOXKqY
+GwXgAEZKgoClM4so3O0409/lPun++1ndYYRP0lSWE2ETPo+Aab6TR7U1Q9Jauz1c
+77NCR807VRMGsAnb/WP2OogKmW9+4c4bU2pEZiNRCHu8W1Ki/QY3OEBhj0qWuJA3
++GbHeJAAFS6LrVE1Uweoa2iu+U48BybNCAVwzDk/dr2l02cmAYamU9JgO3xDf1WK
+vJUawSg5TB9D0pH0clmKuVb8P7Sd2nCcdlqMQ1DujjByTd//SffGqWfZbawCEeI6
+FiWnWAjLb1NBnEg4R2gz0dfHj9R0IdTDBZB6/86WiLEVKV0jq9BgoRJP3vQXzTLl
+yb/IQ639Lo7xr+L0mPoSHyDYwKcMhcWQ9DstliaxLL5Mq+ux0orJ23gTDx4JnW2P
+AJ8C2sH6H3p6CcRK5ogql5+Ji/03X186zjhZhkuvcQu02PJwT58yE+Owp1fl2tpD
+y4Q08ijE6m30Ku/Ba3ba+367hTzSU8JNvnHhRdH9I2cNE3X7z2VnIp2usAnRCf8d
+NL/+I5c30jn6PQ0GC7TbO6Orb1wdtn7os4I07QZcJA==
+-----END CERTIFICATE-----
+
+# Issuer: CN=T-TeleSec GlobalRoot Class 2 O=T-Systems Enterprise Services GmbH OU=T-Systems Trust Center
+# Subject: CN=T-TeleSec GlobalRoot Class 2 O=T-Systems Enterprise Services GmbH OU=T-Systems Trust Center
+# Label: "T-TeleSec GlobalRoot Class 2"
+# Serial: 1
+# MD5 Fingerprint: 2b:9b:9e:e4:7b:6c:1f:00:72:1a:cc:c1:77:79:df:6a
+# SHA1 Fingerprint: 59:0d:2d:7d:88:4f:40:2e:61:7e:a5:62:32:17:65:cf:17:d8:94:e9
+# SHA256 Fingerprint: 91:e2:f5:78:8d:58:10:eb:a7:ba:58:73:7d:e1:54:8a:8e:ca:cd:01:45:98:bc:0b:14:3e:04:1b:17:05:25:52
+-----BEGIN CERTIFICATE-----
+MIIDwzCCAqugAwIBAgIBATANBgkqhkiG9w0BAQsFADCBgjELMAkGA1UEBhMCREUx
+KzApBgNVBAoMIlQtU3lzdGVtcyBFbnRlcnByaXNlIFNlcnZpY2VzIEdtYkgxHzAd
+BgNVBAsMFlQtU3lzdGVtcyBUcnVzdCBDZW50ZXIxJTAjBgNVBAMMHFQtVGVsZVNl
+YyBHbG9iYWxSb290IENsYXNzIDIwHhcNMDgxMDAxMTA0MDE0WhcNMzMxMDAxMjM1
+OTU5WjCBgjELMAkGA1UEBhMCREUxKzApBgNVBAoMIlQtU3lzdGVtcyBFbnRlcnBy
+aXNlIFNlcnZpY2VzIEdtYkgxHzAdBgNVBAsMFlQtU3lzdGVtcyBUcnVzdCBDZW50
+ZXIxJTAjBgNVBAMMHFQtVGVsZVNlYyBHbG9iYWxSb290IENsYXNzIDIwggEiMA0G
+CSqGSIb3DQEBAQUAA4IBDwAwggEKAoIBAQCqX9obX+hzkeXaXPSi5kfl82hVYAUd
+AqSzm1nzHoqvNK38DcLZSBnuaY/JIPwhqgcZ7bBcrGXHX+0CfHt8LRvWurmAwhiC
+FoT6ZrAIxlQjgeTNuUk/9k9uN0goOA/FvudocP05l03Sx5iRUKrERLMjfTlH6VJi
+1hKTXrcxlkIF+3anHqP1wvzpesVsqXFP6st4vGCvx9702cu+fjOlbpSD8DT6Iavq
+jnKgP6TeMFvvhk1qlVtDRKgQFRzlAVfFmPHmBiiRqiDFt1MmUUOyCxGVWOHAD3bZ
+wI18gfNycJ5v/hqO2V81xrJvNHy+SE/iWjnX2J14np+GPgNeGYtEotXHAgMBAAGj
+QjBAMA8GA1UdEwEB/wQFMAMBAf8wDgYDVR0PAQH/BAQDAgEGMB0GA1UdDgQWBBS/
+WSA2AHmgoCJrjNXyYdK4LMuCSjANBgkqhkiG9w0BAQsFAAOCAQEAMQOiYQsfdOhy
+NsZt+U2e+iKo4YFWz827n+qrkRk4r6p8FU3ztqONpfSO9kSpp+ghla0+AGIWiPAC
+uvxhI+YzmzB6azZie60EI4RYZeLbK4rnJVM3YlNfvNoBYimipidx5joifsFvHZVw
+IEoHNN/q/xWA5brXethbdXwFeilHfkCoMRN3zUA7tFFHei4R40cR3p1m0IvVVGb6
+g1XqfMIpiRvpb7PO4gWEyS8+eIVibslfwXhjdFjASBgMmTnrpMwatXlajRWc2BQN
+9noHV8cigwUtPJslJj0Ys6lDfMjIq2SPDqO/nBudMNva0Bkuqjzx+zOAduTNrRlP
+BSeOE6Fuwg==
+-----END CERTIFICATE-----
+
+# Issuer: CN=Atos TrustedRoot 2011 O=Atos
+# Subject: CN=Atos TrustedRoot 2011 O=Atos
+# Label: "Atos TrustedRoot 2011"
+# Serial: 6643877497813316402
+# MD5 Fingerprint: ae:b9:c4:32:4b:ac:7f:5d:66:cc:77:94:bb:2a:77:56
+# SHA1 Fingerprint: 2b:b1:f5:3e:55:0c:1d:c5:f1:d4:e6:b7:6a:46:4b:55:06:02:ac:21
+# SHA256 Fingerprint: f3:56:be:a2:44:b7:a9:1e:b3:5d:53:ca:9a:d7:86:4a:ce:01:8e:2d:35:d5:f8:f9:6d:df:68:a6:f4:1a:a4:74
+-----BEGIN CERTIFICATE-----
+MIIDdzCCAl+gAwIBAgIIXDPLYixfszIwDQYJKoZIhvcNAQELBQAwPDEeMBwGA1UE
+AwwVQXRvcyBUcnVzdGVkUm9vdCAyMDExMQ0wCwYDVQQKDARBdG9zMQswCQYDVQQG
+EwJERTAeFw0xMTA3MDcxNDU4MzBaFw0zMDEyMzEyMzU5NTlaMDwxHjAcBgNVBAMM
+FUF0b3MgVHJ1c3RlZFJvb3QgMjAxMTENMAsGA1UECgwEQXRvczELMAkGA1UEBhMC
+REUwggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIBAQCVhTuXbyo7LjvPpvMp
+Nb7PGKw+qtn4TaA+Gke5vJrf8v7MPkfoepbCJI419KkM/IL9bcFyYie96mvr54rM
+VD6QUM+A1JX76LWC1BTFtqlVJVfbsVD2sGBkWXppzwO3bw2+yj5vdHLqqjAqc2K+
+SZFhyBH+DgMq92og3AIVDV4VavzjgsG1xZ1kCWyjWZgHJ8cblithdHFsQ/H3NYkQ
+4J7sVaE3IqKHBAUsR320HLliKWYoyrfhk/WklAOZuXCFteZI6o1Q/NnezG8HDt0L
+cp2AMBYHlT8oDv3FdU9T1nSatCQujgKRz3bFmx5VdJx4IbHwLfELn8LVlhgf8FQi
+eowHAgMBAAGjfTB7MB0GA1UdDgQWBBSnpQaxLKYJYO7Rl+lwrrw7GWzbITAPBgNV
+HRMBAf8EBTADAQH/MB8GA1UdIwQYMBaAFKelBrEspglg7tGX6XCuvDsZbNshMBgG
+A1UdIAQRMA8wDQYLKwYBBAGwLQMEAQEwDgYDVR0PAQH/BAQDAgGGMA0GCSqGSIb3
+DQEBCwUAA4IBAQAmdzTblEiGKkGdLD4GkGDEjKwLVLgfuXvTBznk+j57sj1O7Z8j
+vZfza1zv7v1Apt+hk6EKhqzvINB5Ab149xnYJDE0BAGmuhWawyfc2E8PzBhj/5kP
+DpFrdRbhIfzYJsdHt6bPWHJxfrrhTZVHO8mvbaG0weyJ9rQPOLXiZNwlz6bb65pc
+maHFCN795trV1lpFDMS3wrUU77QR/w4VtfX128a961qn8FYiqTxlVMYVqL2Gns2D
+lmh6cYGJ4Qvh6hEbaAjMaZ7snkGeRDImeuKHCnE96+RapNLbxc3G3mB/ufNPRJLv
+KrcYPqcZ2Qt9sTdBQrC6YB3y/gkRsPCHe6ed
+-----END CERTIFICATE-----
+
+# Issuer: CN=QuoVadis Root CA 1 G3 O=QuoVadis Limited
+# Subject: CN=QuoVadis Root CA 1 G3 O=QuoVadis Limited
+# Label: "QuoVadis Root CA 1 G3"
+# Serial: 687049649626669250736271037606554624078720034195
+# MD5 Fingerprint: a4:bc:5b:3f:fe:37:9a:fa:64:f0:e2:fa:05:3d:0b:ab
+# SHA1 Fingerprint: 1b:8e:ea:57:96:29:1a:c9:39:ea:b8:0a:81:1a:73:73:c0:93:79:67
+# SHA256 Fingerprint: 8a:86:6f:d1:b2:76:b5:7e:57:8e:92:1c:65:82:8a:2b:ed:58:e9:f2:f2:88:05:41:34:b7:f1:f4:bf:c9:cc:74
+-----BEGIN CERTIFICATE-----
+MIIFYDCCA0igAwIBAgIUeFhfLq0sGUvjNwc1NBMotZbUZZMwDQYJKoZIhvcNAQEL
+BQAwSDELMAkGA1UEBhMCQk0xGTAXBgNVBAoTEFF1b1ZhZGlzIExpbWl0ZWQxHjAc
+BgNVBAMTFVF1b1ZhZGlzIFJvb3QgQ0EgMSBHMzAeFw0xMjAxMTIxNzI3NDRaFw00
+MjAxMTIxNzI3NDRaMEgxCzAJBgNVBAYTAkJNMRkwFwYDVQQKExBRdW9WYWRpcyBM
+aW1pdGVkMR4wHAYDVQQDExVRdW9WYWRpcyBSb290IENBIDEgRzMwggIiMA0GCSqG
+SIb3DQEBAQUAA4ICDwAwggIKAoICAQCgvlAQjunybEC0BJyFuTHK3C3kEakEPBtV
+wedYMB0ktMPvhd6MLOHBPd+C5k+tR4ds7FtJwUrVu4/sh6x/gpqG7D0DmVIB0jWe
+rNrwU8lmPNSsAgHaJNM7qAJGr6Qc4/hzWHa39g6QDbXwz8z6+cZM5cOGMAqNF341
+68Xfuw6cwI2H44g4hWf6Pser4BOcBRiYz5P1sZK0/CPTz9XEJ0ngnjybCKOLXSoh
+4Pw5qlPafX7PGglTvF0FBM+hSo+LdoINofjSxxR3W5A2B4GbPgb6Ul5jxaYA/qXp
+UhtStZI5cgMJYr2wYBZupt0lwgNm3fME0UDiTouG9G/lg6AnhF4EwfWQvTA9xO+o
+abw4m6SkltFi2mnAAZauy8RRNOoMqv8hjlmPSlzkYZqn0ukqeI1RPToV7qJZjqlc
+3sX5kCLliEVx3ZGZbHqfPT2YfF72vhZooF6uCyP8Wg+qInYtyaEQHeTTRCOQiJ/G
+KubX9ZqzWB4vMIkIG1SitZgj7Ah3HJVdYdHLiZxfokqRmu8hqkkWCKi9YSgxyXSt
+hfbZxbGL0eUQMk1fiyA6PEkfM4VZDdvLCXVDaXP7a3F98N/ETH3Goy7IlXnLc6KO
+Tk0k+17kBL5yG6YnLUlamXrXXAkgt3+UuU/xDRxeiEIbEbfnkduebPRq34wGmAOt
+zCjvpUfzUwIDAQABo0IwQDAPBgNVHRMBAf8EBTADAQH/MA4GA1UdDwEB/wQEAwIB
+BjAdBgNVHQ4EFgQUo5fW816iEOGrRZ88F2Q87gFwnMwwDQYJKoZIhvcNAQELBQAD
+ggIBABj6W3X8PnrHX3fHyt/PX8MSxEBd1DKquGrX1RUVRpgjpeaQWxiZTOOtQqOC
+MTaIzen7xASWSIsBx40Bz1szBpZGZnQdT+3Btrm0DWHMY37XLneMlhwqI2hrhVd2
+cDMT/uFPpiN3GPoajOi9ZcnPP/TJF9zrx7zABC4tRi9pZsMbj/7sPtPKlL92CiUN
+qXsCHKnQO18LwIE6PWThv6ctTr1NxNgpxiIY0MWscgKCP6o6ojoilzHdCGPDdRS5
+YCgtW2jgFqlmgiNR9etT2DGbe+m3nUvriBbP+V04ikkwj+3x6xn0dxoxGE1nVGwv
+b2X52z3sIexe9PSLymBlVNFxZPT5pqOBMzYzcfCkeF9OrYMh3jRJjehZrJ3ydlo2
+8hP0r+AJx2EqbPfgna67hkooby7utHnNkDPDs3b69fBsnQGQ+p6Q9pxyz0fawx/k
+NSBT8lTR32GDpgLiJTjehTItXnOQUl1CxM49S+H5GYQd1aJQzEH7QRTDvdbJWqNj
+ZgKAvQU6O0ec7AAmTPWIUb+oI38YB7AL7YsmoWTTYUrrXJ/es69nA7Mf3W1daWhp
+q1467HxpvMc7hU6eFbm0FU/DlXpY18ls6Wy58yljXrQs8C097Vpl4KlbQMJImYFt
+nh8GKjwStIsPm6Ik8KaN1nrgS7ZklmOVhMJKzRwuJIczYOXD
+-----END CERTIFICATE-----
+
+# Issuer: CN=QuoVadis Root CA 2 G3 O=QuoVadis Limited
+# Subject: CN=QuoVadis Root CA 2 G3 O=QuoVadis Limited
+# Label: "QuoVadis Root CA 2 G3"
+# Serial: 390156079458959257446133169266079962026824725800
+# MD5 Fingerprint: af:0c:86:6e:bf:40:2d:7f:0b:3e:12:50:ba:12:3d:06
+# SHA1 Fingerprint: 09:3c:61:f3:8b:8b:dc:7d:55:df:75:38:02:05:00:e1:25:f5:c8:36
+# SHA256 Fingerprint: 8f:e4:fb:0a:f9:3a:4d:0d:67:db:0b:eb:b2:3e:37:c7:1b:f3:25:dc:bc:dd:24:0e:a0:4d:af:58:b4:7e:18:40
+-----BEGIN CERTIFICATE-----
+MIIFYDCCA0igAwIBAgIURFc0JFuBiZs18s64KztbpybwdSgwDQYJKoZIhvcNAQEL
+BQAwSDELMAkGA1UEBhMCQk0xGTAXBgNVBAoTEFF1b1ZhZGlzIExpbWl0ZWQxHjAc
+BgNVBAMTFVF1b1ZhZGlzIFJvb3QgQ0EgMiBHMzAeFw0xMjAxMTIxODU5MzJaFw00
+MjAxMTIxODU5MzJaMEgxCzAJBgNVBAYTAkJNMRkwFwYDVQQKExBRdW9WYWRpcyBM
+aW1pdGVkMR4wHAYDVQQDExVRdW9WYWRpcyBSb290IENBIDIgRzMwggIiMA0GCSqG
+SIb3DQEBAQUAA4ICDwAwggIKAoICAQChriWyARjcV4g/Ruv5r+LrI3HimtFhZiFf
+qq8nUeVuGxbULX1QsFN3vXg6YOJkApt8hpvWGo6t/x8Vf9WVHhLL5hSEBMHfNrMW
+n4rjyduYNM7YMxcoRvynyfDStNVNCXJJ+fKH46nafaF9a7I6JaltUkSs+L5u+9ym
+c5GQYaYDFCDy54ejiK2toIz/pgslUiXnFgHVy7g1gQyjO/Dh4fxaXc6AcW34Sas+
+O7q414AB+6XrW7PFXmAqMaCvN+ggOp+oMiwMzAkd056OXbxMmO7FGmh77FOm6RQ1
+o9/NgJ8MSPsc9PG/Srj61YxxSscfrf5BmrODXfKEVu+lV0POKa2Mq1W/xPtbAd0j
+IaFYAI7D0GoT7RPjEiuA3GfmlbLNHiJuKvhB1PLKFAeNilUSxmn1uIZoL1NesNKq
+IcGY5jDjZ1XHm26sGahVpkUG0CM62+tlXSoREfA7T8pt9DTEceT/AFr2XK4jYIVz
+8eQQsSWu1ZK7E8EM4DnatDlXtas1qnIhO4M15zHfeiFuuDIIfR0ykRVKYnLP43eh
+vNURG3YBZwjgQQvD6xVu+KQZ2aKrr+InUlYrAoosFCT5v0ICvybIxo/gbjh9Uy3l
+7ZizlWNof/k19N+IxWA1ksB8aRxhlRbQ694Lrz4EEEVlWFA4r0jyWbYW8jwNkALG
+cC4BrTwV1wIDAQABo0IwQDAPBgNVHRMBAf8EBTADAQH/MA4GA1UdDwEB/wQEAwIB
+BjAdBgNVHQ4EFgQU7edvdlq/YOxJW8ald7tyFnGbxD0wDQYJKoZIhvcNAQELBQAD
+ggIBAJHfgD9DCX5xwvfrs4iP4VGyvD11+ShdyLyZm3tdquXK4Qr36LLTn91nMX66
+AarHakE7kNQIXLJgapDwyM4DYvmL7ftuKtwGTTwpD4kWilhMSA/ohGHqPHKmd+RC
+roijQ1h5fq7KpVMNqT1wvSAZYaRsOPxDMuHBR//47PERIjKWnML2W2mWeyAMQ0Ga
+W/ZZGYjeVYg3UQt4XAoeo0L9x52ID8DyeAIkVJOviYeIyUqAHerQbj5hLja7NQ4n
+lv1mNDthcnPxFlxHBlRJAHpYErAK74X9sbgzdWqTHBLmYF5vHX/JHyPLhGGfHoJE
++V+tYlUkmlKY7VHnoX6XOuYvHxHaU4AshZ6rNRDbIl9qxV6XU/IyAgkwo1jwDQHV
+csaxfGl7w/U2Rcxhbl5MlMVerugOXou/983g7aEOGzPuVBj+D77vfoRrQ+NwmNtd
+dbINWQeFFSM51vHfqSYP1kjHs6Yi9TM3WpVHn3u6GBVv/9YUZINJ0gpnIdsPNWNg
+KCLjsZWDzYWm3S8P52dSbrsvhXz1SnPnxT7AvSESBT/8twNJAlvIJebiVDj1eYeM
+HVOyToV7BjjHLPj4sHKNJeV3UvQDHEimUF+IIDBu8oJDqz2XhOdT+yHBTw8imoa4
+WSr2Rz0ZiC3oheGe7IUIarFsNMkd7EgrO3jtZsSOeWmD3n+M
+-----END CERTIFICATE-----
+
+# Issuer: CN=QuoVadis Root CA 3 G3 O=QuoVadis Limited
+# Subject: CN=QuoVadis Root CA 3 G3 O=QuoVadis Limited
+# Label: "QuoVadis Root CA 3 G3"
+# Serial: 268090761170461462463995952157327242137089239581
+# MD5 Fingerprint: df:7d:b9:ad:54:6f:68:a1:df:89:57:03:97:43:b0:d7
+# SHA1 Fingerprint: 48:12:bd:92:3c:a8:c4:39:06:e7:30:6d:27:96:e6:a4:cf:22:2e:7d
+# SHA256 Fingerprint: 88:ef:81:de:20:2e:b0:18:45:2e:43:f8:64:72:5c:ea:5f:bd:1f:c2:d9:d2:05:73:07:09:c5:d8:b8:69:0f:46
+-----BEGIN CERTIFICATE-----
+MIIFYDCCA0igAwIBAgIULvWbAiin23r/1aOp7r0DoM8Sah0wDQYJKoZIhvcNAQEL
+BQAwSDELMAkGA1UEBhMCQk0xGTAXBgNVBAoTEFF1b1ZhZGlzIExpbWl0ZWQxHjAc
+BgNVBAMTFVF1b1ZhZGlzIFJvb3QgQ0EgMyBHMzAeFw0xMjAxMTIyMDI2MzJaFw00
+MjAxMTIyMDI2MzJaMEgxCzAJBgNVBAYTAkJNMRkwFwYDVQQKExBRdW9WYWRpcyBM
+aW1pdGVkMR4wHAYDVQQDExVRdW9WYWRpcyBSb290IENBIDMgRzMwggIiMA0GCSqG
+SIb3DQEBAQUAA4ICDwAwggIKAoICAQCzyw4QZ47qFJenMioKVjZ/aEzHs286IxSR
+/xl/pcqs7rN2nXrpixurazHb+gtTTK/FpRp5PIpM/6zfJd5O2YIyC0TeytuMrKNu
+FoM7pmRLMon7FhY4futD4tN0SsJiCnMK3UmzV9KwCoWdcTzeo8vAMvMBOSBDGzXR
+U7Ox7sWTaYI+FrUoRqHe6okJ7UO4BUaKhvVZR74bbwEhELn9qdIoyhA5CcoTNs+c
+ra1AdHkrAj80//ogaX3T7mH1urPnMNA3I4ZyYUUpSFlob3emLoG+B01vr87ERROR
+FHAGjx+f+IdpsQ7vw4kZ6+ocYfx6bIrc1gMLnia6Et3UVDmrJqMz6nWB2i3ND0/k
+A9HvFZcba5DFApCTZgIhsUfei5pKgLlVj7WiL8DWM2fafsSntARE60f75li59wzw
+eyuxwHApw0BiLTtIadwjPEjrewl5qW3aqDCYz4ByA4imW0aucnl8CAMhZa634Ryl
+sSqiMd5mBPfAdOhx3v89WcyWJhKLhZVXGqtrdQtEPREoPHtht+KPZ0/l7DxMYIBp
+VzgeAVuNVejH38DMdyM0SXV89pgR6y3e7UEuFAUCf+D+IOs15xGsIs5XPd7JMG0Q
+A4XN8f+MFrXBsj6IbGB/kE+V9/YtrQE5BwT6dYB9v0lQ7e/JxHwc64B+27bQ3RP+
+ydOc17KXqQIDAQABo0IwQDAPBgNVHRMBAf8EBTADAQH/MA4GA1UdDwEB/wQEAwIB
+BjAdBgNVHQ4EFgQUxhfQvKjqAkPyGwaZXSuQILnXnOQwDQYJKoZIhvcNAQELBQAD
+ggIBADRh2Va1EodVTd2jNTFGu6QHcrxfYWLopfsLN7E8trP6KZ1/AvWkyaiTt3px
+KGmPc+FSkNrVvjrlt3ZqVoAh313m6Tqe5T72omnHKgqwGEfcIHB9UqM+WXzBusnI
+FUBhynLWcKzSt/Ac5IYp8M7vaGPQtSCKFWGafoaYtMnCdvvMujAWzKNhxnQT5Wvv
+oxXqA/4Ti2Tk08HS6IT7SdEQTXlm66r99I0xHnAUrdzeZxNMgRVhvLfZkXdxGYFg
+u/BYpbWcC/ePIlUnwEsBbTuZDdQdm2NnL9DuDcpmvJRPpq3t/O5jrFc/ZSXPsoaP
+0Aj/uHYUbt7lJ+yreLVTubY/6CD50qi+YUbKh4yE8/nxoGibIh6BJpsQBJFxwAYf
+3KDTuVan45gtf4Od34wrnDKOMpTwATwiKp9Dwi7DmDkHOHv8XgBCH/MyJnmDhPbl
+8MFREsALHgQjDFSlTC9JxUrRtm5gDWv8a4uFJGS3iQ6rJUdbPM9+Sb3H6QrG2vd+
+DhcI00iX0HGS8A85PjRqHH3Y8iKuu2n0M7SmSFXRDw4m6Oy2Cy2nhTXN/VnIn9HN
+PlopNLk9hM6xZdRZkZFWdSHBd575euFgndOtBBj0fOtek49TSiIp+EgrPk2GrFt/
+ywaZWWDYWGWVjUTR939+J399roD1B0y2PpxxVJkES/1Y+Zj0
+-----END CERTIFICATE-----
+
+# Issuer: CN=DigiCert Assured ID Root G2 O=DigiCert Inc OU=www.digicert.com
+# Subject: CN=DigiCert Assured ID Root G2 O=DigiCert Inc OU=www.digicert.com
+# Label: "DigiCert Assured ID Root G2"
+# Serial: 15385348160840213938643033620894905419
+# MD5 Fingerprint: 92:38:b9:f8:63:24:82:65:2c:57:33:e6:fe:81:8f:9d
+# SHA1 Fingerprint: a1:4b:48:d9:43:ee:0a:0e:40:90:4f:3c:e0:a4:c0:91:93:51:5d:3f
+# SHA256 Fingerprint: 7d:05:eb:b6:82:33:9f:8c:94:51:ee:09:4e:eb:fe:fa:79:53:a1:14:ed:b2:f4:49:49:45:2f:ab:7d:2f:c1:85
+-----BEGIN CERTIFICATE-----
+MIIDljCCAn6gAwIBAgIQC5McOtY5Z+pnI7/Dr5r0SzANBgkqhkiG9w0BAQsFADBl
+MQswCQYDVQQGEwJVUzEVMBMGA1UEChMMRGlnaUNlcnQgSW5jMRkwFwYDVQQLExB3
+d3cuZGlnaWNlcnQuY29tMSQwIgYDVQQDExtEaWdpQ2VydCBBc3N1cmVkIElEIFJv
+b3QgRzIwHhcNMTMwODAxMTIwMDAwWhcNMzgwMTE1MTIwMDAwWjBlMQswCQYDVQQG
+EwJVUzEVMBMGA1UEChMMRGlnaUNlcnQgSW5jMRkwFwYDVQQLExB3d3cuZGlnaWNl
+cnQuY29tMSQwIgYDVQQDExtEaWdpQ2VydCBBc3N1cmVkIElEIFJvb3QgRzIwggEi
+MA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIBAQDZ5ygvUj82ckmIkzTz+GoeMVSA
+n61UQbVH35ao1K+ALbkKz3X9iaV9JPrjIgwrvJUXCzO/GU1BBpAAvQxNEP4Htecc
+biJVMWWXvdMX0h5i89vqbFCMP4QMls+3ywPgym2hFEwbid3tALBSfK+RbLE4E9Hp
+EgjAALAcKxHad3A2m67OeYfcgnDmCXRwVWmvo2ifv922ebPynXApVfSr/5Vh88lA
+bx3RvpO704gqu52/clpWcTs/1PPRCv4o76Pu2ZmvA9OPYLfykqGxvYmJHzDNw6Yu
+YjOuFgJ3RFrngQo8p0Quebg/BLxcoIfhG69Rjs3sLPr4/m3wOnyqi+RnlTGNAgMB
+AAGjQjBAMA8GA1UdEwEB/wQFMAMBAf8wDgYDVR0PAQH/BAQDAgGGMB0GA1UdDgQW
+BBTOw0q5mVXyuNtgv6l+vVa1lzan1jANBgkqhkiG9w0BAQsFAAOCAQEAyqVVjOPI
+QW5pJ6d1Ee88hjZv0p3GeDgdaZaikmkuOGybfQTUiaWxMTeKySHMq2zNixya1r9I
+0jJmwYrA8y8678Dj1JGG0VDjA9tzd29KOVPt3ibHtX2vK0LRdWLjSisCx1BL4Gni
+lmwORGYQRI+tBev4eaymG+g3NJ1TyWGqolKvSnAWhsI6yLETcDbYz+70CjTVW0z9
+B5yiutkBclzzTcHdDrEcDcRjvq30FPuJ7KJBDkzMyFdA0G4Dqs0MjomZmWzwPDCv
+ON9vvKO+KSAnq3T/EyJ43pdSVR6DtVQgA+6uwE9W3jfMw3+qBCe703e4YtsXfJwo
+IhNzbM8m9Yop5w==
+-----END CERTIFICATE-----
+
+# Issuer: CN=DigiCert Assured ID Root G3 O=DigiCert Inc OU=www.digicert.com
+# Subject: CN=DigiCert Assured ID Root G3 O=DigiCert Inc OU=www.digicert.com
+# Label: "DigiCert Assured ID Root G3"
+# Serial: 15459312981008553731928384953135426796
+# MD5 Fingerprint: 7c:7f:65:31:0c:81:df:8d:ba:3e:99:e2:5c:ad:6e:fb
+# SHA1 Fingerprint: f5:17:a2:4f:9a:48:c6:c9:f8:a2:00:26:9f:dc:0f:48:2c:ab:30:89
+# SHA256 Fingerprint: 7e:37:cb:8b:4c:47:09:0c:ab:36:55:1b:a6:f4:5d:b8:40:68:0f:ba:16:6a:95:2d:b1:00:71:7f:43:05:3f:c2
+-----BEGIN CERTIFICATE-----
+MIICRjCCAc2gAwIBAgIQC6Fa+h3foLVJRK/NJKBs7DAKBggqhkjOPQQDAzBlMQsw
+CQYDVQQGEwJVUzEVMBMGA1UEChMMRGlnaUNlcnQgSW5jMRkwFwYDVQQLExB3d3cu
+ZGlnaWNlcnQuY29tMSQwIgYDVQQDExtEaWdpQ2VydCBBc3N1cmVkIElEIFJvb3Qg
+RzMwHhcNMTMwODAxMTIwMDAwWhcNMzgwMTE1MTIwMDAwWjBlMQswCQYDVQQGEwJV
+UzEVMBMGA1UEChMMRGlnaUNlcnQgSW5jMRkwFwYDVQQLExB3d3cuZGlnaWNlcnQu
+Y29tMSQwIgYDVQQDExtEaWdpQ2VydCBBc3N1cmVkIElEIFJvb3QgRzMwdjAQBgcq
+hkjOPQIBBgUrgQQAIgNiAAQZ57ysRGXtzbg/WPuNsVepRC0FFfLvC/8QdJ+1YlJf
+Zn4f5dwbRXkLzMZTCp2NXQLZqVneAlr2lSoOjThKiknGvMYDOAdfVdp+CW7if17Q
+RSAPWXYQ1qAk8C3eNvJsKTmjQjBAMA8GA1UdEwEB/wQFMAMBAf8wDgYDVR0PAQH/
+BAQDAgGGMB0GA1UdDgQWBBTL0L2p4ZgFUaFNN6KDec6NHSrkhDAKBggqhkjOPQQD
+AwNnADBkAjAlpIFFAmsSS3V0T8gj43DydXLefInwz5FyYZ5eEJJZVrmDxxDnOOlY
+JjZ91eQ0hjkCMHw2U/Aw5WJjOpnitqM7mzT6HtoQknFekROn3aRukswy1vUhZscv
+6pZjamVFkpUBtA==
+-----END CERTIFICATE-----
+
+# Issuer: CN=DigiCert Global Root G2 O=DigiCert Inc OU=www.digicert.com
+# Subject: CN=DigiCert Global Root G2 O=DigiCert Inc OU=www.digicert.com
+# Label: "DigiCert Global Root G2"
+# Serial: 4293743540046975378534879503202253541
+# MD5 Fingerprint: e4:a6:8a:c8:54:ac:52:42:46:0a:fd:72:48:1b:2a:44
+# SHA1 Fingerprint: df:3c:24:f9:bf:d6:66:76:1b:26:80:73:fe:06:d1:cc:8d:4f:82:a4
+# SHA256 Fingerprint: cb:3c:cb:b7:60:31:e5:e0:13:8f:8d:d3:9a:23:f9:de:47:ff:c3:5e:43:c1:14:4c:ea:27:d4:6a:5a:b1:cb:5f
+-----BEGIN CERTIFICATE-----
+MIIDjjCCAnagAwIBAgIQAzrx5qcRqaC7KGSxHQn65TANBgkqhkiG9w0BAQsFADBh
+MQswCQYDVQQGEwJVUzEVMBMGA1UEChMMRGlnaUNlcnQgSW5jMRkwFwYDVQQLExB3
+d3cuZGlnaWNlcnQuY29tMSAwHgYDVQQDExdEaWdpQ2VydCBHbG9iYWwgUm9vdCBH
+MjAeFw0xMzA4MDExMjAwMDBaFw0zODAxMTUxMjAwMDBaMGExCzAJBgNVBAYTAlVT
+MRUwEwYDVQQKEwxEaWdpQ2VydCBJbmMxGTAXBgNVBAsTEHd3dy5kaWdpY2VydC5j
+b20xIDAeBgNVBAMTF0RpZ2lDZXJ0IEdsb2JhbCBSb290IEcyMIIBIjANBgkqhkiG
+9w0BAQEFAAOCAQ8AMIIBCgKCAQEAuzfNNNx7a8myaJCtSnX/RrohCgiN9RlUyfuI
+2/Ou8jqJkTx65qsGGmvPrC3oXgkkRLpimn7Wo6h+4FR1IAWsULecYxpsMNzaHxmx
+1x7e/dfgy5SDN67sH0NO3Xss0r0upS/kqbitOtSZpLYl6ZtrAGCSYP9PIUkY92eQ
+q2EGnI/yuum06ZIya7XzV+hdG82MHauVBJVJ8zUtluNJbd134/tJS7SsVQepj5Wz
+tCO7TG1F8PapspUwtP1MVYwnSlcUfIKdzXOS0xZKBgyMUNGPHgm+F6HmIcr9g+UQ
+vIOlCsRnKPZzFBQ9RnbDhxSJITRNrw9FDKZJobq7nMWxM4MphQIDAQABo0IwQDAP
+BgNVHRMBAf8EBTADAQH/MA4GA1UdDwEB/wQEAwIBhjAdBgNVHQ4EFgQUTiJUIBiV
+5uNu5g/6+rkS7QYXjzkwDQYJKoZIhvcNAQELBQADggEBAGBnKJRvDkhj6zHd6mcY
+1Yl9PMWLSn/pvtsrF9+wX3N3KjITOYFnQoQj8kVnNeyIv/iPsGEMNKSuIEyExtv4
+NeF22d+mQrvHRAiGfzZ0JFrabA0UWTW98kndth/Jsw1HKj2ZL7tcu7XUIOGZX1NG
+Fdtom/DzMNU+MeKNhJ7jitralj41E6Vf8PlwUHBHQRFXGU7Aj64GxJUTFy8bJZ91
+8rGOmaFvE7FBcf6IKshPECBV1/MUReXgRPTqh5Uykw7+U0b6LJ3/iyK5S9kJRaTe
+pLiaWN0bfVKfjllDiIGknibVb63dDcY3fe0Dkhvld1927jyNxF1WW6LZZm6zNTfl
+MrY=
+-----END CERTIFICATE-----
+
+# Issuer: CN=DigiCert Global Root G3 O=DigiCert Inc OU=www.digicert.com
+# Subject: CN=DigiCert Global Root G3 O=DigiCert Inc OU=www.digicert.com
+# Label: "DigiCert Global Root G3"
+# Serial: 7089244469030293291760083333884364146
+# MD5 Fingerprint: f5:5d:a4:50:a5:fb:28:7e:1e:0f:0d:cc:96:57:56:ca
+# SHA1 Fingerprint: 7e:04:de:89:6a:3e:66:6d:00:e6:87:d3:3f:fa:d9:3b:e8:3d:34:9e
+# SHA256 Fingerprint: 31:ad:66:48:f8:10:41:38:c7:38:f3:9e:a4:32:01:33:39:3e:3a:18:cc:02:29:6e:f9:7c:2a:c9:ef:67:31:d0
+-----BEGIN CERTIFICATE-----
+MIICPzCCAcWgAwIBAgIQBVVWvPJepDU1w6QP1atFcjAKBggqhkjOPQQDAzBhMQsw
+CQYDVQQGEwJVUzEVMBMGA1UEChMMRGlnaUNlcnQgSW5jMRkwFwYDVQQLExB3d3cu
+ZGlnaWNlcnQuY29tMSAwHgYDVQQDExdEaWdpQ2VydCBHbG9iYWwgUm9vdCBHMzAe
+Fw0xMzA4MDExMjAwMDBaFw0zODAxMTUxMjAwMDBaMGExCzAJBgNVBAYTAlVTMRUw
+EwYDVQQKEwxEaWdpQ2VydCBJbmMxGTAXBgNVBAsTEHd3dy5kaWdpY2VydC5jb20x
+IDAeBgNVBAMTF0RpZ2lDZXJ0IEdsb2JhbCBSb290IEczMHYwEAYHKoZIzj0CAQYF
+K4EEACIDYgAE3afZu4q4C/sLfyHS8L6+c/MzXRq8NOrexpu80JX28MzQC7phW1FG
+fp4tn+6OYwwX7Adw9c+ELkCDnOg/QW07rdOkFFk2eJ0DQ+4QE2xy3q6Ip6FrtUPO
+Z9wj/wMco+I+o0IwQDAPBgNVHRMBAf8EBTADAQH/MA4GA1UdDwEB/wQEAwIBhjAd
+BgNVHQ4EFgQUs9tIpPmhxdiuNkHMEWNpYim8S8YwCgYIKoZIzj0EAwMDaAAwZQIx
+AK288mw/EkrRLTnDCgmXc/SINoyIJ7vmiI1Qhadj+Z4y3maTD/HMsQmP3Wyr+mt/
+oAIwOWZbwmSNuJ5Q3KjVSaLtx9zRSX8XAbjIho9OjIgrqJqpisXRAL34VOKa5Vt8
+sycX
+-----END CERTIFICATE-----
+
+# Issuer: CN=DigiCert Trusted Root G4 O=DigiCert Inc OU=www.digicert.com
+# Subject: CN=DigiCert Trusted Root G4 O=DigiCert Inc OU=www.digicert.com
+# Label: "DigiCert Trusted Root G4"
+# Serial: 7451500558977370777930084869016614236
+# MD5 Fingerprint: 78:f2:fc:aa:60:1f:2f:b4:eb:c9:37:ba:53:2e:75:49
+# SHA1 Fingerprint: dd:fb:16:cd:49:31:c9:73:a2:03:7d:3f:c8:3a:4d:7d:77:5d:05:e4
+# SHA256 Fingerprint: 55:2f:7b:dc:f1:a7:af:9e:6c:e6:72:01:7f:4f:12:ab:f7:72:40:c7:8e:76:1a:c2:03:d1:d9:d2:0a:c8:99:88
+-----BEGIN CERTIFICATE-----
+MIIFkDCCA3igAwIBAgIQBZsbV56OITLiOQe9p3d1XDANBgkqhkiG9w0BAQwFADBi
+MQswCQYDVQQGEwJVUzEVMBMGA1UEChMMRGlnaUNlcnQgSW5jMRkwFwYDVQQLExB3
+d3cuZGlnaWNlcnQuY29tMSEwHwYDVQQDExhEaWdpQ2VydCBUcnVzdGVkIFJvb3Qg
+RzQwHhcNMTMwODAxMTIwMDAwWhcNMzgwMTE1MTIwMDAwWjBiMQswCQYDVQQGEwJV
+UzEVMBMGA1UEChMMRGlnaUNlcnQgSW5jMRkwFwYDVQQLExB3d3cuZGlnaWNlcnQu
+Y29tMSEwHwYDVQQDExhEaWdpQ2VydCBUcnVzdGVkIFJvb3QgRzQwggIiMA0GCSqG
+SIb3DQEBAQUAA4ICDwAwggIKAoICAQC/5pBzaN675F1KPDAiMGkz7MKnJS7JIT3y
+ithZwuEppz1Yq3aaza57G4QNxDAf8xukOBbrVsaXbR2rsnnyyhHS5F/WBTxSD1If
+xp4VpX6+n6lXFllVcq9ok3DCsrp1mWpzMpTREEQQLt+C8weE5nQ7bXHiLQwb7iDV
+ySAdYyktzuxeTsiT+CFhmzTrBcZe7FsavOvJz82sNEBfsXpm7nfISKhmV1efVFiO
+DCu3T6cw2Vbuyntd463JT17lNecxy9qTXtyOj4DatpGYQJB5w3jHtrHEtWoYOAMQ
+jdjUN6QuBX2I9YI+EJFwq1WCQTLX2wRzKm6RAXwhTNS8rhsDdV14Ztk6MUSaM0C/
+CNdaSaTC5qmgZ92kJ7yhTzm1EVgX9yRcRo9k98FpiHaYdj1ZXUJ2h4mXaXpI8OCi
+EhtmmnTK3kse5w5jrubU75KSOp493ADkRSWJtppEGSt+wJS00mFt6zPZxd9LBADM
+fRyVw4/3IbKyEbe7f/LVjHAsQWCqsWMYRJUadmJ+9oCw++hkpjPRiQfhvbfmQ6QY
+uKZ3AeEPlAwhHbJUKSWJbOUOUlFHdL4mrLZBdd56rF+NP8m800ERElvlEFDrMcXK
+chYiCd98THU/Y+whX8QgUWtvsauGi0/C1kVfnSD8oR7FwI+isX4KJpn15GkvmB0t
+9dmpsh3lGwIDAQABo0IwQDAPBgNVHRMBAf8EBTADAQH/MA4GA1UdDwEB/wQEAwIB
+hjAdBgNVHQ4EFgQU7NfjgtJxXWRM3y5nP+e6mK4cD08wDQYJKoZIhvcNAQEMBQAD
+ggIBALth2X2pbL4XxJEbw6GiAI3jZGgPVs93rnD5/ZpKmbnJeFwMDF/k5hQpVgs2
+SV1EY+CtnJYYZhsjDT156W1r1lT40jzBQ0CuHVD1UvyQO7uYmWlrx8GnqGikJ9yd
++SeuMIW59mdNOj6PWTkiU0TryF0Dyu1Qen1iIQqAyHNm0aAFYF/opbSnr6j3bTWc
+fFqK1qI4mfN4i/RN0iAL3gTujJtHgXINwBQy7zBZLq7gcfJW5GqXb5JQbZaNaHqa
+sjYUegbyJLkJEVDXCLG4iXqEI2FCKeWjzaIgQdfRnGTZ6iahixTXTBmyUEFxPT9N
+cCOGDErcgdLMMpSEDQgJlxxPwO5rIHQw0uA5NBCFIRUBCOhVMt5xSdkoF1BN5r5N
+0XWs0Mr7QbhDparTwwVETyw2m+L64kW4I1NsBm9nVX9GtUw/bihaeSbSpKhil9Ie
+4u1Ki7wb/UdKDd9nZn6yW0HQO+T0O/QEY+nvwlQAUaCKKsnOeMzV6ocEGLPOr0mI
+r/OSmbaz5mEP0oUA51Aa5BuVnRmhuZyxm7EAHu/QD09CbMkKvO5D+jpxpchNJqU1
+/YldvIViHTLSoCtU7ZpXwdv6EM8Zt4tKG48BtieVU+i2iW1bvGjUI+iLUaJW+fCm
+gKDWHrO8Dw9TdSmq6hN35N6MgSGtBxBHEa2HPQfRdbzP82Z+
+-----END CERTIFICATE-----
+
+# Issuer: CN=COMODO RSA Certification Authority O=COMODO CA Limited
+# Subject: CN=COMODO RSA Certification Authority O=COMODO CA Limited
+# Label: "COMODO RSA Certification Authority"
+# Serial: 101909084537582093308941363524873193117
+# MD5 Fingerprint: 1b:31:b0:71:40:36:cc:14:36:91:ad:c4:3e:fd:ec:18
+# SHA1 Fingerprint: af:e5:d2:44:a8:d1:19:42:30:ff:47:9f:e2:f8:97:bb:cd:7a:8c:b4
+# SHA256 Fingerprint: 52:f0:e1:c4:e5:8e:c6:29:29:1b:60:31:7f:07:46:71:b8:5d:7e:a8:0d:5b:07:27:34:63:53:4b:32:b4:02:34
+-----BEGIN CERTIFICATE-----
+MIIF2DCCA8CgAwIBAgIQTKr5yttjb+Af907YWwOGnTANBgkqhkiG9w0BAQwFADCB
+hTELMAkGA1UEBhMCR0IxGzAZBgNVBAgTEkdyZWF0ZXIgTWFuY2hlc3RlcjEQMA4G
+A1UEBxMHU2FsZm9yZDEaMBgGA1UEChMRQ09NT0RPIENBIExpbWl0ZWQxKzApBgNV
+BAMTIkNPTU9ETyBSU0EgQ2VydGlmaWNhdGlvbiBBdXRob3JpdHkwHhcNMTAwMTE5
+MDAwMDAwWhcNMzgwMTE4MjM1OTU5WjCBhTELMAkGA1UEBhMCR0IxGzAZBgNVBAgT
+EkdyZWF0ZXIgTWFuY2hlc3RlcjEQMA4GA1UEBxMHU2FsZm9yZDEaMBgGA1UEChMR
+Q09NT0RPIENBIExpbWl0ZWQxKzApBgNVBAMTIkNPTU9ETyBSU0EgQ2VydGlmaWNh
+dGlvbiBBdXRob3JpdHkwggIiMA0GCSqGSIb3DQEBAQUAA4ICDwAwggIKAoICAQCR
+6FSS0gpWsawNJN3Fz0RndJkrN6N9I3AAcbxT38T6KhKPS38QVr2fcHK3YX/JSw8X
+pz3jsARh7v8Rl8f0hj4K+j5c+ZPmNHrZFGvnnLOFoIJ6dq9xkNfs/Q36nGz637CC
+9BR++b7Epi9Pf5l/tfxnQ3K9DADWietrLNPtj5gcFKt+5eNu/Nio5JIk2kNrYrhV
+/erBvGy2i/MOjZrkm2xpmfh4SDBF1a3hDTxFYPwyllEnvGfDyi62a+pGx8cgoLEf
+Zd5ICLqkTqnyg0Y3hOvozIFIQ2dOciqbXL1MGyiKXCJ7tKuY2e7gUYPDCUZObT6Z
++pUX2nwzV0E8jVHtC7ZcryxjGt9XyD+86V3Em69FmeKjWiS0uqlWPc9vqv9JWL7w
+qP/0uK3pN/u6uPQLOvnoQ0IeidiEyxPx2bvhiWC4jChWrBQdnArncevPDt09qZah
+SL0896+1DSJMwBGB7FY79tOi4lu3sgQiUpWAk2nojkxl8ZEDLXB0AuqLZxUpaVIC
+u9ffUGpVRr+goyhhf3DQw6KqLCGqR84onAZFdr+CGCe01a60y1Dma/RMhnEw6abf
+Fobg2P9A3fvQQoh/ozM6LlweQRGBY84YcWsr7KaKtzFcOmpH4MN5WdYgGq/yapiq
+crxXStJLnbsQ/LBMQeXtHT1eKJ2czL+zUdqnR+WEUwIDAQABo0IwQDAdBgNVHQ4E
+FgQUu69+Aj36pvE8hI6t7jiY7NkyMtQwDgYDVR0PAQH/BAQDAgEGMA8GA1UdEwEB
+/wQFMAMBAf8wDQYJKoZIhvcNAQEMBQADggIBAArx1UaEt65Ru2yyTUEUAJNMnMvl
+wFTPoCWOAvn9sKIN9SCYPBMtrFaisNZ+EZLpLrqeLppysb0ZRGxhNaKatBYSaVqM
+4dc+pBroLwP0rmEdEBsqpIt6xf4FpuHA1sj+nq6PK7o9mfjYcwlYRm6mnPTXJ9OV
+2jeDchzTc+CiR5kDOF3VSXkAKRzH7JsgHAckaVd4sjn8OoSgtZx8jb8uk2Intzna
+FxiuvTwJaP+EmzzV1gsD41eeFPfR60/IvYcjt7ZJQ3mFXLrrkguhxuhoqEwWsRqZ
+CuhTLJK7oQkYdQxlqHvLI7cawiiFwxv/0Cti76R7CZGYZ4wUAc1oBmpjIXUDgIiK
+boHGhfKppC3n9KUkEEeDys30jXlYsQab5xoq2Z0B15R97QNKyvDb6KkBPvVWmcke
+jkk9u+UJueBPSZI9FoJAzMxZxuY67RIuaTxslbH9qh17f4a+Hg4yRvv7E491f0yL
+S0Zj/gA0QHDBw7mh3aZw4gSzQbzpgJHqZJx64SIDqZxubw5lT2yHh17zbqD5daWb
+QOhTsiedSrnAdyGN/4fy3ryM7xfft0kL0fJuMAsaDk527RH89elWsn2/x20Kk4yl
+0MC2Hb46TpSi125sC8KKfPog88Tk5c0NqMuRkrF8hey1FGlmDoLnzc7ILaZRfyHB
+NVOFBkpdn627G190
+-----END CERTIFICATE-----
+
+# Issuer: CN=USERTrust RSA Certification Authority O=The USERTRUST Network
+# Subject: CN=USERTrust RSA Certification Authority O=The USERTRUST Network
+# Label: "USERTrust RSA Certification Authority"
+# Serial: 2645093764781058787591871645665788717
+# MD5 Fingerprint: 1b:fe:69:d1:91:b7:19:33:a3:72:a8:0f:e1:55:e5:b5
+# SHA1 Fingerprint: 2b:8f:1b:57:33:0d:bb:a2:d0:7a:6c:51:f7:0e:e9:0d:da:b9:ad:8e
+# SHA256 Fingerprint: e7:93:c9:b0:2f:d8:aa:13:e2:1c:31:22:8a:cc:b0:81:19:64:3b:74:9c:89:89:64:b1:74:6d:46:c3:d4:cb:d2
+-----BEGIN CERTIFICATE-----
+MIIF3jCCA8agAwIBAgIQAf1tMPyjylGoG7xkDjUDLTANBgkqhkiG9w0BAQwFADCB
+iDELMAkGA1UEBhMCVVMxEzARBgNVBAgTCk5ldyBKZXJzZXkxFDASBgNVBAcTC0pl
+cnNleSBDaXR5MR4wHAYDVQQKExVUaGUgVVNFUlRSVVNUIE5ldHdvcmsxLjAsBgNV
+BAMTJVVTRVJUcnVzdCBSU0EgQ2VydGlmaWNhdGlvbiBBdXRob3JpdHkwHhcNMTAw
+MjAxMDAwMDAwWhcNMzgwMTE4MjM1OTU5WjCBiDELMAkGA1UEBhMCVVMxEzARBgNV
+BAgTCk5ldyBKZXJzZXkxFDASBgNVBAcTC0plcnNleSBDaXR5MR4wHAYDVQQKExVU
+aGUgVVNFUlRSVVNUIE5ldHdvcmsxLjAsBgNVBAMTJVVTRVJUcnVzdCBSU0EgQ2Vy
+dGlmaWNhdGlvbiBBdXRob3JpdHkwggIiMA0GCSqGSIb3DQEBAQUAA4ICDwAwggIK
+AoICAQCAEmUXNg7D2wiz0KxXDXbtzSfTTK1Qg2HiqiBNCS1kCdzOiZ/MPans9s/B
+3PHTsdZ7NygRK0faOca8Ohm0X6a9fZ2jY0K2dvKpOyuR+OJv0OwWIJAJPuLodMkY
+tJHUYmTbf6MG8YgYapAiPLz+E/CHFHv25B+O1ORRxhFnRghRy4YUVD+8M/5+bJz/
+Fp0YvVGONaanZshyZ9shZrHUm3gDwFA66Mzw3LyeTP6vBZY1H1dat//O+T23LLb2
+VN3I5xI6Ta5MirdcmrS3ID3KfyI0rn47aGYBROcBTkZTmzNg95S+UzeQc0PzMsNT
+79uq/nROacdrjGCT3sTHDN/hMq7MkztReJVni+49Vv4M0GkPGw/zJSZrM233bkf6
+c0Plfg6lZrEpfDKEY1WJxA3Bk1QwGROs0303p+tdOmw1XNtB1xLaqUkL39iAigmT
+Yo61Zs8liM2EuLE/pDkP2QKe6xJMlXzzawWpXhaDzLhn4ugTncxbgtNMs+1b/97l
+c6wjOy0AvzVVdAlJ2ElYGn+SNuZRkg7zJn0cTRe8yexDJtC/QV9AqURE9JnnV4ee
+UB9XVKg+/XRjL7FQZQnmWEIuQxpMtPAlR1n6BB6T1CZGSlCBst6+eLf8ZxXhyVeE
+Hg9j1uliutZfVS7qXMYoCAQlObgOK6nyTJccBz8NUvXt7y+CDwIDAQABo0IwQDAd
+BgNVHQ4EFgQUU3m/WqorSs9UgOHYm8Cd8rIDZsswDgYDVR0PAQH/BAQDAgEGMA8G
+A1UdEwEB/wQFMAMBAf8wDQYJKoZIhvcNAQEMBQADggIBAFzUfA3P9wF9QZllDHPF
+Up/L+M+ZBn8b2kMVn54CVVeWFPFSPCeHlCjtHzoBN6J2/FNQwISbxmtOuowhT6KO
+VWKR82kV2LyI48SqC/3vqOlLVSoGIG1VeCkZ7l8wXEskEVX/JJpuXior7gtNn3/3
+ATiUFJVDBwn7YKnuHKsSjKCaXqeYalltiz8I+8jRRa8YFWSQEg9zKC7F4iRO/Fjs
+8PRF/iKz6y+O0tlFYQXBl2+odnKPi4w2r78NBc5xjeambx9spnFixdjQg3IM8WcR
+iQycE0xyNN+81XHfqnHd4blsjDwSXWXavVcStkNr/+XeTWYRUc+ZruwXtuhxkYze
+Sf7dNXGiFSeUHM9h4ya7b6NnJSFd5t0dCy5oGzuCr+yDZ4XUmFF0sbmZgIn/f3gZ
+XHlKYC6SQK5MNyosycdiyA5d9zZbyuAlJQG03RoHnHcAP9Dc1ew91Pq7P8yF1m9/
+qS3fuQL39ZeatTXaw2ewh0qpKJ4jjv9cJ2vhsE/zB+4ALtRZh8tSQZXq9EfX7mRB
+VXyNWQKV3WKdwrnuWih0hKWbt5DHDAff9Yk2dDLWKMGwsAvgnEzDHNb842m1R0aB
+L6KCq9NjRHDEjf8tM7qtj3u1cIiuPhnPQCjY/MiQu12ZIvVS5ljFH4gxQ+6IHdfG
+jjxDah2nGN59PRbxYvnKkKj9
+-----END CERTIFICATE-----
+
+# Issuer: CN=USERTrust ECC Certification Authority O=The USERTRUST Network
+# Subject: CN=USERTrust ECC Certification Authority O=The USERTRUST Network
+# Label: "USERTrust ECC Certification Authority"
+# Serial: 123013823720199481456569720443997572134
+# MD5 Fingerprint: fa:68:bc:d9:b5:7f:ad:fd:c9:1d:06:83:28:cc:24:c1
+# SHA1 Fingerprint: d1:cb:ca:5d:b2:d5:2a:7f:69:3b:67:4d:e5:f0:5a:1d:0c:95:7d:f0
+# SHA256 Fingerprint: 4f:f4:60:d5:4b:9c:86:da:bf:bc:fc:57:12:e0:40:0d:2b:ed:3f:bc:4d:4f:bd:aa:86:e0:6a:dc:d2:a9:ad:7a
+-----BEGIN CERTIFICATE-----
+MIICjzCCAhWgAwIBAgIQXIuZxVqUxdJxVt7NiYDMJjAKBggqhkjOPQQDAzCBiDEL
+MAkGA1UEBhMCVVMxEzARBgNVBAgTCk5ldyBKZXJzZXkxFDASBgNVBAcTC0plcnNl
+eSBDaXR5MR4wHAYDVQQKExVUaGUgVVNFUlRSVVNUIE5ldHdvcmsxLjAsBgNVBAMT
+JVVTRVJUcnVzdCBFQ0MgQ2VydGlmaWNhdGlvbiBBdXRob3JpdHkwHhcNMTAwMjAx
+MDAwMDAwWhcNMzgwMTE4MjM1OTU5WjCBiDELMAkGA1UEBhMCVVMxEzARBgNVBAgT
+Ck5ldyBKZXJzZXkxFDASBgNVBAcTC0plcnNleSBDaXR5MR4wHAYDVQQKExVUaGUg
+VVNFUlRSVVNUIE5ldHdvcmsxLjAsBgNVBAMTJVVTRVJUcnVzdCBFQ0MgQ2VydGlm
+aWNhdGlvbiBBdXRob3JpdHkwdjAQBgcqhkjOPQIBBgUrgQQAIgNiAAQarFRaqflo
+I+d61SRvU8Za2EurxtW20eZzca7dnNYMYf3boIkDuAUU7FfO7l0/4iGzzvfUinng
+o4N+LZfQYcTxmdwlkWOrfzCjtHDix6EznPO/LlxTsV+zfTJ/ijTjeXmjQjBAMB0G
+A1UdDgQWBBQ64QmG1M8ZwpZ2dEl23OA1xmNjmjAOBgNVHQ8BAf8EBAMCAQYwDwYD
+VR0TAQH/BAUwAwEB/zAKBggqhkjOPQQDAwNoADBlAjA2Z6EWCNzklwBBHU6+4WMB
+zzuqQhFkoJ2UOQIReVx7Hfpkue4WQrO/isIJxOzksU0CMQDpKmFHjFJKS04YcPbW
+RNZu9YO6bVi9JNlWSOrvxKJGgYhqOkbRqZtNyWHa0V1Xahg=
+-----END CERTIFICATE-----
+
+# Issuer: CN=GlobalSign O=GlobalSign OU=GlobalSign ECC Root CA - 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"
+# Serial: 32785792099990507226680698011560947931244
+# MD5 Fingerprint: 9f:ad:3b:1c:02:1e:8a:ba:17:74:38:81:0c:a2:bc:08
+# SHA1 Fingerprint: 1f:24:c6:30:cd:a4:18:ef:20:69:ff:ad:4f:dd:5f:46:3a:1b:69:aa
+# SHA256 Fingerprint: 17:9f:bc:14:8a:3d:d0:0f:d2:4e:a1:34:58:cc:43:bf:a7:f5:9c:81:82:d7:83:a5:13:f6:eb:ec:10:0c:89:24
+-----BEGIN CERTIFICATE-----
+MIICHjCCAaSgAwIBAgIRYFlJ4CYuu1X5CneKcflK2GwwCgYIKoZIzj0EAwMwUDEk
+MCIGA1UECxMbR2xvYmFsU2lnbiBFQ0MgUm9vdCBDQSAtIFI1MRMwEQYDVQQKEwpH
+bG9iYWxTaWduMRMwEQYDVQQDEwpHbG9iYWxTaWduMB4XDTEyMTExMzAwMDAwMFoX
+DTM4MDExOTAzMTQwN1owUDEkMCIGA1UECxMbR2xvYmFsU2lnbiBFQ0MgUm9vdCBD
+QSAtIFI1MRMwEQYDVQQKEwpHbG9iYWxTaWduMRMwEQYDVQQDEwpHbG9iYWxTaWdu
+MHYwEAYHKoZIzj0CAQYFK4EEACIDYgAER0UOlvt9Xb/pOdEh+J8LttV7HpI6SFkc
+8GIxLcB6KP4ap1yztsyX50XUWPrRd21DosCHZTQKH3rd6zwzocWdTaRvQZU4f8ke
+hOvRnkmSh5SHDDqFSmafnVmTTZdhBoZKo0IwQDAOBgNVHQ8BAf8EBAMCAQYwDwYD
+VR0TAQH/BAUwAwEB/zAdBgNVHQ4EFgQUPeYpSJvqB8ohREom3m7e0oPQn1kwCgYI
+KoZIzj0EAwMDaAAwZQIxAOVpEslu28YxuglB4Zf4+/2a4n0Sye18ZNPLBSWLVtmg
+515dTguDnFt2KaAJJiFqYgIwcdK1j1zqO+F4CYWodZI7yFz9SO8NdCKoCOJuxUnO
+xwy8p2Fp8fc74SrL+SvzZpA3
+-----END CERTIFICATE-----
+
+# Issuer: CN=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"
+# Serial: 13298821034946342390520003877796839426
+# MD5 Fingerprint: b3:3e:77:73:75:ee:a0:d3:e3:7e:49:63:49:59:bb:c7
+# SHA1 Fingerprint: df:71:7e:aa:4a:d9:4e:c9:55:84:99:60:2d:48:de:5f:bc:f0:3a:25
+# SHA256 Fingerprint: 5d:56:49:9b:e4:d2:e0:8b:cf:ca:d0:8a:3e:38:72:3d:50:50:3b:de:70:69:48:e4:2f:55:60:30:19:e5:28:ae
+-----BEGIN CERTIFICATE-----
+MIIFYDCCA0igAwIBAgIQCgFCgAAAAUUjyES1AAAAAjANBgkqhkiG9w0BAQsFADBK
+MQswCQYDVQQGEwJVUzESMBAGA1UEChMJSWRlblRydXN0MScwJQYDVQQDEx5JZGVu
+VHJ1c3QgQ29tbWVyY2lhbCBSb290IENBIDEwHhcNMTQwMTE2MTgxMjIzWhcNMzQw
+MTE2MTgxMjIzWjBKMQswCQYDVQQGEwJVUzESMBAGA1UEChMJSWRlblRydXN0MScw
+JQYDVQQDEx5JZGVuVHJ1c3QgQ29tbWVyY2lhbCBSb290IENBIDEwggIiMA0GCSqG
+SIb3DQEBAQUAA4ICDwAwggIKAoICAQCnUBneP5k91DNG8W9RYYKyqU+PZ4ldhNlT
+3Qwo2dfw/66VQ3KZ+bVdfIrBQuExUHTRgQ18zZshq0PirK1ehm7zCYofWjK9ouuU
++ehcCuz/mNKvcbO0U59Oh++SvL3sTzIwiEsXXlfEU8L2ApeN2WIrvyQfYo3fw7gp
+S0l4PJNgiCL8mdo2yMKi1CxUAGc1bnO/AljwpN3lsKImesrgNqUZFvX9t++uP0D1
+bVoE/c40yiTcdCMbXTMTEl3EASX2MN0CXZ/g1Ue9tOsbobtJSdifWwLziuQkkORi
+T0/Br4sOdBeo0XKIanoBScy0RnnGF7HamB4HWfp1IYVl3ZBWzvurpWCdxJ35UrCL
+vYf5jysjCiN2O/cz4ckA82n5S6LgTrx+kzmEB/dEcH7+B1rlsazRGMzyNeVJSQjK
+Vsk9+w8YfYs7wRPCTY/JTw436R+hDmrfYi7LNQZReSzIJTj0+kuniVyc0uMNOYZK
+dHzVWYfCP04MXFL0PfdSgvHqo6z9STQaKPNBiDoT7uje/5kdX7rL6B7yuVBgwDHT
+c+XvvqDtMwt0viAgxGds8AgDelWAf0ZOlqf0Hj7h9tgJ4TNkK2PXMl6f+cB7D3hv
+l7yTmvmcEpB4eoCHFddydJxVdHixuuFucAS6T6C6aMN7/zHwcz09lCqxC0EOoP5N
+iGVreTO01wIDAQABo0IwQDAOBgNVHQ8BAf8EBAMCAQYwDwYDVR0TAQH/BAUwAwEB
+/zAdBgNVHQ4EFgQU7UQZwNPwBovupHu+QucmVMiONnYwDQYJKoZIhvcNAQELBQAD
+ggIBAA2ukDL2pkt8RHYZYR4nKM1eVO8lvOMIkPkp165oCOGUAFjvLi5+U1KMtlwH
+6oi6mYtQlNeCgN9hCQCTrQ0U5s7B8jeUeLBfnLOic7iPBZM4zY0+sLj7wM+x8uwt
+LRvM7Kqas6pgghstO8OEPVeKlh6cdbjTMM1gCIOQ045U8U1mwF10A0Cj7oV+wh93
+nAbowacYXVKV7cndJZ5t+qntozo00Fl72u1Q8zW/7esUTTHHYPTa8Yec4kjixsU3
++wYQ+nVZZjFHKdp2mhzpgq7vmrlR94gjmmmVYjzlVYA211QC//G5Xc7UI2/YRYRK
+W2XviQzdFKcgyxilJbQN+QHwotL0AMh0jqEqSI5l2xPE4iUXfeu+h1sXIFRRk0pT
+AwvsXcoz7WL9RccvW9xYoIA55vrX/hMUpu09lEpCdNTDd1lzzY9GvlU47/rokTLq
+l1gEIt44w8y8bckzOmoKaT+gyOpyj4xjhiO9bTyWnpXgSUyqorkqG5w2gXjtw+hG
+4iZZRHUe2XWJUc0QhJ1hYMtd+ZciTY6Y5uN/9lu7rs3KSoFrXgvzUeF0K+l+J6fZ
+mUlO+KWA2yUPHGNiiskzZ2s8EIPGrd6ozRaOjfAHN3Gf8qv8QfXBi+wAN10J5U6A
+7/qxXDgGpRtK4dw4LTzcqx+QGtVKnO7RcGzM7vRX+Bi6hG6H
+-----END CERTIFICATE-----
+
+# Issuer: CN=IdenTrust Public Sector Root CA 1 O=IdenTrust
+# Subject: CN=IdenTrust Public Sector Root CA 1 O=IdenTrust
+# Label: "IdenTrust Public Sector Root CA 1"
+# Serial: 13298821034946342390521976156843933698
+# MD5 Fingerprint: 37:06:a5:b0:fc:89:9d:ba:f4:6b:8c:1a:64:cd:d5:ba
+# SHA1 Fingerprint: ba:29:41:60:77:98:3f:f4:f3:ef:f2:31:05:3b:2e:ea:6d:4d:45:fd
+# SHA256 Fingerprint: 30:d0:89:5a:9a:44:8a:26:20:91:63:55:22:d1:f5:20:10:b5:86:7a:ca:e1:2c:78:ef:95:8f:d4:f4:38:9f:2f
+-----BEGIN CERTIFICATE-----
+MIIFZjCCA06gAwIBAgIQCgFCgAAAAUUjz0Z8AAAAAjANBgkqhkiG9w0BAQsFADBN
+MQswCQYDVQQGEwJVUzESMBAGA1UEChMJSWRlblRydXN0MSowKAYDVQQDEyFJZGVu
+VHJ1c3QgUHVibGljIFNlY3RvciBSb290IENBIDEwHhcNMTQwMTE2MTc1MzMyWhcN
+MzQwMTE2MTc1MzMyWjBNMQswCQYDVQQGEwJVUzESMBAGA1UEChMJSWRlblRydXN0
+MSowKAYDVQQDEyFJZGVuVHJ1c3QgUHVibGljIFNlY3RvciBSb290IENBIDEwggIi
+MA0GCSqGSIb3DQEBAQUAA4ICDwAwggIKAoICAQC2IpT8pEiv6EdrCvsnduTyP4o7
+ekosMSqMjbCpwzFrqHd2hCa2rIFCDQjrVVi7evi8ZX3yoG2LqEfpYnYeEe4IFNGy
+RBb06tD6Hi9e28tzQa68ALBKK0CyrOE7S8ItneShm+waOh7wCLPQ5CQ1B5+ctMlS
+bdsHyo+1W/CD80/HLaXIrcuVIKQxKFdYWuSNG5qrng0M8gozOSI5Cpcu81N3uURF
+/YTLNiCBWS2ab21ISGHKTN9T0a9SvESfqy9rg3LvdYDaBjMbXcjaY8ZNzaxmMc3R
+3j6HEDbhuaR672BQssvKplbgN6+rNBM5Jeg5ZuSYeqoSmJxZZoY+rfGwyj4GD3vw
+EUs3oERte8uojHH01bWRNszwFcYr3lEXsZdMUD2xlVl8BX0tIdUAvwFnol57plzy
+9yLxkA2T26pEUWbMfXYD62qoKjgZl3YNa4ph+bz27nb9cCvdKTz4Ch5bQhyLVi9V
+GxyhLrXHFub4qjySjmm2AcG1hp2JDws4lFTo6tyePSW8Uybt1as5qsVATFSrsrTZ
+2fjXctscvG29ZV/viDUqZi/u9rNl8DONfJhBaUYPQxxp+pu10GFqzcpL2UyQRqsV
+WaFHVCkugyhfHMKiq3IXAAaOReyL4jM9f9oZRORicsPfIsbyVtTdX5Vy7W1f90gD
+W/3FKqD2cyOEEBsB5wIDAQABo0IwQDAOBgNVHQ8BAf8EBAMCAQYwDwYDVR0TAQH/
+BAUwAwEB/zAdBgNVHQ4EFgQU43HgntinQtnbcZFrlJPrw6PRFKMwDQYJKoZIhvcN
+AQELBQADggIBAEf63QqwEZE4rU1d9+UOl1QZgkiHVIyqZJnYWv6IAcVYpZmxI1Qj
+t2odIFflAWJBF9MJ23XLblSQdf4an4EKwt3X9wnQW3IV5B4Jaj0z8yGa5hV+rVHV
+DRDtfULAj+7AmgjVQdZcDiFpboBhDhXAuM/FSRJSzL46zNQuOAXeNf0fb7iAaJg9
+TaDKQGXSc3z1i9kKlT/YPyNtGtEqJBnZhbMX73huqVjRI9PHE+1yJX9dsXNw0H8G
+lwmEKYBhHfpe/3OsoOOJuBxxFcbeMX8S3OFtm6/n6J91eEyrRjuazr8FGF1NFTwW
+mhlQBJqymm9li1JfPFgEKCXAZmExfrngdbkaqIHWchezxQMxNRF4eKLg6TCMf4Df
+WN88uieW4oA0beOY02QnrEh+KHdcxiVhJfiFDGX6xDIvpZgF5PgLZxYWxoK4Mhn5
++bl53B/N66+rDt0b20XkeucC4pVd/GnwU2lhlXV5C15V5jgclKlZM57IcXR5f1GJ
+tshquDDIajjDbp7hNxbqBWJMWxJH7ae0s1hWx0nzfxJoCTFx8G34Tkf71oXuxVhA
+GaQdp/lLQzfcaFpPz+vCZHTetBXZ9FRUGi8c15dxVJCO2SCdUyt/q4/i6jC8UDfv
+8Ue1fXwsBOxonbRJRBD0ckscZOf85muQ3Wl9af0AVqW3rLatt8o+Ae+c
+-----END CERTIFICATE-----
+
+# Issuer: CN=Entrust Root Certification Authority - G2 O=Entrust, Inc. OU=See www.entrust.net/legal-terms/(c) 2009 Entrust, Inc. - for authorized use only
+# Subject: CN=Entrust Root Certification Authority - G2 O=Entrust, Inc. OU=See www.entrust.net/legal-terms/(c) 2009 Entrust, Inc. - for authorized use only
+# Label: "Entrust Root Certification Authority - G2"
+# Serial: 1246989352
+# MD5 Fingerprint: 4b:e2:c9:91:96:65:0c:f4:0e:5a:93:92:a0:0a:fe:b2
+# SHA1 Fingerprint: 8c:f4:27:fd:79:0c:3a:d1:66:06:8d:e8:1e:57:ef:bb:93:22:72:d4
+# SHA256 Fingerprint: 43:df:57:74:b0:3e:7f:ef:5f:e4:0d:93:1a:7b:ed:f1:bb:2e:6b:42:73:8c:4e:6d:38:41:10:3d:3a:a7:f3:39
+-----BEGIN CERTIFICATE-----
+MIIEPjCCAyagAwIBAgIESlOMKDANBgkqhkiG9w0BAQsFADCBvjELMAkGA1UEBhMC
+VVMxFjAUBgNVBAoTDUVudHJ1c3QsIEluYy4xKDAmBgNVBAsTH1NlZSB3d3cuZW50
+cnVzdC5uZXQvbGVnYWwtdGVybXMxOTA3BgNVBAsTMChjKSAyMDA5IEVudHJ1c3Qs
+IEluYy4gLSBmb3IgYXV0aG9yaXplZCB1c2Ugb25seTEyMDAGA1UEAxMpRW50cnVz
+dCBSb290IENlcnRpZmljYXRpb24gQXV0aG9yaXR5IC0gRzIwHhcNMDkwNzA3MTcy
+NTU0WhcNMzAxMjA3MTc1NTU0WjCBvjELMAkGA1UEBhMCVVMxFjAUBgNVBAoTDUVu
+dHJ1c3QsIEluYy4xKDAmBgNVBAsTH1NlZSB3d3cuZW50cnVzdC5uZXQvbGVnYWwt
+dGVybXMxOTA3BgNVBAsTMChjKSAyMDA5IEVudHJ1c3QsIEluYy4gLSBmb3IgYXV0
+aG9yaXplZCB1c2Ugb25seTEyMDAGA1UEAxMpRW50cnVzdCBSb290IENlcnRpZmlj
+YXRpb24gQXV0aG9yaXR5IC0gRzIwggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEK
+AoIBAQC6hLZy254Ma+KZ6TABp3bqMriVQRrJ2mFOWHLP/vaCeb9zYQYKpSfYs1/T
+RU4cctZOMvJyig/3gxnQaoCAAEUesMfnmr8SVycco2gvCoe9amsOXmXzHHfV1IWN
+cCG0szLni6LVhjkCsbjSR87kyUnEO6fe+1R9V77w6G7CebI6C1XiUJgWMhNcL3hW
+wcKUs/Ja5CeanyTXxuzQmyWC48zCxEXFjJd6BmsqEZ+pCm5IO2/b1BEZQvePB7/1
+U1+cPvQXLOZprE4yTGJ36rfo5bs0vBmLrpxR57d+tVOxMyLlbc9wPBr64ptntoP0
+jaWvYkxN4FisZDQSA/i2jZRjJKRxAgMBAAGjQjBAMA4GA1UdDwEB/wQEAwIBBjAP
+BgNVHRMBAf8EBTADAQH/MB0GA1UdDgQWBBRqciZ60B7vfec7aVHUbI2fkBJmqzAN
+BgkqhkiG9w0BAQsFAAOCAQEAeZ8dlsa2eT8ijYfThwMEYGprmi5ZiXMRrEPR9RP/
+jTkrwPK9T3CMqS/qF8QLVJ7UG5aYMzyorWKiAHarWWluBh1+xLlEjZivEtRh2woZ
+Rkfz6/djwUAFQKXSt/S1mja/qYh2iARVBCuch38aNzx+LaUa2NSJXsq9rD1s2G2v
+1fN2D807iDginWyTmsQ9v4IbZT+mD12q/OWyFcq1rca8PdCE6OoGcrBNOTJ4vz4R
+nAuknZoh8/CbCzB428Hch0P+vGOaysXCHMnHjf87ElgI5rY97HosTvuDls4MPGmH
+VHOkc8KT/1EQrBVUAdj8BbGJoX90g5pJ19xOe4pIb4tF9g==
+-----END CERTIFICATE-----
+
+# Issuer: CN=Entrust Root Certification Authority - EC1 O=Entrust, Inc. OU=See www.entrust.net/legal-terms/(c) 2012 Entrust, Inc. - for authorized use only
+# Subject: CN=Entrust Root Certification Authority - EC1 O=Entrust, Inc. OU=See www.entrust.net/legal-terms/(c) 2012 Entrust, Inc. - for authorized use only
+# Label: "Entrust Root Certification Authority - EC1"
+# Serial: 51543124481930649114116133369
+# MD5 Fingerprint: b6:7e:1d:f0:58:c5:49:6c:24:3b:3d:ed:98:18:ed:bc
+# SHA1 Fingerprint: 20:d8:06:40:df:9b:25:f5:12:25:3a:11:ea:f7:59:8a:eb:14:b5:47
+# SHA256 Fingerprint: 02:ed:0e:b2:8c:14:da:45:16:5c:56:67:91:70:0d:64:51:d7:fb:56:f0:b2:ab:1d:3b:8e:b0:70:e5:6e:df:f5
+-----BEGIN CERTIFICATE-----
+MIIC+TCCAoCgAwIBAgINAKaLeSkAAAAAUNCR+TAKBggqhkjOPQQDAzCBvzELMAkG
+A1UEBhMCVVMxFjAUBgNVBAoTDUVudHJ1c3QsIEluYy4xKDAmBgNVBAsTH1NlZSB3
+d3cuZW50cnVzdC5uZXQvbGVnYWwtdGVybXMxOTA3BgNVBAsTMChjKSAyMDEyIEVu
+dHJ1c3QsIEluYy4gLSBmb3IgYXV0aG9yaXplZCB1c2Ugb25seTEzMDEGA1UEAxMq
+RW50cnVzdCBSb290IENlcnRpZmljYXRpb24gQXV0aG9yaXR5IC0gRUMxMB4XDTEy
+MTIxODE1MjUzNloXDTM3MTIxODE1NTUzNlowgb8xCzAJBgNVBAYTAlVTMRYwFAYD
+VQQKEw1FbnRydXN0LCBJbmMuMSgwJgYDVQQLEx9TZWUgd3d3LmVudHJ1c3QubmV0
+L2xlZ2FsLXRlcm1zMTkwNwYDVQQLEzAoYykgMjAxMiBFbnRydXN0LCBJbmMuIC0g
+Zm9yIGF1dGhvcml6ZWQgdXNlIG9ubHkxMzAxBgNVBAMTKkVudHJ1c3QgUm9vdCBD
+ZXJ0aWZpY2F0aW9uIEF1dGhvcml0eSAtIEVDMTB2MBAGByqGSM49AgEGBSuBBAAi
+A2IABIQTydC6bUF74mzQ61VfZgIaJPRbiWlH47jCffHyAsWfoPZb1YsGGYZPUxBt
+ByQnoaD41UcZYUx9ypMn6nQM72+WCf5j7HBdNq1nd67JnXxVRDqiY1Ef9eNi1KlH
+Bz7MIKNCMEAwDgYDVR0PAQH/BAQDAgEGMA8GA1UdEwEB/wQFMAMBAf8wHQYDVR0O
+BBYEFLdj5xrdjekIplWDpOBqUEFlEUJJMAoGCCqGSM49BAMDA2cAMGQCMGF52OVC
+R98crlOZF7ZvHH3hvxGU0QOIdeSNiaSKd0bebWHvAvX7td/M/k7//qnmpwIwW5nX
+hTcGtXsI/esni0qU+eH6p44mCOh8kmhtc9hvJqwhAriZtyZBWyVgrtBIGu4G
+-----END CERTIFICATE-----
+
+# Issuer: CN=CFCA EV ROOT O=China Financial Certification Authority
+# Subject: CN=CFCA EV ROOT O=China Financial Certification Authority
+# Label: "CFCA EV ROOT"
+# Serial: 407555286
+# MD5 Fingerprint: 74:e1:b6:ed:26:7a:7a:44:30:33:94:ab:7b:27:81:30
+# SHA1 Fingerprint: e2:b8:29:4b:55:84:ab:6b:58:c2:90:46:6c:ac:3f:b8:39:8f:84:83
+# SHA256 Fingerprint: 5c:c3:d7:8e:4e:1d:5e:45:54:7a:04:e6:87:3e:64:f9:0c:f9:53:6d:1c:cc:2e:f8:00:f3:55:c4:c5:fd:70:fd
+-----BEGIN CERTIFICATE-----
+MIIFjTCCA3WgAwIBAgIEGErM1jANBgkqhkiG9w0BAQsFADBWMQswCQYDVQQGEwJD
+TjEwMC4GA1UECgwnQ2hpbmEgRmluYW5jaWFsIENlcnRpZmljYXRpb24gQXV0aG9y
+aXR5MRUwEwYDVQQDDAxDRkNBIEVWIFJPT1QwHhcNMTIwODA4MDMwNzAxWhcNMjkx
+MjMxMDMwNzAxWjBWMQswCQYDVQQGEwJDTjEwMC4GA1UECgwnQ2hpbmEgRmluYW5j
+aWFsIENlcnRpZmljYXRpb24gQXV0aG9yaXR5MRUwEwYDVQQDDAxDRkNBIEVWIFJP
+T1QwggIiMA0GCSqGSIb3DQEBAQUAA4ICDwAwggIKAoICAQDXXWvNED8fBVnVBU03
+sQ7smCuOFR36k0sXgiFxEFLXUWRwFsJVaU2OFW2fvwwbwuCjZ9YMrM8irq93VCpL
+TIpTUnrD7i7es3ElweldPe6hL6P3KjzJIx1qqx2hp/Hz7KDVRM8Vz3IvHWOX6Jn5
+/ZOkVIBMUtRSqy5J35DNuF++P96hyk0g1CXohClTt7GIH//62pCfCqktQT+x8Rgp
+7hZZLDRJGqgG16iI0gNyejLi6mhNbiyWZXvKWfry4t3uMCz7zEasxGPrb382KzRz
+EpR/38wmnvFyXVBlWY9ps4deMm/DGIq1lY+wejfeWkU7xzbh72fROdOXW3NiGUgt
+hxwG+3SYIElz8AXSG7Ggo7cbcNOIabla1jj0Ytwli3i/+Oh+uFzJlU9fpy25IGvP
+a931DfSCt/SyZi4QKPaXWnuWFo8BGS1sbn85WAZkgwGDg8NNkt0yxoekN+kWzqot
+aK8KgWU6cMGbrU1tVMoqLUuFG7OA5nBFDWteNfB/O7ic5ARwiRIlk9oKmSJgamNg
+TnYGmE69g60dWIolhdLHZR4tjsbftsbhf4oEIRUpdPA+nJCdDC7xij5aqgwJHsfV
+PKPtl8MeNPo4+QgO48BdK4PRVmrJtqhUUy54Mmc9gn900PvhtgVguXDbjgv5E1hv
+cWAQUhC5wUEJ73IfZzF4/5YFjQIDAQABo2MwYTAfBgNVHSMEGDAWgBTj/i39KNAL
+tbq2osS/BqoFjJP7LzAPBgNVHRMBAf8EBTADAQH/MA4GA1UdDwEB/wQEAwIBBjAd
+BgNVHQ4EFgQU4/4t/SjQC7W6tqLEvwaqBYyT+y8wDQYJKoZIhvcNAQELBQADggIB
+ACXGumvrh8vegjmWPfBEp2uEcwPenStPuiB/vHiyz5ewG5zz13ku9Ui20vsXiObT
+ej/tUxPQ4i9qecsAIyjmHjdXNYmEwnZPNDatZ8POQQaIxffu2Bq41gt/UP+TqhdL
+jOztUmCypAbqTuv0axn96/Ua4CUqmtzHQTb3yHQFhDmVOdYLO6Qn+gjYXB74BGBS
+ESgoA//vU2YApUo0FmZ8/Qmkrp5nGm9BC2sGE5uPhnEFtC+NiWYzKXZUmhH4J/qy
+P5Hgzg0b8zAarb8iXRvTvyUFTeGSGn+ZnzxEk8rUQElsgIfXBDrDMlI1Dlb4pd19
+xIsNER9Tyx6yF7Zod1rg1MvIB671Oi6ON7fQAUtDKXeMOZePglr4UeWJoBjnaH9d
+Ci77o0cOPaYjesYBx4/IXr9tgFa+iiS6M+qf4TIRnvHST4D2G0CvOJ4RUHlzEhLN
+5mydLIhyPDCBBpEi6lmt2hkuIsKNuYyH4Ga8cyNfIWRjgEj1oDwYPZTISEEdQLpe
+/v5WOaHIz16eGWRGENoXkbcFgKyLmZJ956LYBws2J+dIeWCKw9cTXPhyQN9Ky8+Z
+AAoACxGV2lZFA4gKn2fQ1XmxqI1AbQ3CekD6819kR5LLU7m7Wc5P/dAVUwHY3+vZ
+5nbv0CO7O6l5s9UCKc2Jo5YPSjXnTkLAdc0Hz+Ys63su
+-----END CERTIFICATE-----
+
+# Issuer: CN=Certinomis - Root CA O=Certinomis OU=0002 433998903
+# Subject: CN=Certinomis - Root CA O=Certinomis OU=0002 433998903
+# Label: "Certinomis - Root CA"
+# Serial: 1
+# MD5 Fingerprint: 14:0a:fd:8d:a8:28:b5:38:69:db:56:7e:61:22:03:3f
+# SHA1 Fingerprint: 9d:70:bb:01:a5:a4:a0:18:11:2e:f7:1c:01:b9:32:c5:34:e7:88:a8
+# SHA256 Fingerprint: 2a:99:f5:bc:11:74:b7:3c:bb:1d:62:08:84:e0:1c:34:e5:1c:cb:39:78:da:12:5f:0e:33:26:88:83:bf:41:58
+-----BEGIN CERTIFICATE-----
+MIIFkjCCA3qgAwIBAgIBATANBgkqhkiG9w0BAQsFADBaMQswCQYDVQQGEwJGUjET
+MBEGA1UEChMKQ2VydGlub21pczEXMBUGA1UECxMOMDAwMiA0MzM5OTg5MDMxHTAb
+BgNVBAMTFENlcnRpbm9taXMgLSBSb290IENBMB4XDTEzMTAyMTA5MTcxOFoXDTMz
+MTAyMTA5MTcxOFowWjELMAkGA1UEBhMCRlIxEzARBgNVBAoTCkNlcnRpbm9taXMx
+FzAVBgNVBAsTDjAwMDIgNDMzOTk4OTAzMR0wGwYDVQQDExRDZXJ0aW5vbWlzIC0g
+Um9vdCBDQTCCAiIwDQYJKoZIhvcNAQEBBQADggIPADCCAgoCggIBANTMCQosP5L2
+fxSeC5yaah1AMGT9qt8OHgZbn1CF6s2Nq0Nn3rD6foCWnoR4kkjW4znuzuRZWJfl
+LieY6pOod5tK8O90gC3rMB+12ceAnGInkYjwSond3IjmFPnVAy//ldu9n+ws+hQV
+WZUKxkd8aRi5pwP5ynapz8dvtF4F/u7BUrJ1Mofs7SlmO/NKFoL21prbcpjp3vDF
+TKWrteoB4owuZH9kb/2jJZOLyKIOSY008B/sWEUuNKqEUL3nskoTuLAPrjhdsKkb
+5nPJWqHZZkCqqU2mNAKthH6yI8H7KsZn9DS2sJVqM09xRLWtwHkziOC/7aOgFLSc
+CbAK42C++PhmiM1b8XcF4LVzbsF9Ri6OSyemzTUK/eVNfaoqoynHWmgE6OXWk6Ri
+wsXm9E/G+Z8ajYJJGYrKWUM66A0ywfRMEwNvbqY/kXPLynNvEiCL7sCCeN5LLsJJ
+wx3tFvYk9CcbXFcx3FXuqB5vbKziRcxXV4p1VxngtViZSTYxPDMBbRZKzbgqg4SG
+m/lg0h9tkQPTYKbVPZrdd5A9NaSfD171UkRpucC63M9933zZxKyGIjK8e2uR73r4
+F2iw4lNVYC2vPsKD2NkJK/DAZNuHi5HMkesE/Xa0lZrmFAYb1TQdvtj/dBxThZng
+WVJKYe2InmtJiUZ+IFrZ50rlau7SZRFDAgMBAAGjYzBhMA4GA1UdDwEB/wQEAwIB
+BjAPBgNVHRMBAf8EBTADAQH/MB0GA1UdDgQWBBTvkUz1pcMw6C8I6tNxIqSSaHh0
+2TAfBgNVHSMEGDAWgBTvkUz1pcMw6C8I6tNxIqSSaHh02TANBgkqhkiG9w0BAQsF
+AAOCAgEAfj1U2iJdGlg+O1QnurrMyOMaauo++RLrVl89UM7g6kgmJs95Vn6RHJk/
+0KGRHCwPT5iVWVO90CLYiF2cN/z7ZMF4jIuaYAnq1fohX9B0ZedQxb8uuQsLrbWw
+F6YSjNRieOpWauwK0kDDPAUwPk2Ut59KA9N9J0u2/kTO+hkzGm2kQtHdzMjI1xZS
+g081lLMSVX3l4kLr5JyTCcBMWwerx20RoFAXlCOotQqSD7J6wWAsOMwaplv/8gzj
+qh8c3LigkyfeY+N/IZ865Z764BNqdeuWXGKRlI5nU7aJ+BIJy29SWwNyhlCVCNSN
+h4YVH5Uk2KRvms6knZtt0rJ2BobGVgjF6wnaNsIbW0G+YSrjcOa4pvi2WsS9Iff/
+ql+hbHY5ZtbqTFXhADObE5hjyW/QASAJN1LnDE8+zbz1X5YnpyACleAu6AdBBR8V
+btaw5BngDwKTACdyxYvRVB9dSsNAl35VpnzBMwQUAR1JIGkLGZOdblgi90AMRgwj
+Y/M50n92Uaf0yKHxDHYiI0ZSKS3io0EHVmmY0gUJvGnHWmHNj4FgFU2A3ZDifcRQ
+8ow7bkrHxuaAKzyBvBGAFhAn1/DNP3nMcyrDflOR1m749fPH0FFNjkulW+YZFzvW
+gQncItzujrnEj1PhZ7szuIgVRs/taTX/dQ1G885x4cVrhkIGuUE=
+-----END CERTIFICATE-----
+
+# Issuer: CN=OISTE WISeKey Global Root GB CA O=WISeKey OU=OISTE Foundation Endorsed
+# Subject: CN=OISTE WISeKey Global Root GB CA O=WISeKey OU=OISTE Foundation Endorsed
+# Label: "OISTE WISeKey Global Root GB CA"
+# Serial: 157768595616588414422159278966750757568
+# MD5 Fingerprint: a4:eb:b9:61:28:2e:b7:2f:98:b0:35:26:90:99:51:1d
+# SHA1 Fingerprint: 0f:f9:40:76:18:d3:d7:6a:4b:98:f0:a8:35:9e:0c:fd:27:ac:cc:ed
+# SHA256 Fingerprint: 6b:9c:08:e8:6e:b0:f7:67:cf:ad:65:cd:98:b6:21:49:e5:49:4a:67:f5:84:5e:7b:d1:ed:01:9f:27:b8:6b:d6
+-----BEGIN CERTIFICATE-----
+MIIDtTCCAp2gAwIBAgIQdrEgUnTwhYdGs/gjGvbCwDANBgkqhkiG9w0BAQsFADBt
+MQswCQYDVQQGEwJDSDEQMA4GA1UEChMHV0lTZUtleTEiMCAGA1UECxMZT0lTVEUg
+Rm91bmRhdGlvbiBFbmRvcnNlZDEoMCYGA1UEAxMfT0lTVEUgV0lTZUtleSBHbG9i
+YWwgUm9vdCBHQiBDQTAeFw0xNDEyMDExNTAwMzJaFw0zOTEyMDExNTEwMzFaMG0x
+CzAJBgNVBAYTAkNIMRAwDgYDVQQKEwdXSVNlS2V5MSIwIAYDVQQLExlPSVNURSBG
+b3VuZGF0aW9uIEVuZG9yc2VkMSgwJgYDVQQDEx9PSVNURSBXSVNlS2V5IEdsb2Jh
+bCBSb290IEdCIENBMIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEA2Be3
+HEokKtaXscriHvt9OO+Y9bI5mE4nuBFde9IllIiCFSZqGzG7qFshISvYD06fWvGx
+WuR51jIjK+FTzJlFXHtPrby/h0oLS5daqPZI7H17Dc0hBt+eFf1Biki3IPShehtX
+1F1Q/7pn2COZH8g/497/b1t3sWtuuMlk9+HKQUYOKXHQuSP8yYFfTvdv37+ErXNk
+u7dCjmn21HYdfp2nuFeKUWdy19SouJVUQHMD9ur06/4oQnc/nSMbsrY9gBQHTC5P
+99UKFg29ZkM3fiNDecNAhvVMKdqOmq0NpQSHiB6F4+lT1ZvIiwNjeOvgGUpuuy9r
+M2RYk61pv48b74JIxwIDAQABo1EwTzALBgNVHQ8EBAMCAYYwDwYDVR0TAQH/BAUw
+AwEB/zAdBgNVHQ4EFgQUNQ/INmNe4qPs+TtmFc5RUuORmj0wEAYJKwYBBAGCNxUB
+BAMCAQAwDQYJKoZIhvcNAQELBQADggEBAEBM+4eymYGQfp3FsLAmzYh7KzKNbrgh
+cViXfa43FK8+5/ea4n32cZiZBKpDdHij40lhPnOMTZTg+XHEthYOU3gf1qKHLwI5
+gSk8rxWYITD+KJAAjNHhy/peyP34EEY7onhCkRd0VQreUGdNZtGn//3ZwLWoo4rO
+ZvUPQ82nK1d7Y0Zqqi5S2PTt4W2tKZB4SLrhI6qjiey1q5bAtEuiHZeeevJuQHHf
+aPFlTc58Bd9TZaml8LGXBHAVRgOY1NK/VLSgWH1Sb9pWJmLU2NuJMW8c8CLC02Ic
+Nc1MaRVUGpCY3useX8p3x8uOPUNpnJpY0CQ73xtAln41rYHHTnG6iBM=
+-----END CERTIFICATE-----
+
+# Issuer: CN=SZAFIR ROOT CA2 O=Krajowa Izba Rozliczeniowa S.A.
+# Subject: CN=SZAFIR ROOT CA2 O=Krajowa Izba Rozliczeniowa S.A.
+# Label: "SZAFIR ROOT CA2"
+# Serial: 357043034767186914217277344587386743377558296292
+# MD5 Fingerprint: 11:64:c1:89:b0:24:b1:8c:b1:07:7e:89:9e:51:9e:99
+# SHA1 Fingerprint: e2:52:fa:95:3f:ed:db:24:60:bd:6e:28:f3:9c:cc:cf:5e:b3:3f:de
+# SHA256 Fingerprint: a1:33:9d:33:28:1a:0b:56:e5:57:d3:d3:2b:1c:e7:f9:36:7e:b0:94:bd:5f:a7:2a:7e:50:04:c8:de:d7:ca:fe
+-----BEGIN CERTIFICATE-----
+MIIDcjCCAlqgAwIBAgIUPopdB+xV0jLVt+O2XwHrLdzk1uQwDQYJKoZIhvcNAQEL
+BQAwUTELMAkGA1UEBhMCUEwxKDAmBgNVBAoMH0tyYWpvd2EgSXpiYSBSb3psaWN6
+ZW5pb3dhIFMuQS4xGDAWBgNVBAMMD1NaQUZJUiBST09UIENBMjAeFw0xNTEwMTkw
+NzQzMzBaFw0zNTEwMTkwNzQzMzBaMFExCzAJBgNVBAYTAlBMMSgwJgYDVQQKDB9L
+cmFqb3dhIEl6YmEgUm96bGljemVuaW93YSBTLkEuMRgwFgYDVQQDDA9TWkFGSVIg
+Uk9PVCBDQTIwggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIBAQC3vD5QqEvN
+QLXOYeeWyrSh2gwisPq1e3YAd4wLz32ohswmUeQgPYUM1ljj5/QqGJ3a0a4m7utT
+3PSQ1hNKDJA8w/Ta0o4NkjrcsbH/ON7Dui1fgLkCvUqdGw+0w8LBZwPd3BucPbOw
+3gAeqDRHu5rr/gsUvTaE2g0gv/pby6kWIK05YO4vdbbnl5z5Pv1+TW9NL++IDWr6
+3fE9biCloBK0TXC5ztdyO4mTp4CEHCdJckm1/zuVnsHMyAHs6A6KCpbns6aH5db5
+BSsNl0BwPLqsdVqc1U2dAgrSS5tmS0YHF2Wtn2yIANwiieDhZNRnvDF5YTy7ykHN
+XGoAyDw4jlivAgMBAAGjQjBAMA8GA1UdEwEB/wQFMAMBAf8wDgYDVR0PAQH/BAQD
+AgEGMB0GA1UdDgQWBBQuFqlKGLXLzPVvUPMjX/hd56zwyDANBgkqhkiG9w0BAQsF
+AAOCAQEAtXP4A9xZWx126aMqe5Aosk3AM0+qmrHUuOQn/6mWmc5G4G18TKI4pAZw
+8PRBEew/R40/cof5O/2kbytTAOD/OblqBw7rHRz2onKQy4I9EYKL0rufKq8h5mOG
+nXkZ7/e7DDWQw4rtTw/1zBLZpD67oPwglV9PJi8RI4NOdQcPv5vRtB3pEAT+ymCP
+oky4rc/hkA/NrgrHXXu3UNLUYfrVFdvXn4dRVOul4+vJhaAlIDf7js4MNIThPIGy
+d05DpYhfhmehPea0XGG2Ptv+tyjFogeutcrKjSoS75ftwjCkySp6+/NNIxuZMzSg
+LvWpCz/UXeHPhJ/iGcJfitYgHuNztw==
+-----END CERTIFICATE-----
+
+# Issuer: CN=Certum Trusted Network CA 2 O=Unizeto Technologies S.A. OU=Certum Certification Authority
+# Subject: CN=Certum Trusted Network CA 2 O=Unizeto Technologies S.A. OU=Certum Certification Authority
+# Label: "Certum Trusted Network CA 2"
+# Serial: 44979900017204383099463764357512596969
+# MD5 Fingerprint: 6d:46:9e:d9:25:6d:08:23:5b:5e:74:7d:1e:27:db:f2
+# SHA1 Fingerprint: d3:dd:48:3e:2b:bf:4c:05:e8:af:10:f5:fa:76:26:cf:d3:dc:30:92
+# SHA256 Fingerprint: b6:76:f2:ed:da:e8:77:5c:d3:6c:b0:f6:3c:d1:d4:60:39:61:f4:9e:62:65:ba:01:3a:2f:03:07:b6:d0:b8:04
+-----BEGIN CERTIFICATE-----
+MIIF0jCCA7qgAwIBAgIQIdbQSk8lD8kyN/yqXhKN6TANBgkqhkiG9w0BAQ0FADCB
+gDELMAkGA1UEBhMCUEwxIjAgBgNVBAoTGVVuaXpldG8gVGVjaG5vbG9naWVzIFMu
+QS4xJzAlBgNVBAsTHkNlcnR1bSBDZXJ0aWZpY2F0aW9uIEF1dGhvcml0eTEkMCIG
+A1UEAxMbQ2VydHVtIFRydXN0ZWQgTmV0d29yayBDQSAyMCIYDzIwMTExMDA2MDgz
+OTU2WhgPMjA0NjEwMDYwODM5NTZaMIGAMQswCQYDVQQGEwJQTDEiMCAGA1UEChMZ
+VW5pemV0byBUZWNobm9sb2dpZXMgUy5BLjEnMCUGA1UECxMeQ2VydHVtIENlcnRp
+ZmljYXRpb24gQXV0aG9yaXR5MSQwIgYDVQQDExtDZXJ0dW0gVHJ1c3RlZCBOZXR3
+b3JrIENBIDIwggIiMA0GCSqGSIb3DQEBAQUAA4ICDwAwggIKAoICAQC9+Xj45tWA
+DGSdhhuWZGc/IjoedQF97/tcZ4zJzFxrqZHmuULlIEub2pt7uZld2ZuAS9eEQCsn
+0+i6MLs+CRqnSZXvK0AkwpfHp+6bJe+oCgCXhVqqndwpyeI1B+twTUrWwbNWuKFB
+OJvR+zF/j+Bf4bE/D44WSWDXBo0Y+aomEKsq09DRZ40bRr5HMNUuctHFY9rnY3lE
+fktjJImGLjQ/KUxSiyqnwOKRKIm5wFv5HdnnJ63/mgKXwcZQkpsCLL2puTRZCr+E
+Sv/f/rOf69me4Jgj7KZrdxYq28ytOxykh9xGc14ZYmhFV+SQgkK7QtbwYeDBoz1m
+o130GO6IyY0XRSmZMnUCMe4pJshrAua1YkV/NxVaI2iJ1D7eTiew8EAMvE0Xy02i
+sx7QBlrd9pPPV3WZ9fqGGmd4s7+W/jTcvedSVuWz5XV710GRBdxdaeOVDUO5/IOW
+OZV7bIBaTxNyxtd9KXpEulKkKtVBRgkg/iKgtlswjbyJDNXXcPiHUv3a76xRLgez
+Tv7QCdpw75j6VuZt27VXS9zlLCUVyJ4ueE742pyehizKV/Ma5ciSixqClnrDvFAS
+adgOWkaLOusm+iPJtrCBvkIApPjW/jAux9JG9uWOdf3yzLnQh1vMBhBgu4M1t15n
+3kfsmUjxpKEV/q2MYo45VU85FrmxY53/twIDAQABo0IwQDAPBgNVHRMBAf8EBTAD
+AQH/MB0GA1UdDgQWBBS2oVQ5AsOgP46KvPrU+Bym0ToO/TAOBgNVHQ8BAf8EBAMC
+AQYwDQYJKoZIhvcNAQENBQADggIBAHGlDs7k6b8/ONWJWsQCYftMxRQXLYtPU2sQ
+F/xlhMcQSZDe28cmk4gmb3DWAl45oPePq5a1pRNcgRRtDoGCERuKTsZPpd1iHkTf
+CVn0W3cLN+mLIMb4Ck4uWBzrM9DPhmDJ2vuAL55MYIR4PSFk1vtBHxgP58l1cb29
+XN40hz5BsA72udY/CROWFC/emh1auVbONTqwX3BNXuMp8SMoclm2q8KMZiYcdywm
+djWLKKdpoPk79SPdhRB0yZADVpHnr7pH1BKXESLjokmUbOe3lEu6LaTaM4tMpkT/
+WjzGHWTYtTHkpjx6qFcL2+1hGsvxznN3Y6SHb0xRONbkX8eftoEq5IVIeVheO/jb
+AoJnwTnbw3RLPTYe+SmTiGhbqEQZIfCn6IENLOiTNrQ3ssqwGyZ6miUfmpqAnksq
+P/ujmv5zMnHCnsZy4YpoJ/HkD7TETKVhk/iXEAcqMCWpuchxuO9ozC1+9eB+D4Ko
+b7a6bINDd82Kkhehnlt4Fj1F4jNy3eFmypnTycUm/Q1oBEauttmbjL4ZvrHG8hnj
+XALKLNhvSgfZyTXaQHXyxKcZb55CEJh15pWLYLztxRLXis7VmFxWlgPF7ncGNf/P
+5O4/E2Hu29othfDNrp2yGAlFw5Khchf8R7agCyzxxN5DaAhqXzvwdmP7zAYspsbi
+DrW5viSP
+-----END CERTIFICATE-----
+
+# Issuer: CN=Hellenic Academic and Research Institutions RootCA 2015 O=Hellenic Academic and Research Institutions Cert. Authority
+# Subject: CN=Hellenic Academic and Research Institutions RootCA 2015 O=Hellenic Academic and Research Institutions Cert. Authority
+# Label: "Hellenic Academic and Research Institutions RootCA 2015"
+# Serial: 0
+# MD5 Fingerprint: ca:ff:e2:db:03:d9:cb:4b:e9:0f:ad:84:fd:7b:18:ce
+# SHA1 Fingerprint: 01:0c:06:95:a6:98:19:14:ff:bf:5f:c6:b0:b6:95:ea:29:e9:12:a6
+# SHA256 Fingerprint: a0:40:92:9a:02:ce:53:b4:ac:f4:f2:ff:c6:98:1c:e4:49:6f:75:5e:6d:45:fe:0b:2a:69:2b:cd:52:52:3f:36
+-----BEGIN CERTIFICATE-----
+MIIGCzCCA/OgAwIBAgIBADANBgkqhkiG9w0BAQsFADCBpjELMAkGA1UEBhMCR1Ix
+DzANBgNVBAcTBkF0aGVuczFEMEIGA1UEChM7SGVsbGVuaWMgQWNhZGVtaWMgYW5k
+IFJlc2VhcmNoIEluc3RpdHV0aW9ucyBDZXJ0LiBBdXRob3JpdHkxQDA+BgNVBAMT
+N0hlbGxlbmljIEFjYWRlbWljIGFuZCBSZXNlYXJjaCBJbnN0aXR1dGlvbnMgUm9v
+dENBIDIwMTUwHhcNMTUwNzA3MTAxMTIxWhcNNDAwNjMwMTAxMTIxWjCBpjELMAkG
+A1UEBhMCR1IxDzANBgNVBAcTBkF0aGVuczFEMEIGA1UEChM7SGVsbGVuaWMgQWNh
+ZGVtaWMgYW5kIFJlc2VhcmNoIEluc3RpdHV0aW9ucyBDZXJ0LiBBdXRob3JpdHkx
+QDA+BgNVBAMTN0hlbGxlbmljIEFjYWRlbWljIGFuZCBSZXNlYXJjaCBJbnN0aXR1
+dGlvbnMgUm9vdENBIDIwMTUwggIiMA0GCSqGSIb3DQEBAQUAA4ICDwAwggIKAoIC
+AQDC+Kk/G4n8PDwEXT2QNrCROnk8ZlrvbTkBSRq0t89/TSNTt5AA4xMqKKYx8ZEA
+4yjsriFBzh/a/X0SWwGDD7mwX5nh8hKDgE0GPt+sr+ehiGsxr/CL0BgzuNtFajT0
+AoAkKAoCFZVedioNmToUW/bLy1O8E00BiDeUJRtCvCLYjqOWXjrZMts+6PAQZe10
+4S+nfK8nNLspfZu2zwnI5dMK/IhlZXQK3HMcXM1AsRzUtoSMTFDPaI6oWa7CJ06C
+ojXdFPQf/7J31Ycvqm59JCfnxssm5uX+Zwdj2EUN3TpZZTlYepKZcj2chF6IIbjV
+9Cz82XBST3i4vTwri5WY9bPRaM8gFH5MXF/ni+X1NYEZN9cRCLdmvtNKzoNXADrD
+gfgXy5I2XdGj2HUb4Ysn6npIQf1FGQatJ5lOwXBH3bWfgVMS5bGMSF0xQxfjjMZ6
+Y5ZLKTBOhE5iGV48zpeQpX8B653g+IuJ3SWYPZK2fu/Z8VFRfS0myGlZYeCsargq
+NhEEelC9MoS+L9xy1dcdFkfkR2YgP/SWxa+OAXqlD3pk9Q0Yh9muiNX6hME6wGko
+LfINaFGq46V3xqSQDqE3izEjR8EJCOtu93ib14L8hCCZSRm2Ekax+0VVFqmjZayc
+Bw/qa9wfLgZy7IaIEuQt218FL+TwA9MmM+eAws1CoRc0CwIDAQABo0IwQDAPBgNV
+HRMBAf8EBTADAQH/MA4GA1UdDwEB/wQEAwIBBjAdBgNVHQ4EFgQUcRVnyMjJvXVd
+ctA4GGqd83EkVAswDQYJKoZIhvcNAQELBQADggIBAHW7bVRLqhBYRjTyYtcWNl0I
+XtVsyIe9tC5G8jH4fOpCtZMWVdyhDBKg2mF+D1hYc2Ryx+hFjtyp8iY/xnmMsVMI
+M4GwVhO+5lFc2JsKT0ucVlMC6U/2DWDqTUJV6HwbISHTGzrMd/K4kPFox/la/vot
+9L/J9UUbzjgQKjeKeaO04wlshYaT/4mWJ3iBj2fjRnRUjtkNaeJK9E10A/+yd+2V
+Z5fkscWrv2oj6NSU4kQoYsRL4vDY4ilrGnB+JGGTe08DMiUNRSQrlrRGar9KC/ea
+j8GsGsVn82800vpzY4zvFrCopEYq+OsS7HK07/grfoxSwIuEVPkvPuNVqNxmsdnh
+X9izjFk0WaSrT2y7HxjbdavYy5LNlDhhDgcGH0tGEPEVvo2FXDtKK4F5D7Rpn0lQ
+l033DlZdwJVqwjbDG2jJ9SrcR5q+ss7FJej6A7na+RZukYT1HCjI/CbM1xyQVqdf
+bzoEvM14iQuODy+jqk+iGxI9FghAD/FGTNeqewjBCvVtJ94Cj8rDtSvK6evIIVM4
+pcw72Hc3MKJP2W/R8kCtQXoXxdZKNYm3QdV8hn9VTYNKpXMgwDqvkPGaJI7ZjnHK
+e7iG2rKPmT4dEw0SEe7Uq/DpFXYC5ODfqiAeW2GFZECpkJcNrVPSWh2HagCXZWK0
+vm9qp/UsQu0yrbYhnr68
+-----END CERTIFICATE-----
+
+# Issuer: CN=Hellenic Academic and Research Institutions ECC RootCA 2015 O=Hellenic Academic and Research Institutions Cert. Authority
+# Subject: CN=Hellenic Academic and Research Institutions ECC RootCA 2015 O=Hellenic Academic and Research Institutions Cert. Authority
+# Label: "Hellenic Academic and Research Institutions ECC RootCA 2015"
+# Serial: 0
+# MD5 Fingerprint: 81:e5:b4:17:eb:c2:f5:e1:4b:0d:41:7b:49:92:fe:ef
+# SHA1 Fingerprint: 9f:f1:71:8d:92:d5:9a:f3:7d:74:97:b4:bc:6f:84:68:0b:ba:b6:66
+# SHA256 Fingerprint: 44:b5:45:aa:8a:25:e6:5a:73:ca:15:dc:27:fc:36:d2:4c:1c:b9:95:3a:06:65:39:b1:15:82:dc:48:7b:48:33
+-----BEGIN CERTIFICATE-----
+MIICwzCCAkqgAwIBAgIBADAKBggqhkjOPQQDAjCBqjELMAkGA1UEBhMCR1IxDzAN
+BgNVBAcTBkF0aGVuczFEMEIGA1UEChM7SGVsbGVuaWMgQWNhZGVtaWMgYW5kIFJl
+c2VhcmNoIEluc3RpdHV0aW9ucyBDZXJ0LiBBdXRob3JpdHkxRDBCBgNVBAMTO0hl
+bGxlbmljIEFjYWRlbWljIGFuZCBSZXNlYXJjaCBJbnN0aXR1dGlvbnMgRUNDIFJv
+b3RDQSAyMDE1MB4XDTE1MDcwNzEwMzcxMloXDTQwMDYzMDEwMzcxMlowgaoxCzAJ
+BgNVBAYTAkdSMQ8wDQYDVQQHEwZBdGhlbnMxRDBCBgNVBAoTO0hlbGxlbmljIEFj
+YWRlbWljIGFuZCBSZXNlYXJjaCBJbnN0aXR1dGlvbnMgQ2VydC4gQXV0aG9yaXR5
+MUQwQgYDVQQDEztIZWxsZW5pYyBBY2FkZW1pYyBhbmQgUmVzZWFyY2ggSW5zdGl0
+dXRpb25zIEVDQyBSb290Q0EgMjAxNTB2MBAGByqGSM49AgEGBSuBBAAiA2IABJKg
+QehLgoRc4vgxEZmGZE4JJS+dQS8KrjVPdJWyUWRrjWvmP3CV8AVER6ZyOFB2lQJa
+jq4onvktTpnvLEhvTCUp6NFxW98dwXU3tNf6e3pCnGoKVlp8aQuqgAkkbH7BRqNC
+MEAwDwYDVR0TAQH/BAUwAwEB/zAOBgNVHQ8BAf8EBAMCAQYwHQYDVR0OBBYEFLQi
+C4KZJAEOnLvkDv2/+5cgk5kqMAoGCCqGSM49BAMCA2cAMGQCMGfOFmI4oqxiRaep
+lSTAGiecMjvAwNW6qef4BENThe5SId6d9SWDPp5YSy/XZxMOIQIwBeF1Ad5o7Sof
+TUwJCA3sS61kFyjndc5FZXIhF8siQQ6ME5g4mlRtm8rifOoCWCKR
+-----END CERTIFICATE-----
+
+# Issuer: CN=ISRG Root X1 O=Internet Security Research Group
+# Subject: CN=ISRG Root X1 O=Internet Security Research Group
+# Label: "ISRG Root X1"
+# Serial: 172886928669790476064670243504169061120
+# MD5 Fingerprint: 0c:d2:f9:e0:da:17:73:e9:ed:86:4d:a5:e3:70:e7:4e
+# SHA1 Fingerprint: ca:bd:2a:79:a1:07:6a:31:f2:1d:25:36:35:cb:03:9d:43:29:a5:e8
+# SHA256 Fingerprint: 96:bc:ec:06:26:49:76:f3:74:60:77:9a:cf:28:c5:a7:cf:e8:a3:c0:aa:e1:1a:8f:fc:ee:05:c0:bd:df:08:c6
+-----BEGIN CERTIFICATE-----
+MIIFazCCA1OgAwIBAgIRAIIQz7DSQONZRGPgu2OCiwAwDQYJKoZIhvcNAQELBQAw
+TzELMAkGA1UEBhMCVVMxKTAnBgNVBAoTIEludGVybmV0IFNlY3VyaXR5IFJlc2Vh
+cmNoIEdyb3VwMRUwEwYDVQQDEwxJU1JHIFJvb3QgWDEwHhcNMTUwNjA0MTEwNDM4
+WhcNMzUwNjA0MTEwNDM4WjBPMQswCQYDVQQGEwJVUzEpMCcGA1UEChMgSW50ZXJu
+ZXQgU2VjdXJpdHkgUmVzZWFyY2ggR3JvdXAxFTATBgNVBAMTDElTUkcgUm9vdCBY
+MTCCAiIwDQYJKoZIhvcNAQEBBQADggIPADCCAgoCggIBAK3oJHP0FDfzm54rVygc
+h77ct984kIxuPOZXoHj3dcKi/vVqbvYATyjb3miGbESTtrFj/RQSa78f0uoxmyF+
+0TM8ukj13Xnfs7j/EvEhmkvBioZxaUpmZmyPfjxwv60pIgbz5MDmgK7iS4+3mX6U
+A5/TR5d8mUgjU+g4rk8Kb4Mu0UlXjIB0ttov0DiNewNwIRt18jA8+o+u3dpjq+sW
+T8KOEUt+zwvo/7V3LvSye0rgTBIlDHCNAymg4VMk7BPZ7hm/ELNKjD+Jo2FR3qyH
+B5T0Y3HsLuJvW5iB4YlcNHlsdu87kGJ55tukmi8mxdAQ4Q7e2RCOFvu396j3x+UC
+B5iPNgiV5+I3lg02dZ77DnKxHZu8A/lJBdiB3QW0KtZB6awBdpUKD9jf1b0SHzUv
+KBds0pjBqAlkd25HN7rOrFleaJ1/ctaJxQZBKT5ZPt0m9STJEadao0xAH0ahmbWn
+OlFuhjuefXKnEgV4We0+UXgVCwOPjdAvBbI+e0ocS3MFEvzG6uBQE3xDk3SzynTn
+jh8BCNAw1FtxNrQHusEwMFxIt4I7mKZ9YIqioymCzLq9gwQbooMDQaHWBfEbwrbw
+qHyGO0aoSCqI3Haadr8faqU9GY/rOPNk3sgrDQoo//fb4hVC1CLQJ13hef4Y53CI
+rU7m2Ys6xt0nUW7/vGT1M0NPAgMBAAGjQjBAMA4GA1UdDwEB/wQEAwIBBjAPBgNV
+HRMBAf8EBTADAQH/MB0GA1UdDgQWBBR5tFnme7bl5AFzgAiIyBpY9umbbjANBgkq
+hkiG9w0BAQsFAAOCAgEAVR9YqbyyqFDQDLHYGmkgJykIrGF1XIpu+ILlaS/V9lZL
+ubhzEFnTIZd+50xx+7LSYK05qAvqFyFWhfFQDlnrzuBZ6brJFe+GnY+EgPbk6ZGQ
+3BebYhtF8GaV0nxvwuo77x/Py9auJ/GpsMiu/X1+mvoiBOv/2X/qkSsisRcOj/KK
+NFtY2PwByVS5uCbMiogziUwthDyC3+6WVwW6LLv3xLfHTjuCvjHIInNzktHCgKQ5
+ORAzI4JMPJ+GslWYHb4phowim57iaztXOoJwTdwJx4nLCgdNbOhdjsnvzqvHu7Ur
+TkXWStAmzOVyyghqpZXjFaH3pO3JLF+l+/+sKAIuvtd7u+Nxe5AW0wdeRlN8NwdC
+jNPElpzVmbUq4JUagEiuTDkHzsxHpFKVK7q4+63SM1N95R1NbdWhscdCb+ZAJzVc
+oyi3B43njTOQ5yOf+1CceWxG1bQVs5ZufpsMljq4Ui0/1lvh+wjChP4kqKOJ2qxq
+4RgqsahDYVvTH9w7jXbyLeiNdd8XM2w9U/t7y0Ff/9yi0GE44Za4rF2LN9d11TPA
+mRGunUHBcnWEvgJBQl9nJEiU0Zsnvgc/ubhPgXRR4Xq37Z0j4r7g1SgEEzwxA57d
+emyPxgcYxn/eR44/KJ4EBs+lVDR3veyJm+kXQ99b21/+jh5Xos1AnX5iItreGCc=
+-----END CERTIFICATE-----
+
+# Issuer: O=FNMT-RCM OU=AC RAIZ FNMT-RCM
+# Subject: O=FNMT-RCM OU=AC RAIZ FNMT-RCM
+# Label: "AC RAIZ FNMT-RCM"
+# Serial: 485876308206448804701554682760554759
+# MD5 Fingerprint: e2:09:04:b4:d3:bd:d1:a0:14:fd:1a:d2:47:c4:57:1d
+# SHA1 Fingerprint: ec:50:35:07:b2:15:c4:95:62:19:e2:a8:9a:5b:42:99:2c:4c:2c:20
+# SHA256 Fingerprint: eb:c5:57:0c:29:01:8c:4d:67:b1:aa:12:7b:af:12:f7:03:b4:61:1e:bc:17:b7:da:b5:57:38:94:17:9b:93:fa
+-----BEGIN CERTIFICATE-----
+MIIFgzCCA2ugAwIBAgIPXZONMGc2yAYdGsdUhGkHMA0GCSqGSIb3DQEBCwUAMDsx
+CzAJBgNVBAYTAkVTMREwDwYDVQQKDAhGTk1ULVJDTTEZMBcGA1UECwwQQUMgUkFJ
+WiBGTk1ULVJDTTAeFw0wODEwMjkxNTU5NTZaFw0zMDAxMDEwMDAwMDBaMDsxCzAJ
+BgNVBAYTAkVTMREwDwYDVQQKDAhGTk1ULVJDTTEZMBcGA1UECwwQQUMgUkFJWiBG
+Tk1ULVJDTTCCAiIwDQYJKoZIhvcNAQEBBQADggIPADCCAgoCggIBALpxgHpMhm5/
+yBNtwMZ9HACXjywMI7sQmkCpGreHiPibVmr75nuOi5KOpyVdWRHbNi63URcfqQgf
+BBckWKo3Shjf5TnUV/3XwSyRAZHiItQDwFj8d0fsjz50Q7qsNI1NOHZnjrDIbzAz
+WHFctPVrbtQBULgTfmxKo0nRIBnuvMApGGWn3v7v3QqQIecaZ5JCEJhfTzC8PhxF
+tBDXaEAUwED653cXeuYLj2VbPNmaUtu1vZ5Gzz3rkQUCwJaydkxNEJY7kvqcfw+Z
+374jNUUeAlz+taibmSXaXvMiwzn15Cou08YfxGyqxRxqAQVKL9LFwag0Jl1mpdIC
+IfkYtwb1TplvqKtMUejPUBjFd8g5CSxJkjKZqLsXF3mwWsXmo8RZZUc1g16p6DUL
+mbvkzSDGm0oGObVo/CK67lWMK07q87Hj/LaZmtVC+nFNCM+HHmpxffnTtOmlcYF7
+wk5HlqX2doWjKI/pgG6BU6VtX7hI+cL5NqYuSf+4lsKMB7ObiFj86xsc3i1w4peS
+MKGJ47xVqCfWS+2QrYv6YyVZLag13cqXM7zlzced0ezvXg5KkAYmY6252TUtB7p2
+ZSysV4999AeU14ECll2jB0nVetBX+RvnU0Z1qrB5QstocQjpYL05ac70r8NWQMet
+UqIJ5G+GR4of6ygnXYMgrwTJbFaai0b1AgMBAAGjgYMwgYAwDwYDVR0TAQH/BAUw
+AwEB/zAOBgNVHQ8BAf8EBAMCAQYwHQYDVR0OBBYEFPd9xf3E6Jobd2Sn9R2gzL+H
+YJptMD4GA1UdIAQ3MDUwMwYEVR0gADArMCkGCCsGAQUFBwIBFh1odHRwOi8vd3d3
+LmNlcnQuZm5tdC5lcy9kcGNzLzANBgkqhkiG9w0BAQsFAAOCAgEAB5BK3/MjTvDD
+nFFlm5wioooMhfNzKWtN/gHiqQxjAb8EZ6WdmF/9ARP67Jpi6Yb+tmLSbkyU+8B1
+RXxlDPiyN8+sD8+Nb/kZ94/sHvJwnvDKuO+3/3Y3dlv2bojzr2IyIpMNOmqOFGYM
+LVN0V2Ue1bLdI4E7pWYjJ2cJj+F3qkPNZVEI7VFY/uY5+ctHhKQV8Xa7pO6kO8Rf
+77IzlhEYt8llvhjho6Tc+hj507wTmzl6NLrTQfv6MooqtyuGC2mDOL7Nii4LcK2N
+JpLuHvUBKwrZ1pebbuCoGRw6IYsMHkCtA+fdZn71uSANA+iW+YJF1DngoABd15jm
+fZ5nc8OaKveri6E6FO80vFIOiZiaBECEHX5FaZNXzuvO+FB8TxxuBEOb+dY7Ixjp
+6o7RTUaN8Tvkasq6+yO3m/qZASlaWFot4/nUbQ4mrcFuNLwy+AwF+mWj2zs3gyLp
+1txyM/1d8iC9djwj2ij3+RvrWWTV3F9yfiD8zYm1kGdNYno/Tq0dwzn+evQoFt9B
+9kiABdcPUXmsEKvU7ANm5mqwujGSQkBqvjrTcuFqN1W8rB2Vt2lh8kORdOag0wok
+RqEIr9baRRmW1FMdW4R58MD3R++Lj8UGrp1MYp3/RgT408m2ECVAdf4WqslKYIYv
+uu8wd+RU4riEmViAqhOLUTpPSPaLtrM=
+-----END CERTIFICATE-----
+
+# Issuer: CN=Amazon Root CA 1 O=Amazon
+# Subject: CN=Amazon Root CA 1 O=Amazon
+# Label: "Amazon Root CA 1"
+# Serial: 143266978916655856878034712317230054538369994
+# MD5 Fingerprint: 43:c6:bf:ae:ec:fe:ad:2f:18:c6:88:68:30:fc:c8:e6
+# SHA1 Fingerprint: 8d:a7:f9:65:ec:5e:fc:37:91:0f:1c:6e:59:fd:c1:cc:6a:6e:de:16
+# SHA256 Fingerprint: 8e:cd:e6:88:4f:3d:87:b1:12:5b:a3:1a:c3:fc:b1:3d:70:16:de:7f:57:cc:90:4f:e1:cb:97:c6:ae:98:19:6e
+-----BEGIN CERTIFICATE-----
+MIIDQTCCAimgAwIBAgITBmyfz5m/jAo54vB4ikPmljZbyjANBgkqhkiG9w0BAQsF
+ADA5MQswCQYDVQQGEwJVUzEPMA0GA1UEChMGQW1hem9uMRkwFwYDVQQDExBBbWF6
+b24gUm9vdCBDQSAxMB4XDTE1MDUyNjAwMDAwMFoXDTM4MDExNzAwMDAwMFowOTEL
+MAkGA1UEBhMCVVMxDzANBgNVBAoTBkFtYXpvbjEZMBcGA1UEAxMQQW1hem9uIFJv
+b3QgQ0EgMTCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBALJ4gHHKeNXj
+ca9HgFB0fW7Y14h29Jlo91ghYPl0hAEvrAIthtOgQ3pOsqTQNroBvo3bSMgHFzZM
+9O6II8c+6zf1tRn4SWiw3te5djgdYZ6k/oI2peVKVuRF4fn9tBb6dNqcmzU5L/qw
+IFAGbHrQgLKm+a/sRxmPUDgH3KKHOVj4utWp+UhnMJbulHheb4mjUcAwhmahRWa6
+VOujw5H5SNz/0egwLX0tdHA114gk957EWW67c4cX8jJGKLhD+rcdqsq08p8kDi1L
+93FcXmn/6pUCyziKrlA4b9v7LWIbxcceVOF34GfID5yHI9Y/QCB/IIDEgEw+OyQm
+jgSubJrIqg0CAwEAAaNCMEAwDwYDVR0TAQH/BAUwAwEB/zAOBgNVHQ8BAf8EBAMC
+AYYwHQYDVR0OBBYEFIQYzIU07LwMlJQuCFmcx7IQTgoIMA0GCSqGSIb3DQEBCwUA
+A4IBAQCY8jdaQZChGsV2USggNiMOruYou6r4lK5IpDB/G/wkjUu0yKGX9rbxenDI
+U5PMCCjjmCXPI6T53iHTfIUJrU6adTrCC2qJeHZERxhlbI1Bjjt/msv0tadQ1wUs
+N+gDS63pYaACbvXy8MWy7Vu33PqUXHeeE6V/Uq2V8viTO96LXFvKWlJbYK8U90vv
+o/ufQJVtMVT8QtPHRh8jrdkPSHCa2XV4cdFyQzR1bldZwgJcJmApzyMZFo6IQ6XU
+5MsI+yMRQ+hDKXJioaldXgjUkK642M4UwtBV8ob2xJNDd2ZhwLnoQdeXeGADbkpy
+rqXRfboQnoZsG4q5WTP468SQvvG5
+-----END CERTIFICATE-----
+
+# Issuer: CN=Amazon Root CA 2 O=Amazon
+# Subject: CN=Amazon Root CA 2 O=Amazon
+# Label: "Amazon Root CA 2"
+# Serial: 143266982885963551818349160658925006970653239
+# MD5 Fingerprint: c8:e5:8d:ce:a8:42:e2:7a:c0:2a:5c:7c:9e:26:bf:66
+# SHA1 Fingerprint: 5a:8c:ef:45:d7:a6:98:59:76:7a:8c:8b:44:96:b5:78:cf:47:4b:1a
+# SHA256 Fingerprint: 1b:a5:b2:aa:8c:65:40:1a:82:96:01:18:f8:0b:ec:4f:62:30:4d:83:ce:c4:71:3a:19:c3:9c:01:1e:a4:6d:b4
+-----BEGIN CERTIFICATE-----
+MIIFQTCCAymgAwIBAgITBmyf0pY1hp8KD+WGePhbJruKNzANBgkqhkiG9w0BAQwF
+ADA5MQswCQYDVQQGEwJVUzEPMA0GA1UEChMGQW1hem9uMRkwFwYDVQQDExBBbWF6
+b24gUm9vdCBDQSAyMB4XDTE1MDUyNjAwMDAwMFoXDTQwMDUyNjAwMDAwMFowOTEL
+MAkGA1UEBhMCVVMxDzANBgNVBAoTBkFtYXpvbjEZMBcGA1UEAxMQQW1hem9uIFJv
+b3QgQ0EgMjCCAiIwDQYJKoZIhvcNAQEBBQADggIPADCCAgoCggIBAK2Wny2cSkxK
+gXlRmeyKy2tgURO8TW0G/LAIjd0ZEGrHJgw12MBvIITplLGbhQPDW9tK6Mj4kHbZ
+W0/jTOgGNk3Mmqw9DJArktQGGWCsN0R5hYGCrVo34A3MnaZMUnbqQ523BNFQ9lXg
+1dKmSYXpN+nKfq5clU1Imj+uIFptiJXZNLhSGkOQsL9sBbm2eLfq0OQ6PBJTYv9K
+8nu+NQWpEjTj82R0Yiw9AElaKP4yRLuH3WUnAnE72kr3H9rN9yFVkE8P7K6C4Z9r
+2UXTu/Bfh+08LDmG2j/e7HJV63mjrdvdfLC6HM783k81ds8P+HgfajZRRidhW+me
+z/CiVX18JYpvL7TFz4QuK/0NURBs+18bvBt+xa47mAExkv8LV/SasrlX6avvDXbR
+8O70zoan4G7ptGmh32n2M8ZpLpcTnqWHsFcQgTfJU7O7f/aS0ZzQGPSSbtqDT6Zj
+mUyl+17vIWR6IF9sZIUVyzfpYgwLKhbcAS4y2j5L9Z469hdAlO+ekQiG+r5jqFoz
+7Mt0Q5X5bGlSNscpb/xVA1wf+5+9R+vnSUeVC06JIglJ4PVhHvG/LopyboBZ/1c6
++XUyo05f7O0oYtlNc/LMgRdg7c3r3NunysV+Ar3yVAhU/bQtCSwXVEqY0VThUWcI
+0u1ufm8/0i2BWSlmy5A5lREedCf+3euvAgMBAAGjQjBAMA8GA1UdEwEB/wQFMAMB
+Af8wDgYDVR0PAQH/BAQDAgGGMB0GA1UdDgQWBBSwDPBMMPQFWAJI/TPlUq9LhONm
+UjANBgkqhkiG9w0BAQwFAAOCAgEAqqiAjw54o+Ci1M3m9Zh6O+oAA7CXDpO8Wqj2
+LIxyh6mx/H9z/WNxeKWHWc8w4Q0QshNabYL1auaAn6AFC2jkR2vHat+2/XcycuUY
++gn0oJMsXdKMdYV2ZZAMA3m3MSNjrXiDCYZohMr/+c8mmpJ5581LxedhpxfL86kS
+k5Nrp+gvU5LEYFiwzAJRGFuFjWJZY7attN6a+yb3ACfAXVU3dJnJUH/jWS5E4ywl
+7uxMMne0nxrpS10gxdr9HIcWxkPo1LsmmkVwXqkLN1PiRnsn/eBG8om3zEK2yygm
+btmlyTrIQRNg91CMFa6ybRoVGld45pIq2WWQgj9sAq+uEjonljYE1x2igGOpm/Hl
+urR8FLBOybEfdF849lHqm/osohHUqS0nGkWxr7JOcQ3AWEbWaQbLU8uz/mtBzUF+
+fUwPfHJ5elnNXkoOrJupmHN5fLT0zLm4BwyydFy4x2+IoZCn9Kr5v2c69BoVYh63
+n749sSmvZ6ES8lgQGVMDMBu4Gon2nL2XA46jCfMdiyHxtN/kHNGfZQIG6lzWE7OE
+76KlXIx3KadowGuuQNKotOrN8I1LOJwZmhsoVLiJkO/KdYE+HvJkJMcYr07/R54H
+9jVlpNMKVv/1F2Rs76giJUmTtt8AF9pYfl3uxRuw0dFfIRDH+fO6AgonB8Xx1sfT
+4PsJYGw=
+-----END CERTIFICATE-----
+
+# Issuer: CN=Amazon Root CA 3 O=Amazon
+# Subject: CN=Amazon Root CA 3 O=Amazon
+# Label: "Amazon Root CA 3"
+# Serial: 143266986699090766294700635381230934788665930
+# MD5 Fingerprint: a0:d4:ef:0b:f7:b5:d8:49:95:2a:ec:f5:c4:fc:81:87
+# SHA1 Fingerprint: 0d:44:dd:8c:3c:8c:1a:1a:58:75:64:81:e9:0f:2e:2a:ff:b3:d2:6e
+# SHA256 Fingerprint: 18:ce:6c:fe:7b:f1:4e:60:b2:e3:47:b8:df:e8:68:cb:31:d0:2e:bb:3a:da:27:15:69:f5:03:43:b4:6d:b3:a4
+-----BEGIN CERTIFICATE-----
+MIIBtjCCAVugAwIBAgITBmyf1XSXNmY/Owua2eiedgPySjAKBggqhkjOPQQDAjA5
+MQswCQYDVQQGEwJVUzEPMA0GA1UEChMGQW1hem9uMRkwFwYDVQQDExBBbWF6b24g
+Um9vdCBDQSAzMB4XDTE1MDUyNjAwMDAwMFoXDTQwMDUyNjAwMDAwMFowOTELMAkG
+A1UEBhMCVVMxDzANBgNVBAoTBkFtYXpvbjEZMBcGA1UEAxMQQW1hem9uIFJvb3Qg
+Q0EgMzBZMBMGByqGSM49AgEGCCqGSM49AwEHA0IABCmXp8ZBf8ANm+gBG1bG8lKl
+ui2yEujSLtf6ycXYqm0fc4E7O5hrOXwzpcVOho6AF2hiRVd9RFgdszflZwjrZt6j
+QjBAMA8GA1UdEwEB/wQFMAMBAf8wDgYDVR0PAQH/BAQDAgGGMB0GA1UdDgQWBBSr
+ttvXBp43rDCGB5Fwx5zEGbF4wDAKBggqhkjOPQQDAgNJADBGAiEA4IWSoxe3jfkr
+BqWTrBqYaGFy+uGh0PsceGCmQ5nFuMQCIQCcAu/xlJyzlvnrxir4tiz+OpAUFteM
+YyRIHN8wfdVoOw==
+-----END CERTIFICATE-----
+
+# Issuer: CN=Amazon Root CA 4 O=Amazon
+# Subject: CN=Amazon Root CA 4 O=Amazon
+# Label: "Amazon Root CA 4"
+# Serial: 143266989758080763974105200630763877849284878
+# MD5 Fingerprint: 89:bc:27:d5:eb:17:8d:06:6a:69:d5:fd:89:47:b4:cd
+# SHA1 Fingerprint: f6:10:84:07:d6:f8:bb:67:98:0c:c2:e2:44:c2:eb:ae:1c:ef:63:be
+# SHA256 Fingerprint: e3:5d:28:41:9e:d0:20:25:cf:a6:90:38:cd:62:39:62:45:8d:a5:c6:95:fb:de:a3:c2:2b:0b:fb:25:89:70:92
+-----BEGIN CERTIFICATE-----
+MIIB8jCCAXigAwIBAgITBmyf18G7EEwpQ+Vxe3ssyBrBDjAKBggqhkjOPQQDAzA5
+MQswCQYDVQQGEwJVUzEPMA0GA1UEChMGQW1hem9uMRkwFwYDVQQDExBBbWF6b24g
+Um9vdCBDQSA0MB4XDTE1MDUyNjAwMDAwMFoXDTQwMDUyNjAwMDAwMFowOTELMAkG
+A1UEBhMCVVMxDzANBgNVBAoTBkFtYXpvbjEZMBcGA1UEAxMQQW1hem9uIFJvb3Qg
+Q0EgNDB2MBAGByqGSM49AgEGBSuBBAAiA2IABNKrijdPo1MN/sGKe0uoe0ZLY7Bi
+9i0b2whxIdIA6GO9mif78DluXeo9pcmBqqNbIJhFXRbb/egQbeOc4OO9X4Ri83Bk
+M6DLJC9wuoihKqB1+IGuYgbEgds5bimwHvouXKNCMEAwDwYDVR0TAQH/BAUwAwEB
+/zAOBgNVHQ8BAf8EBAMCAYYwHQYDVR0OBBYEFNPsxzplbszh2naaVvuc84ZtV+WB
+MAoGCCqGSM49BAMDA2gAMGUCMDqLIfG9fhGt0O9Yli/W651+kI0rz2ZVwyzjKKlw
+CkcO8DdZEv8tmZQoTipPNU0zWgIxAOp1AE47xDqUEpHJWEadIRNyp4iciuRMStuW
+1KyLa2tJElMzrdfkviT8tQp21KW8EA==
+-----END CERTIFICATE-----
+
+# Issuer: CN=LuxTrust Global Root 2 O=LuxTrust S.A.
+# Subject: CN=LuxTrust Global Root 2 O=LuxTrust S.A.
+# Label: "LuxTrust Global Root 2"
+# Serial: 59914338225734147123941058376788110305822489521
+# MD5 Fingerprint: b2:e1:09:00:61:af:f7:f1:91:6f:c4:ad:8d:5e:3b:7c
+# SHA1 Fingerprint: 1e:0e:56:19:0a:d1:8b:25:98:b2:04:44:ff:66:8a:04:17:99:5f:3f
+# SHA256 Fingerprint: 54:45:5f:71:29:c2:0b:14:47:c4:18:f9:97:16:8f:24:c5:8f:c5:02:3b:f5:da:5b:e2:eb:6e:1d:d8:90:2e:d5
+-----BEGIN CERTIFICATE-----
+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
+-----END CERTIFICATE-----
+
+# Issuer: CN=TUBITAK Kamu SM SSL Kok Sertifikasi - Surum 1 O=Turkiye Bilimsel ve Teknolojik Arastirma Kurumu - TUBITAK OU=Kamu Sertifikasyon Merkezi - Kamu SM
+# Subject: CN=TUBITAK Kamu SM SSL Kok Sertifikasi - Surum 1 O=Turkiye Bilimsel ve Teknolojik Arastirma Kurumu - TUBITAK OU=Kamu Sertifikasyon Merkezi - Kamu SM
+# Label: "TUBITAK Kamu SM SSL Kok Sertifikasi - Surum 1"
+# Serial: 1
+# MD5 Fingerprint: dc:00:81:dc:69:2f:3e:2f:b0:3b:f6:3d:5a:91:8e:49
+# SHA1 Fingerprint: 31:43:64:9b:ec:ce:27:ec:ed:3a:3f:0b:8f:0d:e4:e8:91:dd:ee:ca
+# SHA256 Fingerprint: 46:ed:c3:68:90:46:d5:3a:45:3f:b3:10:4a:b8:0d:ca:ec:65:8b:26:60:ea:16:29:dd:7e:86:79:90:64:87:16
+-----BEGIN CERTIFICATE-----
+MIIEYzCCA0ugAwIBAgIBATANBgkqhkiG9w0BAQsFADCB0jELMAkGA1UEBhMCVFIx
+GDAWBgNVBAcTD0dlYnplIC0gS29jYWVsaTFCMEAGA1UEChM5VHVya2l5ZSBCaWxp
+bXNlbCB2ZSBUZWtub2xvamlrIEFyYXN0aXJtYSBLdXJ1bXUgLSBUVUJJVEFLMS0w
+KwYDVQQLEyRLYW11IFNlcnRpZmlrYXN5b24gTWVya2V6aSAtIEthbXUgU00xNjA0
+BgNVBAMTLVRVQklUQUsgS2FtdSBTTSBTU0wgS29rIFNlcnRpZmlrYXNpIC0gU3Vy
+dW0gMTAeFw0xMzExMjUwODI1NTVaFw00MzEwMjUwODI1NTVaMIHSMQswCQYDVQQG
+EwJUUjEYMBYGA1UEBxMPR2ViemUgLSBLb2NhZWxpMUIwQAYDVQQKEzlUdXJraXll
+IEJpbGltc2VsIHZlIFRla25vbG9qaWsgQXJhc3Rpcm1hIEt1cnVtdSAtIFRVQklU
+QUsxLTArBgNVBAsTJEthbXUgU2VydGlmaWthc3lvbiBNZXJrZXppIC0gS2FtdSBT
+TTE2MDQGA1UEAxMtVFVCSVRBSyBLYW11IFNNIFNTTCBLb2sgU2VydGlmaWthc2kg
+LSBTdXJ1bSAxMIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAr3UwM6q7
+a9OZLBI3hNmNe5eA027n/5tQlT6QlVZC1xl8JoSNkvoBHToP4mQ4t4y86Ij5iySr
+LqP1N+RAjhgleYN1Hzv/bKjFxlb4tO2KRKOrbEz8HdDc72i9z+SqzvBV96I01INr
+N3wcwv61A+xXzry0tcXtAA9TNypN9E8Mg/uGz8v+jE69h/mniyFXnHrfA2eJLJ2X
+YacQuFWQfw4tJzh03+f92k4S400VIgLI4OD8D62K18lUUMw7D8oWgITQUVbDjlZ/
+iSIzL+aFCr2lqBs23tPcLG07xxO9WSMs5uWk99gL7eqQQESolbuT1dCANLZGeA4f
+AJNG4e7p+exPFwIDAQABo0IwQDAdBgNVHQ4EFgQUZT/HiobGPN08VFw1+DrtUgxH
+V8gwDgYDVR0PAQH/BAQDAgEGMA8GA1UdEwEB/wQFMAMBAf8wDQYJKoZIhvcNAQEL
+BQADggEBACo/4fEyjq7hmFxLXs9rHmoJ0iKpEsdeV31zVmSAhHqT5Am5EM2fKifh
+AHe+SMg1qIGf5LgsyX8OsNJLN13qudULXjS99HMpw+0mFZx+CFOKWI3QSyjfwbPf
+IPP54+M638yclNhOT8NrF7f3cuitZjO1JVOr4PhMqZ398g26rrnZqsZr+ZO7rqu4
+lzwDGrpDxpa5RXI4s6ehlj2Re37AIVNMh+3yC1SVUZPVIqUNivGTDj5UDrDYyU7c
+8jEyVupk+eq1nRZmQnLzf9OxMUP8pI4X8W0jq5Rm+K37DwhuJi1/FwcJsoz7UMCf
+lo3Ptv0AnVoUmr8CRPXBwp8iXqIPoeM=
+-----END CERTIFICATE-----
+
+# Issuer: CN=GDCA TrustAUTH R5 ROOT O=GUANG DONG CERTIFICATE AUTHORITY CO.,LTD.
+# Subject: CN=GDCA TrustAUTH R5 ROOT O=GUANG DONG CERTIFICATE AUTHORITY CO.,LTD.
+# Label: "GDCA TrustAUTH R5 ROOT"
+# Serial: 9009899650740120186
+# MD5 Fingerprint: 63:cc:d9:3d:34:35:5c:6f:53:a3:e2:08:70:48:1f:b4
+# SHA1 Fingerprint: 0f:36:38:5b:81:1a:25:c3:9b:31:4e:83:ca:e9:34:66:70:cc:74:b4
+# SHA256 Fingerprint: bf:ff:8f:d0:44:33:48:7d:6a:8a:a6:0c:1a:29:76:7a:9f:c2:bb:b0:5e:42:0f:71:3a:13:b9:92:89:1d:38:93
+-----BEGIN CERTIFICATE-----
+MIIFiDCCA3CgAwIBAgIIfQmX/vBH6nowDQYJKoZIhvcNAQELBQAwYjELMAkGA1UE
+BhMCQ04xMjAwBgNVBAoMKUdVQU5HIERPTkcgQ0VSVElGSUNBVEUgQVVUSE9SSVRZ
+IENPLixMVEQuMR8wHQYDVQQDDBZHRENBIFRydXN0QVVUSCBSNSBST09UMB4XDTE0
+MTEyNjA1MTMxNVoXDTQwMTIzMTE1NTk1OVowYjELMAkGA1UEBhMCQ04xMjAwBgNV
+BAoMKUdVQU5HIERPTkcgQ0VSVElGSUNBVEUgQVVUSE9SSVRZIENPLixMVEQuMR8w
+HQYDVQQDDBZHRENBIFRydXN0QVVUSCBSNSBST09UMIICIjANBgkqhkiG9w0BAQEF
+AAOCAg8AMIICCgKCAgEA2aMW8Mh0dHeb7zMNOwZ+Vfy1YI92hhJCfVZmPoiC7XJj
+Dp6L3TQsAlFRwxn9WVSEyfFrs0yw6ehGXTjGoqcuEVe6ghWinI9tsJlKCvLriXBj
+TnnEt1u9ol2x8kECK62pOqPseQrsXzrj/e+APK00mxqriCZ7VqKChh/rNYmDf1+u
+KU49tm7srsHwJ5uu4/Ts765/94Y9cnrrpftZTqfrlYwiOXnhLQiPzLyRuEH3FMEj
+qcOtmkVEs7LXLM3GKeJQEK5cy4KOFxg2fZfmiJqwTTQJ9Cy5WmYqsBebnh52nUpm
+MUHfP/vFBu8btn4aRjb3ZGM74zkYI+dndRTVdVeSN72+ahsmUPI2JgaQxXABZG12
+ZuGR224HwGGALrIuL4xwp9E7PLOR5G62xDtw8mySlwnNR30YwPO7ng/Wi64HtloP
+zgsMR6flPri9fcebNaBhlzpBdRfMK5Z3KpIhHtmVdiBnaM8Nvd/WHwlqmuLMc3Gk
+L30SgLdTMEZeS1SZD2fJpcjyIMGC7J0R38IC+xo70e0gmu9lZJIQDSri3nDxGGeC
+jGHeuLzRL5z7D9Ar7Rt2ueQ5Vfj4oR24qoAATILnsn8JuLwwoC8N9VKejveSswoA
+HQBUlwbgsQfZxw9cZX08bVlX5O2ljelAU58VS6Bx9hoh49pwBiFYFIeFd3mqgnkC
+AwEAAaNCMEAwHQYDVR0OBBYEFOLJQJ9NzuiaoXzPDj9lxSmIahlRMA8GA1UdEwEB
+/wQFMAMBAf8wDgYDVR0PAQH/BAQDAgGGMA0GCSqGSIb3DQEBCwUAA4ICAQDRSVfg
+p8xoWLoBDysZzY2wYUWsEe1jUGn4H3++Fo/9nesLqjJHdtJnJO29fDMylyrHBYZm
+DRd9FBUb1Ov9H5r2XpdptxolpAqzkT9fNqyL7FeoPueBihhXOYV0GkLH6VsTX4/5
+COmSdI31R9KrO9b7eGZONn356ZLpBN79SWP8bfsUcZNnL0dKt7n/HipzcEYwv1ry
+L3ml4Y0M2fmyYzeMN2WFcGpcWwlyua1jPLHd+PwyvzeG5LuOmCd+uh8W4XAR8gPf
+JWIyJyYYMoSf/wA6E7qaTfRPuBRwIrHKK5DOKcFw9C+df/KQHtZa37dG/OaG+svg
+IHZ6uqbL9XzeYqWxi+7egmaKTjowHz+Ay60nugxe19CxVsp3cbK1daFQqUBDF8Io
+2c9Si1vIY9RCPqAzekYu9wogRlR+ak8x8YF+QnQ4ZXMn7sZ8uI7XpTrXmKGcjBBV
+09tL7ECQ8s1uV9JiDnxXk7Gnbc2dg7sq5+W2O3FYrf3RRbxake5TFW/TRQl1brqQ
+XR4EzzffHqhmsYzmIGrv/EhOdJhCrylvLmrH+33RZjEizIYAfmaDDEL0vTSSwxrq
+T8p+ck0LcIymSLumoRT2+1hEmRSuqguTaaApJUqlyyvdimYHFngVV3Eb7PVHhPOe
+MTd61X8kreS8/f3MboPoDKi3QWwH3b08hpcv0g==
+-----END CERTIFICATE-----
+
+# Issuer: CN=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"
+# Serial: 8875640296558310041
+# MD5 Fingerprint: 86:69:12:c0:70:f1:ec:ac:ac:c2:d5:bc:a5:5b:a1:29
+# SHA1 Fingerprint: b7:ab:33:08:d1:ea:44:77:ba:14:80:12:5a:6f:bd:a9:36:49:0c:bb
+# SHA256 Fingerprint: 85:66:6a:56:2e:e0:be:5c:e9:25:c1:d8:89:0a:6f:76:a8:7e:c1:6d:4d:7d:5f:29:ea:74:19:cf:20:12:3b:69
+-----BEGIN CERTIFICATE-----
+MIIF3TCCA8WgAwIBAgIIeyyb0xaAMpkwDQYJKoZIhvcNAQELBQAwfDELMAkGA1UE
+BhMCVVMxDjAMBgNVBAgMBVRleGFzMRAwDgYDVQQHDAdIb3VzdG9uMRgwFgYDVQQK
+DA9TU0wgQ29ycG9yYXRpb24xMTAvBgNVBAMMKFNTTC5jb20gUm9vdCBDZXJ0aWZp
+Y2F0aW9uIEF1dGhvcml0eSBSU0EwHhcNMTYwMjEyMTczOTM5WhcNNDEwMjEyMTcz
+OTM5WjB8MQswCQYDVQQGEwJVUzEOMAwGA1UECAwFVGV4YXMxEDAOBgNVBAcMB0hv
+dXN0b24xGDAWBgNVBAoMD1NTTCBDb3Jwb3JhdGlvbjExMC8GA1UEAwwoU1NMLmNv
+bSBSb290IENlcnRpZmljYXRpb24gQXV0aG9yaXR5IFJTQTCCAiIwDQYJKoZIhvcN
+AQEBBQADggIPADCCAgoCggIBAPkP3aMrfcvQKv7sZ4Wm5y4bunfh4/WvpOz6Sl2R
+xFdHaxh3a3by/ZPkPQ/CFp4LZsNWlJ4Xg4XOVu/yFv0AYvUiCVToZRdOQbngT0aX
+qhvIuG5iXmmxX9sqAn78bMrzQdjt0Oj8P2FI7bADFB0QDksZ4LtO7IZl/zbzXmcC
+C52GVWH9ejjt/uIZALdvoVBidXQ8oPrIJZK0bnoix/geoeOy3ZExqysdBP+lSgQ3
+6YWkMyv94tZVNHwZpEpox7Ko07fKoZOI68GXvIz5HdkihCR0xwQ9aqkpk8zruFvh
+/l8lqjRYyMEjVJ0bmBHDOJx+PYZspQ9AhnwC9FwCTyjLrnGfDzrIM/4RJTXq/LrF
+YD3ZfBjVsqnTdXgDciLKOsMf7yzlLqn6niy2UUb9rwPW6mBo6oUWNmuF6R7As93E
+JNyAKoFBbZQ+yODJgUEAnl6/f8UImKIYLEJAs/lvOCdLToD0PYFH4Ih86hzOtXVc
+US4cK38acijnALXRdMbX5J+tB5O2UzU1/Dfkw/ZdFr4hc96SCvigY2q8lpJqPvi8
+ZVWb3vUNiSYE/CUapiVpy8JtynziWV+XrOvvLsi81xtZPCvM8hnIk2snYxnP/Okm
++Mpxm3+T/jRnhE6Z6/yzeAkzcLpmpnbtG3PrGqUNxCITIJRWCk4sbE6x/c+cCbqi
+M+2HAgMBAAGjYzBhMB0GA1UdDgQWBBTdBAkHovV6fVJTEpKV7jiAJQ2mWTAPBgNV
+HRMBAf8EBTADAQH/MB8GA1UdIwQYMBaAFN0ECQei9Xp9UlMSkpXuOIAlDaZZMA4G
+A1UdDwEB/wQEAwIBhjANBgkqhkiG9w0BAQsFAAOCAgEAIBgRlCn7Jp0cHh5wYfGV
+cpNxJK1ok1iOMq8bs3AD/CUrdIWQPXhq9LmLpZc7tRiRux6n+UBbkflVma8eEdBc
+Hadm47GUBwwyOabqG7B52B2ccETjit3E+ZUfijhDPwGFpUenPUayvOUiaPd7nNgs
+PgohyC0zrL/FgZkxdMF1ccW+sfAjRfSda/wZY52jvATGGAslu1OJD7OAUN5F7kR/
+q5R4ZJjT9ijdh9hwZXT7DrkT66cPYakylszeu+1jTBi7qUD3oFRuIIhxdRjqerQ0
+cuAjJ3dctpDqhiVAq+8zD8ufgr6iIPv2tS0a5sKFsXQP+8hlAqRSAUfdSSLBv9jr
+a6x+3uxjMxW3IwiPxg+NQVrdjsW5j+VFP3jbutIbQLH+cU0/4IGiul607BXgk90I
+H37hVZkLId6Tngr75qNJvTYw/ud3sqB1l7UtgYgXZSD32pAAn8lSzDLKNXz1PQ/Y
+K9f1JmzJBjSWFupwWRoyeXkLtoh/D1JIPb9s2KJELtFOt3JY04kTlf5Eq/jXixtu
+nLwsoFvVagCvXzfh1foQC5ichucmj87w7G6KVwuA406ywKBjYZC6VWg3dGq2ktuf
+oYYitmUnDuy2n0Jg5GfCtdpBC8TTi2EbvPofkSvXRAdeuims2cXp71NIWuuA8ShY
+Ic2wBlX7Jz9TkHCpBB5XJ7k=
+-----END CERTIFICATE-----
+
+# Issuer: CN=SSL.com Root Certification Authority ECC O=SSL Corporation
+# Subject: CN=SSL.com Root Certification Authority ECC O=SSL Corporation
+# Label: "SSL.com Root Certification Authority ECC"
+# Serial: 8495723813297216424
+# MD5 Fingerprint: 2e:da:e4:39:7f:9c:8f:37:d1:70:9f:26:17:51:3a:8e
+# SHA1 Fingerprint: c3:19:7c:39:24:e6:54:af:1b:c4:ab:20:95:7a:e2:c3:0e:13:02:6a
+# SHA256 Fingerprint: 34:17:bb:06:cc:60:07:da:1b:96:1c:92:0b:8a:b4:ce:3f:ad:82:0e:4a:a3:0b:9a:cb:c4:a7:4e:bd:ce:bc:65
+-----BEGIN CERTIFICATE-----
+MIICjTCCAhSgAwIBAgIIdebfy8FoW6gwCgYIKoZIzj0EAwIwfDELMAkGA1UEBhMC
+VVMxDjAMBgNVBAgMBVRleGFzMRAwDgYDVQQHDAdIb3VzdG9uMRgwFgYDVQQKDA9T
+U0wgQ29ycG9yYXRpb24xMTAvBgNVBAMMKFNTTC5jb20gUm9vdCBDZXJ0aWZpY2F0
+aW9uIEF1dGhvcml0eSBFQ0MwHhcNMTYwMjEyMTgxNDAzWhcNNDEwMjEyMTgxNDAz
+WjB8MQswCQYDVQQGEwJVUzEOMAwGA1UECAwFVGV4YXMxEDAOBgNVBAcMB0hvdXN0
+b24xGDAWBgNVBAoMD1NTTCBDb3Jwb3JhdGlvbjExMC8GA1UEAwwoU1NMLmNvbSBS
+b290IENlcnRpZmljYXRpb24gQXV0aG9yaXR5IEVDQzB2MBAGByqGSM49AgEGBSuB
+BAAiA2IABEVuqVDEpiM2nl8ojRfLliJkP9x6jh3MCLOicSS6jkm5BBtHllirLZXI
+7Z4INcgn64mMU1jrYor+8FsPazFSY0E7ic3s7LaNGdM0B9y7xgZ/wkWV7Mt/qCPg
+CemB+vNH06NjMGEwHQYDVR0OBBYEFILRhXMw5zUE044CkvvlpNHEIejNMA8GA1Ud
+EwEB/wQFMAMBAf8wHwYDVR0jBBgwFoAUgtGFczDnNQTTjgKS++Wk0cQh6M0wDgYD
+VR0PAQH/BAQDAgGGMAoGCCqGSM49BAMCA2cAMGQCMG/n61kRpGDPYbCWe+0F+S8T
+kdzt5fxQaxFGRrMcIQBiu77D5+jNB5n5DQtdcj7EqgIwH7y6C+IwJPt8bYBVCpk+
+gA0z5Wajs6O7pdWLjwkspl1+4vAHCGht0nxpbl/f5Wpl
+-----END CERTIFICATE-----
+
+# Issuer: CN=SSL.com EV Root Certification Authority RSA R2 O=SSL Corporation
+# Subject: CN=SSL.com EV Root Certification Authority RSA R2 O=SSL Corporation
+# Label: "SSL.com EV Root Certification Authority RSA R2"
+# Serial: 6248227494352943350
+# MD5 Fingerprint: e1:1e:31:58:1a:ae:54:53:02:f6:17:6a:11:7b:4d:95
+# SHA1 Fingerprint: 74:3a:f0:52:9b:d0:32:a0:f4:4a:83:cd:d4:ba:a9:7b:7c:2e:c4:9a
+# SHA256 Fingerprint: 2e:7b:f1:6c:c2:24:85:a7:bb:e2:aa:86:96:75:07:61:b0:ae:39:be:3b:2f:e9:d0:cc:6d:4e:f7:34:91:42:5c
+-----BEGIN CERTIFICATE-----
+MIIF6zCCA9OgAwIBAgIIVrYpzTS8ePYwDQYJKoZIhvcNAQELBQAwgYIxCzAJBgNV
+BAYTAlVTMQ4wDAYDVQQIDAVUZXhhczEQMA4GA1UEBwwHSG91c3RvbjEYMBYGA1UE
+CgwPU1NMIENvcnBvcmF0aW9uMTcwNQYDVQQDDC5TU0wuY29tIEVWIFJvb3QgQ2Vy
+dGlmaWNhdGlvbiBBdXRob3JpdHkgUlNBIFIyMB4XDTE3MDUzMTE4MTQzN1oXDTQy
+MDUzMDE4MTQzN1owgYIxCzAJBgNVBAYTAlVTMQ4wDAYDVQQIDAVUZXhhczEQMA4G
+A1UEBwwHSG91c3RvbjEYMBYGA1UECgwPU1NMIENvcnBvcmF0aW9uMTcwNQYDVQQD
+DC5TU0wuY29tIEVWIFJvb3QgQ2VydGlmaWNhdGlvbiBBdXRob3JpdHkgUlNBIFIy
+MIICIjANBgkqhkiG9w0BAQEFAAOCAg8AMIICCgKCAgEAjzZlQOHWTcDXtOlG2mvq
+M0fNTPl9fb69LT3w23jhhqXZuglXaO1XPqDQCEGD5yhBJB/jchXQARr7XnAjssuf
+OePPxU7Gkm0mxnu7s9onnQqG6YE3Bf7wcXHswxzpY6IXFJ3vG2fThVUCAtZJycxa
+4bH3bzKfydQ7iEGonL3Lq9ttewkfokxykNorCPzPPFTOZw+oz12WGQvE43LrrdF9
+HSfvkusQv1vrO6/PgN3B0pYEW3p+pKk8OHakYo6gOV7qd89dAFmPZiw+B6KjBSYR
+aZfqhbcPlgtLyEDhULouisv3D5oi53+aNxPN8k0TayHRwMwi8qFG9kRpnMphNQcA
+b9ZhCBHqurj26bNg5U257J8UZslXWNvNh2n4ioYSA0e/ZhN2rHd9NCSFg83XqpyQ
+Gp8hLH94t2S42Oim9HizVcuE0jLEeK6jj2HdzghTreyI/BXkmg3mnxp3zkyPuBQV
+PWKchjgGAGYS5Fl2WlPAApiiECtoRHuOec4zSnaqW4EWG7WK2NAAe15itAnWhmMO
+pgWVSbooi4iTsjQc2KRVbrcc0N6ZVTsj9CLg+SlmJuwgUHfbSguPvuUCYHBBXtSu
+UDkiFCbLsjtzdFVHB3mBOagwE0TlBIqulhMlQg+5U8Sb/M3kHN48+qvWBkofZ6aY
+MBzdLNvcGJVXZsb/XItW9XcCAwEAAaNjMGEwDwYDVR0TAQH/BAUwAwEB/zAfBgNV
+HSMEGDAWgBT5YLvU49U09rj1BoAlp3PbRmmonjAdBgNVHQ4EFgQU+WC71OPVNPa4
+9QaAJadz20ZpqJ4wDgYDVR0PAQH/BAQDAgGGMA0GCSqGSIb3DQEBCwUAA4ICAQBW
+s47LCp1Jjr+kxJG7ZhcFUZh1++VQLHqe8RT6q9OKPv+RKY9ji9i0qVQBDb6Thi/5
+Sm3HXvVX+cpVHBK+Rw82xd9qt9t1wkclf7nxY/hoLVUE0fKNsKTPvDxeH3jnpaAg
+cLAExbf3cqfeIg29MyVGjGSSJuM+LmOW2puMPfgYCdcDzH2GguDKBAdRUNf/ktUM
+79qGn5nX67evaOI5JpS6aLe/g9Pqemc9YmeuJeVy6OLk7K4S9ksrPJ/psEDzOFSz
+/bdoyNrGj1E8svuR3Bznm53htw1yj+KkxKl4+esUrMZDBcJlOSgYAsOCsp0FvmXt
+ll9ldDz7CTUue5wT/RsPXcdtgTpWD8w74a8CLyKsRspGPKAcTNZEtF4uXBVmCeEm
+Kf7GUmG6sXP/wwyc5WxqlD8UykAWlYTzWamsX0xhk23RO8yilQwipmdnRC652dKK
+QbNmC1r7fSOl8hqw/96bg5Qu0T/fkreRrwU7ZcegbLHNYhLDkBvjJc40vG93drEQ
+w/cFGsDWr3RiSBd3kmmQYRzelYB0VI8YHMPzA9C/pEN1hlMYegouCRw2n5H9gooi
+S9EOUCXdywMMF8mDAAhONU2Ki+3wApRmLER/y5UnlhetCTCstnEXbosX9hwJ1C07
+mKVx01QT2WDz9UtmT/rx7iASjbSsV7FFY6GsdqnC+w==
+-----END CERTIFICATE-----
+
+# Issuer: CN=SSL.com EV Root Certification Authority ECC O=SSL Corporation
+# Subject: CN=SSL.com EV Root Certification Authority ECC O=SSL Corporation
+# Label: "SSL.com EV Root Certification Authority ECC"
+# Serial: 3182246526754555285
+# MD5 Fingerprint: 59:53:22:65:83:42:01:54:c0:ce:42:b9:5a:7c:f2:90
+# SHA1 Fingerprint: 4c:dd:51:a3:d1:f5:20:32:14:b0:c6:c5:32:23:03:91:c7:46:42:6d
+# SHA256 Fingerprint: 22:a2:c1:f7:bd:ed:70:4c:c1:e7:01:b5:f4:08:c3:10:88:0f:e9:56:b5:de:2a:4a:44:f9:9c:87:3a:25:a7:c8
+-----BEGIN CERTIFICATE-----
+MIIClDCCAhqgAwIBAgIILCmcWxbtBZUwCgYIKoZIzj0EAwIwfzELMAkGA1UEBhMC
+VVMxDjAMBgNVBAgMBVRleGFzMRAwDgYDVQQHDAdIb3VzdG9uMRgwFgYDVQQKDA9T
+U0wgQ29ycG9yYXRpb24xNDAyBgNVBAMMK1NTTC5jb20gRVYgUm9vdCBDZXJ0aWZp
+Y2F0aW9uIEF1dGhvcml0eSBFQ0MwHhcNMTYwMjEyMTgxNTIzWhcNNDEwMjEyMTgx
+NTIzWjB/MQswCQYDVQQGEwJVUzEOMAwGA1UECAwFVGV4YXMxEDAOBgNVBAcMB0hv
+dXN0b24xGDAWBgNVBAoMD1NTTCBDb3Jwb3JhdGlvbjE0MDIGA1UEAwwrU1NMLmNv
+bSBFViBSb290IENlcnRpZmljYXRpb24gQXV0aG9yaXR5IEVDQzB2MBAGByqGSM49
+AgEGBSuBBAAiA2IABKoSR5CYG/vvw0AHgyBO8TCCogbR8pKGYfL2IWjKAMTH6kMA
+VIbc/R/fALhBYlzccBYy3h+Z1MzFB8gIH2EWB1E9fVwHU+M1OIzfzZ/ZLg1Kthku
+WnBaBu2+8KGwytAJKaNjMGEwHQYDVR0OBBYEFFvKXuXe0oGqzagtZFG22XKbl+ZP
+MA8GA1UdEwEB/wQFMAMBAf8wHwYDVR0jBBgwFoAUW8pe5d7SgarNqC1kUbbZcpuX
+5k8wDgYDVR0PAQH/BAQDAgGGMAoGCCqGSM49BAMCA2gAMGUCMQCK5kCJN+vp1RPZ
+ytRrJPOwPYdGWBrssd9v+1a6cGvHOMzosYxPD/fxZ3YOg9AeUY8CMD32IygmTMZg
+h5Mmm7I1HrrW9zzRHM76JTymGoEVW/MSD2zuZYrJh6j5B+BimoxcSg==
+-----END CERTIFICATE-----
+
+# Issuer: CN=GlobalSign O=GlobalSign OU=GlobalSign Root CA - R6
+# Subject: CN=GlobalSign O=GlobalSign OU=GlobalSign Root CA - R6
+# Label: "GlobalSign Root CA - R6"
+# Serial: 1417766617973444989252670301619537
+# MD5 Fingerprint: 4f:dd:07:e4:d4:22:64:39:1e:0c:37:42:ea:d1:c6:ae
+# SHA1 Fingerprint: 80:94:64:0e:b5:a7:a1:ca:11:9c:1f:dd:d5:9f:81:02:63:a7:fb:d1
+# SHA256 Fingerprint: 2c:ab:ea:fe:37:d0:6c:a2:2a:ba:73:91:c0:03:3d:25:98:29:52:c4:53:64:73:49:76:3a:3a:b5:ad:6c:cf:69
+-----BEGIN CERTIFICATE-----
+MIIFgzCCA2ugAwIBAgIORea7A4Mzw4VlSOb/RVEwDQYJKoZIhvcNAQEMBQAwTDEg
+MB4GA1UECxMXR2xvYmFsU2lnbiBSb290IENBIC0gUjYxEzARBgNVBAoTCkdsb2Jh
+bFNpZ24xEzARBgNVBAMTCkdsb2JhbFNpZ24wHhcNMTQxMjEwMDAwMDAwWhcNMzQx
+MjEwMDAwMDAwWjBMMSAwHgYDVQQLExdHbG9iYWxTaWduIFJvb3QgQ0EgLSBSNjET
+MBEGA1UEChMKR2xvYmFsU2lnbjETMBEGA1UEAxMKR2xvYmFsU2lnbjCCAiIwDQYJ
+KoZIhvcNAQEBBQADggIPADCCAgoCggIBAJUH6HPKZvnsFMp7PPcNCPG0RQssgrRI
+xutbPK6DuEGSMxSkb3/pKszGsIhrxbaJ0cay/xTOURQh7ErdG1rG1ofuTToVBu1k
+ZguSgMpE3nOUTvOniX9PeGMIyBJQbUJmL025eShNUhqKGoC3GYEOfsSKvGRMIRxD
+aNc9PIrFsmbVkJq3MQbFvuJtMgamHvm566qjuL++gmNQ0PAYid/kD3n16qIfKtJw
+LnvnvJO7bVPiSHyMEAc4/2ayd2F+4OqMPKq0pPbzlUoSB239jLKJz9CgYXfIWHSw
+1CM69106yqLbnQneXUQtkPGBzVeS+n68UARjNN9rkxi+azayOeSsJDa38O+2HBNX
+k7besvjihbdzorg1qkXy4J02oW9UivFyVm4uiMVRQkQVlO6jxTiWm05OWgtH8wY2
+SXcwvHE35absIQh1/OZhFj931dmRl4QKbNQCTXTAFO39OfuD8l4UoQSwC+n+7o/h
+bguyCLNhZglqsQY6ZZZZwPA1/cnaKI0aEYdwgQqomnUdnjqGBQCe24DWJfncBZ4n
+WUx2OVvq+aWh2IMP0f/fMBH5hc8zSPXKbWQULHpYT9NLCEnFlWQaYw55PfWzjMpY
+rZxCRXluDocZXFSxZba/jJvcE+kNb7gu3GduyYsRtYQUigAZcIN5kZeR1Bonvzce
+MgfYFGM8KEyvAgMBAAGjYzBhMA4GA1UdDwEB/wQEAwIBBjAPBgNVHRMBAf8EBTAD
+AQH/MB0GA1UdDgQWBBSubAWjkxPioufi1xzWx/B/yGdToDAfBgNVHSMEGDAWgBSu
+bAWjkxPioufi1xzWx/B/yGdToDANBgkqhkiG9w0BAQwFAAOCAgEAgyXt6NH9lVLN
+nsAEoJFp5lzQhN7craJP6Ed41mWYqVuoPId8AorRbrcWc+ZfwFSY1XS+wc3iEZGt
+Ixg93eFyRJa0lV7Ae46ZeBZDE1ZXs6KzO7V33EByrKPrmzU+sQghoefEQzd5Mr61
+55wsTLxDKZmOMNOsIeDjHfrYBzN2VAAiKrlNIC5waNrlU/yDXNOd8v9EDERm8tLj
+vUYAGm0CuiVdjaExUd1URhxN25mW7xocBFymFe944Hn+Xds+qkxV/ZoVqW/hpvvf
+cDDpw+5CRu3CkwWJ+n1jez/QcYF8AOiYrg54NMMl+68KnyBr3TsTjxKM4kEaSHpz
+oHdpx7Zcf4LIHv5YGygrqGytXm3ABdJ7t+uA/iU3/gKbaKxCXcPu9czc8FB10jZp
+nOZ7BN9uBmm23goJSFmH63sUYHpkqmlD75HHTOwY3WzvUy2MmeFe8nI+z1TIvWfs
+pA9MRf/TuTAjB0yPEL+GltmZWrSZVxykzLsViVO6LAUP5MSeGbEYNNVMnbrt9x+v
+JJUEeKgDu+6B5dpffItKoZB0JaezPkvILFa9x8jvOOJckvB595yEunQtYQEgfn7R
+8k8HWV+LLUNS60YMlOH1Zkd5d9VUWx+tJDfLRVpOoERIyNiwmcUVhAn21klJwGW4
+5hpxbqCo8YLoRT5s1gLXCmeDBVrJpBA=
+-----END CERTIFICATE-----
+
+# Issuer: CN=OISTE WISeKey Global Root GC CA O=WISeKey OU=OISTE Foundation Endorsed
+# Subject: CN=OISTE WISeKey Global Root GC CA O=WISeKey OU=OISTE Foundation Endorsed
+# Label: "OISTE WISeKey Global Root GC CA"
+# Serial: 44084345621038548146064804565436152554
+# MD5 Fingerprint: a9:d6:b9:2d:2f:93:64:f8:a5:69:ca:91:e9:68:07:23
+# SHA1 Fingerprint: e0:11:84:5e:34:de:be:88:81:b9:9c:f6:16:26:d1:96:1f:c3:b9:31
+# SHA256 Fingerprint: 85:60:f9:1c:36:24:da:ba:95:70:b5:fe:a0:db:e3:6f:f1:1a:83:23:be:94:86:85:4f:b3:f3:4a:55:71:19:8d
+-----BEGIN CERTIFICATE-----
+MIICaTCCAe+gAwIBAgIQISpWDK7aDKtARb8roi066jAKBggqhkjOPQQDAzBtMQsw
+CQYDVQQGEwJDSDEQMA4GA1UEChMHV0lTZUtleTEiMCAGA1UECxMZT0lTVEUgRm91
+bmRhdGlvbiBFbmRvcnNlZDEoMCYGA1UEAxMfT0lTVEUgV0lTZUtleSBHbG9iYWwg
+Um9vdCBHQyBDQTAeFw0xNzA1MDkwOTQ4MzRaFw00MjA1MDkwOTU4MzNaMG0xCzAJ
+BgNVBAYTAkNIMRAwDgYDVQQKEwdXSVNlS2V5MSIwIAYDVQQLExlPSVNURSBGb3Vu
+ZGF0aW9uIEVuZG9yc2VkMSgwJgYDVQQDEx9PSVNURSBXSVNlS2V5IEdsb2JhbCBS
+b290IEdDIENBMHYwEAYHKoZIzj0CAQYFK4EEACIDYgAETOlQwMYPchi82PG6s4ni
+eUqjFqdrVCTbUf/q9Akkwwsin8tqJ4KBDdLArzHkdIJuyiXZjHWd8dvQmqJLIX4W
+p2OQ0jnUsYd4XxiWD1AbNTcPasbc2RNNpI6QN+a9WzGRo1QwUjAOBgNVHQ8BAf8E
+BAMCAQYwDwYDVR0TAQH/BAUwAwEB/zAdBgNVHQ4EFgQUSIcUrOPDnpBgOtfKie7T
+rYy0UGYwEAYJKwYBBAGCNxUBBAMCAQAwCgYIKoZIzj0EAwMDaAAwZQIwJsdpW9zV
+57LnyAyMjMPdeYwbY9XJUpROTYJKcx6ygISpJcBMWm1JKWB4E+J+SOtkAjEA2zQg
+Mgj/mkkCtojeFK9dbJlxjRo/i9fgojaGHAeCOnZT/cKi7e97sIBPWA9LUzm9
+-----END CERTIFICATE-----
+
+# Issuer: CN=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"
+# Serial: 124779693093741543919145257850076631279
+# MD5 Fingerprint: 80:fe:f0:c4:4a:f0:5c:62:32:9f:1c:ba:78:a9:50:f8
+# SHA1 Fingerprint: 28:f9:78:16:19:7a:ff:18:25:18:aa:44:fe:c1:a0:ce:5c:b6:4c:8a
+# SHA256 Fingerprint: 9b:ea:11:c9:76:fe:01:47:64:c1:be:56:a6:f9:14:b5:a5:60:31:7a:bd:99:88:39:33:82:e5:16:1a:a0:49:3c
+-----BEGIN CERTIFICATE-----
+MIIFRjCCAy6gAwIBAgIQXd+x2lqj7V2+WmUgZQOQ7zANBgkqhkiG9w0BAQsFADA9
+MQswCQYDVQQGEwJDTjERMA8GA1UECgwIVW5pVHJ1c3QxGzAZBgNVBAMMElVDQSBH
+bG9iYWwgRzIgUm9vdDAeFw0xNjAzMTEwMDAwMDBaFw00MDEyMzEwMDAwMDBaMD0x
+CzAJBgNVBAYTAkNOMREwDwYDVQQKDAhVbmlUcnVzdDEbMBkGA1UEAwwSVUNBIEds
+b2JhbCBHMiBSb290MIICIjANBgkqhkiG9w0BAQEFAAOCAg8AMIICCgKCAgEAxeYr
+b3zvJgUno4Ek2m/LAfmZmqkywiKHYUGRO8vDaBsGxUypK8FnFyIdK+35KYmToni9
+kmugow2ifsqTs6bRjDXVdfkX9s9FxeV67HeToI8jrg4aA3++1NDtLnurRiNb/yzm
+VHqUwCoV8MmNsHo7JOHXaOIxPAYzRrZUEaalLyJUKlgNAQLx+hVRZ2zA+te2G3/R
+VogvGjqNO7uCEeBHANBSh6v7hn4PJGtAnTRnvI3HLYZveT6OqTwXS3+wmeOwcWDc
+C/Vkw85DvG1xudLeJ1uK6NjGruFZfc8oLTW4lVYa8bJYS7cSN8h8s+1LgOGN+jIj
+tm+3SJUIsUROhYw6AlQgL9+/V087OpAh18EmNVQg7Mc/R+zvWr9LesGtOxdQXGLY
+D0tK3Cv6brxzks3sx1DoQZbXqX5t2Okdj4q1uViSukqSKwxW/YDrCPBeKW4bHAyv
+j5OJrdu9o54hyokZ7N+1wxrrFv54NkzWbtA+FxyQF2smuvt6L78RHBgOLXMDj6Dl
+NaBa4kx1HXHhOThTeEDMg5PXCp6dW4+K5OXgSORIskfNTip1KnvyIvbJvgmRlld6
+iIis7nCs+dwp4wwcOxJORNanTrAmyPPZGpeRaOrvjUYG0lZFWJo8DA+DuAUlwznP
+O6Q0ibd5Ei9Hxeepl2n8pndntd978XplFeRhVmUCAwEAAaNCMEAwDgYDVR0PAQH/
+BAQDAgEGMA8GA1UdEwEB/wQFMAMBAf8wHQYDVR0OBBYEFIHEjMz15DD/pQwIX4wV
+ZyF0Ad/fMA0GCSqGSIb3DQEBCwUAA4ICAQATZSL1jiutROTL/7lo5sOASD0Ee/oj
+L3rtNtqyzm325p7lX1iPyzcyochltq44PTUbPrw7tgTQvPlJ9Zv3hcU2tsu8+Mg5
+1eRfB70VVJd0ysrtT7q6ZHafgbiERUlMjW+i67HM0cOU2kTC5uLqGOiiHycFutfl
+1qnN3e92mI0ADs0b+gO3joBYDic/UvuUospeZcnWhNq5NXHzJsBPd+aBJ9J3O5oU
+b3n09tDh05S60FdRvScFDcH9yBIw7m+NESsIndTUv4BFFJqIRNow6rSn4+7vW4LV
+PtateJLbXDzz2K36uGt/xDYotgIVilQsnLAXc47QN6MUPJiVAAwpBVueSUmxX8fj
+y88nZY41F7dXyDDZQVu5FLbowg+UMaeUmMxq67XhJ/UQqAHojhJi6IjMtX9Gl8Cb
+EGY4GjZGXyJoPd/JxhMnq1MGrKI8hgZlb7F+sSlEmqO6SWkoaY/X5V+tBIZkbxqg
+DMUIYs6Ao9Dz7GjevjPHF1t/gMRMTLGmhIrDO7gJzRSBuhjjVFc2/tsvfEehOjPI
++Vg7RE+xygKJBJYoaMVLuCaJu9YzL1DV/pqJuhgyklTGW+Cd+V7lDSKb9triyCGy
+YiGqhkCyLmTTX8jjfhFnRR8F/uOi77Oos/N9j/gMHyIfLXC0uAE0djAA5SN4p1bX
+UB+K+wb1whnw0A==
+-----END CERTIFICATE-----
+
+# Issuer: CN=UCA Extended Validation Root O=UniTrust
+# Subject: CN=UCA Extended Validation Root O=UniTrust
+# Label: "UCA Extended Validation Root"
+# Serial: 106100277556486529736699587978573607008
+# MD5 Fingerprint: a1:f3:5f:43:c6:34:9b:da:bf:8c:7e:05:53:ad:96:e2
+# SHA1 Fingerprint: a3:a1:b0:6f:24:61:23:4a:e3:36:a5:c2:37:fc:a6:ff:dd:f0:d7:3a
+# SHA256 Fingerprint: d4:3a:f9:b3:54:73:75:5c:96:84:fc:06:d7:d8:cb:70:ee:5c:28:e7:73:fb:29:4e:b4:1e:e7:17:22:92:4d:24
+-----BEGIN CERTIFICATE-----
+MIIFWjCCA0KgAwIBAgIQT9Irj/VkyDOeTzRYZiNwYDANBgkqhkiG9w0BAQsFADBH
+MQswCQYDVQQGEwJDTjERMA8GA1UECgwIVW5pVHJ1c3QxJTAjBgNVBAMMHFVDQSBF
+eHRlbmRlZCBWYWxpZGF0aW9uIFJvb3QwHhcNMTUwMzEzMDAwMDAwWhcNMzgxMjMx
+MDAwMDAwWjBHMQswCQYDVQQGEwJDTjERMA8GA1UECgwIVW5pVHJ1c3QxJTAjBgNV
+BAMMHFVDQSBFeHRlbmRlZCBWYWxpZGF0aW9uIFJvb3QwggIiMA0GCSqGSIb3DQEB
+AQUAA4ICDwAwggIKAoICAQCpCQcoEwKwmeBkqh5DFnpzsZGgdT6o+uM4AHrsiWog
+D4vFsJszA1qGxliG1cGFu0/GnEBNyr7uaZa4rYEwmnySBesFK5pI0Lh2PpbIILvS
+sPGP2KxFRv+qZ2C0d35qHzwaUnoEPQc8hQ2E0B92CvdqFN9y4zR8V05WAT558aop
+O2z6+I9tTcg1367r3CTueUWnhbYFiN6IXSV8l2RnCdm/WhUFhvMJHuxYMjMR83dk
+sHYf5BA1FxvyDrFspCqjc/wJHx4yGVMR59mzLC52LqGj3n5qiAno8geK+LLNEOfi
+c0CTuwjRP+H8C5SzJe98ptfRr5//lpr1kXuYC3fUfugH0mK1lTnj8/FtDw5lhIpj
+VMWAtuCeS31HJqcBCF3RiJ7XwzJE+oJKCmhUfzhTA8ykADNkUVkLo4KRel7sFsLz
+KuZi2irbWWIQJUoqgQtHB0MGcIfS+pMRKXpITeuUx3BNr2fVUbGAIAEBtHoIppB/
+TuDvB0GHr2qlXov7z1CymlSvw4m6WC31MJixNnI5fkkE/SmnTHnkBVfblLkWU41G
+sx2VYVdWf6/wFlthWG82UBEL2KwrlRYaDh8IzTY0ZRBiZtWAXxQgXy0MoHgKaNYs
+1+lvK9JKBZP8nm9rZ/+I8U6laUpSNwXqxhaN0sSZ0YIrO7o1dfdRUVjzyAfd5LQD
+fwIDAQABo0IwQDAdBgNVHQ4EFgQU2XQ65DA9DfcS3H5aBZ8eNJr34RQwDwYDVR0T
+AQH/BAUwAwEB/zAOBgNVHQ8BAf8EBAMCAYYwDQYJKoZIhvcNAQELBQADggIBADaN
+l8xCFWQpN5smLNb7rhVpLGsaGvdftvkHTFnq88nIua7Mui563MD1sC3AO6+fcAUR
+ap8lTwEpcOPlDOHqWnzcSbvBHiqB9RZLcpHIojG5qtr8nR/zXUACE/xOHAbKsxSQ
+VBcZEhrxH9cMaVr2cXj0lH2RC47skFSOvG+hTKv8dGT9cZr4QQehzZHkPJrgmzI5
+c6sq1WnIeJEmMX3ixzDx/BR4dxIOE/TdFpS/S2d7cFOFyrC78zhNLJA5wA3CXWvp
+4uXViI3WLL+rG761KIcSF3Ru/H38j9CHJrAb+7lsq+KePRXBOy5nAliRn+/4Qh8s
+t2j1da3Ptfb/EX3C8CSlrdP6oDyp+l3cpaDvRKS+1ujl5BOWF3sGPjLtx7dCvHaj
+2GU4Kzg1USEODm8uNBNA4StnDG1KQTAYI1oyVZnJF+A83vbsea0rWBmirSwiGpWO
+vpaQXUJXxPkUAzUrHC1RVwinOt4/5Mi0A3PCwSaAuwtCH60NryZy2sy+s6ODWA2C
+xR9GUeOcGMyNm43sSet1UNWMKFnKdDTajAshqx7qG+XH/RU+wBeq+yNuJkbL+vmx
+cmtpzyKEC2IPrNkZAJSidjzULZrtBJ4tBmIQN1IchXIbJ+XMxjHsN+xjWZsLHXbM
+fjKaiJUINlK73nZfdklJrX+9ZSCyycErdhh2n1ax
+-----END CERTIFICATE-----
+
+# Issuer: CN=Certigna Root CA O=Dhimyotis OU=0002 48146308100036
+# Subject: CN=Certigna Root CA O=Dhimyotis OU=0002 48146308100036
+# Label: "Certigna Root CA"
+# Serial: 269714418870597844693661054334862075617
+# MD5 Fingerprint: 0e:5c:30:62:27:eb:5b:bc:d7:ae:62:ba:e9:d5:df:77
+# SHA1 Fingerprint: 2d:0d:52:14:ff:9e:ad:99:24:01:74:20:47:6e:6c:85:27:27:f5:43
+# SHA256 Fingerprint: d4:8d:3d:23:ee:db:50:a4:59:e5:51:97:60:1c:27:77:4b:9d:7b:18:c9:4d:5a:05:95:11:a1:02:50:b9:31:68
+-----BEGIN CERTIFICATE-----
+MIIGWzCCBEOgAwIBAgIRAMrpG4nxVQMNo+ZBbcTjpuEwDQYJKoZIhvcNAQELBQAw
+WjELMAkGA1UEBhMCRlIxEjAQBgNVBAoMCURoaW15b3RpczEcMBoGA1UECwwTMDAw
+MiA0ODE0NjMwODEwMDAzNjEZMBcGA1UEAwwQQ2VydGlnbmEgUm9vdCBDQTAeFw0x
+MzEwMDEwODMyMjdaFw0zMzEwMDEwODMyMjdaMFoxCzAJBgNVBAYTAkZSMRIwEAYD
+VQQKDAlEaGlteW90aXMxHDAaBgNVBAsMEzAwMDIgNDgxNDYzMDgxMDAwMzYxGTAX
+BgNVBAMMEENlcnRpZ25hIFJvb3QgQ0EwggIiMA0GCSqGSIb3DQEBAQUAA4ICDwAw
+ggIKAoICAQDNGDllGlmx6mQWDoyUJJV8g9PFOSbcDO8WV43X2KyjQn+Cyu3NW9sO
+ty3tRQgXstmzy9YXUnIo245Onoq2C/mehJpNdt4iKVzSs9IGPjA5qXSjklYcoW9M
+CiBtnyN6tMbaLOQdLNyzKNAT8kxOAkmhVECe5uUFoC2EyP+YbNDrihqECB63aCPu
+I9Vwzm1RaRDuoXrC0SIxwoKF0vJVdlB8JXrJhFwLrN1CTivngqIkicuQstDuI7pm
+TLtipPlTWmR7fJj6o0ieD5Wupxj0auwuA0Wv8HT4Ks16XdG+RCYyKfHx9WzMfgIh
+C59vpD++nVPiz32pLHxYGpfhPTc3GGYo0kDFUYqMwy3OU4gkWGQwFsWq4NYKpkDf
+ePb1BHxpE4S80dGnBs8B92jAqFe7OmGtBIyT46388NtEbVncSVmurJqZNjBBe3Yz
+IoejwpKGbvlw7q6Hh5UbxHq9MfPU0uWZ/75I7HX1eBYdpnDBfzwboZL7z8g81sWT
+Co/1VTp2lc5ZmIoJlXcymoO6LAQ6l73UL77XbJuiyn1tJslV1c/DeVIICZkHJC1k
+JWumIWmbat10TWuXekG9qxf5kBdIjzb5LdXF2+6qhUVB+s06RbFo5jZMm5BX7CO5
+hwjCxAnxl4YqKE3idMDaxIzb3+KhF1nOJFl0Mdp//TBt2dzhauH8XwIDAQABo4IB
+GjCCARYwDwYDVR0TAQH/BAUwAwEB/zAOBgNVHQ8BAf8EBAMCAQYwHQYDVR0OBBYE
+FBiHVuBud+4kNTxOc5of1uHieX4rMB8GA1UdIwQYMBaAFBiHVuBud+4kNTxOc5of
+1uHieX4rMEQGA1UdIAQ9MDswOQYEVR0gADAxMC8GCCsGAQUFBwIBFiNodHRwczov
+L3d3d3cuY2VydGlnbmEuZnIvYXV0b3JpdGVzLzBtBgNVHR8EZjBkMC+gLaArhilo
+dHRwOi8vY3JsLmNlcnRpZ25hLmZyL2NlcnRpZ25hcm9vdGNhLmNybDAxoC+gLYYr
+aHR0cDovL2NybC5kaGlteW90aXMuY29tL2NlcnRpZ25hcm9vdGNhLmNybDANBgkq
+hkiG9w0BAQsFAAOCAgEAlLieT/DjlQgi581oQfccVdV8AOItOoldaDgvUSILSo3L
+6btdPrtcPbEo/uRTVRPPoZAbAh1fZkYJMyjhDSSXcNMQH+pkV5a7XdrnxIxPTGRG
+HVyH41neQtGbqH6mid2PHMkwgu07nM3A6RngatgCdTer9zQoKJHyBApPNeNgJgH6
+0BGM+RFq7q89w1DTj18zeTyGqHNFkIwgtnJzFyO+B2XleJINugHA64wcZr+shncB
+lA2c5uk5jR+mUYyZDDl34bSb+hxnV29qao6pK0xXeXpXIs/NX2NGjVxZOob4Mkdi
+o2cNGJHc+6Zr9UhhcyNZjgKnvETq9Emd8VRY+WCv2hikLyhF3HqgiIZd8zvn/yk1
+gPxkQ5Tm4xxvvq0OKmOZK8l+hfZx6AYDlf7ej0gcWtSS6Cvu5zHbugRqh5jnxV/v
+faci9wHYTfmJ0A6aBVmknpjZbyvKcL5kwlWj9Omvw5Ip3IgWJJk8jSaYtlu3zM63
+Nwf9JtmYhST/WSMDmu2dnajkXjjO11INb9I/bbEFa0nOipFGc/T2L/Coc3cOZayh
+jWZSaX5LaAzHHjcng6WMxwLkFM1JAbBzs/3GkDpv0mztO+7skb6iQ12LAEpmJURw
+3kAP+HwV96LOPNdeE4yBFxgX0b3xdxA61GU5wSesVywlVP+i2k+KYTlerj1KjL0=
+-----END CERTIFICATE-----
+
+# Issuer: CN=emSign Root CA - G1 O=eMudhra Technologies Limited OU=emSign PKI
+# Subject: CN=emSign Root CA - G1 O=eMudhra Technologies Limited OU=emSign PKI
+# Label: "emSign Root CA - G1"
+# Serial: 235931866688319308814040
+# MD5 Fingerprint: 9c:42:84:57:dd:cb:0b:a7:2e:95:ad:b6:f3:da:bc:ac
+# SHA1 Fingerprint: 8a:c7:ad:8f:73:ac:4e:c1:b5:75:4d:a5:40:f4:fc:cf:7c:b5:8e:8c
+# SHA256 Fingerprint: 40:f6:af:03:46:a9:9a:a1:cd:1d:55:5a:4e:9c:ce:62:c7:f9:63:46:03:ee:40:66:15:83:3d:c8:c8:d0:03:67
+-----BEGIN CERTIFICATE-----
+MIIDlDCCAnygAwIBAgIKMfXkYgxsWO3W2DANBgkqhkiG9w0BAQsFADBnMQswCQYD
+VQQGEwJJTjETMBEGA1UECxMKZW1TaWduIFBLSTElMCMGA1UEChMcZU11ZGhyYSBU
+ZWNobm9sb2dpZXMgTGltaXRlZDEcMBoGA1UEAxMTZW1TaWduIFJvb3QgQ0EgLSBH
+MTAeFw0xODAyMTgxODMwMDBaFw00MzAyMTgxODMwMDBaMGcxCzAJBgNVBAYTAklO
+MRMwEQYDVQQLEwplbVNpZ24gUEtJMSUwIwYDVQQKExxlTXVkaHJhIFRlY2hub2xv
+Z2llcyBMaW1pdGVkMRwwGgYDVQQDExNlbVNpZ24gUm9vdCBDQSAtIEcxMIIBIjAN
+BgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAk0u76WaK7p1b1TST0Bsew+eeuGQz
+f2N4aLTNLnF115sgxk0pvLZoYIr3IZpWNVrzdr3YzZr/k1ZLpVkGoZM0Kd0WNHVO
+8oG0x5ZOrRkVUkr+PHB1cM2vK6sVmjM8qrOLqs1D/fXqcP/tzxE7lM5OMhbTI0Aq
+d7OvPAEsbO2ZLIvZTmmYsvePQbAyeGHWDV/D+qJAkh1cF+ZwPjXnorfCYuKrpDhM
+tTk1b+oDafo6VGiFbdbyL0NVHpENDtjVaqSW0RM8LHhQ6DqS0hdW5TUaQBw+jSzt
+Od9C4INBdN+jzcKGYEho42kLVACL5HZpIQ15TjQIXhTCzLG3rdd8cIrHhQIDAQAB
+o0IwQDAdBgNVHQ4EFgQU++8Nhp6w492pufEhF38+/PB3KxowDgYDVR0PAQH/BAQD
+AgEGMA8GA1UdEwEB/wQFMAMBAf8wDQYJKoZIhvcNAQELBQADggEBAFn/8oz1h31x
+PaOfG1vR2vjTnGs2vZupYeveFix0PZ7mddrXuqe8QhfnPZHr5X3dPpzxz5KsbEjM
+wiI/aTvFthUvozXGaCocV685743QNcMYDHsAVhzNixl03r4PEuDQqqE/AjSxcM6d
+GNYIAwlG7mDgfrbESQRRfXBgvKqy/3lyeqYdPV8q+Mri/Tm3R7nrft8EI6/6nAYH
+6ftjk4BAtcZsCjEozgyfz7MjNYBBjWzEN3uBL4ChQEKF6dk4jeihU80Bv2noWgby
+RQuQ+q7hv53yrlc8pa6yVvSLZUDp/TGBLPQ5Cdjua6e0ph0VpZj3AYHYhX3zUVxx
+iN66zB+Afko=
+-----END CERTIFICATE-----
+
+# Issuer: CN=emSign ECC Root CA - G3 O=eMudhra Technologies Limited OU=emSign PKI
+# Subject: CN=emSign ECC Root CA - G3 O=eMudhra Technologies Limited OU=emSign PKI
+# Label: "emSign ECC Root CA - G3"
+# Serial: 287880440101571086945156
+# MD5 Fingerprint: ce:0b:72:d1:9f:88:8e:d0:50:03:e8:e3:b8:8b:67:40
+# SHA1 Fingerprint: 30:43:fa:4f:f2:57:dc:a0:c3:80:ee:2e:58:ea:78:b2:3f:e6:bb:c1
+# SHA256 Fingerprint: 86:a1:ec:ba:08:9c:4a:8d:3b:be:27:34:c6:12:ba:34:1d:81:3e:04:3c:f9:e8:a8:62:cd:5c:57:a3:6b:be:6b
+-----BEGIN CERTIFICATE-----
+MIICTjCCAdOgAwIBAgIKPPYHqWhwDtqLhDAKBggqhkjOPQQDAzBrMQswCQYDVQQG
+EwJJTjETMBEGA1UECxMKZW1TaWduIFBLSTElMCMGA1UEChMcZU11ZGhyYSBUZWNo
+bm9sb2dpZXMgTGltaXRlZDEgMB4GA1UEAxMXZW1TaWduIEVDQyBSb290IENBIC0g
+RzMwHhcNMTgwMjE4MTgzMDAwWhcNNDMwMjE4MTgzMDAwWjBrMQswCQYDVQQGEwJJ
+TjETMBEGA1UECxMKZW1TaWduIFBLSTElMCMGA1UEChMcZU11ZGhyYSBUZWNobm9s
+b2dpZXMgTGltaXRlZDEgMB4GA1UEAxMXZW1TaWduIEVDQyBSb290IENBIC0gRzMw
+djAQBgcqhkjOPQIBBgUrgQQAIgNiAAQjpQy4LRL1KPOxst3iAhKAnjlfSU2fySU0
+WXTsuwYc58Byr+iuL+FBVIcUqEqy6HyC5ltqtdyzdc6LBtCGI79G1Y4PPwT01xyS
+fvalY8L1X44uT6EYGQIrMgqCZH0Wk9GjQjBAMB0GA1UdDgQWBBR8XQKEE9TMipuB
+zhccLikenEhjQjAOBgNVHQ8BAf8EBAMCAQYwDwYDVR0TAQH/BAUwAwEB/zAKBggq
+hkjOPQQDAwNpADBmAjEAvvNhzwIQHWSVB7gYboiFBS+DCBeQyh+KTOgNG3qxrdWB
+CUfvO6wIBHxcmbHtRwfSAjEAnbpV/KlK6O3t5nYBQnvI+GDZjVGLVTv7jHvrZQnD
++JbNR6iC8hZVdyR+EhCVBCyj
+-----END CERTIFICATE-----
+
+# Issuer: CN=emSign Root CA - C1 O=eMudhra Inc OU=emSign PKI
+# Subject: CN=emSign Root CA - C1 O=eMudhra Inc OU=emSign PKI
+# Label: "emSign Root CA - C1"
+# Serial: 825510296613316004955058
+# MD5 Fingerprint: d8:e3:5d:01:21:fa:78:5a:b0:df:ba:d2:ee:2a:5f:68
+# SHA1 Fingerprint: e7:2e:f1:df:fc:b2:09:28:cf:5d:d4:d5:67:37:b1:51:cb:86:4f:01
+# SHA256 Fingerprint: 12:56:09:aa:30:1d:a0:a2:49:b9:7a:82:39:cb:6a:34:21:6f:44:dc:ac:9f:39:54:b1:42:92:f2:e8:c8:60:8f
+-----BEGIN CERTIFICATE-----
+MIIDczCCAlugAwIBAgILAK7PALrEzzL4Q7IwDQYJKoZIhvcNAQELBQAwVjELMAkG
+A1UEBhMCVVMxEzARBgNVBAsTCmVtU2lnbiBQS0kxFDASBgNVBAoTC2VNdWRocmEg
+SW5jMRwwGgYDVQQDExNlbVNpZ24gUm9vdCBDQSAtIEMxMB4XDTE4MDIxODE4MzAw
+MFoXDTQzMDIxODE4MzAwMFowVjELMAkGA1UEBhMCVVMxEzARBgNVBAsTCmVtU2ln
+biBQS0kxFDASBgNVBAoTC2VNdWRocmEgSW5jMRwwGgYDVQQDExNlbVNpZ24gUm9v
+dCBDQSAtIEMxMIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAz+upufGZ
+BczYKCFK83M0UYRWEPWgTywS4/oTmifQz/l5GnRfHXk5/Fv4cI7gklL35CX5VIPZ
+HdPIWoU/Xse2B+4+wM6ar6xWQio5JXDWv7V7Nq2s9nPczdcdioOl+yuQFTdrHCZH
+3DspVpNqs8FqOp099cGXOFgFixwR4+S0uF2FHYP+eF8LRWgYSKVGczQ7/g/IdrvH
+GPMF0Ybzhe3nudkyrVWIzqa2kbBPrH4VI5b2P/AgNBbeCsbEBEV5f6f9vtKppa+c
+xSMq9zwhbL2vj07FOrLzNBL834AaSaTUqZX3noleoomslMuoaJuvimUnzYnu3Yy1
+aylwQ6BpC+S5DwIDAQABo0IwQDAdBgNVHQ4EFgQU/qHgcB4qAzlSWkK+XJGFehiq
+TbUwDgYDVR0PAQH/BAQDAgEGMA8GA1UdEwEB/wQFMAMBAf8wDQYJKoZIhvcNAQEL
+BQADggEBAMJKVvoVIXsoounlHfv4LcQ5lkFMOycsxGwYFYDGrK9HWS8mC+M2sO87
+/kOXSTKZEhVb3xEp/6tT+LvBeA+snFOvV71ojD1pM/CjoCNjO2RnIkSt1XHLVip4
+kqNPEjE2NuLe/gDEo2APJ62gsIq1NnpSob0n9CAnYuhNlCQT5AoE6TyrLshDCUrG
+YQTlSTR+08TI9Q/Aqum6VF7zYytPT1DU/rl7mYw9wC68AivTxEDkigcxHpvOJpkT
++xHqmiIMERnHXhuBUDDIlhJu58tBf5E7oke3VIAb3ADMmpDqw8NQBmIMMMAVSKeo
+WXzhriKi4gp6D/piq1JM4fHfyr6DDUI=
+-----END CERTIFICATE-----
+
+# Issuer: CN=emSign ECC Root CA - C3 O=eMudhra Inc OU=emSign PKI
+# Subject: CN=emSign ECC Root CA - C3 O=eMudhra Inc OU=emSign PKI
+# Label: "emSign ECC Root CA - C3"
+# Serial: 582948710642506000014504
+# MD5 Fingerprint: 3e:53:b3:a3:81:ee:d7:10:f8:d3:b0:1d:17:92:f5:d5
+# SHA1 Fingerprint: b6:af:43:c2:9b:81:53:7d:f6:ef:6b:c3:1f:1f:60:15:0c:ee:48:66
+# SHA256 Fingerprint: bc:4d:80:9b:15:18:9d:78:db:3e:1d:8c:f4:f9:72:6a:79:5d:a1:64:3c:a5:f1:35:8e:1d:db:0e:dc:0d:7e:b3
+-----BEGIN CERTIFICATE-----
+MIICKzCCAbGgAwIBAgIKe3G2gla4EnycqDAKBggqhkjOPQQDAzBaMQswCQYDVQQG
+EwJVUzETMBEGA1UECxMKZW1TaWduIFBLSTEUMBIGA1UEChMLZU11ZGhyYSBJbmMx
+IDAeBgNVBAMTF2VtU2lnbiBFQ0MgUm9vdCBDQSAtIEMzMB4XDTE4MDIxODE4MzAw
+MFoXDTQzMDIxODE4MzAwMFowWjELMAkGA1UEBhMCVVMxEzARBgNVBAsTCmVtU2ln
+biBQS0kxFDASBgNVBAoTC2VNdWRocmEgSW5jMSAwHgYDVQQDExdlbVNpZ24gRUND
+IFJvb3QgQ0EgLSBDMzB2MBAGByqGSM49AgEGBSuBBAAiA2IABP2lYa57JhAd6bci
+MK4G9IGzsUJxlTm801Ljr6/58pc1kjZGDoeVjbk5Wum739D+yAdBPLtVb4Ojavti
+sIGJAnB9SMVK4+kiVCJNk7tCDK93nCOmfddhEc5lx/h//vXyqaNCMEAwHQYDVR0O
+BBYEFPtaSNCAIEDyqOkAB2kZd6fmw/TPMA4GA1UdDwEB/wQEAwIBBjAPBgNVHRMB
+Af8EBTADAQH/MAoGCCqGSM49BAMDA2gAMGUCMQC02C8Cif22TGK6Q04ThHK1rt0c
+3ta13FaPWEBaLd4gTCKDypOofu4SQMfWh0/434UCMBwUZOR8loMRnLDRWmFLpg9J
+0wD8ofzkpf9/rdcw0Md3f76BB1UwUCAU9Vc4CqgxUQ==
+-----END CERTIFICATE-----
+
+# Issuer: CN=Hongkong Post Root CA 3 O=Hongkong Post
+# Subject: CN=Hongkong Post Root CA 3 O=Hongkong Post
+# Label: "Hongkong Post Root CA 3"
+# Serial: 46170865288971385588281144162979347873371282084
+# MD5 Fingerprint: 11:fc:9f:bd:73:30:02:8a:fd:3f:f3:58:b9:cb:20:f0
+# SHA1 Fingerprint: 58:a2:d0:ec:20:52:81:5b:c1:f3:f8:64:02:24:4e:c2:8e:02:4b:02
+# SHA256 Fingerprint: 5a:2f:c0:3f:0c:83:b0:90:bb:fa:40:60:4b:09:88:44:6c:76:36:18:3d:f9:84:6e:17:10:1a:44:7f:b8:ef:d6
+-----BEGIN CERTIFICATE-----
+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
+mpv0
+-----END CERTIFICATE-----
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/certifi/core.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/certifi/core.py
new file mode 100644
index 0000000..7271acf
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/certifi/core.py
@@ -0,0 +1,15 @@
+# -*- coding: utf-8 -*-
+
+"""
+certifi.py
+~~~~~~~~~~
+
+This module returns the installation location of cacert.pem.
+"""
+import os
+
+
+def where():
+    f = os.path.dirname(__file__)
+
+    return os.path.join(f, 'cacert.pem')
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/certifi/core.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/certifi/core.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..e660751a74bed784d0f00c99f0b477d62c29bef1
GIT binary patch
literal 633
zcmZSn%**AGdLky70ScHH7#JKF7#ND>85kH+7#N}$7*ZG+QkWQW7#X4%8B&-TS{N9j
zm_Q=I8Z01%p$rTRT*;|LC7EfNdIgnSb#TDN6_SxztdN_ZQks*hP?TCyT9j9;P?C|V
zkeOFpl9-c|Sdy8ar;wAM3}NJ_DI_O?Owubz&DG<|{Qv*|e?PFx7#SECm>C!toIw_<
zGB7ZdFfe2>GGs9^lrS?iGcwe|MOYYWz%FiPVhGj%dB(4pi-CawVXg)%NIOU-zqkbC
zfr7-6j1qQ`Z!?SX5_3~aI2afh;^WgYb5i5u!78%yGxIb+PACBpX&RuQ0u#mA3=9nV
z1x1-<i6yD}Wr;=lY56%RsYS*5Nh$i}NlAIRrn$vNhDqk>Rp}O{7UelvRb~btke;U>
zqF<0%pbHHMUAHn1PvZcP5E#dorRJsN7wLlnBQq^iKRLfBRj;731myPejMSo39#BAl
zT+hHL#H0ZV8n74Q<5TjJ<Ku%sE(~I0U|;|{6G713!Jx3T$pt3>I}p1V<YqQT9%cY;
C=b;4v

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/__init__.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/__init__.py
new file mode 100644
index 0000000..0f9f820
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/__init__.py
@@ -0,0 +1,39 @@
+######################## BEGIN LICENSE BLOCK ########################
+# This library is free software; you can redistribute it and/or
+# modify it under the terms of the GNU Lesser General Public
+# License as published by the Free Software Foundation; either
+# version 2.1 of the License, or (at your option) any later version.
+#
+# This library is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+# Lesser General Public License for more details.
+#
+# You should have received a copy of the GNU Lesser General Public
+# License along with this library; if not, write to the Free Software
+# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
+# 02110-1301  USA
+######################### END LICENSE BLOCK #########################
+
+
+from .compat import PY2, PY3
+from .universaldetector import UniversalDetector
+from .version import __version__, VERSION
+
+
+def detect(byte_str):
+    """
+    Detect the encoding of the given byte string.
+
+    :param byte_str:     The byte sequence to examine.
+    :type byte_str:      ``bytes`` or ``bytearray``
+    """
+    if not isinstance(byte_str, bytearray):
+        if not isinstance(byte_str, bytes):
+            raise TypeError('Expected object of type bytes or bytearray, got: '
+                            '{0}'.format(type(byte_str)))
+        else:
+            byte_str = bytearray(byte_str)
+    detector = UniversalDetector()
+    detector.feed(byte_str)
+    return detector.close()
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/__init__.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/__init__.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..4e87e40e5318a8affe3d373f8b891ecdd938de64
GIT binary patch
literal 1088
zcmZSn%**AGdLky70ScHH7#JKF7#NB@85kH+7#LC*8FCmHav2$-7#VVz7^0XM7(t>;
z3^~jUxhxD(ED%03Lk=rLE*nD>8$&KTLlip$V+spH3j;$G2SW-gL$C%L0|P@QBLf42
z2FQXEW(Ed^fJh@KZL9&3DG_8~U<l32EK4maPRwyhElEu-$uEMa=VoAFh>r)!Waj6^
z$Ct1(FffF<1_gWi`z3?)f(&J0U|?_txjdVJfuV$fp@xB>gpr|{iJ{mV#$^I?Z5T?J
zLH^2OVJKk*DQjkAfS@KuhC*+Ut{MiANG$_H9s@%O8$&Y#LoFji4I@JqJ5)U*h{FMr
z2nM^bcrgP51DAq=f&#?h3MCn-3aNR?`6-!s=?eL2V19aLS!$j_Qe{c1LUBn^W?s4;
z7g&o`L1Iy2E?6SIxTMGmWQ;;cMk-iDp*Xd$G&L_dRiPwbA+;hgH#09)52CH4vH+q6
zp-Ukl0c3u0LV`km5tNfyRFqhmkO0<GY{J06;960Tnp~2aqL81Im6}`vb{@>AVvs(N
z5nx?93hDVJRtnVywHlnDP~`$eV{v9)aY<rca%u@k46e3>m4Sf)#484ihg24%x)v4X
z7nOkGJ}ti}H?gDy6h|Oe2Z16C%u7p6O#$mn&dD!M1&3t`2h<>tx4@hfSYiMrQVkGM
zoX^0(pkGjwS(aFms$Z5^q@R|blag9gte=#kU!Ihdmus3^Y-E^Zo?ex1VQNvHlT~GA
z00QZG`XTxSnFYFFPvqq2x|Ml&8V7)cz&O4vH7_N<NIy9vu_z_AL_a=0GcU6wK3=b&
z66_I(QzSs?OaSB%c78^FMovaiCJ@QX=m!ZWke8G5a|;qnf<TIbKxq`5zDr^08)8m=
z5hNr)=^2{3gFtyB2oz93{Gj{-(hv4Bm>3X$gW|&`H$SB`C)G|E<a3bs#25t_#h3ws
CX$lhn

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/big5freq.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/big5freq.py
new file mode 100644
index 0000000..38f3251
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/big5freq.py
@@ -0,0 +1,386 @@
+######################## BEGIN LICENSE BLOCK ########################
+# The Original Code is Mozilla Communicator client code.
+#
+# The Initial Developer of the Original Code is
+# Netscape Communications Corporation.
+# Portions created by the Initial Developer are Copyright (C) 1998
+# the Initial Developer. All Rights Reserved.
+#
+# Contributor(s):
+#   Mark Pilgrim - port to Python
+#
+# This library is free software; you can redistribute it and/or
+# modify it under the terms of the GNU Lesser General Public
+# License as published by the Free Software Foundation; either
+# version 2.1 of the License, or (at your option) any later version.
+#
+# This library is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+# Lesser General Public License for more details.
+#
+# You should have received a copy of the GNU Lesser General Public
+# License along with this library; if not, write to the Free Software
+# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
+# 02110-1301  USA
+######################### END LICENSE BLOCK #########################
+
+# Big5 frequency table
+# by Taiwan's Mandarin Promotion Council
+# <http://www.edu.tw:81/mandr/>
+#
+# 128  --> 0.42261
+# 256  --> 0.57851
+# 512  --> 0.74851
+# 1024 --> 0.89384
+# 2048 --> 0.97583
+#
+# Ideal Distribution Ratio = 0.74851/(1-0.74851) =2.98
+# Random Distribution Ration = 512/(5401-512)=0.105
+#
+# Typical Distribution Ratio about 25% of Ideal one, still much higher than RDR
+
+BIG5_TYPICAL_DISTRIBUTION_RATIO = 0.75
+
+#Char to FreqOrder table
+BIG5_TABLE_SIZE = 5376
+
+BIG5_CHAR_TO_FREQ_ORDER = (
+   1,1801,1506, 255,1431, 198,   9,  82,   6,5008, 177, 202,3681,1256,2821, 110, #   16
+3814,  33,3274, 261,  76,  44,2114,  16,2946,2187,1176, 659,3971,  26,3451,2653, #   32
+1198,3972,3350,4202, 410,2215, 302, 590, 361,1964,   8, 204,  58,4510,5009,1932, #   48
+  63,5010,5011, 317,1614,  75, 222, 159,4203,2417,1480,5012,3555,3091, 224,2822, #   64
+3682,   3,  10,3973,1471,  29,2787,1135,2866,1940, 873, 130,3275,1123, 312,5013, #   80
+4511,2052, 507, 252, 682,5014, 142,1915, 124, 206,2947,  34,3556,3204,  64, 604, #   96
+5015,2501,1977,1978, 155,1991, 645, 641,1606,5016,3452, 337,  72, 406,5017,  80, #  112
+ 630, 238,3205,1509, 263, 939,1092,2654, 756,1440,1094,3453, 449,  69,2987, 591, #  128
+ 179,2096, 471, 115,2035,1844,  60,  50,2988, 134, 806,1869, 734,2036,3454, 180, #  144
+ 995,1607, 156, 537,2907, 688,5018, 319,1305, 779,2145, 514,2379, 298,4512, 359, #  160
+2502,  90,2716,1338, 663,  11, 906,1099,2553,  20,2441, 182, 532,1716,5019, 732, #  176
+1376,4204,1311,1420,3206,  25,2317,1056, 113, 399, 382,1950, 242,3455,2474, 529, #  192
+3276, 475,1447,3683,5020, 117,  21, 656, 810,1297,2300,2334,3557,5021, 126,4205, #  208
+ 706, 456, 150, 613,4513,  71,1118,2037,4206, 145,3092,  85, 835, 486,2115,1246, #  224
+1426, 428, 727,1285,1015, 800, 106, 623, 303,1281,5022,2128,2359, 347,3815, 221, #  240
+3558,3135,5023,1956,1153,4207,  83, 296,1199,3093, 192, 624,  93,5024, 822,1898, #  256
+2823,3136, 795,2065, 991,1554,1542,1592,  27,  43,2867, 859, 139,1456, 860,4514, #  272
+ 437, 712,3974, 164,2397,3137, 695, 211,3037,2097, 195,3975,1608,3559,3560,3684, #  288
+3976, 234, 811,2989,2098,3977,2233,1441,3561,1615,2380, 668,2077,1638, 305, 228, #  304
+1664,4515, 467, 415,5025, 262,2099,1593, 239, 108, 300, 200,1033, 512,1247,2078, #  320
+5026,5027,2176,3207,3685,2682, 593, 845,1062,3277,  88,1723,2038,3978,1951, 212, #  336
+ 266, 152, 149, 468,1899,4208,4516,  77, 187,5028,3038,  37,   5,2990,5029,3979, #  352
+5030,5031,  39,2524,4517,2908,3208,2079,  55, 148,  74,4518, 545, 483,1474,1029, #  368
+1665, 217,1870,1531,3138,1104,2655,4209,  24, 172,3562, 900,3980,3563,3564,4519, #  384
+  32,1408,2824,1312, 329, 487,2360,2251,2717, 784,2683,   4,3039,3351,1427,1789, #  400
+ 188, 109, 499,5032,3686,1717,1790, 888,1217,3040,4520,5033,3565,5034,3352,1520, #  416
+3687,3981, 196,1034, 775,5035,5036, 929,1816, 249, 439,  38,5037,1063,5038, 794, #  432
+3982,1435,2301,  46, 178,3278,2066,5039,2381,5040, 214,1709,4521, 804,  35, 707, #  448
+ 324,3688,1601,2554, 140, 459,4210,5041,5042,1365, 839, 272, 978,2262,2580,3456, #  464
+2129,1363,3689,1423, 697, 100,3094,  48,  70,1231, 495,3139,2196,5043,1294,5044, #  480
+2080, 462, 586,1042,3279, 853, 256, 988, 185,2382,3457,1698, 434,1084,5045,3458, #  496
+ 314,2625,2788,4522,2335,2336, 569,2285, 637,1817,2525, 757,1162,1879,1616,3459, #  512
+ 287,1577,2116, 768,4523,1671,2868,3566,2526,1321,3816, 909,2418,5046,4211, 933, #  528
+3817,4212,2053,2361,1222,4524, 765,2419,1322, 786,4525,5047,1920,1462,1677,2909, #  544
+1699,5048,4526,1424,2442,3140,3690,2600,3353,1775,1941,3460,3983,4213, 309,1369, #  560
+1130,2825, 364,2234,1653,1299,3984,3567,3985,3986,2656, 525,1085,3041, 902,2001, #  576
+1475, 964,4527, 421,1845,1415,1057,2286, 940,1364,3141, 376,4528,4529,1381,   7, #  592
+2527, 983,2383, 336,1710,2684,1846, 321,3461, 559,1131,3042,2752,1809,1132,1313, #  608
+ 265,1481,1858,5049, 352,1203,2826,3280, 167,1089, 420,2827, 776, 792,1724,3568, #  624
+4214,2443,3281,5050,4215,5051, 446, 229, 333,2753, 901,3818,1200,1557,4530,2657, #  640
+1921, 395,2754,2685,3819,4216,1836, 125, 916,3209,2626,4531,5052,5053,3820,5054, #  656
+5055,5056,4532,3142,3691,1133,2555,1757,3462,1510,2318,1409,3569,5057,2146, 438, #  672
+2601,2910,2384,3354,1068, 958,3043, 461, 311,2869,2686,4217,1916,3210,4218,1979, #  688
+ 383, 750,2755,2627,4219, 274, 539, 385,1278,1442,5058,1154,1965, 384, 561, 210, #  704
+  98,1295,2556,3570,5059,1711,2420,1482,3463,3987,2911,1257, 129,5060,3821, 642, #  720
+ 523,2789,2790,2658,5061, 141,2235,1333,  68, 176, 441, 876, 907,4220, 603,2602, #  736
+ 710, 171,3464, 404, 549,  18,3143,2398,1410,3692,1666,5062,3571,4533,2912,4534, #  752
+5063,2991, 368,5064, 146, 366,  99, 871,3693,1543, 748, 807,1586,1185,  22,2263, #  768
+ 379,3822,3211,5065,3212, 505,1942,2628,1992,1382,2319,5066, 380,2362, 218, 702, #  784
+1818,1248,3465,3044,3572,3355,3282,5067,2992,3694, 930,3283,3823,5068,  59,5069, #  800
+ 585, 601,4221, 497,3466,1112,1314,4535,1802,5070,1223,1472,2177,5071, 749,1837, #  816
+ 690,1900,3824,1773,3988,1476, 429,1043,1791,2236,2117, 917,4222, 447,1086,1629, #  832
+5072, 556,5073,5074,2021,1654, 844,1090, 105, 550, 966,1758,2828,1008,1783, 686, #  848
+1095,5075,2287, 793,1602,5076,3573,2603,4536,4223,2948,2302,4537,3825, 980,2503, #  864
+ 544, 353, 527,4538, 908,2687,2913,5077, 381,2629,1943,1348,5078,1341,1252, 560, #  880
+3095,5079,3467,2870,5080,2054, 973, 886,2081, 143,4539,5081,5082, 157,3989, 496, #  896
+4224,  57, 840, 540,2039,4540,4541,3468,2118,1445, 970,2264,1748,1966,2082,4225, #  912
+3144,1234,1776,3284,2829,3695, 773,1206,2130,1066,2040,1326,3990,1738,1725,4226, #  928
+ 279,3145,  51,1544,2604, 423,1578,2131,2067, 173,4542,1880,5083,5084,1583, 264, #  944
+ 610,3696,4543,2444, 280, 154,5085,5086,5087,1739, 338,1282,3096, 693,2871,1411, #  960
+1074,3826,2445,5088,4544,5089,5090,1240, 952,2399,5091,2914,1538,2688, 685,1483, #  976
+4227,2475,1436, 953,4228,2055,4545, 671,2400,  79,4229,2446,3285, 608, 567,2689, #  992
+3469,4230,4231,1691, 393,1261,1792,2401,5092,4546,5093,5094,5095,5096,1383,1672, # 1008
+3827,3213,1464, 522,1119, 661,1150, 216, 675,4547,3991,1432,3574, 609,4548,2690, # 1024
+2402,5097,5098,5099,4232,3045,   0,5100,2476, 315, 231,2447, 301,3356,4549,2385, # 1040
+5101, 233,4233,3697,1819,4550,4551,5102,  96,1777,1315,2083,5103, 257,5104,1810, # 1056
+3698,2718,1139,1820,4234,2022,1124,2164,2791,1778,2659,5105,3097, 363,1655,3214, # 1072
+5106,2993,5107,5108,5109,3992,1567,3993, 718, 103,3215, 849,1443, 341,3357,2949, # 1088
+1484,5110,1712, 127,  67, 339,4235,2403, 679,1412, 821,5111,5112, 834, 738, 351, # 1104
+2994,2147, 846, 235,1497,1881, 418,1993,3828,2719, 186,1100,2148,2756,3575,1545, # 1120
+1355,2950,2872,1377, 583,3994,4236,2581,2995,5113,1298,3699,1078,2557,3700,2363, # 1136
+  78,3829,3830, 267,1289,2100,2002,1594,4237, 348, 369,1274,2197,2178,1838,4552, # 1152
+1821,2830,3701,2757,2288,2003,4553,2951,2758, 144,3358, 882,4554,3995,2759,3470, # 1168
+4555,2915,5114,4238,1726, 320,5115,3996,3046, 788,2996,5116,2831,1774,1327,2873, # 1184
+3997,2832,5117,1306,4556,2004,1700,3831,3576,2364,2660, 787,2023, 506, 824,3702, # 1200
+ 534, 323,4557,1044,3359,2024,1901, 946,3471,5118,1779,1500,1678,5119,1882,4558, # 1216
+ 165, 243,4559,3703,2528, 123, 683,4239, 764,4560,  36,3998,1793, 589,2916, 816, # 1232
+ 626,1667,3047,2237,1639,1555,1622,3832,3999,5120,4000,2874,1370,1228,1933, 891, # 1248
+2084,2917, 304,4240,5121, 292,2997,2720,3577, 691,2101,4241,1115,4561, 118, 662, # 1264
+5122, 611,1156, 854,2386,1316,2875,   2, 386, 515,2918,5123,5124,3286, 868,2238, # 1280
+1486, 855,2661, 785,2216,3048,5125,1040,3216,3578,5126,3146, 448,5127,1525,5128, # 1296
+2165,4562,5129,3833,5130,4242,2833,3579,3147, 503, 818,4001,3148,1568, 814, 676, # 1312
+1444, 306,1749,5131,3834,1416,1030, 197,1428, 805,2834,1501,4563,5132,5133,5134, # 1328
+1994,5135,4564,5136,5137,2198,  13,2792,3704,2998,3149,1229,1917,5138,3835,2132, # 1344
+5139,4243,4565,2404,3580,5140,2217,1511,1727,1120,5141,5142, 646,3836,2448, 307, # 1360
+5143,5144,1595,3217,5145,5146,5147,3705,1113,1356,4002,1465,2529,2530,5148, 519, # 1376
+5149, 128,2133,  92,2289,1980,5150,4003,1512, 342,3150,2199,5151,2793,2218,1981, # 1392
+3360,4244, 290,1656,1317, 789, 827,2365,5152,3837,4566, 562, 581,4004,5153, 401, # 1408
+4567,2252,  94,4568,5154,1399,2794,5155,1463,2025,4569,3218,1944,5156, 828,1105, # 1424
+4245,1262,1394,5157,4246, 605,4570,5158,1784,2876,5159,2835, 819,2102, 578,2200, # 1440
+2952,5160,1502, 436,3287,4247,3288,2836,4005,2919,3472,3473,5161,2721,2320,5162, # 1456
+5163,2337,2068,  23,4571, 193, 826,3838,2103, 699,1630,4248,3098, 390,1794,1064, # 1472
+3581,5164,1579,3099,3100,1400,5165,4249,1839,1640,2877,5166,4572,4573, 137,4250, # 1488
+ 598,3101,1967, 780, 104, 974,2953,5167, 278, 899, 253, 402, 572, 504, 493,1339, # 1504
+5168,4006,1275,4574,2582,2558,5169,3706,3049,3102,2253, 565,1334,2722, 863,  41, # 1520
+5170,5171,4575,5172,1657,2338,  19, 463,2760,4251, 606,5173,2999,3289,1087,2085, # 1536
+1323,2662,3000,5174,1631,1623,1750,4252,2691,5175,2878, 791,2723,2663,2339, 232, # 1552
+2421,5176,3001,1498,5177,2664,2630, 755,1366,3707,3290,3151,2026,1609, 119,1918, # 1568
+3474, 862,1026,4253,5178,4007,3839,4576,4008,4577,2265,1952,2477,5179,1125, 817, # 1584
+4254,4255,4009,1513,1766,2041,1487,4256,3050,3291,2837,3840,3152,5180,5181,1507, # 1600
+5182,2692, 733,  40,1632,1106,2879, 345,4257, 841,2531, 230,4578,3002,1847,3292, # 1616
+3475,5183,1263, 986,3476,5184, 735, 879, 254,1137, 857, 622,1300,1180,1388,1562, # 1632
+4010,4011,2954, 967,2761,2665,1349, 592,2134,1692,3361,3003,1995,4258,1679,4012, # 1648
+1902,2188,5185, 739,3708,2724,1296,1290,5186,4259,2201,2202,1922,1563,2605,2559, # 1664
+1871,2762,3004,5187, 435,5188, 343,1108, 596,  17,1751,4579,2239,3477,3709,5189, # 1680
+4580, 294,3582,2955,1693, 477, 979, 281,2042,3583, 643,2043,3710,2631,2795,2266, # 1696
+1031,2340,2135,2303,3584,4581, 367,1249,2560,5190,3585,5191,4582,1283,3362,2005, # 1712
+ 240,1762,3363,4583,4584, 836,1069,3153, 474,5192,2149,2532, 268,3586,5193,3219, # 1728
+1521,1284,5194,1658,1546,4260,5195,3587,3588,5196,4261,3364,2693,1685,4262, 961, # 1744
+1673,2632, 190,2006,2203,3841,4585,4586,5197, 570,2504,3711,1490,5198,4587,2633, # 1760
+3293,1957,4588, 584,1514, 396,1045,1945,5199,4589,1968,2449,5200,5201,4590,4013, # 1776
+ 619,5202,3154,3294, 215,2007,2796,2561,3220,4591,3221,4592, 763,4263,3842,4593, # 1792
+5203,5204,1958,1767,2956,3365,3712,1174, 452,1477,4594,3366,3155,5205,2838,1253, # 1808
+2387,2189,1091,2290,4264, 492,5206, 638,1169,1825,2136,1752,4014, 648, 926,1021, # 1824
+1324,4595, 520,4596, 997, 847,1007, 892,4597,3843,2267,1872,3713,2405,1785,4598, # 1840
+1953,2957,3103,3222,1728,4265,2044,3714,4599,2008,1701,3156,1551,  30,2268,4266, # 1856
+5207,2027,4600,3589,5208, 501,5209,4267, 594,3478,2166,1822,3590,3479,3591,3223, # 1872
+ 829,2839,4268,5210,1680,3157,1225,4269,5211,3295,4601,4270,3158,2341,5212,4602, # 1888
+4271,5213,4015,4016,5214,1848,2388,2606,3367,5215,4603, 374,4017, 652,4272,4273, # 1904
+ 375,1140, 798,5216,5217,5218,2366,4604,2269, 546,1659, 138,3051,2450,4605,5219, # 1920
+2254, 612,1849, 910, 796,3844,1740,1371, 825,3845,3846,5220,2920,2562,5221, 692, # 1936
+ 444,3052,2634, 801,4606,4274,5222,1491, 244,1053,3053,4275,4276, 340,5223,4018, # 1952
+1041,3005, 293,1168,  87,1357,5224,1539, 959,5225,2240, 721, 694,4277,3847, 219, # 1968
+1478, 644,1417,3368,2666,1413,1401,1335,1389,4019,5226,5227,3006,2367,3159,1826, # 1984
+ 730,1515, 184,2840,  66,4607,5228,1660,2958, 246,3369, 378,1457, 226,3480, 975, # 2000
+4020,2959,1264,3592, 674, 696,5229, 163,5230,1141,2422,2167, 713,3593,3370,4608, # 2016
+4021,5231,5232,1186,  15,5233,1079,1070,5234,1522,3224,3594, 276,1050,2725, 758, # 2032
+1126, 653,2960,3296,5235,2342, 889,3595,4022,3104,3007, 903,1250,4609,4023,3481, # 2048
+3596,1342,1681,1718, 766,3297, 286,  89,2961,3715,5236,1713,5237,2607,3371,3008, # 2064
+5238,2962,2219,3225,2880,5239,4610,2505,2533, 181, 387,1075,4024, 731,2190,3372, # 2080
+5240,3298, 310, 313,3482,2304, 770,4278,  54,3054, 189,4611,3105,3848,4025,5241, # 2096
+1230,1617,1850, 355,3597,4279,4612,3373, 111,4280,3716,1350,3160,3483,3055,4281, # 2112
+2150,3299,3598,5242,2797,4026,4027,3009, 722,2009,5243,1071, 247,1207,2343,2478, # 2128
+1378,4613,2010, 864,1437,1214,4614, 373,3849,1142,2220, 667,4615, 442,2763,2563, # 2144
+3850,4028,1969,4282,3300,1840, 837, 170,1107, 934,1336,1883,5244,5245,2119,4283, # 2160
+2841, 743,1569,5246,4616,4284, 582,2389,1418,3484,5247,1803,5248, 357,1395,1729, # 2176
+3717,3301,2423,1564,2241,5249,3106,3851,1633,4617,1114,2086,4285,1532,5250, 482, # 2192
+2451,4618,5251,5252,1492, 833,1466,5253,2726,3599,1641,2842,5254,1526,1272,3718, # 2208
+4286,1686,1795, 416,2564,1903,1954,1804,5255,3852,2798,3853,1159,2321,5256,2881, # 2224
+4619,1610,1584,3056,2424,2764, 443,3302,1163,3161,5257,5258,4029,5259,4287,2506, # 2240
+3057,4620,4030,3162,2104,1647,3600,2011,1873,4288,5260,4289, 431,3485,5261, 250, # 2256
+  97,  81,4290,5262,1648,1851,1558, 160, 848,5263, 866, 740,1694,5264,2204,2843, # 2272
+3226,4291,4621,3719,1687, 950,2479, 426, 469,3227,3720,3721,4031,5265,5266,1188, # 2288
+ 424,1996, 861,3601,4292,3854,2205,2694, 168,1235,3602,4293,5267,2087,1674,4622, # 2304
+3374,3303, 220,2565,1009,5268,3855, 670,3010, 332,1208, 717,5269,5270,3603,2452, # 2320
+4032,3375,5271, 513,5272,1209,2882,3376,3163,4623,1080,5273,5274,5275,5276,2534, # 2336
+3722,3604, 815,1587,4033,4034,5277,3605,3486,3856,1254,4624,1328,3058,1390,4035, # 2352
+1741,4036,3857,4037,5278, 236,3858,2453,3304,5279,5280,3723,3859,1273,3860,4625, # 2368
+5281, 308,5282,4626, 245,4627,1852,2480,1307,2583, 430, 715,2137,2454,5283, 270, # 2384
+ 199,2883,4038,5284,3606,2727,1753, 761,1754, 725,1661,1841,4628,3487,3724,5285, # 2400
+5286, 587,  14,3305, 227,2608, 326, 480,2270, 943,2765,3607, 291, 650,1884,5287, # 2416
+1702,1226, 102,1547,  62,3488, 904,4629,3489,1164,4294,5288,5289,1224,1548,2766, # 2432
+ 391, 498,1493,5290,1386,1419,5291,2056,1177,4630, 813, 880,1081,2368, 566,1145, # 2448
+4631,2291,1001,1035,2566,2609,2242, 394,1286,5292,5293,2069,5294,  86,1494,1730, # 2464
+4039, 491,1588, 745, 897,2963, 843,3377,4040,2767,2884,3306,1768, 998,2221,2070, # 2480
+ 397,1827,1195,1970,3725,3011,3378, 284,5295,3861,2507,2138,2120,1904,5296,4041, # 2496
+2151,4042,4295,1036,3490,1905, 114,2567,4296, 209,1527,5297,5298,2964,2844,2635, # 2512
+2390,2728,3164, 812,2568,5299,3307,5300,1559, 737,1885,3726,1210, 885,  28,2695, # 2528
+3608,3862,5301,4297,1004,1780,4632,5302, 346,1982,2222,2696,4633,3863,1742, 797, # 2544
+1642,4043,1934,1072,1384,2152, 896,4044,3308,3727,3228,2885,3609,5303,2569,1959, # 2560
+4634,2455,1786,5304,5305,5306,4045,4298,1005,1308,3728,4299,2729,4635,4636,1528, # 2576
+2610, 161,1178,4300,1983, 987,4637,1101,4301, 631,4046,1157,3229,2425,1343,1241, # 2592
+1016,2243,2570, 372, 877,2344,2508,1160, 555,1935, 911,4047,5307, 466,1170, 169, # 2608
+1051,2921,2697,3729,2481,3012,1182,2012,2571,1251,2636,5308, 992,2345,3491,1540, # 2624
+2730,1201,2071,2406,1997,2482,5309,4638, 528,1923,2191,1503,1874,1570,2369,3379, # 2640
+3309,5310, 557,1073,5311,1828,3492,2088,2271,3165,3059,3107, 767,3108,2799,4639, # 2656
+1006,4302,4640,2346,1267,2179,3730,3230, 778,4048,3231,2731,1597,2667,5312,4641, # 2672
+5313,3493,5314,5315,5316,3310,2698,1433,3311, 131,  95,1504,4049, 723,4303,3166, # 2688
+1842,3610,2768,2192,4050,2028,2105,3731,5317,3013,4051,1218,5318,3380,3232,4052, # 2704
+4304,2584, 248,1634,3864, 912,5319,2845,3732,3060,3865, 654,  53,5320,3014,5321, # 2720
+1688,4642, 777,3494,1032,4053,1425,5322, 191, 820,2121,2846, 971,4643, 931,3233, # 2736
+ 135, 664, 783,3866,1998, 772,2922,1936,4054,3867,4644,2923,3234, 282,2732, 640, # 2752
+1372,3495,1127, 922, 325,3381,5323,5324, 711,2045,5325,5326,4055,2223,2800,1937, # 2768
+4056,3382,2224,2255,3868,2305,5327,4645,3869,1258,3312,4057,3235,2139,2965,4058, # 2784
+4059,5328,2225, 258,3236,4646, 101,1227,5329,3313,1755,5330,1391,3314,5331,2924, # 2800
+2057, 893,5332,5333,5334,1402,4305,2347,5335,5336,3237,3611,5337,5338, 878,1325, # 2816
+1781,2801,4647, 259,1385,2585, 744,1183,2272,4648,5339,4060,2509,5340, 684,1024, # 2832
+4306,5341, 472,3612,3496,1165,3315,4061,4062, 322,2153, 881, 455,1695,1152,1340, # 2848
+ 660, 554,2154,4649,1058,4650,4307, 830,1065,3383,4063,4651,1924,5342,1703,1919, # 2864
+5343, 932,2273, 122,5344,4652, 947, 677,5345,3870,2637, 297,1906,1925,2274,4653, # 2880
+2322,3316,5346,5347,4308,5348,4309,  84,4310, 112, 989,5349, 547,1059,4064, 701, # 2896
+3613,1019,5350,4311,5351,3497, 942, 639, 457,2306,2456, 993,2966, 407, 851, 494, # 2912
+4654,3384, 927,5352,1237,5353,2426,3385, 573,4312, 680, 921,2925,1279,1875, 285, # 2928
+ 790,1448,1984, 719,2168,5354,5355,4655,4065,4066,1649,5356,1541, 563,5357,1077, # 2944
+5358,3386,3061,3498, 511,3015,4067,4068,3733,4069,1268,2572,3387,3238,4656,4657, # 2960
+5359, 535,1048,1276,1189,2926,2029,3167,1438,1373,2847,2967,1134,2013,5360,4313, # 2976
+1238,2586,3109,1259,5361, 700,5362,2968,3168,3734,4314,5363,4315,1146,1876,1907, # 2992
+4658,2611,4070, 781,2427, 132,1589, 203, 147, 273,2802,2407, 898,1787,2155,4071, # 3008
+4072,5364,3871,2803,5365,5366,4659,4660,5367,3239,5368,1635,3872, 965,5369,1805, # 3024
+2699,1516,3614,1121,1082,1329,3317,4073,1449,3873,  65,1128,2848,2927,2769,1590, # 3040
+3874,5370,5371,  12,2668,  45, 976,2587,3169,4661, 517,2535,1013,1037,3240,5372, # 3056
+3875,2849,5373,3876,5374,3499,5375,2612, 614,1999,2323,3877,3110,2733,2638,5376, # 3072
+2588,4316, 599,1269,5377,1811,3735,5378,2700,3111, 759,1060, 489,1806,3388,3318, # 3088
+1358,5379,5380,2391,1387,1215,2639,2256, 490,5381,5382,4317,1759,2392,2348,5383, # 3104
+4662,3878,1908,4074,2640,1807,3241,4663,3500,3319,2770,2349, 874,5384,5385,3501, # 3120
+3736,1859,  91,2928,3737,3062,3879,4664,5386,3170,4075,2669,5387,3502,1202,1403, # 3136
+3880,2969,2536,1517,2510,4665,3503,2511,5388,4666,5389,2701,1886,1495,1731,4076, # 3152
+2370,4667,5390,2030,5391,5392,4077,2702,1216, 237,2589,4318,2324,4078,3881,4668, # 3168
+4669,2703,3615,3504, 445,4670,5393,5394,5395,5396,2771,  61,4079,3738,1823,4080, # 3184
+5397, 687,2046, 935, 925, 405,2670, 703,1096,1860,2734,4671,4081,1877,1367,2704, # 3200
+3389, 918,2106,1782,2483, 334,3320,1611,1093,4672, 564,3171,3505,3739,3390, 945, # 3216
+2641,2058,4673,5398,1926, 872,4319,5399,3506,2705,3112, 349,4320,3740,4082,4674, # 3232
+3882,4321,3741,2156,4083,4675,4676,4322,4677,2408,2047, 782,4084, 400, 251,4323, # 3248
+1624,5400,5401, 277,3742, 299,1265, 476,1191,3883,2122,4324,4325,1109, 205,5402, # 3264
+2590,1000,2157,3616,1861,5403,5404,5405,4678,5406,4679,2573, 107,2484,2158,4085, # 3280
+3507,3172,5407,1533, 541,1301, 158, 753,4326,2886,3617,5408,1696, 370,1088,4327, # 3296
+4680,3618, 579, 327, 440, 162,2244, 269,1938,1374,3508, 968,3063,  56,1396,3113, # 3312
+2107,3321,3391,5409,1927,2159,4681,3016,5410,3619,5411,5412,3743,4682,2485,5413, # 3328
+2804,5414,1650,4683,5415,2613,5416,5417,4086,2671,3392,1149,3393,4087,3884,4088, # 3344
+5418,1076,  49,5419, 951,3242,3322,3323, 450,2850, 920,5420,1812,2805,2371,4328, # 3360
+1909,1138,2372,3885,3509,5421,3243,4684,1910,1147,1518,2428,4685,3886,5422,4686, # 3376
+2393,2614, 260,1796,3244,5423,5424,3887,3324, 708,5425,3620,1704,5426,3621,1351, # 3392
+1618,3394,3017,1887, 944,4329,3395,4330,3064,3396,4331,5427,3744, 422, 413,1714, # 3408
+3325, 500,2059,2350,4332,2486,5428,1344,1911, 954,5429,1668,5430,5431,4089,2409, # 3424
+4333,3622,3888,4334,5432,2307,1318,2512,3114, 133,3115,2887,4687, 629,  31,2851, # 3440
+2706,3889,4688, 850, 949,4689,4090,2970,1732,2089,4335,1496,1853,5433,4091, 620, # 3456
+3245, 981,1242,3745,3397,1619,3746,1643,3326,2140,2457,1971,1719,3510,2169,5434, # 3472
+3246,5435,5436,3398,1829,5437,1277,4690,1565,2048,5438,1636,3623,3116,5439, 869, # 3488
+2852, 655,3890,3891,3117,4092,3018,3892,1310,3624,4691,5440,5441,5442,1733, 558, # 3504
+4692,3747, 335,1549,3065,1756,4336,3748,1946,3511,1830,1291,1192, 470,2735,2108, # 3520
+2806, 913,1054,4093,5443,1027,5444,3066,4094,4693, 982,2672,3399,3173,3512,3247, # 3536
+3248,1947,2807,5445, 571,4694,5446,1831,5447,3625,2591,1523,2429,5448,2090, 984, # 3552
+4695,3749,1960,5449,3750, 852, 923,2808,3513,3751, 969,1519, 999,2049,2325,1705, # 3568
+5450,3118, 615,1662, 151, 597,4095,2410,2326,1049, 275,4696,3752,4337, 568,3753, # 3584
+3626,2487,4338,3754,5451,2430,2275, 409,3249,5452,1566,2888,3514,1002, 769,2853, # 3600
+ 194,2091,3174,3755,2226,3327,4339, 628,1505,5453,5454,1763,2180,3019,4096, 521, # 3616
+1161,2592,1788,2206,2411,4697,4097,1625,4340,4341, 412,  42,3119, 464,5455,2642, # 3632
+4698,3400,1760,1571,2889,3515,2537,1219,2207,3893,2643,2141,2373,4699,4700,3328, # 3648
+1651,3401,3627,5456,5457,3628,2488,3516,5458,3756,5459,5460,2276,2092, 460,5461, # 3664
+4701,5462,3020, 962, 588,3629, 289,3250,2644,1116,  52,5463,3067,1797,5464,5465, # 3680
+5466,1467,5467,1598,1143,3757,4342,1985,1734,1067,4702,1280,3402, 465,4703,1572, # 3696
+ 510,5468,1928,2245,1813,1644,3630,5469,4704,3758,5470,5471,2673,1573,1534,5472, # 3712
+5473, 536,1808,1761,3517,3894,3175,2645,5474,5475,5476,4705,3518,2929,1912,2809, # 3728
+5477,3329,1122, 377,3251,5478, 360,5479,5480,4343,1529, 551,5481,2060,3759,1769, # 3744
+2431,5482,2930,4344,3330,3120,2327,2109,2031,4706,1404, 136,1468,1479, 672,1171, # 3760
+3252,2308, 271,3176,5483,2772,5484,2050, 678,2736, 865,1948,4707,5485,2014,4098, # 3776
+2971,5486,2737,2227,1397,3068,3760,4708,4709,1735,2931,3403,3631,5487,3895, 509, # 3792
+2854,2458,2890,3896,5488,5489,3177,3178,4710,4345,2538,4711,2309,1166,1010, 552, # 3808
+ 681,1888,5490,5491,2972,2973,4099,1287,1596,1862,3179, 358, 453, 736, 175, 478, # 3824
+1117, 905,1167,1097,5492,1854,1530,5493,1706,5494,2181,3519,2292,3761,3520,3632, # 3840
+4346,2093,4347,5495,3404,1193,2489,4348,1458,2193,2208,1863,1889,1421,3331,2932, # 3856
+3069,2182,3521, 595,2123,5496,4100,5497,5498,4349,1707,2646, 223,3762,1359, 751, # 3872
+3121, 183,3522,5499,2810,3021, 419,2374, 633, 704,3897,2394, 241,5500,5501,5502, # 3888
+ 838,3022,3763,2277,2773,2459,3898,1939,2051,4101,1309,3122,2246,1181,5503,1136, # 3904
+2209,3899,2375,1446,4350,2310,4712,5504,5505,4351,1055,2615, 484,3764,5506,4102, # 3920
+ 625,4352,2278,3405,1499,4353,4103,5507,4104,4354,3253,2279,2280,3523,5508,5509, # 3936
+2774, 808,2616,3765,3406,4105,4355,3123,2539, 526,3407,3900,4356, 955,5510,1620, # 3952
+4357,2647,2432,5511,1429,3766,1669,1832, 994, 928,5512,3633,1260,5513,5514,5515, # 3968
+1949,2293, 741,2933,1626,4358,2738,2460, 867,1184, 362,3408,1392,5516,5517,4106, # 3984
+4359,1770,1736,3254,2934,4713,4714,1929,2707,1459,1158,5518,3070,3409,2891,1292, # 4000
+1930,2513,2855,3767,1986,1187,2072,2015,2617,4360,5519,2574,2514,2170,3768,2490, # 4016
+3332,5520,3769,4715,5521,5522, 666,1003,3023,1022,3634,4361,5523,4716,1814,2257, # 4032
+ 574,3901,1603, 295,1535, 705,3902,4362, 283, 858, 417,5524,5525,3255,4717,4718, # 4048
+3071,1220,1890,1046,2281,2461,4107,1393,1599, 689,2575, 388,4363,5526,2491, 802, # 4064
+5527,2811,3903,2061,1405,2258,5528,4719,3904,2110,1052,1345,3256,1585,5529, 809, # 4080
+5530,5531,5532, 575,2739,3524, 956,1552,1469,1144,2328,5533,2329,1560,2462,3635, # 4096
+3257,4108, 616,2210,4364,3180,2183,2294,5534,1833,5535,3525,4720,5536,1319,3770, # 4112
+3771,1211,3636,1023,3258,1293,2812,5537,5538,5539,3905, 607,2311,3906, 762,2892, # 4128
+1439,4365,1360,4721,1485,3072,5540,4722,1038,4366,1450,2062,2648,4367,1379,4723, # 4144
+2593,5541,5542,4368,1352,1414,2330,2935,1172,5543,5544,3907,3908,4724,1798,1451, # 4160
+5545,5546,5547,5548,2936,4109,4110,2492,2351, 411,4111,4112,3637,3333,3124,4725, # 4176
+1561,2674,1452,4113,1375,5549,5550,  47,2974, 316,5551,1406,1591,2937,3181,5552, # 4192
+1025,2142,3125,3182, 354,2740, 884,2228,4369,2412, 508,3772, 726,3638, 996,2433, # 4208
+3639, 729,5553, 392,2194,1453,4114,4726,3773,5554,5555,2463,3640,2618,1675,2813, # 4224
+ 919,2352,2975,2353,1270,4727,4115,  73,5556,5557, 647,5558,3259,2856,2259,1550, # 4240
+1346,3024,5559,1332, 883,3526,5560,5561,5562,5563,3334,2775,5564,1212, 831,1347, # 4256
+4370,4728,2331,3909,1864,3073, 720,3910,4729,4730,3911,5565,4371,5566,5567,4731, # 4272
+5568,5569,1799,4732,3774,2619,4733,3641,1645,2376,4734,5570,2938, 669,2211,2675, # 4288
+2434,5571,2893,5572,5573,1028,3260,5574,4372,2413,5575,2260,1353,5576,5577,4735, # 4304
+3183, 518,5578,4116,5579,4373,1961,5580,2143,4374,5581,5582,3025,2354,2355,3912, # 4320
+ 516,1834,1454,4117,2708,4375,4736,2229,2620,1972,1129,3642,5583,2776,5584,2976, # 4336
+1422, 577,1470,3026,1524,3410,5585,5586, 432,4376,3074,3527,5587,2594,1455,2515, # 4352
+2230,1973,1175,5588,1020,2741,4118,3528,4737,5589,2742,5590,1743,1361,3075,3529, # 4368
+2649,4119,4377,4738,2295, 895, 924,4378,2171, 331,2247,3076, 166,1627,3077,1098, # 4384
+5591,1232,2894,2231,3411,4739, 657, 403,1196,2377, 542,3775,3412,1600,4379,3530, # 4400
+5592,4740,2777,3261, 576, 530,1362,4741,4742,2540,2676,3776,4120,5593, 842,3913, # 4416
+5594,2814,2032,1014,4121, 213,2709,3413, 665, 621,4380,5595,3777,2939,2435,5596, # 4432
+2436,3335,3643,3414,4743,4381,2541,4382,4744,3644,1682,4383,3531,1380,5597, 724, # 4448
+2282, 600,1670,5598,1337,1233,4745,3126,2248,5599,1621,4746,5600, 651,4384,5601, # 4464
+1612,4385,2621,5602,2857,5603,2743,2312,3078,5604, 716,2464,3079, 174,1255,2710, # 4480
+4122,3645, 548,1320,1398, 728,4123,1574,5605,1891,1197,3080,4124,5606,3081,3082, # 4496
+3778,3646,3779, 747,5607, 635,4386,4747,5608,5609,5610,4387,5611,5612,4748,5613, # 4512
+3415,4749,2437, 451,5614,3780,2542,2073,4388,2744,4389,4125,5615,1764,4750,5616, # 4528
+4390, 350,4751,2283,2395,2493,5617,4391,4126,2249,1434,4127, 488,4752, 458,4392, # 4544
+4128,3781, 771,1330,2396,3914,2576,3184,2160,2414,1553,2677,3185,4393,5618,2494, # 4560
+2895,2622,1720,2711,4394,3416,4753,5619,2543,4395,5620,3262,4396,2778,5621,2016, # 4576
+2745,5622,1155,1017,3782,3915,5623,3336,2313, 201,1865,4397,1430,5624,4129,5625, # 4592
+5626,5627,5628,5629,4398,1604,5630, 414,1866, 371,2595,4754,4755,3532,2017,3127, # 4608
+4756,1708, 960,4399, 887, 389,2172,1536,1663,1721,5631,2232,4130,2356,2940,1580, # 4624
+5632,5633,1744,4757,2544,4758,4759,5634,4760,5635,2074,5636,4761,3647,3417,2896, # 4640
+4400,5637,4401,2650,3418,2815, 673,2712,2465, 709,3533,4131,3648,4402,5638,1148, # 4656
+ 502, 634,5639,5640,1204,4762,3649,1575,4763,2623,3783,5641,3784,3128, 948,3263, # 4672
+ 121,1745,3916,1110,5642,4403,3083,2516,3027,4132,3785,1151,1771,3917,1488,4133, # 4688
+1987,5643,2438,3534,5644,5645,2094,5646,4404,3918,1213,1407,2816, 531,2746,2545, # 4704
+3264,1011,1537,4764,2779,4405,3129,1061,5647,3786,3787,1867,2897,5648,2018, 120, # 4720
+4406,4407,2063,3650,3265,2314,3919,2678,3419,1955,4765,4134,5649,3535,1047,2713, # 4736
+1266,5650,1368,4766,2858, 649,3420,3920,2546,2747,1102,2859,2679,5651,5652,2000, # 4752
+5653,1111,3651,2977,5654,2495,3921,3652,2817,1855,3421,3788,5655,5656,3422,2415, # 4768
+2898,3337,3266,3653,5657,2577,5658,3654,2818,4135,1460, 856,5659,3655,5660,2899, # 4784
+2978,5661,2900,3922,5662,4408, 632,2517, 875,3923,1697,3924,2296,5663,5664,4767, # 4800
+3028,1239, 580,4768,4409,5665, 914, 936,2075,1190,4136,1039,2124,5666,5667,5668, # 4816
+5669,3423,1473,5670,1354,4410,3925,4769,2173,3084,4137, 915,3338,4411,4412,3339, # 4832
+1605,1835,5671,2748, 398,3656,4413,3926,4138, 328,1913,2860,4139,3927,1331,4414, # 4848
+3029, 937,4415,5672,3657,4140,4141,3424,2161,4770,3425, 524, 742, 538,3085,1012, # 4864
+5673,5674,3928,2466,5675, 658,1103, 225,3929,5676,5677,4771,5678,4772,5679,3267, # 4880
+1243,5680,4142, 963,2250,4773,5681,2714,3658,3186,5682,5683,2596,2332,5684,4774, # 4896
+5685,5686,5687,3536, 957,3426,2547,2033,1931,2941,2467, 870,2019,3659,1746,2780, # 4912
+2781,2439,2468,5688,3930,5689,3789,3130,3790,3537,3427,3791,5690,1179,3086,5691, # 4928
+3187,2378,4416,3792,2548,3188,3131,2749,4143,5692,3428,1556,2549,2297, 977,2901, # 4944
+2034,4144,1205,3429,5693,1765,3430,3189,2125,1271, 714,1689,4775,3538,5694,2333, # 4960
+3931, 533,4417,3660,2184, 617,5695,2469,3340,3539,2315,5696,5697,3190,5698,5699, # 4976
+3932,1988, 618, 427,2651,3540,3431,5700,5701,1244,1690,5702,2819,4418,4776,5703, # 4992
+3541,4777,5704,2284,1576, 473,3661,4419,3432, 972,5705,3662,5706,3087,5707,5708, # 5008
+4778,4779,5709,3793,4145,4146,5710, 153,4780, 356,5711,1892,2902,4420,2144, 408, # 5024
+ 803,2357,5712,3933,5713,4421,1646,2578,2518,4781,4782,3934,5714,3935,4422,5715, # 5040
+2416,3433, 752,5716,5717,1962,3341,2979,5718, 746,3030,2470,4783,4423,3794, 698, # 5056
+4784,1893,4424,3663,2550,4785,3664,3936,5719,3191,3434,5720,1824,1302,4147,2715, # 5072
+3937,1974,4425,5721,4426,3192, 823,1303,1288,1236,2861,3542,4148,3435, 774,3938, # 5088
+5722,1581,4786,1304,2862,3939,4787,5723,2440,2162,1083,3268,4427,4149,4428, 344, # 5104
+1173, 288,2316, 454,1683,5724,5725,1461,4788,4150,2597,5726,5727,4789, 985, 894, # 5120
+5728,3436,3193,5729,1914,2942,3795,1989,5730,2111,1975,5731,4151,5732,2579,1194, # 5136
+ 425,5733,4790,3194,1245,3796,4429,5734,5735,2863,5736, 636,4791,1856,3940, 760, # 5152
+1800,5737,4430,2212,1508,4792,4152,1894,1684,2298,5738,5739,4793,4431,4432,2213, # 5168
+ 479,5740,5741, 832,5742,4153,2496,5743,2980,2497,3797, 990,3132, 627,1815,2652, # 5184
+4433,1582,4434,2126,2112,3543,4794,5744, 799,4435,3195,5745,4795,2113,1737,3031, # 5200
+1018, 543, 754,4436,3342,1676,4796,4797,4154,4798,1489,5746,3544,5747,2624,2903, # 5216
+4155,5748,5749,2981,5750,5751,5752,5753,3196,4799,4800,2185,1722,5754,3269,3270, # 5232
+1843,3665,1715, 481, 365,1976,1857,5755,5756,1963,2498,4801,5757,2127,3666,3271, # 5248
+ 433,1895,2064,2076,5758, 602,2750,5759,5760,5761,5762,5763,3032,1628,3437,5764, # 5264
+3197,4802,4156,2904,4803,2519,5765,2551,2782,5766,5767,5768,3343,4804,2905,5769, # 5280
+4805,5770,2864,4806,4807,1221,2982,4157,2520,5771,5772,5773,1868,1990,5774,5775, # 5296
+5776,1896,5777,5778,4808,1897,4158, 318,5779,2095,4159,4437,5780,5781, 485,5782, # 5312
+ 938,3941, 553,2680, 116,5783,3942,3667,5784,3545,2681,2783,3438,3344,2820,5785, # 5328
+3668,2943,4160,1747,2944,2983,5786,5787, 207,5788,4809,5789,4810,2521,5790,3033, # 5344
+ 890,3669,3943,5791,1878,3798,3439,5792,2186,2358,3440,1652,5793,5794,5795, 941, # 5360
+2299, 208,3546,4161,2020, 330,4438,3944,2906,2499,3799,4439,4811,5796,5797,5798, # 5376
+)
+
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/big5freq.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/big5freq.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..0578a2277137e0468e564606b4d98898840025d0
GIT binary patch
literal 54748
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

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/big5prober.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/big5prober.py
new file mode 100644
index 0000000..98f9970
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/big5prober.py
@@ -0,0 +1,47 @@
+######################## BEGIN LICENSE BLOCK ########################
+# The Original Code is Mozilla Communicator client code.
+#
+# The Initial Developer of the Original Code is
+# Netscape Communications Corporation.
+# Portions created by the Initial Developer are Copyright (C) 1998
+# the Initial Developer. All Rights Reserved.
+#
+# Contributor(s):
+#   Mark Pilgrim - port to Python
+#
+# This library is free software; you can redistribute it and/or
+# modify it under the terms of the GNU Lesser General Public
+# License as published by the Free Software Foundation; either
+# version 2.1 of the License, or (at your option) any later version.
+#
+# This library is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+# Lesser General Public License for more details.
+#
+# You should have received a copy of the GNU Lesser General Public
+# License along with this library; if not, write to the Free Software
+# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
+# 02110-1301  USA
+######################### END LICENSE BLOCK #########################
+
+from .mbcharsetprober import MultiByteCharSetProber
+from .codingstatemachine import CodingStateMachine
+from .chardistribution import Big5DistributionAnalysis
+from .mbcssm import BIG5_SM_MODEL
+
+
+class Big5Prober(MultiByteCharSetProber):
+    def __init__(self):
+        super(Big5Prober, self).__init__()
+        self.coding_sm = CodingStateMachine(BIG5_SM_MODEL)
+        self.distribution_analyzer = Big5DistributionAnalysis()
+        self.reset()
+
+    @property
+    def charset_name(self):
+        return "Big5"
+
+    @property
+    def language(self):
+        return "Chinese"
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/big5prober.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/big5prober.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..58702c4e0e4c34608f89dc24311518a6345c6090
GIT binary patch
literal 1592
zcmZSn%**AGdLky70ScHI7#JKF7#ND97#J8*7#LC*8FCmHav2$-7#SErd?tn*CWc&Q
zhA3tTpP3<tg&~)fA&M2kXJN=;W5{J^h+=18Okrh6Wn@TWWJqCSXklPzW?+bn;$TQ&
zX9(8dU|?X#WMp7q&;Su7VhjunzNI-OnNF1@sm>XRMZu{h0Y&*qsYMWZAqEBp=lqn+
zy!7Cb#FA9s#N>?3yi|ys1Oo$uQ)arUOJ;FNQD#zUNoIbYV_srTWpQRPL<KKMg{Qk|
ze6Vl4ufL0{PYD-DBs1L<Vh7y!Odw&9@AVlN7*ZKPo=#x^IX#MrA(a^v7$9#jGDNX}
zxlACbW=4?TgMu|cL6;2j4G4oc&LER)7#J8z7#K<z8EP09nwc1~m_XscSi;Ou!otuD
z7L8|RC}9JM)-W){vxC%Sae%m>@D2w1z)yn{WDG0Fz|w-$q97I!7Zir^@tJv<CGqh=
zAWMTlww7=*Ffb&8!z#WwHwfgV5>ZfOA_Y%;A}D;SQj1DJMi!+Or<Q>2DFK;VoSKuS
z0ZI;FqPUQOfkD5ZD6=fFBvrpGu}D8HKPM%%s8~NKMZY{LDKFPFx7f%q$vnL(-NMwO
zJSVHl%m4(^^YlaX3o;9IGxLf|5_58N-O4;XjRQbJU>skTnwOGaq@SFTSd@}lqMwwR
zZdw42a=n7eAT|aD24#?UL7rq_6lUaS<Y9z|F37Xs&;_|Sg^?jx1LRFVu=7Dl0qk<H
zkAgrk4dH^kG%&s?;Q>WSMq*KMYDs)vVs5G?$Y&rYGcXbK6FVsBgHn5OD#RZk&kqi7
zf#N17F)zI|F+Eim;Ux`F<duLV<H5d-j|b<s`1suXl+v8k_;_&af)x}L<rkzDl~e|S
zLMVt2R33n$3F1)@YhWS_oWGPnJ_31#jgga$p9Pu+`571(a+5%bwm7u}l3s&A4lMx{
zQIKp`3@V~>Aw?88UzP|!<39x{4?=P#$o$--<l^F7aOMSDjPN~}H84Q{jvgCGjM>S6
Nf&vtw0*qkD3;+sJcC7#a

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/chardistribution.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/chardistribution.py
new file mode 100644
index 0000000..c0395f4
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/chardistribution.py
@@ -0,0 +1,233 @@
+######################## BEGIN LICENSE BLOCK ########################
+# The Original Code is Mozilla Communicator client code.
+#
+# The Initial Developer of the Original Code is
+# Netscape Communications Corporation.
+# Portions created by the Initial Developer are Copyright (C) 1998
+# the Initial Developer. All Rights Reserved.
+#
+# Contributor(s):
+#   Mark Pilgrim - port to Python
+#
+# This library is free software; you can redistribute it and/or
+# modify it under the terms of the GNU Lesser General Public
+# License as published by the Free Software Foundation; either
+# version 2.1 of the License, or (at your option) any later version.
+#
+# This library is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+# Lesser General Public License for more details.
+#
+# You should have received a copy of the GNU Lesser General Public
+# License along with this library; if not, write to the Free Software
+# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
+# 02110-1301  USA
+######################### END LICENSE BLOCK #########################
+
+from .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):
+    ENOUGH_DATA_THRESHOLD = 1024
+    SURE_YES = 0.99
+    SURE_NO = 0.01
+    MINIMUM_DATA_THRESHOLD = 3
+
+    def __init__(self):
+        # 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
+        # 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.reset()
+
+    def reset(self):
+        """reset analyser, clear any state"""
+        # If this flag is set to True, detection is done and conclusion has
+        # been made
+        self._done = False
+        self._total_chars = 0  # Total characters encountered
+        # The number of characters whose frequency order is less than 512
+        self._freq_chars = 0
+
+    def feed(self, char, char_len):
+        """feed a character with known length"""
+        if char_len == 2:
+            # we only care about 2-bytes character in our distribution analysis
+            order = self.get_order(char)
+        else:
+            order = -1
+        if order >= 0:
+            self._total_chars += 1
+            # order is valid
+            if order < self._table_size:
+                if 512 > self._char_to_freq_order[order]:
+                    self._freq_chars += 1
+
+    def get_confidence(self):
+        """return confidence based on existing data"""
+        # if we didn't receive any character in our consideration range,
+        # return negative answer
+        if self._total_chars <= 0 or self._freq_chars <= self.MINIMUM_DATA_THRESHOLD:
+            return self.SURE_NO
+
+        if self._total_chars != self._freq_chars:
+            r = (self._freq_chars / ((self._total_chars - self._freq_chars)
+                 * self.typical_distribution_ratio))
+            if r < self.SURE_YES:
+                return r
+
+        # normalize confidence (we don't want to be 100% sure)
+        return self.SURE_YES
+
+    def got_enough_data(self):
+        # 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):
+        # We do not handle characters based on the original encoding string,
+        # but convert this encoding string to a number, here called order.
+        # This allows multiple encodings of a language to share one frequency
+        # table.
+        return -1
+
+
+class EUCTWDistributionAnalysis(CharDistributionAnalysis):
+    def __init__(self):
+        super(EUCTWDistributionAnalysis, self).__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):
+        # for euc-TW encoding, we are interested
+        #   first  byte range: 0xc4 -- 0xfe
+        #   second byte range: 0xa1 -- 0xfe
+        # no validation needed here. State machine has done that
+        first_char = byte_str[0]
+        if first_char >= 0xC4:
+            return 94 * (first_char - 0xC4) + byte_str[1] - 0xA1
+        else:
+            return -1
+
+
+class EUCKRDistributionAnalysis(CharDistributionAnalysis):
+    def __init__(self):
+        super(EUCKRDistributionAnalysis, self).__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):
+        # for euc-KR encoding, we are interested
+        #   first  byte range: 0xb0 -- 0xfe
+        #   second byte range: 0xa1 -- 0xfe
+        # no validation needed here. State machine has done that
+        first_char = byte_str[0]
+        if first_char >= 0xB0:
+            return 94 * (first_char - 0xB0) + byte_str[1] - 0xA1
+        else:
+            return -1
+
+
+class GB2312DistributionAnalysis(CharDistributionAnalysis):
+    def __init__(self):
+        super(GB2312DistributionAnalysis, self).__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):
+        # for GB2312 encoding, we are interested
+        #  first  byte range: 0xb0 -- 0xfe
+        #  second byte range: 0xa1 -- 0xfe
+        # no validation needed here. State machine has done that
+        first_char, second_char = byte_str[0], byte_str[1]
+        if (first_char >= 0xB0) and (second_char >= 0xA1):
+            return 94 * (first_char - 0xB0) + second_char - 0xA1
+        else:
+            return -1
+
+
+class Big5DistributionAnalysis(CharDistributionAnalysis):
+    def __init__(self):
+        super(Big5DistributionAnalysis, self).__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):
+        # for big5 encoding, we are interested
+        #   first  byte range: 0xa4 -- 0xfe
+        #   second byte range: 0x40 -- 0x7e , 0xa1 -- 0xfe
+        # no validation needed here. State machine has done that
+        first_char, second_char = byte_str[0], byte_str[1]
+        if first_char >= 0xA4:
+            if second_char >= 0xA1:
+                return 157 * (first_char - 0xA4) + second_char - 0xA1 + 63
+            else:
+                return 157 * (first_char - 0xA4) + second_char - 0x40
+        else:
+            return -1
+
+
+class SJISDistributionAnalysis(CharDistributionAnalysis):
+    def __init__(self):
+        super(SJISDistributionAnalysis, self).__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):
+        # 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):
+            order = 188 * (first_char - 0x81)
+        elif (first_char >= 0xE0) and (first_char <= 0xEF):
+            order = 188 * (first_char - 0xE0 + 31)
+        else:
+            return -1
+        order = order + second_char - 0x40
+        if second_char > 0x7F:
+            order = -1
+        return order
+
+
+class EUCJPDistributionAnalysis(CharDistributionAnalysis):
+    def __init__(self):
+        super(EUCJPDistributionAnalysis, self).__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):
+        # 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
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/chardistribution.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/chardistribution.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..3c5c0c7aa396f38ef3450ece1da6a0bd84dd3915
GIT binary patch
literal 9073
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

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/charsetgroupprober.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/charsetgroupprober.py
new file mode 100644
index 0000000..8b3738e
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/charsetgroupprober.py
@@ -0,0 +1,106 @@
+######################## BEGIN LICENSE BLOCK ########################
+# The Original Code is Mozilla Communicator client code.
+#
+# The Initial Developer of the Original Code is
+# Netscape Communications Corporation.
+# Portions created by the Initial Developer are Copyright (C) 1998
+# the Initial Developer. All Rights Reserved.
+#
+# Contributor(s):
+#   Mark Pilgrim - port to Python
+#
+# This library is free software; you can redistribute it and/or
+# modify it under the terms of the GNU Lesser General Public
+# License as published by the Free Software Foundation; either
+# version 2.1 of the License, or (at your option) any later version.
+#
+# This library is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+# Lesser General Public License for more details.
+#
+# You should have received a copy of the GNU Lesser General Public
+# License along with this library; if not, write to the Free Software
+# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
+# 02110-1301  USA
+######################### END LICENSE BLOCK #########################
+
+from .enums import ProbingState
+from .charsetprober import CharSetProber
+
+
+class CharSetGroupProber(CharSetProber):
+    def __init__(self, lang_filter=None):
+        super(CharSetGroupProber, self).__init__(lang_filter=lang_filter)
+        self._active_num = 0
+        self.probers = []
+        self._best_guess_prober = None
+
+    def reset(self):
+        super(CharSetGroupProber, self).reset()
+        self._active_num = 0
+        for prober in self.probers:
+            if prober:
+                prober.reset()
+                prober.active = True
+                self._active_num += 1
+        self._best_guess_prober = None
+
+    @property
+    def charset_name(self):
+        if not self._best_guess_prober:
+            self.get_confidence()
+            if not self._best_guess_prober:
+                return None
+        return self._best_guess_prober.charset_name
+
+    @property
+    def language(self):
+        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):
+        for prober in self.probers:
+            if not prober:
+                continue
+            if not prober.active:
+                continue
+            state = prober.feed(byte_str)
+            if not state:
+                continue
+            if state == ProbingState.FOUND_IT:
+                self._best_guess_prober = prober
+                return self.state
+            elif state == ProbingState.NOT_ME:
+                prober.active = False
+                self._active_num -= 1
+                if self._active_num <= 0:
+                    self._state = ProbingState.NOT_ME
+                    return self.state
+        return self.state
+
+    def get_confidence(self):
+        state = self.state
+        if state == ProbingState.FOUND_IT:
+            return 0.99
+        elif 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)
+                continue
+            conf = prober.get_confidence()
+            self.logger.debug('%s %s confidence = %s', prober.charset_name, prober.language, conf)
+            if best_conf < conf:
+                best_conf = conf
+                self._best_guess_prober = prober
+        if not self._best_guess_prober:
+            return 0.0
+        return best_conf
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/charsetgroupprober.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/charsetgroupprober.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..175b85de811e1c9828139728a38a7f92d0671e18
GIT binary patch
literal 3249
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
J3NQ*V0|0=UxH$j-

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/charsetprober.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/charsetprober.py
new file mode 100644
index 0000000..eac4e59
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/charsetprober.py
@@ -0,0 +1,145 @@
+######################## BEGIN LICENSE BLOCK ########################
+# The Original Code is Mozilla Universal charset detector code.
+#
+# The Initial Developer of the Original Code is
+# Netscape Communications Corporation.
+# Portions created by the Initial Developer are Copyright (C) 2001
+# the Initial Developer. All Rights Reserved.
+#
+# Contributor(s):
+#   Mark Pilgrim - port to Python
+#   Shy Shalom - original C code
+#
+# This library is free software; you can redistribute it and/or
+# modify it under the terms of the GNU Lesser General Public
+# License as published by the Free Software Foundation; either
+# version 2.1 of the License, or (at your option) any later version.
+#
+# This library is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+# Lesser General Public License for more details.
+#
+# You should have received a copy of the GNU Lesser General Public
+# License along with this library; if not, write to the Free Software
+# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
+# 02110-1301  USA
+######################### END LICENSE BLOCK #########################
+
+import logging
+import re
+
+from .enums import ProbingState
+
+
+class CharSetProber(object):
+
+    SHORTCUT_THRESHOLD = 0.95
+
+    def __init__(self, lang_filter=None):
+        self._state = None
+        self.lang_filter = lang_filter
+        self.logger = logging.getLogger(__name__)
+
+    def reset(self):
+        self._state = ProbingState.DETECTING
+
+    @property
+    def charset_name(self):
+        return None
+
+    def feed(self, buf):
+        pass
+
+    @property
+    def state(self):
+        return self._state
+
+    def get_confidence(self):
+        return 0.0
+
+    @staticmethod
+    def filter_high_byte_only(buf):
+        buf = re.sub(b'([\x00-\x7F])+', b' ', buf)
+        return buf
+
+    @staticmethod
+    def filter_international_words(buf):
+        """
+        We define three types of bytes:
+        alphabet: english alphabets [a-zA-Z]
+        international: international characters [\x80-\xFF]
+        marker: everything else [^a-zA-Z\x80-\xFF]
+
+        The input buffer can be thought to contain a series of words delimited
+        by markers. This function works to filter all words that contain at
+        least one international character. All contiguous sequences of markers
+        are replaced by a single space ascii character.
+
+        This filter applies to all scripts which do not use English characters.
+        """
+        filtered = bytearray()
+
+        # This regex expression filters out only words that have at-least one
+        # international character. The word may include one marker character at
+        # the end.
+        words = re.findall(b'[a-zA-Z]*[\x80-\xFF]+[a-zA-Z]*[^a-zA-Z\x80-\xFF]?',
+                           buf)
+
+        for word in words:
+            filtered.extend(word[:-1])
+
+            # If the last character in the word is a marker, replace it with a
+            # space as markers shouldn't affect our analysis (they are used
+            # similarly across all languages and may thus have similar
+            # frequencies).
+            last_char = word[-1:]
+            if not last_char.isalpha() and last_char < b'\x80':
+                last_char = b' '
+            filtered.extend(last_char)
+
+        return filtered
+
+    @staticmethod
+    def filter_with_english_letters(buf):
+        """
+        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``.
+        """
+        filtered = bytearray()
+        in_tag = False
+        prev = 0
+
+        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
+
+            # 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
+                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
+
+        # If we're not in a tag...
+        if not in_tag:
+            # Keep everything after last non-extended-ASCII, non-alphabetic
+            # character
+            filtered.extend(buf[prev:])
+
+        return filtered
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/charsetprober.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/charsetprober.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..240eb28adfcf467e1e5ae21bd35f2eedae069de5
GIT binary patch
literal 4666
zcmZSn%**AGdLky70ScHI7#JKF7#ND37#J8*7#LC*8FCmHqTp;shA2jc6eflgW`-Ol
zhFoTbC}sx66c&b57KSuNh7?wY76yi928PHeR*=?U4K@Y_hRpx}|Nr;PWMp7q&;Su7
zJPZsB0Y&*qnR)5KC5a`eCA<s_49*#eMZu{hAo0{9xO<ow7#KiKDQ;k3U`S;E+s?oc
z#l(=p1+t)pks*o&<enA=hA38sR5p;qKu%y}h+=0*VF5WOiUTYTaT+5-6emLp8(5r+
zA(fjUg&o9hW@L!s0dqNETwXAj6UOCZ2nyEVW?*1QPXmK@_Q@c(!LTzZ%rqcjR>Qy$
z&&W{2$N*w6F_bVfWU(-murf45MA$&#8Vn8zKMi&U28I$A1_lPd{Jhi>P-w*$gM$QQ
zRZe1FdVE@DPDyG}2}og1etLRlUU~^9$Qh|6KKbeCsYN9m3=9nM@p*~4sqyh(6F|yR
zi!?w^0~=kOnv)g;vIFEk1~5@v!oa|wUr>};mRORiUzS*;pO&AKl3G-(pOm6so|KfA
zYnoeZWSC^0UX^ZPYEhn(Rb^%X0_l1BA^HWG1-hAe#U+V3Il69T9-hVlAR#c0FH6l!
z$uH7R&PXguNi6}>#i=C)MfpjoMS2C5P}gSWWtPOptAhd!<Yxv(PDW0~WKiM&VUWwg
z0V)6r9R`LhMrcr`FfhOZ4wO)XK#3L{8ZNFOuFfHze(pgaad6lMae~qtNW}pAn3aKn
zp(wRDwL}NxU69`x5MBj&7wlC~{2+M`Bpw7(JGlG;%DJGZElw=~r#OAMmzdz$0pxUS
zUIIr2$V=duDFH=PQfV4Ea=^sErAbiOr=_N*7{h&oC4xX1u!eyl3y}mt9v!6V4P1tp
z!M(!-&srciBO-^9AsAdt_@#p)2ZX^fF}TtkAEdO4PtMOv%S=hlOHQ?ddkhgzpg073
zOcGvZq=0Lx8U}`DW`<e@P!STW0ZMg##h@ZnBbq_CK2}q^1Qa9+;9w{LrOu*MaMCO;
zO@agi$a+YqfWl|s5~(Ny0|TTkh|kDO&xlW|EJ=;e&&#Q_1%(F4`wUE?knjMNI3NLV
zcvL~cqnUxBmXV=^ks*r-RB?hrg^8h-iJ>Bbp@xaUB{qPemKjuMWid0<FoSATg=R(u
zMhH{BmW82)1yqYQGcfQJrGhvq%naF}at&0;*0M0<F~Bslfa*EMLM4Xq8c^~Axuw{Y
ziGhJj0SdxX6;e{uGV@XuN-~O4Qx!@o3sQ>}^3xPRJ}S0?t4qu&$Vf~|EwNHa%}dY8
zEY47Xi4-eDC+b!?>PE%F6=&v^q!#5RmSpDVCFWQupl}sHC01f`NorBCLUe=fe}t~w
z#G>rfA}fW|vecr=l8nr}bcNKM;#7s`IEeXR#c(@9GEx;X^9o8!6p~8Q(o%~Qk`wb3
zl0e?bFHO%VQ7Fk*NY2kINzBYsNK`0JEy{#=t31CbrC1>)H77GSvm`YIZd_8O0>u7e
zJ%x~r%wmPK(!6Al2NcTli?WMB#zEp+Au%ThB$iUFP?C{Yg0Q3nZdOieVsVK=ejdny
zNCAQHxt@Y!P7YXSW_oFUX|Y0aYGElTFM&fI>JGSZiAAXjMX3cjiOH!c3Q3h9?_}ns
z=cFnW7bGU9DkK&sXJ#Uq%>~y8@dvoYqL5fnkOK;Wl6<fSij#{n3rdO=$}=*PGZa$t
z74q^+6iSOz6<ndQi-;vXxOv5@3=9mg$kqZ!o;HGu6ifEtMrJW6FE<1UfogtG!UMMr
zK*=hxs3@^ANEnnAK;?K^W?o8SP7b)Wlv+`enwJ7@Uu719Q<w%wYY-^kgIg<*NJvd7
z0SSX66Wpo-vB2i%Bo>#%gB(8?N(m`MDS?s);z7;@H|mQ;K;;-eCo3l-ClfEDAR8B>
zBqJxIAf%1}wZ=gH1Q#7IK;Z>$&qIoiT5!=(%gj)*iJ=7Cumu$(jGzqf5<8CpR7x;_
z%7z+nlU!V}mX)D~71ScnW@0D`0Tn*AObmIVU_llJkYFaL@e2}U01L8$%M=X|JBt<6
zkKifN02|26kj=tSv=dZR@qj2shAcKvfnLK5l2!y4Rba6cHjrx=LB$co5w*+=g&H6f
zUc<yt`~+M|!L-VQ^nsLu3Mx>#C_cf6R8R$_mXsFd6)PkvB<B}Yf=Z}_grw56gak-7
zEJ_7s^<o838LUu}k&2q7ps5<3lEEn}DYZl)F)u{{RDgqvJ47ae=50{U17(b))ROYl
z)I0?nJ0vBDeBqc=oUZ_L0MsgY@rc`s%-r16l+47E)SODV!;(_d@{3Xx@{^NGi;CbS
zf}I}rObspaAbC3lR7QacC)B(RD+H7BOEO@&8*Uvaqd?1IP)I;>UuueiW3aQQCz4-v
z6p~6y6f%nyAkHeuse}Y{X)(A+f}59+;FDOAnP&*;Hzp(?!YC7z&cVG-a20O{CT)<5
z2vC#<iGdP1D9O7e<`k!bGkH;BUOJ=|kdvAR&g>yYrKv%nmPL>RsB8h{5^w<#1j=vV
zVk9#!z9canthk^kwG7MvIUQVtB$cKOni4`9Q9_hwmSn_3E7$m()Dln)32F%zD}jQJ
zhm(<wk&Q``Nsx($k&}^!k&{`HNtjuLNq|w1nT=V5$xnlyfq@|i6pAHW;7(|6eoAQ$
zs2d6@frCB#gF>7`L*hd`f?R_={C!-&9hxAJ(jZVr0vt32MfnA(MJ1I%pfP|Tuz{dn
zUyvXuT0p8mP1(%k+|-hc{FES2BPd7?WUD499zf0<1f^~esM=8mHN!w<D;pCV6AvpV
zGd~Lyv+}Eg$3cQXsSHvHfmo?|rMbnBE-WZL<tJsOCYOMXLU;+x8n`wmsGV#BiBvmT
PkpDmq<zeJu5?}@Z@*9@C

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/cli/__init__.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/cli/__init__.py
new file mode 100644
index 0000000..8b13789
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/cli/__init__.py
@@ -0,0 +1 @@
+
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/cli/__init__.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/cli/__init__.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..bed13a97971067f8579ad19da79ab24068df2a0b
GIT binary patch
literal 202
zcmZSn%**AGdLky70SXuy7#JKF7#NCK7#J8*7#M;zKq7t`AZawBxR`-~LBF6Vvn;VB
zRlh8;NIxw<CndG0SU)L6zdR`^FV{4;*vK%+JiRL2!qlQXC#%ZL00h$W^h5LuG7EGw
z^NLFnb8>Xu$~-)c13*Gx9AB22my%zkpPZ3cl#*JapPZAaA0MBYmst`YuUAl6!ok46
SV3V7lQks)$2XY<A9Si`FC^KgO

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/cli/chardetect.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/cli/chardetect.py
new file mode 100644
index 0000000..c61136b
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/cli/chardetect.py
@@ -0,0 +1,85 @@
+#!/usr/bin/env python
+"""
+Script which takes one or more file paths and reports on their detected
+encodings
+
+Example::
+
+    % chardetect somefile someotherfile
+    somefile: windows-1252 with confidence 0.5
+    someotherfile: ascii with confidence 1.0
+
+If no paths are provided, it takes its input from stdin.
+
+"""
+
+from __future__ import absolute_import, print_function, unicode_literals
+
+import argparse
+import sys
+
+from pip._vendor.chardet import __version__
+from pip._vendor.chardet.compat import PY2
+from pip._vendor.chardet.universaldetector import UniversalDetector
+
+
+def description_of(lines, name='stdin'):
+    """
+    Return a string describing the probable encoding of a file or
+    list of strings.
+
+    :param lines: The lines to get the encoding of.
+    :type lines: Iterable of bytes
+    :param name: Name of file or collection of lines
+    :type name: str
+    """
+    u = UniversalDetector()
+    for line in lines:
+        line = bytearray(line)
+        u.feed(line)
+        # shortcut out of the loop to save reading further - particularly useful if we read a BOM.
+        if u.done:
+            break
+    u.close()
+    result = u.result
+    if PY2:
+        name = name.decode(sys.getfilesystemencoding(), 'ignore')
+    if result['encoding']:
+        return '{0}: {1} with confidence {2}'.format(name, result['encoding'],
+                                                     result['confidence'])
+    else:
+        return '{0}: no result'.format(name)
+
+
+def main(argv=None):
+    """
+    Handles command line arguments and gets things started.
+
+    :param argv: List of arguments, as if specified on the command-line.
+                 If None, ``sys.argv[1:]`` is used instead.
+    :type argv: list of str
+    """
+    # Get command line arguments
+    parser = argparse.ArgumentParser(
+        description="Takes one or more file paths and reports their detected \
+                     encodings")
+    parser.add_argument('input',
+                        help='File whose encoding we would like to determine. \
+                              (default: stdin)',
+                        type=argparse.FileType('rb'), nargs='*',
+                        default=[sys.stdin if PY2 else sys.stdin.buffer])
+    parser.add_argument('--version', action='version',
+                        version='%(prog)s {0}'.format(__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__':
+    main()
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/cli/chardetect.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/cli/chardetect.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..7a5ba54e0f7fcaa503109863d92c09db69d7eeaf
GIT binary patch
literal 3331
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

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/codingstatemachine.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/codingstatemachine.py
new file mode 100644
index 0000000..68fba44
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/codingstatemachine.py
@@ -0,0 +1,88 @@
+######################## BEGIN LICENSE BLOCK ########################
+# The Original Code is mozilla.org code.
+#
+# The Initial Developer of the Original Code is
+# Netscape Communications Corporation.
+# Portions created by the Initial Developer are Copyright (C) 1998
+# the Initial Developer. All Rights Reserved.
+#
+# Contributor(s):
+#   Mark Pilgrim - port to Python
+#
+# This library is free software; you can redistribute it and/or
+# modify it under the terms of the GNU Lesser General Public
+# License as published by the Free Software Foundation; either
+# version 2.1 of the License, or (at your option) any later version.
+#
+# This library is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+# Lesser General Public License for more details.
+#
+# You should have received a copy of the GNU Lesser General Public
+# License along with this library; if not, write to the Free Software
+# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
+# 02110-1301  USA
+######################### END LICENSE BLOCK #########################
+
+import logging
+
+from .enums import MachineState
+
+
+class CodingStateMachine(object):
+    """
+    A state machine to verify a byte sequence for a particular encoding. For
+    each byte the detector receives, it will feed that byte to every active
+    state machine available, one byte at a time. The state machine changes its
+    state based on its previous state and the byte it receives. There are 3
+    states in a state machine that are of interest to an auto-detector:
+
+    START state: This is the state to start with, or a legal byte sequence
+                 (i.e. a valid code point) for character has been identified.
+
+    ME state:  This indicates that the state machine identified a byte sequence
+               that is specific to the charset it is designed for and that
+               there is no other possible encoding which can contain this byte
+               sequence. This will to lead to an immediate positive answer for
+               the detector.
+
+    ERROR state: This indicates the state machine identified an illegal byte
+                 sequence for that encoding. This will lead to an immediate
+                 negative answer for this encoding. Detector will exclude this
+                 encoding from consideration from here on.
+    """
+    def __init__(self, sm):
+        self._model = sm
+        self._curr_byte_pos = 0
+        self._curr_char_len = 0
+        self._curr_state = None
+        self.logger = logging.getLogger(__name__)
+        self.reset()
+
+    def reset(self):
+        self._curr_state = MachineState.START
+
+    def next_state(self, c):
+        # for each byte we get its class
+        # if it is first byte, we also get byte length
+        byte_class = self._model['class_table'][c]
+        if self._curr_state == MachineState.START:
+            self._curr_byte_pos = 0
+            self._curr_char_len = self._model['char_len_table'][byte_class]
+        # from byte's class and state_table, we get its next state
+        curr_state = (self._curr_state * self._model['class_factor']
+                      + byte_class)
+        self._curr_state = self._model['state_table'][curr_state]
+        self._curr_byte_pos += 1
+        return self._curr_state
+
+    def get_current_charlen(self):
+        return self._curr_char_len
+
+    def get_coding_state_machine(self):
+        return self._model['name']
+
+    @property
+    def language(self):
+        return self._model['language']
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/codingstatemachine.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/codingstatemachine.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..6ca0292d54f0b9bd8997e90aef6c4b2d61146d9b
GIT binary patch
literal 3736
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

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/compat.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/compat.py
new file mode 100644
index 0000000..ddd7468
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/compat.py
@@ -0,0 +1,34 @@
+######################## 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
+    base_str = (str, unicode)
+    text_type = unicode
+else:
+    PY2 = False
+    PY3 = True
+    base_str = (bytes, str)
+    text_type = str
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/compat.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/compat.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..557b967c704c23d8e524da78cb3cf615b7917f95
GIT binary patch
literal 451
zcmZSn%**AGdLky70ScHI7#JKF7#ND<7#J8*7#LC*8FCmHq8J!b85pt{8B$mnvKbhP
zY#36R7^0XNQdt<HSQ%2;7*g38(wG>cI6#ajPKG==uoN>`87o677f20M0UJXUC&<`f
z4ORvQhRpx}|Nr;P1X-I2a)JgEND#s0W?*0_0db2fi%WPI7#PY@i;6Sz^Wrn}((+4K
z7#J8rib_+#Dgq*nN<c=sCFT^vM2x{Q#U({0><kPHrFogj`6;O-91IK$Nr}a&@gNCK
zkPWF7CGjPd1*u>Ik}6A5i#5QmffL2K3=9nV1x1-<i6yD}Wr;=lY56%RsYS*5Nh$i}
zNlAIRrn$vNhDqk>Rp}O{7UelvRb~btke;U>qF<0%pqrUjT#}fRqw7}Y;b|NI5(4A+
zvedkk{38A2jKrdp)Dr#V{M>@X61{>-uq$nH^HWN5QtiY*Q6j{^z`(=I&&bBe#>m6S
H$poPR!rEhO

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/cp949prober.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/cp949prober.py
new file mode 100644
index 0000000..efd793a
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/cp949prober.py
@@ -0,0 +1,49 @@
+######################## BEGIN LICENSE BLOCK ########################
+# The Original Code is mozilla.org code.
+#
+# The Initial Developer of the Original Code is
+# Netscape Communications Corporation.
+# Portions created by the Initial Developer are Copyright (C) 1998
+# the Initial Developer. All Rights Reserved.
+#
+# Contributor(s):
+#   Mark Pilgrim - port to Python
+#
+# This library is free software; you can redistribute it and/or
+# modify it under the terms of the GNU Lesser General Public
+# License as published by the Free Software Foundation; either
+# version 2.1 of the License, or (at your option) any later version.
+#
+# This library is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+# Lesser General Public License for more details.
+#
+# You should have received a copy of the GNU Lesser General Public
+# License along with this library; if not, write to the Free Software
+# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
+# 02110-1301  USA
+######################### END LICENSE BLOCK #########################
+
+from .chardistribution import EUCKRDistributionAnalysis
+from .codingstatemachine import CodingStateMachine
+from .mbcharsetprober import MultiByteCharSetProber
+from .mbcssm import CP949_SM_MODEL
+
+
+class CP949Prober(MultiByteCharSetProber):
+    def __init__(self):
+        super(CP949Prober, self).__init__()
+        self.coding_sm = CodingStateMachine(CP949_SM_MODEL)
+        # NOTE: CP949 is a superset of EUC-KR, so the distribution should be
+        #       not different.
+        self.distribution_analyzer = EUCKRDistributionAnalysis()
+        self.reset()
+
+    @property
+    def charset_name(self):
+        return "CP949"
+
+    @property
+    def language(self):
+        return "Korean"
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/cp949prober.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/cp949prober.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..6524f453ec701a4321c80678acbeace50e82d3c2
GIT binary patch
literal 1600
zcmZSn%**AGdLky70ScHI7#JKF7#ND97#J8*7#LC*8FCmHav2$-7#SErd?tn*CWc&Q
zhA3tTpP3<tg&~)fA&M2kXJN=;W5{J^h+=18Okrh6Wo1ZXWJqCSXklPzW?+bn;$TQ&
zX9(8dU|?X#WMp7q&;Su7k_-$CuA$D}K`xoaB}JJ@r6rm9d5(FBIhDnk#SkSz3=9m;
z`6-!s>A@w5C8@rN$r+h>sSr6a1_lP-(wve^r^=F4=ZwUn;M9_UqWq-PB8WU6NN<3p
ziDi7SZ@jO+i>prwH%thk4juqZ3=9lTpa9TkU|>jP0QozG0p$89CWcgIP<ViR!pIQC
z0_HM-q?#E)-VX}a0EJ#M$U`6u;y8m$vSDCgC}ChIVPvRbU}$Dy$YKHo1!D;_LkSB*
zGgvg9m7#<UBwEA35YG-$m&F0%f`U94><2#$PLMIIAOlMaQj3CEKwMBT#>Z#oWtPOp
z2Z1aN0@+%^$-uyn3=XUK;@lum)Ru^X;u9%w;}b!lTa{W=0y45FwK%l|Y)=Wu+~U-n
zG!2k8Fi~8@z`&qiP?TAgSdyw=mRO{pmY<W7T2!o`l%ijrl$4iinp<pSm}H(_m2P2b
zQJ#}kWo7^Z>3RAg`URN<x|w;!C5bsXx^872p2h(nAux_FOU+BkFVauWNGwW8EzwUd
zur#qO0LPnNL1hpd0|SFH$iE<8GB64=@-y==!h;v&TX67#9Gt?)5Uc@;IzO;?oI!C7
zc01TlL0q7OHqibl;Q_@;Mq*KMYDs)vVs5H7$ZsG=GcXbK6(}sc^NUgw^9G%_K(UjP
zn3rCfn4SvCG{q1vX@Hzu0+Nge`!+tl1QZSN@wxdar8%kb@!<FcD<~++FGwvasSE;z
zP!K4yLOeOpF$T_KN}yN*`Gt*<lY^fHnhyn_ahZaYr63s%R8B$iUNNYg%7v6u;LKUV
z&%nTtn*>Vk#i=EbgdPM6trC#=xk<^z#kt@N47PZ1gaJ5$Y#?!FCj$x#P?QQVf*~^i
D*^74r

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/enums.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/enums.py
new file mode 100644
index 0000000..0451207
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/enums.py
@@ -0,0 +1,76 @@
+"""
+All of the Enums that are used throughout the chardet package.
+
+:author: Dan Blanchard (dan.blanchard@gmail.com)
+"""
+
+
+class InputState(object):
+    """
+    This enum represents the different states a universal detector can be in.
+    """
+    PURE_ASCII = 0
+    ESC_ASCII = 1
+    HIGH_BYTE = 2
+
+
+class LanguageFilter(object):
+    """
+    This enum represents the different language filters we can apply to a
+    ``UniversalDetector``.
+    """
+    CHINESE_SIMPLIFIED = 0x01
+    CHINESE_TRADITIONAL = 0x02
+    JAPANESE = 0x04
+    KOREAN = 0x08
+    NON_CJK = 0x10
+    ALL = 0x1F
+    CHINESE = CHINESE_SIMPLIFIED | CHINESE_TRADITIONAL
+    CJK = CHINESE | JAPANESE | KOREAN
+
+
+class ProbingState(object):
+    """
+    This enum represents the different states a prober can be in.
+    """
+    DETECTING = 0
+    FOUND_IT = 1
+    NOT_ME = 2
+
+
+class MachineState(object):
+    """
+    This enum represents the different states a state machine can be in.
+    """
+    START = 0
+    ERROR = 1
+    ITS_ME = 2
+
+
+class SequenceLikelihood(object):
+    """
+    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):
+        """:returns: The number of likelihood categories in the enum."""
+        return 4
+
+
+class CharacterCategory(object):
+    """
+    This enum represents the different categories language models for
+    ``SingleByteCharsetProber`` put characters into.
+
+    Anything less than CONTROL is considered a letter.
+    """
+    UNDEFINED = 255
+    LINE_BREAK = 254
+    SYMBOL = 253
+    DIGIT = 252
+    CONTROL = 251
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/enums.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/enums.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..c599f11001b38a824619cf1b1623edc471d168bd
GIT binary patch
literal 3505
zcmZSn%**AGdLky70ScHI7#JKF7#NEC7#J8*7#N}$7*ZG+QW+W27#UKS7+M$@ni&`(
zqnH>{m|>zUa8YK46jqoh8(fryA%z_#$^jQ;Wk}(KiE_b3*%(r|VWK>6QFewDUWQ-|
zK9IYL7#JA19CLCM^3xPbGEx;>^Gb7z6-qJ^OB51|QWZ*zQ&SX5GK%s`(=+l*OTbE!
zGZKqZQcDyH5|gtN(^K`hxU3ROOEU6{tQ1@l^AwzN67#@H6f{y2^YoHnT!-}B#LOJM
z<osMst`aT=1_sZ(g3^-UlEji!cyKW?FfcfQoTb3Pz>vzo5XA@%G$v4>MKOayEQ$pb
zR8g!9LBSd<AeF%&4=5-oD1>BW7AvIYmF6lGr4|&W7N_QwfIO0_kdm2}mRgjWSE5i1
zvaDDkQK2+1vn;i!I59^dCAB0qxg@_xAvrNmAt_ZMGf$5TWLhRD0y9DG$z)<+V9;P=
zU|=ZWU|?W~kIzfYO^uHSdm%nPH$SB`2gGFu%cbNeL!|;jgIwbsgPlD+OE?)A7+iy$
zk$4`S?jG?@ks+=cAZrjraSj6mgML9#W?5oMs(x8wk$zf!PD*M~v3^pDetA+-Uao0w
zv5{etd3sg4g{eh(PF9tf0SKh$>4)eSWESXV<`tJD=H%$Qm3ep?2Y`gYIKC`3FD1W7
z9~?2MCHkOnD%LBg3<B8?@>Vg3U}I)u1i=ze((p;lOD|1KPj$=8DM>AYM-eDAz)|Ey
zFp5%G7^2ufX*i0VA%%@0ii07QnIV;h!6}N9A(fLMm6gFMm5sqEiVGB(pztfsA|Wz!
zpzc#h13R!-p*$5FiHQXTIh6_}`3i~Ph)hTbg+;atG_Dg8pm7Y3-b_$Z$^->LrT_y2
zL#8|^%DEXB7=l1bf<S%_0%heAAqEBpXAe(5*I?K9U{BuwA5S+=SC<lDB;k-CM;Ff!
zPk%p0A8>;4atv?;sV@N~A#eX6S4Y1RkZ1k;{o<Xyyh}jlI{Ns4#h^xm#hkso5eWm#
zqJQcDxl<67%Rv5SV*#ZN1m<Ea;bCB42q?-=%FIirI3v505clwmTu_vsluA_QMUP2P
zrgU))adi&y^m7MCl$(F3pG&-F2sonr{6pe>2R?g(QX{A=M9rR{VE0W-&dAJ5r8wCA
z$O(3E_$%Z>oB+;s1d2}d&}U^}U<eLz3<@a$v0Q_K{DZ*3?imt17=m4dfq_92l<q-A
z0=!fNWrE<;!qU{d<W!%`?9`mhjQso*%#zWR$dWOY9aK1i+5n88!Z9cqT+0+k5R8!=
zxaFW~J5d2tswXCwq!uZp<>%z&muKdsgKO%7qSUg?{L*5D{Jd0Xkq0X85!G5IsPIV!
zm2oia4DvOoG)!S+2-W}<e8pA_3=CF9sU@XFdBs)=AsML(d8N6aT$i7wfaH?o#FEtX
z{G!a%Vuj2+u=SuyMh{%Hf{QN=kR9NnEjgzcA_8&^-AgraA)cOE5}#L^8;@|cHOS{6
z4>K@pfC>lnBnwIkey;A0A)aBb;PN8W&&Si-)h801aG^|)q5%J3Pp~3T1(KYTSX`W&
zT9T2U5+ntxRX|=IK+gwBFfcF}fxHSTL|{pqjggJ11XR#FXCxMZQ<5_zHY?$&8x(oq
zdS8dg)Sbf05XBCv*+KPQ@eYEC8qrKc#EAmDlF!XgNzEx%NXsvR*6P8TdFeT+PL(C8
zAU7AMmVoM^)S`q0g@V!&M2-L@#*%zJF0d}gyvmXcQ0B-<Ee5p>6Y~_D{ry6M{CyNM
zixrad^NKT5Qj1bk6cQD3QcFrwi=dh2Kd4Rc4@CS05r06$Z%|}{q8mM(fYMH=pNp%T
zr=P0}xRvPR>E{~n6y)mY4NfY-k-kp;KH!4S#nat01XA-u+<{0LU>4o;Mi8j7afBxi
zHbiajrvdgXsK5aGB0niBHMs=behdON6M{fhRS>A)1Sc`DL0~^12)g?QoK0;YO>{d@
RMN<q(^kST1{9>FS5&*#!O7;K%

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/escprober.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/escprober.py
new file mode 100644
index 0000000..c70493f
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/escprober.py
@@ -0,0 +1,101 @@
+######################## BEGIN LICENSE BLOCK ########################
+# The Original Code is mozilla.org code.
+#
+# The Initial Developer of the Original Code is
+# Netscape Communications Corporation.
+# Portions created by the Initial Developer are Copyright (C) 1998
+# the Initial Developer. All Rights Reserved.
+#
+# Contributor(s):
+#   Mark Pilgrim - port to Python
+#
+# This library is free software; you can redistribute it and/or
+# modify it under the terms of the GNU Lesser General Public
+# License as published by the Free Software Foundation; either
+# version 2.1 of the License, or (at your option) any later version.
+#
+# This library is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+# Lesser General Public License for more details.
+#
+# You should have received a copy of the GNU Lesser General Public
+# License along with this library; if not, write to the Free Software
+# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
+# 02110-1301  USA
+######################### END LICENSE BLOCK #########################
+
+from .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)
+
+
+class EscCharSetProber(CharSetProber):
+    """
+    This CharSetProber uses a "code scheme" approach for detecting encodings,
+    whereby easily recognizable escape or shift sequences are relied on to
+    identify these encodings.
+    """
+
+    def __init__(self, lang_filter=None):
+        super(EscCharSetProber, self).__init__(lang_filter=lang_filter)
+        self.coding_sm = []
+        if self.lang_filter & LanguageFilter.CHINESE_SIMPLIFIED:
+            self.coding_sm.append(CodingStateMachine(HZ_SM_MODEL))
+            self.coding_sm.append(CodingStateMachine(ISO2022CN_SM_MODEL))
+        if self.lang_filter & LanguageFilter.JAPANESE:
+            self.coding_sm.append(CodingStateMachine(ISO2022JP_SM_MODEL))
+        if self.lang_filter & LanguageFilter.KOREAN:
+            self.coding_sm.append(CodingStateMachine(ISO2022KR_SM_MODEL))
+        self.active_sm_count = None
+        self._detected_charset = None
+        self._detected_language = None
+        self._state = None
+        self.reset()
+
+    def reset(self):
+        super(EscCharSetProber, self).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)
+        self._detected_charset = None
+        self._detected_language = None
+
+    @property
+    def charset_name(self):
+        return self._detected_charset
+
+    @property
+    def language(self):
+        return self._detected_language
+
+    def get_confidence(self):
+        if self._detected_charset:
+            return 0.99
+        else:
+            return 0.00
+
+    def feed(self, byte_str):
+        for c in byte_str:
+            for coding_sm in self.coding_sm:
+                if not coding_sm or not coding_sm.active:
+                    continue
+                coding_state = coding_sm.next_state(c)
+                if coding_state == MachineState.ERROR:
+                    coding_sm.active = False
+                    self.active_sm_count -= 1
+                    if self.active_sm_count <= 0:
+                        self._state = ProbingState.NOT_ME
+                        return self.state
+                elif coding_state == MachineState.ITS_ME:
+                    self._state = ProbingState.FOUND_IT
+                    self._detected_charset = coding_sm.get_coding_state_machine()
+                    self._detected_language = coding_sm.language
+                    return self.state
+
+        return self.state
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/escprober.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/escprober.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..589484872ec22077d252708a255351fb5b553673
GIT binary patch
literal 3607
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

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/escsm.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/escsm.py
new file mode 100644
index 0000000..0069523
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/escsm.py
@@ -0,0 +1,246 @@
+######################## BEGIN LICENSE BLOCK ########################
+# The Original Code is mozilla.org code.
+#
+# The Initial Developer of the Original Code is
+# Netscape Communications Corporation.
+# Portions created by the Initial Developer are Copyright (C) 1998
+# the Initial Developer. All Rights Reserved.
+#
+# Contributor(s):
+#   Mark Pilgrim - port to Python
+#
+# This library is free software; you can redistribute it and/or
+# modify it under the terms of the GNU Lesser General Public
+# License as published by the Free Software Foundation; either
+# version 2.1 of the License, or (at your option) any later version.
+#
+# This library is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+# Lesser General Public License for more details.
+#
+# You should have received a copy of the GNU Lesser General Public
+# License along with this library; if not, write to the Free Software
+# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
+# 02110-1301  USA
+######################### END LICENSE BLOCK #########################
+
+from .enums import MachineState
+
+HZ_CLS = (
+1,0,0,0,0,0,0,0,  # 00 - 07
+0,0,0,0,0,0,0,0,  # 08 - 0f
+0,0,0,0,0,0,0,0,  # 10 - 17
+0,0,0,1,0,0,0,0,  # 18 - 1f
+0,0,0,0,0,0,0,0,  # 20 - 27
+0,0,0,0,0,0,0,0,  # 28 - 2f
+0,0,0,0,0,0,0,0,  # 30 - 37
+0,0,0,0,0,0,0,0,  # 38 - 3f
+0,0,0,0,0,0,0,0,  # 40 - 47
+0,0,0,0,0,0,0,0,  # 48 - 4f
+0,0,0,0,0,0,0,0,  # 50 - 57
+0,0,0,0,0,0,0,0,  # 58 - 5f
+0,0,0,0,0,0,0,0,  # 60 - 67
+0,0,0,0,0,0,0,0,  # 68 - 6f
+0,0,0,0,0,0,0,0,  # 70 - 77
+0,0,0,4,0,5,2,0,  # 78 - 7f
+1,1,1,1,1,1,1,1,  # 80 - 87
+1,1,1,1,1,1,1,1,  # 88 - 8f
+1,1,1,1,1,1,1,1,  # 90 - 97
+1,1,1,1,1,1,1,1,  # 98 - 9f
+1,1,1,1,1,1,1,1,  # a0 - a7
+1,1,1,1,1,1,1,1,  # a8 - af
+1,1,1,1,1,1,1,1,  # b0 - b7
+1,1,1,1,1,1,1,1,  # b8 - bf
+1,1,1,1,1,1,1,1,  # c0 - c7
+1,1,1,1,1,1,1,1,  # c8 - cf
+1,1,1,1,1,1,1,1,  # d0 - d7
+1,1,1,1,1,1,1,1,  # d8 - df
+1,1,1,1,1,1,1,1,  # e0 - e7
+1,1,1,1,1,1,1,1,  # e8 - ef
+1,1,1,1,1,1,1,1,  # f0 - f7
+1,1,1,1,1,1,1,1,  # f8 - ff
+)
+
+HZ_ST = (
+MachineState.START,MachineState.ERROR,     3,MachineState.START,MachineState.START,MachineState.START,MachineState.ERROR,MachineState.ERROR,# 00-07
+MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,# 08-0f
+MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ERROR,MachineState.ERROR,MachineState.START,MachineState.START,     4,MachineState.ERROR,# 10-17
+     5,MachineState.ERROR,     6,MachineState.ERROR,     5,     5,     4,MachineState.ERROR,# 18-1f
+     4,MachineState.ERROR,     4,     4,     4,MachineState.ERROR,     4,MachineState.ERROR,# 20-27
+     4,MachineState.ITS_ME,MachineState.START,MachineState.START,MachineState.START,MachineState.START,MachineState.START,MachineState.START,# 28-2f
+)
+
+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'}
+
+ISO2022CN_CLS = (
+2,0,0,0,0,0,0,0,  # 00 - 07
+0,0,0,0,0,0,0,0,  # 08 - 0f
+0,0,0,0,0,0,0,0,  # 10 - 17
+0,0,0,1,0,0,0,0,  # 18 - 1f
+0,0,0,0,0,0,0,0,  # 20 - 27
+0,3,0,0,0,0,0,0,  # 28 - 2f
+0,0,0,0,0,0,0,0,  # 30 - 37
+0,0,0,0,0,0,0,0,  # 38 - 3f
+0,0,0,4,0,0,0,0,  # 40 - 47
+0,0,0,0,0,0,0,0,  # 48 - 4f
+0,0,0,0,0,0,0,0,  # 50 - 57
+0,0,0,0,0,0,0,0,  # 58 - 5f
+0,0,0,0,0,0,0,0,  # 60 - 67
+0,0,0,0,0,0,0,0,  # 68 - 6f
+0,0,0,0,0,0,0,0,  # 70 - 77
+0,0,0,0,0,0,0,0,  # 78 - 7f
+2,2,2,2,2,2,2,2,  # 80 - 87
+2,2,2,2,2,2,2,2,  # 88 - 8f
+2,2,2,2,2,2,2,2,  # 90 - 97
+2,2,2,2,2,2,2,2,  # 98 - 9f
+2,2,2,2,2,2,2,2,  # a0 - a7
+2,2,2,2,2,2,2,2,  # a8 - af
+2,2,2,2,2,2,2,2,  # b0 - b7
+2,2,2,2,2,2,2,2,  # b8 - bf
+2,2,2,2,2,2,2,2,  # c0 - c7
+2,2,2,2,2,2,2,2,  # c8 - cf
+2,2,2,2,2,2,2,2,  # d0 - d7
+2,2,2,2,2,2,2,2,  # d8 - df
+2,2,2,2,2,2,2,2,  # e0 - e7
+2,2,2,2,2,2,2,2,  # e8 - ef
+2,2,2,2,2,2,2,2,  # f0 - f7
+2,2,2,2,2,2,2,2,  # f8 - ff
+)
+
+ISO2022CN_ST = (
+MachineState.START,     3,MachineState.ERROR,MachineState.START,MachineState.START,MachineState.START,MachineState.START,MachineState.START,# 00-07
+MachineState.START,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,# 08-0f
+MachineState.ERROR,MachineState.ERROR,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,# 10-17
+MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,     4,MachineState.ERROR,# 18-1f
+MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ITS_ME,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,# 20-27
+     5,     6,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,# 28-2f
+MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ITS_ME,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,# 30-37
+MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ITS_ME,MachineState.ERROR,MachineState.START,# 38-3f
+)
+
+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'}
+
+ISO2022JP_CLS = (
+2,0,0,0,0,0,0,0,  # 00 - 07
+0,0,0,0,0,0,2,2,  # 08 - 0f
+0,0,0,0,0,0,0,0,  # 10 - 17
+0,0,0,1,0,0,0,0,  # 18 - 1f
+0,0,0,0,7,0,0,0,  # 20 - 27
+3,0,0,0,0,0,0,0,  # 28 - 2f
+0,0,0,0,0,0,0,0,  # 30 - 37
+0,0,0,0,0,0,0,0,  # 38 - 3f
+6,0,4,0,8,0,0,0,  # 40 - 47
+0,9,5,0,0,0,0,0,  # 48 - 4f
+0,0,0,0,0,0,0,0,  # 50 - 57
+0,0,0,0,0,0,0,0,  # 58 - 5f
+0,0,0,0,0,0,0,0,  # 60 - 67
+0,0,0,0,0,0,0,0,  # 68 - 6f
+0,0,0,0,0,0,0,0,  # 70 - 77
+0,0,0,0,0,0,0,0,  # 78 - 7f
+2,2,2,2,2,2,2,2,  # 80 - 87
+2,2,2,2,2,2,2,2,  # 88 - 8f
+2,2,2,2,2,2,2,2,  # 90 - 97
+2,2,2,2,2,2,2,2,  # 98 - 9f
+2,2,2,2,2,2,2,2,  # a0 - a7
+2,2,2,2,2,2,2,2,  # a8 - af
+2,2,2,2,2,2,2,2,  # b0 - b7
+2,2,2,2,2,2,2,2,  # b8 - bf
+2,2,2,2,2,2,2,2,  # c0 - c7
+2,2,2,2,2,2,2,2,  # c8 - cf
+2,2,2,2,2,2,2,2,  # d0 - d7
+2,2,2,2,2,2,2,2,  # d8 - df
+2,2,2,2,2,2,2,2,  # e0 - e7
+2,2,2,2,2,2,2,2,  # e8 - ef
+2,2,2,2,2,2,2,2,  # f0 - f7
+2,2,2,2,2,2,2,2,  # f8 - ff
+)
+
+ISO2022JP_ST = (
+MachineState.START,     3,MachineState.ERROR,MachineState.START,MachineState.START,MachineState.START,MachineState.START,MachineState.START,# 00-07
+MachineState.START,MachineState.START,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,# 08-0f
+MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,# 10-17
+MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ERROR,MachineState.ERROR,# 18-1f
+MachineState.ERROR,     5,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,     4,MachineState.ERROR,MachineState.ERROR,# 20-27
+MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,     6,MachineState.ITS_ME,MachineState.ERROR,MachineState.ITS_ME,MachineState.ERROR,# 28-2f
+MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ITS_ME,MachineState.ITS_ME,# 30-37
+MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ITS_ME,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,# 38-3f
+MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ITS_ME,MachineState.ERROR,MachineState.START,MachineState.START,# 40-47
+)
+
+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'}
+
+ISO2022KR_CLS = (
+2,0,0,0,0,0,0,0,  # 00 - 07
+0,0,0,0,0,0,0,0,  # 08 - 0f
+0,0,0,0,0,0,0,0,  # 10 - 17
+0,0,0,1,0,0,0,0,  # 18 - 1f
+0,0,0,0,3,0,0,0,  # 20 - 27
+0,4,0,0,0,0,0,0,  # 28 - 2f
+0,0,0,0,0,0,0,0,  # 30 - 37
+0,0,0,0,0,0,0,0,  # 38 - 3f
+0,0,0,5,0,0,0,0,  # 40 - 47
+0,0,0,0,0,0,0,0,  # 48 - 4f
+0,0,0,0,0,0,0,0,  # 50 - 57
+0,0,0,0,0,0,0,0,  # 58 - 5f
+0,0,0,0,0,0,0,0,  # 60 - 67
+0,0,0,0,0,0,0,0,  # 68 - 6f
+0,0,0,0,0,0,0,0,  # 70 - 77
+0,0,0,0,0,0,0,0,  # 78 - 7f
+2,2,2,2,2,2,2,2,  # 80 - 87
+2,2,2,2,2,2,2,2,  # 88 - 8f
+2,2,2,2,2,2,2,2,  # 90 - 97
+2,2,2,2,2,2,2,2,  # 98 - 9f
+2,2,2,2,2,2,2,2,  # a0 - a7
+2,2,2,2,2,2,2,2,  # a8 - af
+2,2,2,2,2,2,2,2,  # b0 - b7
+2,2,2,2,2,2,2,2,  # b8 - bf
+2,2,2,2,2,2,2,2,  # c0 - c7
+2,2,2,2,2,2,2,2,  # c8 - cf
+2,2,2,2,2,2,2,2,  # d0 - d7
+2,2,2,2,2,2,2,2,  # d8 - df
+2,2,2,2,2,2,2,2,  # e0 - e7
+2,2,2,2,2,2,2,2,  # e8 - ef
+2,2,2,2,2,2,2,2,  # f0 - f7
+2,2,2,2,2,2,2,2,  # f8 - ff
+)
+
+ISO2022KR_ST = (
+MachineState.START,     3,MachineState.ERROR,MachineState.START,MachineState.START,MachineState.START,MachineState.ERROR,MachineState.ERROR,# 00-07
+MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,# 08-0f
+MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,     4,MachineState.ERROR,MachineState.ERROR,# 10-17
+MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,     5,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,# 18-1f
+MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ITS_ME,MachineState.START,MachineState.START,MachineState.START,MachineState.START,# 20-27
+)
+
+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'}
+
+
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/escsm.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/escsm.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..b708c1f2796884ab50ea1b5904f04717bb82c235
GIT binary patch
literal 8062
zcmZSn%**AGdLky70R|Wu7#tWF7>Y&M7#LC*7*ZG+au^tL85yD&85mQf7^0XMQW+Vt
zn873qLkb(10pTK(EMRf`Br8}AeiGRPnE5FX1`9(9Og4obY!p}|g@pm30Irf5B#2cU
z<Q<3`Ac}F5X$A~YYz!&V3{mV1nQRQHObjU;3}z|p3@MxpW~popDO?O@sq73X+ze(Z
zJPawk3}z{O3@Q8!W>FjrDKZREoM1;X!vYQBc-+>390rkvs3etyc#2dK)fRY&fgFP>
z1rmW6jwud_2w0?mRAN(uPaL<&_;f*RLDtL6kmkS;#l?^!%Mis4jx|n5tO-D3jSCWM
z+>lrkM2R&Xh7>u5C|+`7jgq)S_6Wo~q>>O5U?e=JAcr1-$Yo)GW-Ex*5TlUU5E1+&
zL_LJWREbL*QzfzpvMxv<Gc%-lFhub&q{uTw@q=TT7ZS@NkXYt}#4<l5mPH}4EC$J&
z0t_h%3{ir_#WJ!paIqoI!%w2>B^VKqSi>5L5GiyLVmmBwK(a7)ng&CZ5JQS0LzFN$
zpadZS1uevcAOR%|2`F($KuJIXN`xUrk|9__iGhJ3laYaeK?6jT@Gvki_$DT2Wagy?
zmn4>?W`Zh`OcszLRuI7iBA7u08v_GF2{!`+Lvl`HadCV}Vp2{jSUZHDmY7_UUj$ZA
z3^E9+fDfc0Be5txCp8ZuRLsS|z~B+3>+Ym$WNc_u0<tSFF*mh@oq>VD8RU@S)DjK`
z28Nu(y!6t<^wdmFP=yAv*)!N**T}%gNY~jf6Qnv5q%0F;UNMTaR{+=muf&4Hywu`U
zR7vlk5|CHC^NUgw^ZYaz7@^?-@j2N014V#hWDq!Gpu9iq?FA)uNc<x57TD9^h#w^&
z1rxY*8YN)G5*?C-2B<)UBusE}#6m#INpNj|MHatas>_0dgkooaYc+~Zp~L`0c|eIN
zBS<ee{f!a~nWJGa5MiJJYKf9mno+aZM8r9nIi93q6WqQ=vuL17OhomBC^5lJe>C@j
zx!^bgx39q5QDPu+%4h+_FdFQjQ3Ft+r2*=plT>Vi6;re9q_`9ysqDmAP9lmgiXB9z
z0iy*Y12}OJO@I>cXlXWDnhj7oAf{_B3L2ROW$e_v(%j-8P{{xu;`E4$clHS`0m%f1
zI0l7)S*}4r{*Vz+&ye7FUstf8M^t=pNQoeLU^d>_!!an{$JH-B#L>ye6+EH~lJ|}G
z^>=agDdA;cVDJp~2aUrz`++S0jUgjMf<sCqP?eyXCxjvyjKx^50CZ!$0zmFVG8Uu+
zr?DW_Sd8@!LO0es2+dfK5}d|@R6~u`0EIDvD9&MEV9+lp$}CGPN!2e)EYeTQ&q+xw
zD%MX*(JxO*%F8v)EjBVtGEc8cw=lIR&&jGXGXR0~JpB;;g3JQl%)H`~#GD*mw=xe;
z;{cEl7{`~T=B4Bp=_h9-7Nw+?=%*GZ7w75~RDy@MZF2KdN^?@}WI)5?1&j;~0?Z7I
zlt4BXT}A^&T}DMlMMh(0HYP4cb|~bcipe0e4H&f;4H(U6VmiodkPm2MzAmFKn!5qu
CzglAe

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/eucjpprober.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/eucjpprober.py
new file mode 100644
index 0000000..20ce8f7
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/eucjpprober.py
@@ -0,0 +1,92 @@
+######################## BEGIN LICENSE BLOCK ########################
+# The Original Code is mozilla.org code.
+#
+# The Initial Developer of the Original Code is
+# Netscape Communications Corporation.
+# Portions created by the Initial Developer are Copyright (C) 1998
+# the Initial Developer. All Rights Reserved.
+#
+# Contributor(s):
+#   Mark Pilgrim - port to Python
+#
+# This library is free software; you can redistribute it and/or
+# modify it under the terms of the GNU Lesser General Public
+# License as published by the Free Software Foundation; either
+# version 2.1 of the License, or (at your option) any later version.
+#
+# This library is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+# Lesser General Public License for more details.
+#
+# You should have received a copy of the GNU Lesser General Public
+# License along with this library; if not, write to the Free Software
+# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
+# 02110-1301  USA
+######################### END LICENSE BLOCK #########################
+
+from .enums import ProbingState, MachineState
+from .mbcharsetprober import MultiByteCharSetProber
+from .codingstatemachine import CodingStateMachine
+from .chardistribution import EUCJPDistributionAnalysis
+from .jpcntx import EUCJPContextAnalysis
+from .mbcssm import EUCJP_SM_MODEL
+
+
+class EUCJPProber(MultiByteCharSetProber):
+    def __init__(self):
+        super(EUCJPProber, self).__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()
+        self.context_analyzer.reset()
+
+    @property
+    def charset_name(self):
+        return "EUC-JP"
+
+    @property
+    def language(self):
+        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])
+            if coding_state == MachineState.ERROR:
+                self.logger.debug('%s %s prober hit error at byte %s',
+                                  self.charset_name, self.language, i)
+                self._state = ProbingState.NOT_ME
+                break
+            elif coding_state == MachineState.ITS_ME:
+                self._state = ProbingState.FOUND_IT
+                break
+            elif 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, char_len)
+                    self.distribution_analyzer.feed(self._last_char, char_len)
+                else:
+                    self.context_analyzer.feed(byte_str[i - 1:i + 1],
+                                                char_len)
+                    self.distribution_analyzer.feed(byte_str[i - 1:i + 1],
+                                                     char_len)
+
+        self._last_char[0] = byte_str[-1]
+
+        if self.state == ProbingState.DETECTING:
+            if (self.context_analyzer.got_enough_data() and
+               (self.get_confidence() > self.SHORTCUT_THRESHOLD)):
+                self._state = ProbingState.FOUND_IT
+
+        return self.state
+
+    def get_confidence(self):
+        context_conf = self.context_analyzer.get_confidence()
+        distrib_conf = self.distribution_analyzer.get_confidence()
+        return max(context_conf, distrib_conf)
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/eucjpprober.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/eucjpprober.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..c8771cdc2372a4e534759877aadd26b99281af2f
GIT binary patch
literal 3422
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
W9H};t$hMOKr43N1i7^VmATt0ED*iwK

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/euckrfreq.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/euckrfreq.py
new file mode 100644
index 0000000..b68078c
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/euckrfreq.py
@@ -0,0 +1,195 @@
+######################## BEGIN LICENSE BLOCK ########################
+# The Original Code is Mozilla Communicator client code.
+#
+# The Initial Developer of the Original Code is
+# Netscape Communications Corporation.
+# Portions created by the Initial Developer are Copyright (C) 1998
+# the Initial Developer. All Rights Reserved.
+#
+# Contributor(s):
+#   Mark Pilgrim - port to Python
+#
+# This library is free software; you can redistribute it and/or
+# modify it under the terms of the GNU Lesser General Public
+# License as published by the Free Software Foundation; either
+# version 2.1 of the License, or (at your option) any later version.
+#
+# This library is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+# Lesser General Public License for more details.
+#
+# You should have received a copy of the GNU Lesser General Public
+# License along with this library; if not, write to the Free Software
+# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
+# 02110-1301  USA
+######################### END LICENSE BLOCK #########################
+
+# Sampling from about 20M text materials include literature and computer technology
+
+# 128  --> 0.79
+# 256  --> 0.92
+# 512  --> 0.986
+# 1024 --> 0.99944
+# 2048 --> 0.99999
+#
+# Idea Distribution Ratio = 0.98653 / (1-0.98653) = 73.24
+# Random Distribution Ration = 512 / (2350-512) = 0.279.
+#
+# Typical Distribution Ratio
+
+EUCKR_TYPICAL_DISTRIBUTION_RATIO = 6.0
+
+EUCKR_TABLE_SIZE = 2352
+
+# Char to FreqOrder table ,
+EUCKR_CHAR_TO_FREQ_ORDER = (
+  13, 130, 120,1396, 481,1719,1720, 328, 609, 212,1721, 707, 400, 299,1722,  87,
+1397,1723, 104, 536,1117,1203,1724,1267, 685,1268, 508,1725,1726,1727,1728,1398,
+1399,1729,1730,1731, 141, 621, 326,1057, 368,1732, 267, 488,  20,1733,1269,1734,
+ 945,1400,1735,  47, 904,1270,1736,1737, 773, 248,1738, 409, 313, 786, 429,1739,
+ 116, 987, 813,1401, 683,  75,1204, 145,1740,1741,1742,1743,  16, 847, 667, 622,
+ 708,1744,1745,1746, 966, 787, 304, 129,1747,  60, 820, 123, 676,1748,1749,1750,
+1751, 617,1752, 626,1753,1754,1755,1756, 653,1757,1758,1759,1760,1761,1762, 856,
+ 344,1763,1764,1765,1766,  89, 401, 418, 806, 905, 848,1767,1768,1769, 946,1205,
+ 709,1770,1118,1771, 241,1772,1773,1774,1271,1775, 569,1776, 999,1777,1778,1779,
+1780, 337, 751,1058,  28, 628, 254,1781, 177, 906, 270, 349, 891,1079,1782,  19,
+1783, 379,1784, 315,1785, 629, 754,1402, 559,1786, 636, 203,1206,1787, 710, 567,
+1788, 935, 814,1789,1790,1207, 766, 528,1791,1792,1208,1793,1794,1795,1796,1797,
+1403,1798,1799, 533,1059,1404,1405,1156,1406, 936, 884,1080,1800, 351,1801,1802,
+1803,1804,1805, 801,1806,1807,1808,1119,1809,1157, 714, 474,1407,1810, 298, 899,
+ 885,1811,1120, 802,1158,1812, 892,1813,1814,1408, 659,1815,1816,1121,1817,1818,
+1819,1820,1821,1822, 319,1823, 594, 545,1824, 815, 937,1209,1825,1826, 573,1409,
+1022,1827,1210,1828,1829,1830,1831,1832,1833, 556, 722, 807,1122,1060,1834, 697,
+1835, 900, 557, 715,1836,1410, 540,1411, 752,1159, 294, 597,1211, 976, 803, 770,
+1412,1837,1838,  39, 794,1413, 358,1839, 371, 925,1840, 453, 661, 788, 531, 723,
+ 544,1023,1081, 869,  91,1841, 392, 430, 790, 602,1414, 677,1082, 457,1415,1416,
+1842,1843, 475, 327,1024,1417, 795, 121,1844, 733, 403,1418,1845,1846,1847, 300,
+ 119, 711,1212, 627,1848,1272, 207,1849,1850, 796,1213, 382,1851, 519,1852,1083,
+ 893,1853,1854,1855, 367, 809, 487, 671,1856, 663,1857,1858, 956, 471, 306, 857,
+1859,1860,1160,1084,1861,1862,1863,1864,1865,1061,1866,1867,1868,1869,1870,1871,
+ 282,  96, 574,1872, 502,1085,1873,1214,1874, 907,1875,1876, 827, 977,1419,1420,
+1421, 268,1877,1422,1878,1879,1880, 308,1881,   2, 537,1882,1883,1215,1884,1885,
+ 127, 791,1886,1273,1423,1887,  34, 336, 404, 643,1888, 571, 654, 894, 840,1889,
+   0, 886,1274, 122, 575, 260, 908, 938,1890,1275, 410, 316,1891,1892, 100,1893,
+1894,1123,  48,1161,1124,1025,1895, 633, 901,1276,1896,1897, 115, 816,1898, 317,
+1899, 694,1900, 909, 734,1424, 572, 866,1425, 691,  85, 524,1010, 543, 394, 841,
+1901,1902,1903,1026,1904,1905,1906,1907,1908,1909,  30, 451, 651, 988, 310,1910,
+1911,1426, 810,1216,  93,1912,1913,1277,1217,1914, 858, 759,  45,  58, 181, 610,
+ 269,1915,1916, 131,1062, 551, 443,1000, 821,1427, 957, 895,1086,1917,1918, 375,
+1919, 359,1920, 687,1921, 822,1922, 293,1923,1924,  40, 662, 118, 692,  29, 939,
+ 887, 640, 482, 174,1925,  69,1162, 728,1428, 910,1926,1278,1218,1279, 386, 870,
+ 217, 854,1163, 823,1927,1928,1929,1930, 834,1931,  78,1932, 859,1933,1063,1934,
+1935,1936,1937, 438,1164, 208, 595,1938,1939,1940,1941,1219,1125,1942, 280, 888,
+1429,1430,1220,1431,1943,1944,1945,1946,1947,1280, 150, 510,1432,1948,1949,1950,
+1951,1952,1953,1954,1011,1087,1955,1433,1043,1956, 881,1957, 614, 958,1064,1065,
+1221,1958, 638,1001, 860, 967, 896,1434, 989, 492, 553,1281,1165,1959,1282,1002,
+1283,1222,1960,1961,1962,1963,  36, 383, 228, 753, 247, 454,1964, 876, 678,1965,
+1966,1284, 126, 464, 490, 835, 136, 672, 529, 940,1088,1435, 473,1967,1968, 467,
+  50, 390, 227, 587, 279, 378, 598, 792, 968, 240, 151, 160, 849, 882,1126,1285,
+ 639,1044, 133, 140, 288, 360, 811, 563,1027, 561, 142, 523,1969,1970,1971,   7,
+ 103, 296, 439, 407, 506, 634, 990,1972,1973,1974,1975, 645,1976,1977,1978,1979,
+1980,1981, 236,1982,1436,1983,1984,1089, 192, 828, 618, 518,1166, 333,1127,1985,
+ 818,1223,1986,1987,1988,1989,1990,1991,1992,1993, 342,1128,1286, 746, 842,1994,
+1995, 560, 223,1287,  98,   8, 189, 650, 978,1288,1996,1437,1997,  17, 345, 250,
+ 423, 277, 234, 512, 226,  97, 289,  42, 167,1998, 201,1999,2000, 843, 836, 824,
+ 532, 338, 783,1090, 182, 576, 436,1438,1439, 527, 500,2001, 947, 889,2002,2003,
+2004,2005, 262, 600, 314, 447,2006, 547,2007, 693, 738,1129,2008,  71,1440, 745,
+ 619, 688,2009, 829,2010,2011, 147,2012,  33, 948,2013,2014,  74, 224,2015,  61,
+ 191, 918, 399, 637,2016,1028,1130, 257, 902,2017,2018,2019,2020,2021,2022,2023,
+2024,2025,2026, 837,2027,2028,2029,2030, 179, 874, 591,  52, 724, 246,2031,2032,
+2033,2034,1167, 969,2035,1289, 630, 605, 911,1091,1168,2036,2037,2038,1441, 912,
+2039, 623,2040,2041, 253,1169,1290,2042,1442, 146, 620, 611, 577, 433,2043,1224,
+ 719,1170, 959, 440, 437, 534,  84, 388, 480,1131, 159, 220, 198, 679,2044,1012,
+ 819,1066,1443, 113,1225, 194, 318,1003,1029,2045,2046,2047,2048,1067,2049,2050,
+2051,2052,2053,  59, 913, 112,2054, 632,2055, 455, 144, 739,1291,2056, 273, 681,
+ 499,2057, 448,2058,2059, 760,2060,2061, 970, 384, 169, 245,1132,2062,2063, 414,
+1444,2064,2065,  41, 235,2066, 157, 252, 877, 568, 919, 789, 580,2067, 725,2068,
+2069,1292,2070,2071,1445,2072,1446,2073,2074,  55, 588,  66,1447, 271,1092,2075,
+1226,2076, 960,1013, 372,2077,2078,2079,2080,2081,1293,2082,2083,2084,2085, 850,
+2086,2087,2088,2089,2090, 186,2091,1068, 180,2092,2093,2094, 109,1227, 522, 606,
+2095, 867,1448,1093, 991,1171, 926, 353,1133,2096, 581,2097,2098,2099,1294,1449,
+1450,2100, 596,1172,1014,1228,2101,1451,1295,1173,1229,2102,2103,1296,1134,1452,
+ 949,1135,2104,2105,1094,1453,1454,1455,2106,1095,2107,2108,2109,2110,2111,2112,
+2113,2114,2115,2116,2117, 804,2118,2119,1230,1231, 805,1456, 405,1136,2120,2121,
+2122,2123,2124, 720, 701,1297, 992,1457, 927,1004,2125,2126,2127,2128,2129,2130,
+  22, 417,2131, 303,2132, 385,2133, 971, 520, 513,2134,1174,  73,1096, 231, 274,
+ 962,1458, 673,2135,1459,2136, 152,1137,2137,2138,2139,2140,1005,1138,1460,1139,
+2141,2142,2143,2144,  11, 374, 844,2145, 154,1232,  46,1461,2146, 838, 830, 721,
+1233, 106,2147,  90, 428, 462, 578, 566,1175, 352,2148,2149, 538,1234, 124,1298,
+2150,1462, 761, 565,2151, 686,2152, 649,2153,  72, 173,2154, 460, 415,2155,1463,
+2156,1235, 305,2157,2158,2159,2160,2161,2162, 579,2163,2164,2165,2166,2167, 747,
+2168,2169,2170,2171,1464, 669,2172,2173,2174,2175,2176,1465,2177,  23, 530, 285,
+2178, 335, 729,2179, 397,2180,2181,2182,1030,2183,2184, 698,2185,2186, 325,2187,
+2188, 369,2189, 799,1097,1015, 348,2190,1069, 680,2191, 851,1466,2192,2193,  10,
+2194, 613, 424,2195, 979, 108, 449, 589,  27, 172,  81,1031,  80, 774, 281, 350,
+1032, 525, 301, 582,1176,2196, 674,1045,2197,2198,1467, 730, 762,2199,2200,2201,
+2202,1468,2203, 993,2204,2205, 266,1070, 963,1140,2206,2207,2208, 664,1098, 972,
+2209,2210,2211,1177,1469,1470, 871,2212,2213,2214,2215,2216,1471,2217,2218,2219,
+2220,2221,2222,2223,2224,2225,2226,2227,1472,1236,2228,2229,2230,2231,2232,2233,
+2234,2235,1299,2236,2237, 200,2238, 477, 373,2239,2240, 731, 825, 777,2241,2242,
+2243, 521, 486, 548,2244,2245,2246,1473,1300,  53, 549, 137, 875,  76, 158,2247,
+1301,1474, 469, 396,1016, 278, 712,2248, 321, 442, 503, 767, 744, 941,1237,1178,
+1475,2249,  82, 178,1141,1179, 973,2250,1302,2251, 297,2252,2253, 570,2254,2255,
+2256,  18, 450, 206,2257, 290, 292,1142,2258, 511, 162,  99, 346, 164, 735,2259,
+1476,1477,   4, 554, 343, 798,1099,2260,1100,2261,  43, 171,1303, 139, 215,2262,
+2263, 717, 775,2264,1033, 322, 216,2265, 831,2266, 149,2267,1304,2268,2269, 702,
+1238, 135, 845, 347, 309,2270, 484,2271, 878, 655, 238,1006,1478,2272,  67,2273,
+ 295,2274,2275, 461,2276, 478, 942, 412,2277,1034,2278,2279,2280, 265,2281, 541,
+2282,2283,2284,2285,2286,  70, 852,1071,2287,2288,2289,2290,  21,  56, 509, 117,
+ 432,2291,2292, 331, 980, 552,1101, 148, 284, 105, 393,1180,1239, 755,2293, 187,
+2294,1046,1479,2295, 340,2296,  63,1047, 230,2297,2298,1305, 763,1306, 101, 800,
+ 808, 494,2299,2300,2301, 903,2302,  37,1072,  14,   5,2303,  79, 675,2304, 312,
+2305,2306,2307,2308,2309,1480,   6,1307,2310,2311,2312,   1, 470,  35,  24, 229,
+2313, 695, 210,  86, 778,  15, 784, 592, 779,  32,  77, 855, 964,2314, 259,2315,
+ 501, 380,2316,2317,  83, 981, 153, 689,1308,1481,1482,1483,2318,2319, 716,1484,
+2320,2321,2322,2323,2324,2325,1485,2326,2327, 128,  57,  68, 261,1048, 211, 170,
+1240,  31,2328,  51, 435, 742,2329,2330,2331, 635,2332, 264, 456,2333,2334,2335,
+ 425,2336,1486, 143, 507, 263, 943,2337, 363, 920,1487, 256,1488,1102, 243, 601,
+1489,2338,2339,2340,2341,2342,2343,2344, 861,2345,2346,2347,2348,2349,2350, 395,
+2351,1490,1491,  62, 535, 166, 225,2352,2353, 668, 419,1241, 138, 604, 928,2354,
+1181,2355,1492,1493,2356,2357,2358,1143,2359, 696,2360, 387, 307,1309, 682, 476,
+2361,2362, 332,  12, 222, 156,2363, 232,2364, 641, 276, 656, 517,1494,1495,1035,
+ 416, 736,1496,2365,1017, 586,2366,2367,2368,1497,2369, 242,2370,2371,2372,1498,
+2373, 965, 713,2374,2375,2376,2377, 740, 982,1499, 944,1500,1007,2378,2379,1310,
+1501,2380,2381,2382, 785, 329,2383,2384,1502,2385,2386,2387, 932,2388,1503,2389,
+2390,2391,2392,1242,2393,2394,2395,2396,2397, 994, 950,2398,2399,2400,2401,1504,
+1311,2402,2403,2404,2405,1049, 749,2406,2407, 853, 718,1144,1312,2408,1182,1505,
+2409,2410, 255, 516, 479, 564, 550, 214,1506,1507,1313, 413, 239, 444, 339,1145,
+1036,1508,1509,1314,1037,1510,1315,2411,1511,2412,2413,2414, 176, 703, 497, 624,
+ 593, 921, 302,2415, 341, 165,1103,1512,2416,1513,2417,2418,2419, 376,2420, 700,
+2421,2422,2423, 258, 768,1316,2424,1183,2425, 995, 608,2426,2427,2428,2429, 221,
+2430,2431,2432,2433,2434,2435,2436,2437, 195, 323, 726, 188, 897, 983,1317, 377,
+ 644,1050, 879,2438, 452,2439,2440,2441,2442,2443,2444, 914,2445,2446,2447,2448,
+ 915, 489,2449,1514,1184,2450,2451, 515,  64, 427, 495,2452, 583,2453, 483, 485,
+1038, 562, 213,1515, 748, 666,2454,2455,2456,2457, 334,2458, 780, 996,1008, 705,
+1243,2459,2460,2461,2462,2463, 114,2464, 493,1146, 366, 163,1516, 961,1104,2465,
+ 291,2466,1318,1105,2467,1517, 365,2468, 355, 951,1244,2469,1319,2470, 631,2471,
+2472, 218,1320, 364, 320, 756,1518,1519,1321,1520,1322,2473,2474,2475,2476, 997,
+2477,2478,2479,2480, 665,1185,2481, 916,1521,2482,2483,2484, 584, 684,2485,2486,
+ 797,2487,1051,1186,2488,2489,2490,1522,2491,2492, 370,2493,1039,1187,  65,2494,
+ 434, 205, 463,1188,2495, 125, 812, 391, 402, 826, 699, 286, 398, 155, 781, 771,
+ 585,2496, 590, 505,1073,2497, 599, 244, 219, 917,1018, 952, 646,1523,2498,1323,
+2499,2500,  49, 984, 354, 741,2501, 625,2502,1324,2503,1019, 190, 357, 757, 491,
+  95, 782, 868,2504,2505,2506,2507,2508,2509, 134,1524,1074, 422,1525, 898,2510,
+ 161,2511,2512,2513,2514, 769,2515,1526,2516,2517, 411,1325,2518, 472,1527,2519,
+2520,2521,2522,2523,2524, 985,2525,2526,2527,2528,2529,2530, 764,2531,1245,2532,
+2533,  25, 204, 311,2534, 496,2535,1052,2536,2537,2538,2539,2540,2541,2542, 199,
+ 704, 504, 468, 758, 657,1528, 196,  44, 839,1246, 272, 750,2543, 765, 862,2544,
+2545,1326,2546, 132, 615, 933,2547, 732,2548,2549,2550,1189,1529,2551, 283,1247,
+1053, 607, 929,2552,2553,2554, 930, 183, 872, 616,1040,1147,2555,1148,1020, 441,
+ 249,1075,2556,2557,2558, 466, 743,2559,2560,2561,  92, 514, 426, 420, 526,2562,
+2563,2564,2565,2566,2567,2568, 185,2569,2570,2571,2572, 776,1530, 658,2573, 362,
+2574, 361, 922,1076, 793,2575,2576,2577,2578,2579,2580,1531, 251,2581,2582,2583,
+2584,1532,  54, 612, 237,1327,2585,2586, 275, 408, 647, 111,2587,1533,1106, 465,
+   3, 458,   9,  38,2588, 107, 110, 890, 209,  26, 737, 498,2589,1534,2590, 431,
+ 202,  88,1535, 356, 287,1107, 660,1149,2591, 381,1536, 986,1150, 445,1248,1151,
+ 974,2592,2593, 846,2594, 446, 953, 184,1249,1250, 727,2595, 923, 193, 883,2596,
+2597,2598, 102, 324, 539, 817,2599, 421,1041,2600, 832,2601,  94, 175, 197, 406,
+2602, 459,2603,2604,2605,2606,2607, 330, 555,2608,2609,2610, 706,1108, 389,2611,
+2612,2613,2614, 233,2615, 833, 558, 931, 954,1251,2616,2617,1537, 546,2618,2619,
+1009,2620,2621,2622,1538, 690,1328,2623, 955,2624,1539,2625,2626, 772,2627,2628,
+2629,2630,2631, 924, 648, 863, 603,2632,2633, 934,1540, 864, 865,2634, 642,1042,
+ 670,1190,2635,2636,2637,2638, 168,2639, 652, 873, 542,1054,1541,2640,2641,2642,  # 512, 256
+)
+
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/euckrfreq.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/euckrfreq.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..9f4992a6a20162246ce2ac5d53d73128581b1942
GIT binary patch
literal 24134
zcmZSn%**AGdLky70SXK_85kTG7#NDh7#J8*7#N}$7*ZG+q8J%cj5wp17*Y&5gEfpf
z85q(b>Lna9K{_&d85kHcn?OVbh$vxYV90#P$iR@fosEGZa|ej<0C5wU7#K3IfRyY6
zi5&)UCx9fhLBuYQSU5<w6lB0|5H|zFl>n)WWno~*+zcZ2fFwSHSZhHNUqGxsAOrS-
zB=&)b{UG81h$sUYRSqH!g1Co3#9<K83o<zuWPlq;uOi5l0ubv6NR}JKdI2ItK<bWy
z#J+-*90Rd7GBYq_R)7pW4&v&Alyrc^zJZjS0EwLh5v(AwA0XLNAnr_%d6pnT2qdu<
z#5xU<C;=(C4HDA@5tSg5SA(494U*UbGISz{bq1vPEQmM<BF=*d0g!}0NZV|Xjyw=?
z1Vmf_$zB8zmq5fZkP=}KVF0qX5v1)hNWuohG66|cgIG&Idar;au7ZebAmTcR$OK8;
z0I`ZdteYU#Ef8@VMBD)py&#FZAl5w)aUVoH01*#C#3K+90kS9p<buZ_?h_F46hu4&
z5s@GlOa#d;0ugE;#hoA`07N_oDR}`RUV?~CAhE5Wz&Q%C_Z3Ji4#a&8VtoV|^#;Ux
z3nJcui0>fT_aK%fNXG{d>p94jk09135b+sAd;t-GAQ!v`sZ#=JlL47m0^<GyvA%+o
zYy`2oKnC!E6vu*yY7o~Pq~jY%i7-gXcMz)@B>MxzvIen!f>@;>^FD!yDo~v3gIK>n
z5;Y*!X^`G+AftYR#EyZ)%t6E-5O+DqB0UiC7sUMsBDRAR{{txz01^K|Vhrq{JP49t
z1hJSv1T%<W0THYqq8em58;HdYB1A!Yl|edcKoYeeq6NgQ1F=?stSkW$79cSWkdAne
zk2parE)c;DB6vUqFNjbCDdq#Q_(6mKh=>R26$G(bL9A0CD{p~JsR!911d`AKahpMU
zOF@J%NGt)QSP8^!1F=LvVl^PHD2OEnA{syjOa_@J4&q9Hh(wTLNf1j4L`Z`O84w{0
zBIH1XJ;*kB5Gx3zR}n-gfVlb~<5z-+ogh;bL1IcE!WN{Y5oFsxkgPIDY!^t03W%i&
zBGf>HI*8B!5t<-E2c+#1h)@S<O9JZv5n3SGogfKq5UT|ws|(_u1`#?Su_lmhG9Yd<
zi1h))Y6t061GzpF#N7?zUI6J;1`$jkq6MT_7i54Qh)@TmD=CmfD@Y;@q*os#Q4C_u
z1xXlyxJN<UsUSl|Kw`om)@2Z(03!Z_#4JI!rGi+|AVUp7+B!hm)`18ykVF(naT~~@
zr686SNXJQ#Y&%G-14I~sv>Ahl+aL*d5WxUa*9nr92ANU`GTsEF<SxjR$si?NAX!t8
zm>GyL2N60TiE@zQ;~;f=K&BLfSQa4JA0X~|kgO$$YXu@?K*sL{Nz{S#T7$&cK{{+e
zENhTNEl7zih-(KT>_J36NU<hJ;yH*lAEd(pBrzStas;uQK*S!9lItKPMj#>*#B~Nq
zxPXWbknuJk!WG1I0}<{Z!UIHjf(TWRtQUyo4I+F%gfEEj0}=ipLJDMZ0?1o-Aj<<l
zV&6bwwjjNMAnra8D+t8u2Du;@#0mis)*$Xh5YY_^&K?la3nF+x284o?^ntixAXYet
zhyW2LAlXO|iwR_}B*@+<5H}h`><8Hv17gL3h<cC`agZHxAns3)Y(L1*co0_!BpU!S
zZwiQL1{swAlCTD``anb-NUsNoNCZiMS|6EZAnq@aQB@!V>_O^SKnC=HBvyflB#`3Y
zASJUv5;h<r86=hhCP3O!L98?okqlC2021p2u~I+;BZx=`$yS1lZv`3p2PBpO63YY;
z#ULF9Ac-sx*A`?)Hi)$iq$3B!>IKQ(192ySJZ%GFC4s~yg1DPO+)$7yJRsI5kc2#l
z)de!j6U5C0nUV)0@<9X>$OQ!;Rw0Ne0ujX^q69>gf(SW~d51v;bc2k#12V-7#4Q8K
zmV<~%Aj`Et5(hx$#e#HHfFvqG#9xruK@d>|;zohgeFqt(3sPqVBDR8vB#;;{$mD8}
zx*8DC43ba-=~V~G?gq)e02yEkA|`|E-3wyXg9tm2x>}I7IuKC~Qd|#WrGr=vAl7=2
zDUBeO8AwMHh@}dWZ3eMgK!gU!%4r~VWgylT5K9)sS`E@s4k8*rVvj)D)`28iLE2nF
ztS*oXZh&N`fSlF`QrrfT{Rfgb1S0-}h$fKUG?45~khU-os~aR?4q~-~baa4-P7u)r
zBAh@H-5{19NJkHd6%7*W1+mmYdiy}Eeh@JML`(z`+dvlefMhR#v;~8lHVGs#8AMD0
z5mQ0LVUUtk5HStJl>lk002x0O<d10};s{7~I*2tLq+|w&m<b|gfr!~4f&nBu4P?<j
zkO4D5+&LhLxgcU5h?ox|7J!I_AYu`S_zbeh9%TGt5O*d>n=pvG1jH=_$u0%4(m<}?
z2jXggWHmv=Q4p~VBwGiPeF>6{0TIVRL<5MJ1v2k0i1h~KDov0&Mvz!9NbhoxUM3Lt
z6-Ws)h;<Aku>vHq5=5*55vxIj3dnEuAXA=zSRX+~eFw3QfyCB;l;nU+Sq73=3*xQ=
z5iB4>>p<!*fYiML5zZiW9U!p<AjN_pVhu>l0c81XkdB)mb?ZR}Yyc6LL0lt{jy4eM
zF^J_2(k2e#R)L5x5LW_Z$_Wth0i<L)h*$t30zqO$AR-N92P?>qdXNqg5VsYiqz6PO
zfQ-rj5!xWd#vmokASH$%Rv$<SH;A<n<f=^|Vl#+f2T6dsbD0_-z1u;=bP(|iL{x!v
z+yj}n1*CW@h}Z@qwu6XPkn9c+YbS`<1tNBXh&>=;FNk;pGJYS3H3#JI{UFu>5a9@N
z+5wQP4aoQ`kWp+Pq7NkD3$i>N#5xF4Yy?tr9K<~Y;vNPOM?l0;5OEAd90w66K*UK9
z5e70K1EhluWbZ4G$zC8+PJv`kg9rnV*nN--*g;B?Kr9Xru@^*ifn+a%bZ~%V&wzBy
z1+mV8Sb`uWksv#Mfmq8yEKv~g3dCgq>3sxZC4vY=kc1Y9wH!p80~v4<#5xaRT>uf@
zAd6f;gawEY0T~bk(#8+sI)VJL4Wz>XB(Vh~F%RUH`5=NHB=!X)b`fOMW{{3b5OE2_
zy$m9*fQYLgf(@iD0;IzV#M%!cu7M<!L1NcItgRr{BM^}ZviAl^%pGL;0+4MlK@!;@
zVgrb{36ix1*>(%Wx(y;GgB0HZu@ph9Eg;#uAnrX7;RO<V03z;#xV9kHeh@JYq^=+2
zpjwd04?wakAQxnT2u6@Z8%W7Rki;Vp@fbur0TE9@#4`}_97MbT5idc+D-hud()Jp}
zdIKWff{1q@Vl&9zERd`}$Vw9s_X>#h4a9m6Qt|;rd;}4nKtw;tEhj-bK7+WNpdcv&
z>4*gp{U8Zvkdg@?;tNR0R}k?HL@Wd;o&Zwv9mLHC>G%O+{R9zzK~_!#Y2yN^`vnqP
z1Y%7BN#uYOCxZw_5U~*y8oxnGPJncr2Z>DrvG#+E-vN@{3L?Zn5+NW1T0q<fAR-&2
zZazrt4v07gB9?>H{Q;Tx1!RCRh|mJ5TMTkRAxOzd5cd#>Wd}0lHAo37NbE02+dmNT
zA4D*4Ffe3lgCrP1EG7`a3?f)S1S^QJ2AMJuWIzFk#Rd|q0J(r2#5xW#ega71F-VLX
z<N^+mgdj*_B}nWuh{XvKI{;#Ffmqxi;s;2U2gKq95vM?QG=P+>1ey00MC5>+#s`w+
z2NCl?vP(dA2!ObPAVL$Q?lp)I0&(YpSbso7F33C!kR8)OEKv~Q0^$mT)LjL!L_jQ2
z5Wxd7R1Cxt2N6p_TnP|s8HgnbVo8ArbCAhCAiYi?)^d<6Kgd-sAeTyml$-*wWI(I~
zAS=Iuh!T(zS&*0<h>!;n3LrueMDT)4Q3A1)L4*p3Pz4b|AiZiJmO6;g01=uXLJLIf
z0=YmN#L@v-xdp`40daLfgdT{<1&N&o$#Q|*90wxwK@!OzlUIQ3bp^@Z2XQBZSo1)v
zM38fHL0kinVpothLlDadL>PkzK9Js(AYv7WFae2$fYeO^Y5N8;<qU{r3X)h2Qo;`+
zrh>%If(SE^ggJ;107>M5#MXdVTS0pBL0k)vtR;wW198`aWY>X+^&r9uB;gK{um-Vg
zK!h!bumchHAi@DeID!Z#5aA3WTtI{?h)@Ap<OX87gNSn=qt1f}RglC6kR4M&0Z{-F
z^8hLF1QA{!!W%^RfQSnqPwxd0f*>6aKzcWVSo1-wHz2|nq|OgS_=AW55D^F>f<Odl
z^fq%L$f95nS0BU*0kIlEtWXf^G{_VVkR6O5A`B!p4dg0MQ2cs;SkFN$A&`zkAjO+N
zE?5Xs91c>v8N`hMv1WkO6@qj`g1Av2A{s=*fQYvsy+t6|Eg&7mAXY3$A`V2vgNOtW
z!3{E{3}l-RNJk<_Y!*oD0!W7*h_w}DKoUs84Wz^lL|g<p=psl-7D!1lNHz+@S_3lb
z9EflNDKP^P(?RMIKw>E%b*Ugi3M6p}BvAv>CIqr04J5G*#QF)6H3bprAhC5IRtAXG
z31Ve}SRNp4Ye7U7h<gTP{Cp6R4dQMGnUVuyT?W}<2$IMJaq~b#K8Pp)5rrV42t+u8
zOfCkoN<c&@h$sUQ<sjlUNVWpRsss^LAfg&X>;PFb7bIH);?{zQIuKD0A{s!%PLPsD
z5KA27Tp^HRS&)O8Kw|zN)=iLDGl<&@;<kWTtstTeM6iLp&<<jCfQVfn#hoBl7l?2L
z>F5TrdO$=Wh}#Qd$%7)w6QuV$h!q2p=mSaUg2YyUOz8)4gF&*pK#rUM;!Xq+Tp*WD
z0<ls->Q;dCP6lx=gB0h0WDkPGd_l6(AnqCv5eOpKLB<DwSZpB0k|1?)Ac6xV!3)x%
z3*x$gSTjIkQ$Qv!0&zt_+^Hb$G!U^H<f>aBiC-XMI!J5=h?of?W`T%3ASJUwtcM`m
z=73mpK?E1b4n2^0hd~l0Al5vP#C#C307T3H8R`X+I0I6$5G1w;L@WjoGeHu2LB{U`
z5$PZ$OF$A!LBui;u^dFK01^8^N>+kct3bqR5U~bCtOXJ4K*V|wu>nME1QDA+#AXn2
z0HpT{$hIvY?p6@74Mc1Q5j#M{P7tvRMC=9;!XO=cK&-tW;shwL_kmb<L7pxJ5&J>h
z10doy$d{HN*K>l1gCMa(AmT8H-~`D&1L;r!v5tVmj)I6|AmSj%A`uW_3bI2Lq@)wX
z$_5$b17ghs5ywG_MM3HgfrzUh^LjwU50E-B5bFd;?+K7PM-X=xi1-d7{(~f5fQYpq
z#aBTAF$+W-1{rk{q$3Dq$0iU_3X+%&BF=&op90B>fz+J_u{1&EodL1Vf(R>+q31xX
z^C02^h!6sqatNgE9Ef!hB&G!7s(^?xkja-oV*f$hMIa@hX}ZiP5O)cPdmm)zWss61
zAbXF32o{ip7Dyr-q)raxG;femS3v4~K&-1EmNrP;Y7ij~($)=PT?Y}@K(g0C#95Fj
z>>vYffVi9>y-pxQZ-CU@1c}*$WN(33Q$b?4K`aT7d3QjpyC7m8$dqd!z3m_+z91dZ
zAX7|1#66IbCm_~+5GxNP+Yi$54y5=Uh<glV-UE=VGf3<qh@}qF@d(6v3?j~gxKBW=
zdmz?2khVD>)>Due7s&EwAl7pb@d89}f@EKUSh677UV&JzLBtyn@fJk90}*Z@D?>o$
z>4Qvp4-)$TB0hqMPar}Rq{IS5`~?|W3Sw;lu|9)jzkmpD5cdkm6b+DVz96HffYix=
zBr-v)P7rGjNa8w(_zY6_6{L4JNcJ0uB?gi>4hoI$AZ`dq#}5$89;8GZB>N1+`Uw*I
z1tKItihqNQk^-?(L9z;9XMl)zAOn7b)cpYwe?de$Na7!er3zAP05X&h#9{>z|3MP|
zAl71#p$wc144D=nQy4)kCJ@04B3M8KD~LD&vX>2{LmJEiiLrwS4iLczlDGykKpDi6
z01;0?1Sd##JIIbpAZ{3l-~u^~AH)&>u>wG{+#r?$NX!>RgoC(8Km-@a0A`TM+#uFh
z5UU16@PN3yAR-u~<0?q;Ob}}$$UGU4BTs^eQy}6rh~NV$<_8gHKuXSl!~{TGK@cGX
zB7{MN2#62`5obY4#6T=@5YYfK-V#K(fCyHQGbBI(dl|%C1tM;Mxbh&D1W1Q5h_xA{
z?it8RNsyQnh>!*m)gUn$5Q_t(<OGP21##s-ggl5?2@+EPvCe_q(hoB4H%N>fM63sS
zS`j3h4dTuKanFO)F@U%iKrBCygFb__MS^U*2oh5Q=}-m{Dj-4?M5uuXbr7KeB4R;C
zX@Xc<AVM2N=zs`a5TOSmx<Pj6gIJe9hF%5{b|8zyK^83ou^xg5Ly(d=AhE?D9XCM^
z>H<l`fW#JnEHVNqnG2EtElJ3{0y63<h%f<3n1Tp15K#_NVh&>M0O_>=v6?}K8iNQ~
zkd9R#i8~;!B}mo^MEHQXJRmFYfrvRE!Wty;0>rWbu^K_zL_q2$fLN>`;u^@j>mY&~
zWbXoy>;sU*4Um{ENZU`4>%Bl?b|9`jh;RTAH$h4qL99<8JDfl)XAt26B5r|XT|um)
zAOlW<3~&Q+-9dy0i0}jvPe2maKuT_dbZh{z?tobDK`bwj5^oS82NJsrB78txUl8F3
zA_PI|JV6fk2XO;H#66I@KoBbkL<EC~B_MSnAl7}5Y$%8o1|q^iL<ESq1qy>m5Gx8q
zM1zPJ5D^O^9)S$l1|s4>+;|X?03s4W!~>9_@*pA!#7zbfDIg*hL`Z^6ehczy8i<<?
zB0@n%odbzgfMgXwdNV*0^FZ8(AZ{jzn*}2NgMyd^r1(C_t0o|p8i=?Cl6VAC{1`+i
zf{3{wCGSBJdqAvU5K##-lm|pS0V#P3B9uS`FG%beh@}i7vO%^z2eEQMtXvS02O>6r
z%-avL@*~K+0uU<@M9c*FLk}dD4^kHjVl4$J_6M2#0%TMHNa7`kRS04gfrw%dQ2|n1
z0%Gj}8C42mm4S$I5WxhJWdIqk0@7On5}OY)v=YR643bCyX{!Qpt3gB!h^Pe-cR?<w
z1F`BsL<5Lu1QAUjq8UWAfQVKQaTui78D!fvka>GR+(wY`*Fl6T$nr{%Yzs(M3gm)(
zkVG3u?-7thJBZZ*B051t7l`Nv5j`Mc5=e0`h}8!o`a#455HT4f@e*XfL=g8C$f5-x
z<0pZ*lR*SC$V$*Er_9wLb?-sM6p(~FNMb68^%x}f6h!cW^csOAu7bSq8f4xZ5O)@c
zm<Ccj9Yo9k5i>!AA4uCQ5Q_)omM0+M1Bf^X(s3JP-fWQU91t-VM9c#b^Fc%r$c_ad
z)?1J%RUpNAAl71##2b+12SG*!fFu@z)G32x7lBx6AlX2W#9|QlEr^>7l3fDgCWBbp
zL3;0ilq>~_se_a(1F_0MPFoIQtpE|XK(=XsWOG2;96-bukdk*GvG*WC6GVIf5n3Q(
zB}m&U5V0CWtN{^ELAI?0vDSfz^&nych?og7Y9YuO8$sMDAax%>rfdRnH-m^RAi@Kr
zZViao3gT`95wak~+d(X8kO7N8#10U5Cy3YuB0hnP+6`ju0TD$Y*Y5?f_(6&ng9t~E
z2ls)*Hi2Z%g1F~FtR*1X{UC{2keCk0wsw%jBoJW*;_e1HNDjp90}-=9>UcpC%pk%O
zBzpj4fFFqU6QsltWavSVSU5=R3rNRp5HS^`;}?k70V3K!vY$b&KLk>&4PqSzv5tTU
zLy(ReAazL~L!W{a9|cJif>_5uEFF-J;~>^=kh*;!9jPG2UqMP<gIMt(F+PxN3WzuX
zQhX9boB|Q2LBtslaTY|hffRoM8EORb!ZMHnUqRd^klu43B@01H&VyJNK*U85aS22)
zf|OhavA%(HTmiAJf{585Q*=RM*FfAGAntb%_d1vhB5s0+TOi^#h`0kHZi39a3u4^^
z5%)pF0}$~LL_7i!e?Y!`3}W2{Irj;O^%O)%f*g4UM3{qYdj=Bw0Af7{v1CAsUw~LI
zLBuN%@ft+D0TFLO#5)ji9Av-&kR3ljdar<pZy@eO5b*=#g(Dy(Iv~Ow<lK88lLbKP
z-hq_72buC0#EJvSegJVlf(Sj3-cKM_3rKG|NXb%=lFuNqJ0R{C5bG<5_y!`Df=vDi
z()Jz1l?K^yA0#FVBH}?h7J>};0h0X*B7T90MIf>5AUiTZtPGGk0g#Sr5b+zNqz1(L
z1CredGV~`%u`yT-B>NXc`~wk}K(fz42K)zc8Mqi2G8sWc3`hqPNMaR8$r2F32jVh;
zWSKz(3y5F^5o{oW9Yk<|h@Bw4oFEn#h~NehJRpJt<e*<5|4srK#S0S40-FqCWrA3<
zKuSzNE|mna_(2i^AVLsC2!RM;5Fr90euIqq4YExX#1#V(;vhl-MEn8Cnt^0fK(@UF
zvGhS=k|0?r5Fre*at4TK2Pw%1DUk+A`~|5C0y*O%NR}BSaSFuZ1hLdWgbYYsHi(r6
zBC0^ny$E7Sfry77^FD!e$b!`U1DPiWVyy>>odPL|01^K|5-A`tc@Pl{vT_PYZ!L%=
z57JQ!l3)NW0=xyXqYfmo7bNxo#Ht4o=Rgt)AjOIx!Vkn%0<rdi)a?XucYthr2vYnA
zL|g~ip$t+o8zg%WBwGw(ser^(L4+EJNCQc@fJ~7F=`aK-Q3pvZ1&IlQjM4yc9Y7MA
zAXXem$9fQP6huq|snY^UoCdM9K`b2*p$j7PK!iSs@B+(%>@Wav4MBtvh&Tii3jtZw
z3Q}SW5;Fl2rXa!$M7#u9WDa6Ef}EiT(y<uC+65vWgY;T}WGz7iBPb-5KuWAYTx$^V
z5v0xr#Igkub|8WYq;3;PodGD0>_K9?LFybpEM}0bBZ%b$B3M8Y&LEZxh;RiFZXm)P
zM9cxnc7TkE2eG0-EDw-`Cx}=E5@P|GmjGfVf(S2=L=#Az5XklOK&)jTmN!Vk2SoUS
z2tN?90_1&v5UU5IE)!&c9Ec?c(!mNcIRGRZ2qJ>G7#RFCMi+cDWR5QQX2={}@Xe4p
zy5O53b9BKsL+0p$Z-&g#1>X#rqYJ(nGDjDDGh~h~_-4o)UGUA2IlADRA#-%WH$&#=
zf^UY*(FNZOnWGE788Sx~d^2Q@F8F5199{6ukU6^Gn;~;_!8b$Z=z?#C%+Uqk44I<~
zz8Nw{7ko2hjxP9S$Q)hp&5${|;F}?Hbip@6=IDZNhRo3g-wc_<dBHb$UBT$8Z-&g#
zRo@JmqpQ9dGDlZ^Gh~jg`ew)+UG>e7IlAhbA#-%qH$&#=s&9tO(N*6JnS7x2sH3aC
z88Sy#eKTZ^uKH%kr0uG24bU!z63|9#*HCBgp!kr;08eK}pLiF~;E*6sr_c~jf4}%3
z#}H5d63}tfP(_YTKCbb>o>8tPpq<?iL1z!gp!g8~c()+ez<B>47uO)r$&CyMq8M}}
zlzu@`W?5oMs(x8wk$zf!PD*M~v3^pDetA+-Uao0wv5{etd3sg4g{eh(PF9tf0SKh$
z>4)eSWESXV<`tJD=H%$Qm3ep?2Y`gYIKC`3FD1W7KRF|@C?&N-KeaSDyC|(FwNS61
i5;X44V3V7lQks)$2Ri+!7<3pO8xtD~1LG(p6aoNF094)p

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/euckrprober.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/euckrprober.py
new file mode 100644
index 0000000..345a060
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/euckrprober.py
@@ -0,0 +1,47 @@
+######################## BEGIN LICENSE BLOCK ########################
+# The Original Code is mozilla.org code.
+#
+# The Initial Developer of the Original Code is
+# Netscape Communications Corporation.
+# Portions created by the Initial Developer are Copyright (C) 1998
+# the Initial Developer. All Rights Reserved.
+#
+# Contributor(s):
+#   Mark Pilgrim - port to Python
+#
+# This library is free software; you can redistribute it and/or
+# modify it under the terms of the GNU Lesser General Public
+# License as published by the Free Software Foundation; either
+# version 2.1 of the License, or (at your option) any later version.
+#
+# This library is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+# Lesser General Public License for more details.
+#
+# You should have received a copy of the GNU Lesser General Public
+# License along with this library; if not, write to the Free Software
+# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
+# 02110-1301  USA
+######################### END LICENSE BLOCK #########################
+
+from .mbcharsetprober import MultiByteCharSetProber
+from .codingstatemachine import CodingStateMachine
+from .chardistribution import EUCKRDistributionAnalysis
+from .mbcssm import EUCKR_SM_MODEL
+
+
+class EUCKRProber(MultiByteCharSetProber):
+    def __init__(self):
+        super(EUCKRProber, self).__init__()
+        self.coding_sm = CodingStateMachine(EUCKR_SM_MODEL)
+        self.distribution_analyzer = EUCKRDistributionAnalysis()
+        self.reset()
+
+    @property
+    def charset_name(self):
+        return "EUC-KR"
+
+    @property
+    def language(self):
+        return "Korean"
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/euckrprober.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/euckrprober.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..96825caaee7afc12e461b22c53e5bbb7ed874ada
GIT binary patch
literal 1601
zcmZSn%**AGdLky70ScHI7#JKF7#ND97#J8*7#LC*8FCmHav2$-7#SErd?tn*CWc&Q
zhA3tTpP3<tg&~)fA&M2kXJN=;W5{J^h+=18Okrh6Wn@TWWJqCSXklPzW?+bn;$TQ&
zX9(8dU|?X#WMp7q&;Su7VhjunzNI-OnNF1@sm>XRMZu{h0Y&*qsYMWZAqEBp=lqn+
zy!7Cb#FA9s#N>?3yi|ysBm)D3YpAn#kV|H9Nl|7}X-Q^&o?~8OPGxasF+>R;Oi6sO
zZ@jO+i>prwH%tg(4Lkst7#J9wKmnl7z`&5o0P=SV1IYDJObn^apzr|sgpnbN1<Yjv
zNi{QqydM;-0SdijkcU7R#Bm0hWW&I~P{P1a!pKm=z|hRZki`TF3dRy<h7uNrX0T{H
zD?<qzNVJB5A)XziE{g-i1qFF9*bjahoFHRZK?ar<q!tCSfViMwjE~RE%PfhH4+2>l
z1hTb+lYxOD85~^k#koNsFO`Ub;u9%=;uAq3RFzs(0y45FwK%l|Y)=Wu+~U-nG!0OS
z029SU3=9nV1x1-<i6yD}Wr;=lY56%RsYS*5Nh$i}NlAIRrn$vNhDqk>Rp}O{7Uelv
zRb~btke;U>qF<0%pqrUjT#}fRqw7}Y;b|NI5(4A+vedkk{38A2jKrdp)Dr#F(&X%-
z0&ukJ6;uYXF)%PFgZvBfB?F@{BR?Y#BRqIPz6A#_$iXR$48a;8fBF@Jbh(B)>v{))
z9S`<Y5Em$=4YY?!ctFvTkyuomS`wd^n478z@*K$33`~T)RRZ#scYaZ7V&0(h7ASgh
z67$ka6Vp?55nj>&Ik^NR84vbte0&Kg8sg(~^HWN5Qsd*n5e!yPP?TSgT2xXQ1j>~`
zyeN?c_U=F>K~UOK0(lAK7dA#tHhvapM&xH;V8~4ZrQG7w5=fd20wu5#P*DZRd&Qul
zDi=~zfiq``05k!lAZ0{I_5_)qo0ME!oD0su;M@)NIf59VFaSr84J6L&WI$m7ic$ea
HFk}V*luUaJ

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/euctwfreq.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/euctwfreq.py
new file mode 100644
index 0000000..ed7a995
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/euctwfreq.py
@@ -0,0 +1,387 @@
+######################## BEGIN LICENSE BLOCK ########################
+# The Original Code is Mozilla Communicator client code.
+#
+# The Initial Developer of the Original Code is
+# Netscape Communications Corporation.
+# Portions created by the Initial Developer are Copyright (C) 1998
+# the Initial Developer. All Rights Reserved.
+#
+# Contributor(s):
+#   Mark Pilgrim - port to Python
+#
+# This library is free software; you can redistribute it and/or
+# modify it under the terms of the GNU Lesser General Public
+# License as published by the Free Software Foundation; either
+# version 2.1 of the License, or (at your option) any later version.
+#
+# This library is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+# Lesser General Public License for more details.
+#
+# You should have received a copy of the GNU Lesser General Public
+# License along with this library; if not, write to the Free Software
+# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
+# 02110-1301  USA
+######################### END LICENSE BLOCK #########################
+
+# EUCTW frequency table
+# Converted from big5 work
+# by Taiwan's Mandarin Promotion Council
+# <http:#www.edu.tw:81/mandr/>
+
+# 128  --> 0.42261
+# 256  --> 0.57851
+# 512  --> 0.74851
+# 1024 --> 0.89384
+# 2048 --> 0.97583
+#
+# Idea Distribution Ratio = 0.74851/(1-0.74851) =2.98
+# Random Distribution Ration = 512/(5401-512)=0.105
+#
+# Typical Distribution Ratio about 25% of Ideal one, still much higher than RDR
+
+EUCTW_TYPICAL_DISTRIBUTION_RATIO = 0.75
+
+# Char to FreqOrder table ,
+EUCTW_TABLE_SIZE = 5376
+
+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
+)
+
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/euctwfreq.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/euctwfreq.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..6f06c09c551e1d6bb55682f68e43707a46ff3201
GIT binary patch
literal 54757
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

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/euctwprober.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/euctwprober.py
new file mode 100644
index 0000000..35669cc
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/euctwprober.py
@@ -0,0 +1,46 @@
+######################## BEGIN LICENSE BLOCK ########################
+# The Original Code is mozilla.org code.
+#
+# The Initial Developer of the Original Code is
+# Netscape Communications Corporation.
+# Portions created by the Initial Developer are Copyright (C) 1998
+# the Initial Developer. All Rights Reserved.
+#
+# Contributor(s):
+#   Mark Pilgrim - port to Python
+#
+# This library is free software; you can redistribute it and/or
+# modify it under the terms of the GNU Lesser General Public
+# License as published by the Free Software Foundation; either
+# version 2.1 of the License, or (at your option) any later version.
+#
+# This library is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+# Lesser General Public License for more details.
+#
+# You should have received a copy of the GNU Lesser General Public
+# License along with this library; if not, write to the Free Software
+# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
+# 02110-1301  USA
+######################### END LICENSE BLOCK #########################
+
+from .mbcharsetprober import MultiByteCharSetProber
+from .codingstatemachine import CodingStateMachine
+from .chardistribution import EUCTWDistributionAnalysis
+from .mbcssm import EUCTW_SM_MODEL
+
+class EUCTWProber(MultiByteCharSetProber):
+    def __init__(self):
+        super(EUCTWProber, self).__init__()
+        self.coding_sm = CodingStateMachine(EUCTW_SM_MODEL)
+        self.distribution_analyzer = EUCTWDistributionAnalysis()
+        self.reset()
+
+    @property
+    def charset_name(self):
+        return "EUC-TW"
+
+    @property
+    def language(self):
+        return "Taiwan"
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/euctwprober.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/euctwprober.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..3b51c0c2f83d90969c93a23f780419a833b48f25
GIT binary patch
literal 1601
zcmZSn%**AGdLky70ScHI7#JKF7#ND97#J8*7#LC*8FCmHav2$-7#SErd?tn*CWc&Q
zhA3tTpP3<tg&~)fA&M2kXJN=;W5{J^h+=18Okrh6Wn@TWWJqCSXklPzW?+bn;$TQ&
zX9(8dU|?X#WMp7q&;Su7VhjunzNI-OnNF1@sm>XRMZu{h0Y&*qsYMWZAqEBp=lqn+
zy!7Cb#FA9s#N>?3yi|ysBm)D3Yp8QbxJzbnNl|7}X-Q^&o?~8OPGxasF+>R;Oi6sO
zZ@jO+i>prwH%tg(4Lkst7#J9wKmnl7z`&5o0P=SV1IYDJObn^apzr|sgpnbN1<Yjv
zNi{QqydM;-0SdijkcU7R#Bm0hWW&I~P{P1a!pKm=z|hRZki`TF3dRy<h7uNrX0T{H
zD?<qzNVJB5A)XziE{g-i1qFF9*bjahoFHRZK?ar<q!tCSfViMwjE~RE%PfhH4+2>l
z1hTb+lYxOD85~^k#koNsFO`Ub;u9%=;uAq3RFzs(0y45FwK%l|Y)=Wu+~U-nG!0OS
z029SU3=9nV1x1-<i6yD}Wr;=lY56%RsYS*5Nh$i}NlAIRrn$vNhDqk>Rp}O{7Uelv
zRb~btke;U>qF<0%pqrUjT#}fRqw7}Y;b|NI5(4A+vedkk{38A2jKrdp)Dr#F(&Uoz
z0&ukJ6;uYXF)%PFf&2^dB?F@{BR?Y#BRqIPz6A#_$iXR$48a;8fBF@Jbh(B)>xP7b
z9S`<Y5Em$=4YY?!ctFvTkyuomS`wd^n41c6U@^$m3`~T)RRZ!>NMdGrVjf5rB-;!U
zZ-JsGCowO*G%-C@2NYirFKK|BTmq7e2m3ZYz62Bv@$tF&DWy57@$ujY1}i8i$}dPQ
zDya+t<;oyll*j^mcc79WC~YZ%yae(K8zUzhKMOP?@-r|n<R*bqZgFY}B+Uka5?BeS
zsDk9ZVo*_)3n{9=nX^OyngCLeG9n~<g3QlNN-i$W1?OOJ?gslDK@3nBfFsBT5@&WY
Ops)Z%sQ@DwG64WE3VVqF

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/gb2312freq.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/gb2312freq.py
new file mode 100644
index 0000000..697837b
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/gb2312freq.py
@@ -0,0 +1,283 @@
+######################## BEGIN LICENSE BLOCK ########################
+# The Original Code is Mozilla Communicator client code.
+#
+# The Initial Developer of the Original Code is
+# Netscape Communications Corporation.
+# Portions created by the Initial Developer are Copyright (C) 1998
+# the Initial Developer. All Rights Reserved.
+#
+# Contributor(s):
+#   Mark Pilgrim - port to Python
+#
+# This library is free software; you can redistribute it and/or
+# modify it under the terms of the GNU Lesser General Public
+# License as published by the Free Software Foundation; either
+# version 2.1 of the License, or (at your option) any later version.
+#
+# This library is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+# Lesser General Public License for more details.
+#
+# You should have received a copy of the GNU Lesser General Public
+# License along with this library; if not, write to the Free Software
+# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
+# 02110-1301  USA
+######################### END LICENSE BLOCK #########################
+
+# GB2312 most frequently used character table
+#
+# Char to FreqOrder table , from hz6763
+
+# 512  --> 0.79  -- 0.79
+# 1024 --> 0.92  -- 0.13
+# 2048 --> 0.98  -- 0.06
+# 6768 --> 1.00  -- 0.02
+#
+# Ideal Distribution Ratio = 0.79135/(1-0.79135) = 3.79
+# Random Distribution Ration = 512 / (3755 - 512) = 0.157
+#
+# Typical Distribution Ratio about 25% of Ideal one, still much higher that RDR
+
+GB2312_TYPICAL_DISTRIBUTION_RATIO = 0.9
+
+GB2312_TABLE_SIZE = 3760
+
+GB2312_CHAR_TO_FREQ_ORDER = (
+1671, 749,1443,2364,3924,3807,2330,3921,1704,3463,2691,1511,1515, 572,3191,2205,
+2361, 224,2558, 479,1711, 963,3162, 440,4060,1905,2966,2947,3580,2647,3961,3842,
+2204, 869,4207, 970,2678,5626,2944,2956,1479,4048, 514,3595, 588,1346,2820,3409,
+ 249,4088,1746,1873,2047,1774, 581,1813, 358,1174,3590,1014,1561,4844,2245, 670,
+1636,3112, 889,1286, 953, 556,2327,3060,1290,3141, 613, 185,3477,1367, 850,3820,
+1715,2428,2642,2303,2732,3041,2562,2648,3566,3946,1349, 388,3098,2091,1360,3585,
+ 152,1687,1539, 738,1559,  59,1232,2925,2267,1388,1249,1741,1679,2960, 151,1566,
+1125,1352,4271, 924,4296, 385,3166,4459, 310,1245,2850,  70,3285,2729,3534,3575,
+2398,3298,3466,1960,2265, 217,3647, 864,1909,2084,4401,2773,1010,3269,5152, 853,
+3051,3121,1244,4251,1895, 364,1499,1540,2313,1180,3655,2268, 562, 715,2417,3061,
+ 544, 336,3768,2380,1752,4075, 950, 280,2425,4382, 183,2759,3272, 333,4297,2155,
+1688,2356,1444,1039,4540, 736,1177,3349,2443,2368,2144,2225, 565, 196,1482,3406,
+ 927,1335,4147, 692, 878,1311,1653,3911,3622,1378,4200,1840,2969,3149,2126,1816,
+2534,1546,2393,2760, 737,2494,  13, 447, 245,2747,  38,2765,2129,2589,1079, 606,
+ 360, 471,3755,2890, 404, 848, 699,1785,1236, 370,2221,1023,3746,2074,2026,2023,
+2388,1581,2119, 812,1141,3091,2536,1519, 804,2053, 406,1596,1090, 784, 548,4414,
+1806,2264,2936,1100, 343,4114,5096, 622,3358, 743,3668,1510,1626,5020,3567,2513,
+3195,4115,5627,2489,2991,  24,2065,2697,1087,2719,  48,1634, 315,  68, 985,2052,
+ 198,2239,1347,1107,1439, 597,2366,2172, 871,3307, 919,2487,2790,1867, 236,2570,
+1413,3794, 906,3365,3381,1701,1982,1818,1524,2924,1205, 616,2586,2072,2004, 575,
+ 253,3099,  32,1365,1182, 197,1714,2454,1201, 554,3388,3224,2748, 756,2587, 250,
+2567,1507,1517,3529,1922,2761,2337,3416,1961,1677,2452,2238,3153, 615, 911,1506,
+1474,2495,1265,1906,2749,3756,3280,2161, 898,2714,1759,3450,2243,2444, 563,  26,
+3286,2266,3769,3344,2707,3677, 611,1402, 531,1028,2871,4548,1375, 261,2948, 835,
+1190,4134, 353, 840,2684,1900,3082,1435,2109,1207,1674, 329,1872,2781,4055,2686,
+2104, 608,3318,2423,2957,2768,1108,3739,3512,3271,3985,2203,1771,3520,1418,2054,
+1681,1153, 225,1627,2929, 162,2050,2511,3687,1954, 124,1859,2431,1684,3032,2894,
+ 585,4805,3969,2869,2704,2088,2032,2095,3656,2635,4362,2209, 256, 518,2042,2105,
+3777,3657, 643,2298,1148,1779, 190, 989,3544, 414,  11,2135,2063,2979,1471, 403,
+3678, 126, 770,1563, 671,2499,3216,2877, 600,1179, 307,2805,4937,1268,1297,2694,
+ 252,4032,1448,1494,1331,1394, 127,2256, 222,1647,1035,1481,3056,1915,1048, 873,
+3651, 210,  33,1608,2516, 200,1520, 415, 102,   0,3389,1287, 817,  91,3299,2940,
+ 836,1814, 549,2197,1396,1669,2987,3582,2297,2848,4528,1070, 687,  20,1819, 121,
+1552,1364,1461,1968,2617,3540,2824,2083, 177, 948,4938,2291, 110,4549,2066, 648,
+3359,1755,2110,2114,4642,4845,1693,3937,3308,1257,1869,2123, 208,1804,3159,2992,
+2531,2549,3361,2418,1350,2347,2800,2568,1291,2036,2680,  72, 842,1990, 212,1233,
+1154,1586,  75,2027,3410,4900,1823,1337,2710,2676, 728,2810,1522,3026,4995, 157,
+ 755,1050,4022, 710, 785,1936,2194,2085,1406,2777,2400, 150,1250,4049,1206, 807,
+1910, 534, 529,3309,1721,1660, 274,  39,2827, 661,2670,1578, 925,3248,3815,1094,
+4278,4901,4252,  41,1150,3747,2572,2227,4501,3658,4902,3813,3357,3617,2884,2258,
+ 887, 538,4187,3199,1294,2439,3042,2329,2343,2497,1255, 107, 543,1527, 521,3478,
+3568, 194,5062,  15, 961,3870,1241,1192,2664,  66,5215,3260,2111,1295,1127,2152,
+3805,4135, 901,1164,1976, 398,1278, 530,1460, 748, 904,1054,1966,1426,  53,2909,
+ 509, 523,2279,1534, 536,1019, 239,1685, 460,2353, 673,1065,2401,3600,4298,2272,
+1272,2363, 284,1753,3679,4064,1695,  81, 815,2677,2757,2731,1386, 859, 500,4221,
+2190,2566, 757,1006,2519,2068,1166,1455, 337,2654,3203,1863,1682,1914,3025,1252,
+1409,1366, 847, 714,2834,2038,3209, 964,2970,1901, 885,2553,1078,1756,3049, 301,
+1572,3326, 688,2130,1996,2429,1805,1648,2930,3421,2750,3652,3088, 262,1158,1254,
+ 389,1641,1812, 526,1719, 923,2073,1073,1902, 468, 489,4625,1140, 857,2375,3070,
+3319,2863, 380, 116,1328,2693,1161,2244, 273,1212,1884,2769,3011,1775,1142, 461,
+3066,1200,2147,2212, 790, 702,2695,4222,1601,1058, 434,2338,5153,3640,  67,2360,
+4099,2502, 618,3472,1329, 416,1132, 830,2782,1807,2653,3211,3510,1662, 192,2124,
+ 296,3979,1739,1611,3684,  23, 118, 324, 446,1239,1225, 293,2520,3814,3795,2535,
+3116,  17,1074, 467,2692,2201, 387,2922,  45,1326,3055,1645,3659,2817, 958, 243,
+1903,2320,1339,2825,1784,3289, 356, 576, 865,2315,2381,3377,3916,1088,3122,1713,
+1655, 935, 628,4689,1034,1327, 441, 800, 720, 894,1979,2183,1528,5289,2702,1071,
+4046,3572,2399,1571,3281,  79, 761,1103, 327, 134, 758,1899,1371,1615, 879, 442,
+ 215,2605,2579, 173,2048,2485,1057,2975,3317,1097,2253,3801,4263,1403,1650,2946,
+ 814,4968,3487,1548,2644,1567,1285,   2, 295,2636,  97, 946,3576, 832, 141,4257,
+3273, 760,3821,3521,3156,2607, 949,1024,1733,1516,1803,1920,2125,2283,2665,3180,
+1501,2064,3560,2171,1592, 803,3518,1416, 732,3897,4258,1363,1362,2458, 119,1427,
+ 602,1525,2608,1605,1639,3175, 694,3064,  10, 465,  76,2000,4846,4208, 444,3781,
+1619,3353,2206,1273,3796, 740,2483, 320,1723,2377,3660,2619,1359,1137,1762,1724,
+2345,2842,1850,1862, 912, 821,1866, 612,2625,1735,2573,3369,1093, 844,  89, 937,
+ 930,1424,3564,2413,2972,1004,3046,3019,2011, 711,3171,1452,4178, 428, 801,1943,
+ 432, 445,2811, 206,4136,1472, 730, 349,  73, 397,2802,2547, 998,1637,1167, 789,
+ 396,3217, 154,1218, 716,1120,1780,2819,4826,1931,3334,3762,2139,1215,2627, 552,
+3664,3628,3232,1405,2383,3111,1356,2652,3577,3320,3101,1703, 640,1045,1370,1246,
+4996, 371,1575,2436,1621,2210, 984,4033,1734,2638,  16,4529, 663,2755,3255,1451,
+3917,2257,1253,1955,2234,1263,2951, 214,1229, 617, 485, 359,1831,1969, 473,2310,
+ 750,2058, 165,  80,2864,2419, 361,4344,2416,2479,1134, 796,3726,1266,2943, 860,
+2715, 938, 390,2734,1313,1384, 248, 202, 877,1064,2854, 522,3907, 279,1602, 297,
+2357, 395,3740, 137,2075, 944,4089,2584,1267,3802,  62,1533,2285, 178, 176, 780,
+2440, 201,3707, 590, 478,1560,4354,2117,1075,  30,  74,4643,4004,1635,1441,2745,
+ 776,2596, 238,1077,1692,1912,2844, 605, 499,1742,3947, 241,3053, 980,1749, 936,
+2640,4511,2582, 515,1543,2162,5322,2892,2993, 890,2148,1924, 665,1827,3581,1032,
+ 968,3163, 339,1044,1896, 270, 583,1791,1720,4367,1194,3488,3669,  43,2523,1657,
+ 163,2167, 290,1209,1622,3378, 550, 634,2508,2510, 695,2634,2384,2512,1476,1414,
+ 220,1469,2341,2138,2852,3183,2900,4939,2865,3502,1211,3680, 854,3227,1299,2976,
+3172, 186,2998,1459, 443,1067,3251,1495, 321,1932,3054, 909, 753,1410,1828, 436,
+2441,1119,1587,3164,2186,1258, 227, 231,1425,1890,3200,3942, 247, 959, 725,5254,
+2741, 577,2158,2079, 929, 120, 174, 838,2813, 591,1115, 417,2024,  40,3240,1536,
+1037, 291,4151,2354, 632,1298,2406,2500,3535,1825,1846,3451, 205,1171, 345,4238,
+  18,1163, 811, 685,2208,1217, 425,1312,1508,1175,4308,2552,1033, 587,1381,3059,
+2984,3482, 340,1316,4023,3972, 792,3176, 519, 777,4690, 918, 933,4130,2981,3741,
+  90,3360,2911,2200,5184,4550, 609,3079,2030, 272,3379,2736, 363,3881,1130,1447,
+ 286, 779, 357,1169,3350,3137,1630,1220,2687,2391, 747,1277,3688,2618,2682,2601,
+1156,3196,5290,4034,3102,1689,3596,3128, 874, 219,2783, 798, 508,1843,2461, 269,
+1658,1776,1392,1913,2983,3287,2866,2159,2372, 829,4076,  46,4253,2873,1889,1894,
+ 915,1834,1631,2181,2318, 298, 664,2818,3555,2735, 954,3228,3117, 527,3511,2173,
+ 681,2712,3033,2247,2346,3467,1652, 155,2164,3382, 113,1994, 450, 899, 494, 994,
+1237,2958,1875,2336,1926,3727, 545,1577,1550, 633,3473, 204,1305,3072,2410,1956,
+2471, 707,2134, 841,2195,2196,2663,3843,1026,4940, 990,3252,4997, 368,1092, 437,
+3212,3258,1933,1829, 675,2977,2893, 412, 943,3723,4644,3294,3283,2230,2373,5154,
+2389,2241,2661,2323,1404,2524, 593, 787, 677,3008,1275,2059, 438,2709,2609,2240,
+2269,2246,1446,  36,1568,1373,3892,1574,2301,1456,3962, 693,2276,5216,2035,1143,
+2720,1919,1797,1811,2763,4137,2597,1830,1699,1488,1198,2090, 424,1694, 312,3634,
+3390,4179,3335,2252,1214, 561,1059,3243,2295,2561, 975,5155,2321,2751,3772, 472,
+1537,3282,3398,1047,2077,2348,2878,1323,3340,3076, 690,2906,  51, 369, 170,3541,
+1060,2187,2688,3670,2541,1083,1683, 928,3918, 459, 109,4427, 599,3744,4286, 143,
+2101,2730,2490,  82,1588,3036,2121, 281,1860, 477,4035,1238,2812,3020,2716,3312,
+1530,2188,2055,1317, 843, 636,1808,1173,3495, 649, 181,1002, 147,3641,1159,2414,
+3750,2289,2795, 813,3123,2610,1136,4368,   5,3391,4541,2174, 420, 429,1728, 754,
+1228,2115,2219, 347,2223,2733, 735,1518,3003,2355,3134,1764,3948,3329,1888,2424,
+1001,1234,1972,3321,3363,1672,1021,1450,1584, 226, 765, 655,2526,3404,3244,2302,
+3665, 731, 594,2184, 319,1576, 621, 658,2656,4299,2099,3864,1279,2071,2598,2739,
+ 795,3086,3699,3908,1707,2352,2402,1382,3136,2475,1465,4847,3496,3865,1085,3004,
+2591,1084, 213,2287,1963,3565,2250, 822, 793,4574,3187,1772,1789,3050, 595,1484,
+1959,2770,1080,2650, 456, 422,2996, 940,3322,4328,4345,3092,2742, 965,2784, 739,
+4124, 952,1358,2498,2949,2565, 332,2698,2378, 660,2260,2473,4194,3856,2919, 535,
+1260,2651,1208,1428,1300,1949,1303,2942, 433,2455,2450,1251,1946, 614,1269, 641,
+1306,1810,2737,3078,2912, 564,2365,1419,1415,1497,4460,2367,2185,1379,3005,1307,
+3218,2175,1897,3063, 682,1157,4040,4005,1712,1160,1941,1399, 394, 402,2952,1573,
+1151,2986,2404, 862, 299,2033,1489,3006, 346, 171,2886,3401,1726,2932, 168,2533,
+  47,2507,1030,3735,1145,3370,1395,1318,1579,3609,4560,2857,4116,1457,2529,1965,
+ 504,1036,2690,2988,2405, 745,5871, 849,2397,2056,3081, 863,2359,3857,2096,  99,
+1397,1769,2300,4428,1643,3455,1978,1757,3718,1440,  35,4879,3742,1296,4228,2280,
+ 160,5063,1599,2013, 166, 520,3479,1646,3345,3012, 490,1937,1545,1264,2182,2505,
+1096,1188,1369,1436,2421,1667,2792,2460,1270,2122, 727,3167,2143, 806,1706,1012,
+1800,3037, 960,2218,1882, 805, 139,2456,1139,1521, 851,1052,3093,3089, 342,2039,
+ 744,5097,1468,1502,1585,2087, 223, 939, 326,2140,2577, 892,2481,1623,4077, 982,
+3708, 135,2131,  87,2503,3114,2326,1106, 876,1616, 547,2997,2831,2093,3441,4530,
+4314,   9,3256,4229,4148, 659,1462,1986,1710,2046,2913,2231,4090,4880,5255,3392,
+3274,1368,3689,4645,1477, 705,3384,3635,1068,1529,2941,1458,3782,1509, 100,1656,
+2548, 718,2339, 408,1590,2780,3548,1838,4117,3719,1345,3530, 717,3442,2778,3220,
+2898,1892,4590,3614,3371,2043,1998,1224,3483, 891, 635, 584,2559,3355, 733,1766,
+1729,1172,3789,1891,2307, 781,2982,2271,1957,1580,5773,2633,2005,4195,3097,1535,
+3213,1189,1934,5693,3262, 586,3118,1324,1598, 517,1564,2217,1868,1893,4445,3728,
+2703,3139,1526,1787,1992,3882,2875,1549,1199,1056,2224,1904,2711,5098,4287, 338,
+1993,3129,3489,2689,1809,2815,1997, 957,1855,3898,2550,3275,3057,1105,1319, 627,
+1505,1911,1883,3526, 698,3629,3456,1833,1431, 746,  77,1261,2017,2296,1977,1885,
+ 125,1334,1600, 525,1798,1109,2222,1470,1945, 559,2236,1186,3443,2476,1929,1411,
+2411,3135,1777,3372,2621,1841,1613,3229, 668,1430,1839,2643,2916, 195,1989,2671,
+2358,1387, 629,3205,2293,5256,4439, 123,1310, 888,1879,4300,3021,3605,1003,1162,
+3192,2910,2010, 140,2395,2859,  55,1082,2012,2901, 662, 419,2081,1438, 680,2774,
+4654,3912,1620,1731,1625,5035,4065,2328, 512,1344, 802,5443,2163,2311,2537, 524,
+3399,  98,1155,2103,1918,2606,3925,2816,1393,2465,1504,3773,2177,3963,1478,4346,
+ 180,1113,4655,3461,2028,1698, 833,2696,1235,1322,1594,4408,3623,3013,3225,2040,
+3022, 541,2881, 607,3632,2029,1665,1219, 639,1385,1686,1099,2803,3231,1938,3188,
+2858, 427, 676,2772,1168,2025, 454,3253,2486,3556, 230,1950, 580, 791,1991,1280,
+1086,1974,2034, 630, 257,3338,2788,4903,1017,  86,4790, 966,2789,1995,1696,1131,
+ 259,3095,4188,1308, 179,1463,5257, 289,4107,1248,  42,3413,1725,2288, 896,1947,
+ 774,4474,4254, 604,3430,4264, 392,2514,2588, 452, 237,1408,3018, 988,4531,1970,
+3034,3310, 540,2370,1562,1288,2990, 502,4765,1147,   4,1853,2708, 207, 294,2814,
+4078,2902,2509, 684,  34,3105,3532,2551, 644, 709,2801,2344, 573,1727,3573,3557,
+2021,1081,3100,4315,2100,3681, 199,2263,1837,2385, 146,3484,1195,2776,3949, 997,
+1939,3973,1008,1091,1202,1962,1847,1149,4209,5444,1076, 493, 117,5400,2521, 972,
+1490,2934,1796,4542,2374,1512,2933,2657, 413,2888,1135,2762,2314,2156,1355,2369,
+ 766,2007,2527,2170,3124,2491,2593,2632,4757,2437, 234,3125,3591,1898,1750,1376,
+1942,3468,3138, 570,2127,2145,3276,4131, 962, 132,1445,4196,  19, 941,3624,3480,
+3366,1973,1374,4461,3431,2629, 283,2415,2275, 808,2887,3620,2112,2563,1353,3610,
+ 955,1089,3103,1053,  96,  88,4097, 823,3808,1583, 399, 292,4091,3313, 421,1128,
+ 642,4006, 903,2539,1877,2082, 596,  29,4066,1790, 722,2157, 130, 995,1569, 769,
+1485, 464, 513,2213, 288,1923,1101,2453,4316, 133, 486,2445,  50, 625, 487,2207,
+  57, 423, 481,2962, 159,3729,1558, 491, 303, 482, 501, 240,2837, 112,3648,2392,
+1783, 362,   8,3433,3422, 610,2793,3277,1390,1284,1654,  21,3823, 734, 367, 623,
+ 193, 287, 374,1009,1483, 816, 476, 313,2255,2340,1262,2150,2899,1146,2581, 782,
+2116,1659,2018,1880, 255,3586,3314,1110,2867,2137,2564, 986,2767,5185,2006, 650,
+ 158, 926, 762, 881,3157,2717,2362,3587, 306,3690,3245,1542,3077,2427,1691,2478,
+2118,2985,3490,2438, 539,2305, 983, 129,1754, 355,4201,2386, 827,2923, 104,1773,
+2838,2771, 411,2905,3919, 376, 767, 122,1114, 828,2422,1817,3506, 266,3460,1007,
+1609,4998, 945,2612,4429,2274, 726,1247,1964,2914,2199,2070,4002,4108, 657,3323,
+1422, 579, 455,2764,4737,1222,2895,1670, 824,1223,1487,2525, 558, 861,3080, 598,
+2659,2515,1967, 752,2583,2376,2214,4180, 977, 704,2464,4999,2622,4109,1210,2961,
+ 819,1541, 142,2284,  44, 418, 457,1126,3730,4347,4626,1644,1876,3671,1864, 302,
+1063,5694, 624, 723,1984,3745,1314,1676,2488,1610,1449,3558,3569,2166,2098, 409,
+1011,2325,3704,2306, 818,1732,1383,1824,1844,3757, 999,2705,3497,1216,1423,2683,
+2426,2954,2501,2726,2229,1475,2554,5064,1971,1794,1666,2014,1343, 783, 724, 191,
+2434,1354,2220,5065,1763,2752,2472,4152, 131, 175,2885,3434,  92,1466,4920,2616,
+3871,3872,3866, 128,1551,1632, 669,1854,3682,4691,4125,1230, 188,2973,3290,1302,
+1213, 560,3266, 917, 763,3909,3249,1760, 868,1958, 764,1782,2097, 145,2277,3774,
+4462,  64,1491,3062, 971,2132,3606,2442, 221,1226,1617, 218, 323,1185,3207,3147,
+ 571, 619,1473,1005,1744,2281, 449,1887,2396,3685, 275, 375,3816,1743,3844,3731,
+ 845,1983,2350,4210,1377, 773, 967,3499,3052,3743,2725,4007,1697,1022,3943,1464,
+3264,2855,2722,1952,1029,2839,2467,  84,4383,2215, 820,1391,2015,2448,3672, 377,
+1948,2168, 797,2545,3536,2578,2645,  94,2874,1678, 405,1259,3071, 771, 546,1315,
+ 470,1243,3083, 895,2468, 981, 969,2037, 846,4181, 653,1276,2928,  14,2594, 557,
+3007,2474, 156, 902,1338,1740,2574, 537,2518, 973,2282,2216,2433,1928, 138,2903,
+1293,2631,1612, 646,3457, 839,2935, 111, 496,2191,2847, 589,3186, 149,3994,2060,
+4031,2641,4067,3145,1870,  37,3597,2136,1025,2051,3009,3383,3549,1121,1016,3261,
+1301, 251,2446,2599,2153, 872,3246, 637, 334,3705, 831, 884, 921,3065,3140,4092,
+2198,1944, 246,2964, 108,2045,1152,1921,2308,1031, 203,3173,4170,1907,3890, 810,
+1401,2003,1690, 506, 647,1242,2828,1761,1649,3208,2249,1589,3709,2931,5156,1708,
+ 498, 666,2613, 834,3817,1231, 184,2851,1124, 883,3197,2261,3710,1765,1553,2658,
+1178,2639,2351,  93,1193, 942,2538,2141,4402, 235,1821, 870,1591,2192,1709,1871,
+3341,1618,4126,2595,2334, 603, 651,  69, 701, 268,2662,3411,2555,1380,1606, 503,
+ 448, 254,2371,2646, 574,1187,2309,1770, 322,2235,1292,1801, 305, 566,1133, 229,
+2067,2057, 706, 167, 483,2002,2672,3295,1820,3561,3067, 316, 378,2746,3452,1112,
+ 136,1981, 507,1651,2917,1117, 285,4591, 182,2580,3522,1304, 335,3303,1835,2504,
+1795,1792,2248, 674,1018,2106,2449,1857,2292,2845, 976,3047,1781,2600,2727,1389,
+1281,  52,3152, 153, 265,3950, 672,3485,3951,4463, 430,1183, 365, 278,2169,  27,
+1407,1336,2304, 209,1340,1730,2202,1852,2403,2883, 979,1737,1062, 631,2829,2542,
+3876,2592, 825,2086,2226,3048,3625, 352,1417,3724, 542, 991, 431,1351,3938,1861,
+2294, 826,1361,2927,3142,3503,1738, 463,2462,2723, 582,1916,1595,2808, 400,3845,
+3891,2868,3621,2254,  58,2492,1123, 910,2160,2614,1372,1603,1196,1072,3385,1700,
+3267,1980, 696, 480,2430, 920, 799,1570,2920,1951,2041,4047,2540,1321,4223,2469,
+3562,2228,1271,2602, 401,2833,3351,2575,5157, 907,2312,1256, 410, 263,3507,1582,
+ 996, 678,1849,2316,1480, 908,3545,2237, 703,2322, 667,1826,2849,1531,2604,2999,
+2407,3146,2151,2630,1786,3711, 469,3542, 497,3899,2409, 858, 837,4446,3393,1274,
+ 786, 620,1845,2001,3311, 484, 308,3367,1204,1815,3691,2332,1532,2557,1842,2020,
+2724,1927,2333,4440, 567,  22,1673,2728,4475,1987,1858,1144,1597, 101,1832,3601,
+  12, 974,3783,4391, 951,1412,   1,3720, 453,4608,4041, 528,1041,1027,3230,2628,
+1129, 875,1051,3291,1203,2262,1069,2860,2799,2149,2615,3278, 144,1758,3040,  31,
+ 475,1680, 366,2685,3184, 311,1642,4008,2466,5036,1593,1493,2809, 216,1420,1668,
+ 233, 304,2128,3284, 232,1429,1768,1040,2008,3407,2740,2967,2543, 242,2133, 778,
+1565,2022,2620, 505,2189,2756,1098,2273, 372,1614, 708, 553,2846,2094,2278, 169,
+3626,2835,4161, 228,2674,3165, 809,1454,1309, 466,1705,1095, 900,3423, 880,2667,
+3751,5258,2317,3109,2571,4317,2766,1503,1342, 866,4447,1118,  63,2076, 314,1881,
+1348,1061, 172, 978,3515,1747, 532, 511,3970,   6, 601, 905,2699,3300,1751, 276,
+1467,3725,2668,  65,4239,2544,2779,2556,1604, 578,2451,1802, 992,2331,2624,1320,
+3446, 713,1513,1013, 103,2786,2447,1661, 886,1702, 916, 654,3574,2031,1556, 751,
+2178,2821,2179,1498,1538,2176, 271, 914,2251,2080,1325, 638,1953,2937,3877,2432,
+2754,  95,3265,1716, 260,1227,4083, 775, 106,1357,3254, 426,1607, 555,2480, 772,
+1985, 244,2546, 474, 495,1046,2611,1851,2061,  71,2089,1675,2590, 742,3758,2843,
+3222,1433, 267,2180,2576,2826,2233,2092,3913,2435, 956,1745,3075, 856,2113,1116,
+ 451,   3,1988,2896,1398, 993,2463,1878,2049,1341,2718,2721,2870,2108, 712,2904,
+4363,2753,2324, 277,2872,2349,2649, 384, 987, 435, 691,3000, 922, 164,3939, 652,
+1500,1184,4153,2482,3373,2165,4848,2335,3775,3508,3154,2806,2830,1554,2102,1664,
+2530,1434,2408, 893,1547,2623,3447,2832,2242,2532,3169,2856,3223,2078,  49,3770,
+3469, 462, 318, 656,2259,3250,3069, 679,1629,2758, 344,1138,1104,3120,1836,1283,
+3115,2154,1437,4448, 934, 759,1999, 794,2862,1038, 533,2560,1722,2342, 855,2626,
+1197,1663,4476,3127,  85,4240,2528,  25,1111,1181,3673, 407,3470,4561,2679,2713,
+ 768,1925,2841,3986,1544,1165, 932, 373,1240,2146,1930,2673, 721,4766, 354,4333,
+ 391,2963, 187,  61,3364,1442,1102, 330,1940,1767, 341,3809,4118, 393,2496,2062,
+2211, 105, 331, 300, 439, 913,1332, 626, 379,3304,1557, 328, 689,3952, 309,1555,
+ 931, 317,2517,3027, 325, 569, 686,2107,3084,  60,1042,1333,2794, 264,3177,4014,
+1628, 258,3712,   7,4464,1176,1043,1778, 683, 114,1975,  78,1492, 383,1886, 510,
+ 386, 645,5291,2891,2069,3305,4138,3867,2939,2603,2493,1935,1066,1848,3588,1015,
+1282,1289,4609, 697,1453,3044,2666,3611,1856,2412,  54, 719,1330, 568,3778,2459,
+1748, 788, 492, 551,1191,1000, 488,3394,3763, 282,1799, 348,2016,1523,3155,2390,
+1049, 382,2019,1788,1170, 729,2968,3523, 897,3926,2785,2938,3292, 350,2319,3238,
+1718,1717,2655,3453,3143,4465, 161,2889,2980,2009,1421,  56,1908,1640,2387,2232,
+1917,1874,2477,4921, 148,  83,3438, 592,4245,2882,1822,1055, 741, 115,1496,1624,
+ 381,1638,4592,1020, 516,3214, 458, 947,4575,1432, 211,1514,2926,1865,2142, 189,
+ 852,1221,1400,1486, 882,2299,4036, 351,  28,1122, 700,6479,6480,6481,6482,6483,  #last 512
+)
+
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/gb2312freq.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/gb2312freq.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..9620275d05ba84d86ec7fd467573c78ae553f507
GIT binary patch
literal 38399
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
Ig~Kfb0Dq&iKL7v#

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/gb2312prober.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/gb2312prober.py
new file mode 100644
index 0000000..8446d2d
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/gb2312prober.py
@@ -0,0 +1,46 @@
+######################## BEGIN LICENSE BLOCK ########################
+# The Original Code is mozilla.org code.
+#
+# The Initial Developer of the Original Code is
+# Netscape Communications Corporation.
+# Portions created by the Initial Developer are Copyright (C) 1998
+# the Initial Developer. All Rights Reserved.
+#
+# Contributor(s):
+#   Mark Pilgrim - port to Python
+#
+# This library is free software; you can redistribute it and/or
+# modify it under the terms of the GNU Lesser General Public
+# License as published by the Free Software Foundation; either
+# version 2.1 of the License, or (at your option) any later version.
+#
+# This library is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+# Lesser General Public License for more details.
+#
+# You should have received a copy of the GNU Lesser General Public
+# License along with this library; if not, write to the Free Software
+# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
+# 02110-1301  USA
+######################### END LICENSE BLOCK #########################
+
+from .mbcharsetprober import MultiByteCharSetProber
+from .codingstatemachine import CodingStateMachine
+from .chardistribution import GB2312DistributionAnalysis
+from .mbcssm import GB2312_SM_MODEL
+
+class GB2312Prober(MultiByteCharSetProber):
+    def __init__(self):
+        super(GB2312Prober, self).__init__()
+        self.coding_sm = CodingStateMachine(GB2312_SM_MODEL)
+        self.distribution_analyzer = GB2312DistributionAnalysis()
+        self.reset()
+
+    @property
+    def charset_name(self):
+        return "GB2312"
+
+    @property
+    def language(self):
+        return "Chinese"
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/gb2312prober.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/gb2312prober.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..76987b62f594d3c1a4115df6c11b6b49ce66e1bf
GIT binary patch
literal 1610
zcmZSn%**AGdLky70ScHI7#JKF7#ND97#J8*7#LC*8FCmHav2$-7#SErd?tn*CWc&Q
zhA3tTpP3<tg&~)fA&M2kXJN=;W5{J^h+=18Okrh6Wn@TWWJqCSXklPzW?+bn;$TQ&
zX9(8dU|?X#WMp7q&;Su7VhjunzNI-OnNF1@sm>XRMZu{h0Y&*qsYMWZAqEBp=lqn+
zy!7Cb#FA9s#N>?3yi|ys6axc;yOWWzp^-~waY<2TQfWzMex74qVoqgoW-&w!KU__G
zuy4Gtzl*C+2@hNhViP<Jm>3usoIqiq&%nTt$^i0u3IoUkQA`Y}%%C6vd4`c8iUrJN
z0!cM9f<hoDSOXM*$sj+0Fo@#}GRcO4fuV$fp@fm4hJm4(i6M&#6dH^r%nT(g49#HC
zcvglIHjroy14BGJNL>~Ohzkn!V6ZRzG&n)Vu!0OMEl4d2VgYeMAsHW^nU`4-A0Gs=
zGzesC2`2*sLoztT;)`>GKwc^l1w|=R5XC2g!l){>s03tWQEG8&3D}+zkh#UFIcXZ8
zL;)s>iy0Ug^b3kI%Mwdc^~(~A^waWlQc{bG^^;Qc%afAwa!qrKjSQ2_)2q@gOfAZD
zvZ~AsKp;I&KSaMEvp_d9uec;JCr8(<%)`?-03-y)@nxxbDfvbE$r*`7DXAs;=}Dl7
zEC5HnUO{CL8v_G_63D|KZ!$0nGx9U?Fv7zZ<Xv$1f?S-!$Plan@~B@4NEakYfL#yv
zRS*{_wGFtBz{w8e+v3!c_`Jm2RFDgcLC$7iBIqx6P&NRi{9>>+Nah(V9s|WtPGVkq
zX<~Y+4k*eXp3(qCMhQqV9_-)v_!3Y|#K-66r<CTT#>a!>7_6Y6D8C@JsH8Folr@9+
zP~r;|Obi2-3_<Bj5#%S3XV@4y+4xzYxsjiNfgv{u8ljMM8w5&ZC7>b;k^zfBMOH4P
z$O7lk5&=-=1f_VS+z82|AoFvRl8cLT!Pyv`#lc=j5Catm;3%?z#G0K9C@?^gD!>Sa
FOaQVMck}=N

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/hebrewprober.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/hebrewprober.py
new file mode 100644
index 0000000..b0e1bf4
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/hebrewprober.py
@@ -0,0 +1,292 @@
+######################## BEGIN LICENSE BLOCK ########################
+# The Original Code is Mozilla Universal charset detector code.
+#
+# The Initial Developer of the Original Code is
+#          Shy Shalom
+# Portions created by the Initial Developer are Copyright (C) 2005
+# the Initial Developer. All Rights Reserved.
+#
+# Contributor(s):
+#   Mark Pilgrim - port to Python
+#
+# This library is free software; you can redistribute it and/or
+# modify it under the terms of the GNU Lesser General Public
+# License as published by the Free Software Foundation; either
+# version 2.1 of the License, or (at your option) any later version.
+#
+# This library is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+# Lesser General Public License for more details.
+#
+# You should have received a copy of the GNU Lesser General Public
+# License along with this library; if not, write to the Free Software
+# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
+# 02110-1301  USA
+######################### END LICENSE BLOCK #########################
+
+from .charsetprober import CharSetProber
+from .enums import ProbingState
+
+# This prober doesn't actually recognize a language or a charset.
+# It is a helper prober for the use of the Hebrew model probers
+
+### General ideas of the Hebrew charset recognition ###
+#
+# Four main charsets exist in Hebrew:
+# "ISO-8859-8" - Visual Hebrew
+# "windows-1255" - Logical Hebrew
+# "ISO-8859-8-I" - Logical Hebrew
+# "x-mac-hebrew" - ?? Logical Hebrew ??
+#
+# Both "ISO" charsets use a completely identical set of code points, whereas
+# "windows-1255" and "x-mac-hebrew" are two different proper supersets of
+# these code points. windows-1255 defines additional characters in the range
+# 0x80-0x9F as some misc punctuation marks as well as some Hebrew-specific
+# diacritics and additional 'Yiddish' ligature letters in the range 0xc0-0xd6.
+# x-mac-hebrew defines similar additional code points but with a different
+# mapping.
+#
+# As far as an average Hebrew text with no diacritics is concerned, all four
+# charsets are identical with respect to code points. Meaning that for the
+# main Hebrew alphabet, all four map the same values to all 27 Hebrew letters
+# (including final letters).
+#
+# The dominant difference between these charsets is their directionality.
+# "Visual" directionality means that the text is ordered as if the renderer is
+# not aware of a BIDI rendering algorithm. The renderer sees the text and
+# draws it from left to right. The text itself when ordered naturally is read
+# backwards. A buffer of Visual Hebrew generally looks like so:
+# "[last word of first line spelled backwards] [whole line ordered backwards
+# and spelled backwards] [first word of first line spelled backwards]
+# [end of line] [last word of second line] ... etc' "
+# adding punctuation marks, numbers and English text to visual text is
+# naturally also "visual" and from left to right.
+#
+# "Logical" directionality means the text is ordered "naturally" according to
+# the order it is read. It is the responsibility of the renderer to display
+# the text from right to left. A BIDI algorithm is used to place general
+# punctuation marks, numbers and English text in the text.
+#
+# Texts in x-mac-hebrew are almost impossible to find on the Internet. From
+# what little evidence I could find, it seems that its general directionality
+# is Logical.
+#
+# To sum up all of the above, the Hebrew probing mechanism knows about two
+# charsets:
+# Visual Hebrew - "ISO-8859-8" - backwards text - Words and sentences are
+#    backwards while line order is natural. For charset recognition purposes
+#    the line order is unimportant (In fact, for this implementation, even
+#    word order is unimportant).
+# Logical Hebrew - "windows-1255" - normal, naturally ordered text.
+#
+# "ISO-8859-8-I" is a subset of windows-1255 and doesn't need to be
+#    specifically identified.
+# "x-mac-hebrew" is also identified as windows-1255. A text in x-mac-hebrew
+#    that contain special punctuation marks or diacritics is displayed with
+#    some unconverted characters showing as question marks. This problem might
+#    be corrected using another model prober for x-mac-hebrew. Due to the fact
+#    that x-mac-hebrew texts are so rare, writing another model prober isn't
+#    worth the effort and performance hit.
+#
+#### The Prober ####
+#
+# The prober is divided between two SBCharSetProbers and a HebrewProber,
+# all of which are managed, created, fed data, inquired and deleted by the
+# SBCSGroupProber. The two SBCharSetProbers identify that the text is in
+# fact some kind of Hebrew, Logical or Visual. The final decision about which
+# one is it is made by the HebrewProber by combining final-letter scores
+# with the scores of the two SBCharSetProbers to produce a final answer.
+#
+# The SBCSGroupProber is responsible for stripping the original text of HTML
+# tags, English characters, numbers, low-ASCII punctuation characters, spaces
+# and new lines. It reduces any sequence of such characters to a single space.
+# The buffer fed to each prober in the SBCS group prober is pure text in
+# high-ASCII.
+# The two SBCharSetProbers (model probers) share the same language model:
+# Win1255Model.
+# The first SBCharSetProber uses the model normally as any other
+# SBCharSetProber does, to recognize windows-1255, upon which this model was
+# built. The second SBCharSetProber is told to make the pair-of-letter
+# lookup in the language model backwards. This in practice exactly simulates
+# a visual Hebrew model using the windows-1255 logical Hebrew model.
+#
+# The HebrewProber is not using any language model. All it does is look for
+# final-letter evidence suggesting the text is either logical Hebrew or visual
+# Hebrew. Disjointed from the model probers, the results of the HebrewProber
+# alone are meaningless. HebrewProber always returns 0.00 as confidence
+# since it never identifies a charset by itself. Instead, the pointer to the
+# HebrewProber is passed to the model probers as a helper "Name Prober".
+# When the Group prober receives a positive identification from any prober,
+# it asks for the name of the charset identified. If the prober queried is a
+# Hebrew model prober, the model prober forwards the call to the
+# HebrewProber to make the final decision. In the HebrewProber, the
+# decision is made according to the final-letters scores maintained and Both
+# model probers scores. The answer is returned in the form of the name of the
+# charset identified, either "windows-1255" or "ISO-8859-8".
+
+class HebrewProber(CharSetProber):
+    # windows-1255 / ISO-8859-8 code points of interest
+    FINAL_KAF = 0xea
+    NORMAL_KAF = 0xeb
+    FINAL_MEM = 0xed
+    NORMAL_MEM = 0xee
+    FINAL_NUN = 0xef
+    NORMAL_NUN = 0xf0
+    FINAL_PE = 0xf3
+    NORMAL_PE = 0xf4
+    FINAL_TSADI = 0xf5
+    NORMAL_TSADI = 0xf6
+
+    # Minimum Visual vs Logical final letter score difference.
+    # If the difference is below this, don't rely solely on the final letter score
+    # distance.
+    MIN_FINAL_CHAR_DISTANCE = 5
+
+    # Minimum Visual vs Logical model score difference.
+    # If the difference is below this, don't rely at all on the model score
+    # distance.
+    MIN_MODEL_DISTANCE = 0.01
+
+    VISUAL_HEBREW_NAME = "ISO-8859-8"
+    LOGICAL_HEBREW_NAME = "windows-1255"
+
+    def __init__(self):
+        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
+        self.reset()
+
+    def reset(self):
+        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 = ' '
+        # These probers are owned by the group prober.
+
+    def set_model_probers(self, logicalProber, visualProber):
+        self._logical_prober = logicalProber
+        self._visual_prober = visualProber
+
+    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_non_final(self, c):
+        # The normal Tsadi is not a good Non-Final letter due to words like
+        # 'lechotet' (to chat) containing an apostrophe after the tsadi. This
+        # apostrophe is converted to a space in FilterWithoutEnglishLetters
+        # causing the Non-Final tsadi to appear at an end of a word even
+        # though this is not the case in the original text.
+        # The letters Pe and Kaf rarely display a related behavior of not being
+        # a good Non-Final letter. Words like 'Pop', 'Winamp' and 'Mubarak'
+        # for example legally end with a Non-Final Pe or Kaf. However, the
+        # benefit of these letters as Non-Final letters outweighs the damage
+        # since these words are quite rare.
+        return c in [self.NORMAL_KAF, self.NORMAL_MEM,
+                     self.NORMAL_NUN, self.NORMAL_PE]
+
+    def feed(self, byte_str):
+        # Final letter analysis for logical-visual decision.
+        # Look for evidence that the received buffer is either logical Hebrew
+        # or visual Hebrew.
+        # The following cases are checked:
+        # 1) A word longer than 1 letter, ending with a final letter. This is
+        #    an indication that the text is laid out "naturally" since the
+        #    final letter really appears at the end. +1 for logical score.
+        # 2) A word longer than 1 letter, ending with a Non-Final letter. In
+        #    normal Hebrew, words ending with Kaf, Mem, Nun, Pe or Tsadi,
+        #    should not end with the Non-Final form of that letter. Exceptions
+        #    to this rule are mentioned above in isNonFinal(). This is an
+        #    indication that the text is laid out backwards. +1 for visual
+        #    score
+        # 3) A word longer than 1 letter, starting with a final letter. Final
+        #    letters should not appear at the beginning of a word. This is an
+        #    indication that the text is laid out backwards. +1 for visual
+        #    score.
+        #
+        # The visual score and logical score are accumulated throughout the
+        # text and are finally checked against each other in GetCharSetName().
+        # No checking for final letters in the middle of words is done since
+        # that case is not an indication for either Logical or Visual text.
+        #
+        # We automatically filter out all 7-bit characters (replace them with
+        # spaces) so the word boundary detection works properly. [MAP]
+
+        if self.state == ProbingState.NOT_ME:
+            # Both model probers say it's not them. No reason to continue.
+            return ProbingState.NOT_ME
+
+        byte_str = self.filter_high_byte_only(byte_str)
+
+        for cur in byte_str:
+            if cur == ' ':
+                # We stand on a space - a word just ended
+                if self._before_prev != ' ':
+                    # next-to-last char was not a space so self._prev is not a
+                    # 1 letter word
+                    if self.is_final(self._prev):
+                        # case (1) [-2:not space][-1:final letter][cur:space]
+                        self._final_char_logical_score += 1
+                    elif self.is_non_final(self._prev):
+                        # case (2) [-2:not space][-1:Non-Final letter][
+                        #  cur:space]
+                        self._final_char_visual_score += 1
+            else:
+                # Not standing on a space
+                if ((self._before_prev == ' ') and
+                        (self.is_final(self._prev)) and (cur != ' ')):
+                    # case (3) [-2:space][-1:final letter][cur:not space]
+                    self._final_char_visual_score += 1
+            self._before_prev = self._prev
+            self._prev = cur
+
+        # Forever detecting, till the end or until both model probers return
+        # ProbingState.NOT_ME (handled above)
+        return ProbingState.DETECTING
+
+    @property
+    def charset_name(self):
+        # Make the decision: is it Logical or Visual?
+        # If the final letter score distance is dominant enough, rely on it.
+        finalsub = self._final_char_logical_score - self._final_char_visual_score
+        if finalsub >= self.MIN_FINAL_CHAR_DISTANCE:
+            return self.LOGICAL_HEBREW_NAME
+        if finalsub <= -self.MIN_FINAL_CHAR_DISTANCE:
+            return self.VISUAL_HEBREW_NAME
+
+        # It's not dominant enough, try to rely on the model scores instead.
+        modelsub = (self._logical_prober.get_confidence()
+                    - self._visual_prober.get_confidence())
+        if modelsub > self.MIN_MODEL_DISTANCE:
+            return self.LOGICAL_HEBREW_NAME
+        if modelsub < -self.MIN_MODEL_DISTANCE:
+            return self.VISUAL_HEBREW_NAME
+
+        # Still no good, back to final letter distance, maybe it'll save the
+        # day.
+        if finalsub < 0.0:
+            return self.VISUAL_HEBREW_NAME
+
+        # (finalsub > 0 - Logical) or (don't know what to do) default to
+        # Logical.
+        return self.LOGICAL_HEBREW_NAME
+
+    @property
+    def language(self):
+        return 'Hebrew'
+
+    @property
+    def state(self):
+        # Remain active as long as any of the model probers are active.
+        if (self._logical_prober.state == ProbingState.NOT_ME) and \
+           (self._visual_prober.state == ProbingState.NOT_ME):
+            return ProbingState.NOT_ME
+        return ProbingState.DETECTING
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/hebrewprober.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/hebrewprober.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..77dfb3df8f972e4ea15bf3b1870f8c8f227db886
GIT binary patch
literal 4331
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
R=A_zz;=33Wivo-S$pBHaw-W#W

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/jisfreq.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/jisfreq.py
new file mode 100644
index 0000000..83fc082
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/jisfreq.py
@@ -0,0 +1,325 @@
+######################## BEGIN LICENSE BLOCK ########################
+# The Original Code is Mozilla Communicator client code.
+#
+# The Initial Developer of the Original Code is
+# Netscape Communications Corporation.
+# Portions created by the Initial Developer are Copyright (C) 1998
+# the Initial Developer. All Rights Reserved.
+#
+# Contributor(s):
+#   Mark Pilgrim - port to Python
+#
+# This library is free software; you can redistribute it and/or
+# modify it under the terms of the GNU Lesser General Public
+# License as published by the Free Software Foundation; either
+# version 2.1 of the License, or (at your option) any later version.
+#
+# This library is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+# Lesser General Public License for more details.
+#
+# You should have received a copy of the GNU Lesser General Public
+# License along with this library; if not, write to the Free Software
+# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
+# 02110-1301  USA
+######################### END LICENSE BLOCK #########################
+
+# Sampling from about 20M text materials include literature and computer technology
+#
+# Japanese frequency table, applied to both S-JIS and EUC-JP
+# They are sorted in order.
+
+# 128  --> 0.77094
+# 256  --> 0.85710
+# 512  --> 0.92635
+# 1024 --> 0.97130
+# 2048 --> 0.99431
+#
+# Ideal Distribution Ratio = 0.92635 / (1-0.92635) = 12.58
+# Random Distribution Ration = 512 / (2965+62+83+86-512) = 0.191
+#
+# Typical Distribution Ratio, 25% of IDR
+
+JIS_TYPICAL_DISTRIBUTION_RATIO = 3.0
+
+# Char to FreqOrder table ,
+JIS_TABLE_SIZE = 4368
+
+JIS_CHAR_TO_FREQ_ORDER = (
+  40,   1,   6, 182, 152, 180, 295,2127, 285, 381,3295,4304,3068,4606,3165,3510, #   16
+3511,1822,2785,4607,1193,2226,5070,4608, 171,2996,1247,  18, 179,5071, 856,1661, #   32
+1262,5072, 619, 127,3431,3512,3230,1899,1700, 232, 228,1294,1298, 284, 283,2041, #   48
+2042,1061,1062,  48,  49,  44,  45, 433, 434,1040,1041, 996, 787,2997,1255,4305, #   64
+2108,4609,1684,1648,5073,5074,5075,5076,5077,5078,3687,5079,4610,5080,3927,3928, #   80
+5081,3296,3432, 290,2285,1471,2187,5082,2580,2825,1303,2140,1739,1445,2691,3375, #   96
+1691,3297,4306,4307,4611, 452,3376,1182,2713,3688,3069,4308,5083,5084,5085,5086, #  112
+5087,5088,5089,5090,5091,5092,5093,5094,5095,5096,5097,5098,5099,5100,5101,5102, #  128
+5103,5104,5105,5106,5107,5108,5109,5110,5111,5112,4097,5113,5114,5115,5116,5117, #  144
+5118,5119,5120,5121,5122,5123,5124,5125,5126,5127,5128,5129,5130,5131,5132,5133, #  160
+5134,5135,5136,5137,5138,5139,5140,5141,5142,5143,5144,5145,5146,5147,5148,5149, #  176
+5150,5151,5152,4612,5153,5154,5155,5156,5157,5158,5159,5160,5161,5162,5163,5164, #  192
+5165,5166,5167,5168,5169,5170,5171,5172,5173,5174,5175,1472, 598, 618, 820,1205, #  208
+1309,1412,1858,1307,1692,5176,5177,5178,5179,5180,5181,5182,1142,1452,1234,1172, #  224
+1875,2043,2149,1793,1382,2973, 925,2404,1067,1241, 960,1377,2935,1491, 919,1217, #  240
+1865,2030,1406,1499,2749,4098,5183,5184,5185,5186,5187,5188,2561,4099,3117,1804, #  256
+2049,3689,4309,3513,1663,5189,3166,3118,3298,1587,1561,3433,5190,3119,1625,2998, #  272
+3299,4613,1766,3690,2786,4614,5191,5192,5193,5194,2161,  26,3377,   2,3929,  20, #  288
+3691,  47,4100,  50,  17,  16,  35, 268,  27, 243,  42, 155,  24, 154,  29, 184, #  304
+   4,  91,  14,  92,  53, 396,  33, 289,   9,  37,  64, 620,  21,  39, 321,   5, #  320
+  12,  11,  52,  13,   3, 208, 138,   0,   7,  60, 526, 141, 151,1069, 181, 275, #  336
+1591,  83, 132,1475, 126, 331, 829,  15,  69, 160,  59,  22, 157,  55,1079, 312, #  352
+ 109,  38,  23,  25,  10,  19,  79,5195,  61, 382,1124,   8,  30,5196,5197,5198, #  368
+5199,5200,5201,5202,5203,5204,5205,5206,  89,  62,  74,  34,2416, 112, 139, 196, #  384
+ 271, 149,  84, 607, 131, 765,  46,  88, 153, 683,  76, 874, 101, 258,  57,  80, #  400
+  32, 364, 121,1508, 169,1547,  68, 235, 145,2999,  41, 360,3027,  70,  63,  31, #  416
+  43, 259, 262,1383,  99, 533, 194,  66,  93, 846, 217, 192,  56, 106,  58, 565, #  432
+ 280, 272, 311, 256, 146,  82, 308,  71, 100, 128, 214, 655, 110, 261, 104,1140, #  448
+  54,  51,  36,  87,  67,3070, 185,2618,2936,2020,  28,1066,2390,2059,5207,5208, #  464
+5209,5210,5211,5212,5213,5214,5215,5216,4615,5217,5218,5219,5220,5221,5222,5223, #  480
+5224,5225,5226,5227,5228,5229,5230,5231,5232,5233,5234,5235,5236,3514,5237,5238, #  496
+5239,5240,5241,5242,5243,5244,2297,2031,4616,4310,3692,5245,3071,5246,3598,5247, #  512
+4617,3231,3515,5248,4101,4311,4618,3808,4312,4102,5249,4103,4104,3599,5250,5251, #  528
+5252,5253,5254,5255,5256,5257,5258,5259,5260,5261,5262,5263,5264,5265,5266,5267, #  544
+5268,5269,5270,5271,5272,5273,5274,5275,5276,5277,5278,5279,5280,5281,5282,5283, #  560
+5284,5285,5286,5287,5288,5289,5290,5291,5292,5293,5294,5295,5296,5297,5298,5299, #  576
+5300,5301,5302,5303,5304,5305,5306,5307,5308,5309,5310,5311,5312,5313,5314,5315, #  592
+5316,5317,5318,5319,5320,5321,5322,5323,5324,5325,5326,5327,5328,5329,5330,5331, #  608
+5332,5333,5334,5335,5336,5337,5338,5339,5340,5341,5342,5343,5344,5345,5346,5347, #  624
+5348,5349,5350,5351,5352,5353,5354,5355,5356,5357,5358,5359,5360,5361,5362,5363, #  640
+5364,5365,5366,5367,5368,5369,5370,5371,5372,5373,5374,5375,5376,5377,5378,5379, #  656
+5380,5381, 363, 642,2787,2878,2788,2789,2316,3232,2317,3434,2011, 165,1942,3930, #  672
+3931,3932,3933,5382,4619,5383,4620,5384,5385,5386,5387,5388,5389,5390,5391,5392, #  688
+5393,5394,5395,5396,5397,5398,5399,5400,5401,5402,5403,5404,5405,5406,5407,5408, #  704
+5409,5410,5411,5412,5413,5414,5415,5416,5417,5418,5419,5420,5421,5422,5423,5424, #  720
+5425,5426,5427,5428,5429,5430,5431,5432,5433,5434,5435,5436,5437,5438,5439,5440, #  736
+5441,5442,5443,5444,5445,5446,5447,5448,5449,5450,5451,5452,5453,5454,5455,5456, #  752
+5457,5458,5459,5460,5461,5462,5463,5464,5465,5466,5467,5468,5469,5470,5471,5472, #  768
+5473,5474,5475,5476,5477,5478,5479,5480,5481,5482,5483,5484,5485,5486,5487,5488, #  784
+5489,5490,5491,5492,5493,5494,5495,5496,5497,5498,5499,5500,5501,5502,5503,5504, #  800
+5505,5506,5507,5508,5509,5510,5511,5512,5513,5514,5515,5516,5517,5518,5519,5520, #  816
+5521,5522,5523,5524,5525,5526,5527,5528,5529,5530,5531,5532,5533,5534,5535,5536, #  832
+5537,5538,5539,5540,5541,5542,5543,5544,5545,5546,5547,5548,5549,5550,5551,5552, #  848
+5553,5554,5555,5556,5557,5558,5559,5560,5561,5562,5563,5564,5565,5566,5567,5568, #  864
+5569,5570,5571,5572,5573,5574,5575,5576,5577,5578,5579,5580,5581,5582,5583,5584, #  880
+5585,5586,5587,5588,5589,5590,5591,5592,5593,5594,5595,5596,5597,5598,5599,5600, #  896
+5601,5602,5603,5604,5605,5606,5607,5608,5609,5610,5611,5612,5613,5614,5615,5616, #  912
+5617,5618,5619,5620,5621,5622,5623,5624,5625,5626,5627,5628,5629,5630,5631,5632, #  928
+5633,5634,5635,5636,5637,5638,5639,5640,5641,5642,5643,5644,5645,5646,5647,5648, #  944
+5649,5650,5651,5652,5653,5654,5655,5656,5657,5658,5659,5660,5661,5662,5663,5664, #  960
+5665,5666,5667,5668,5669,5670,5671,5672,5673,5674,5675,5676,5677,5678,5679,5680, #  976
+5681,5682,5683,5684,5685,5686,5687,5688,5689,5690,5691,5692,5693,5694,5695,5696, #  992
+5697,5698,5699,5700,5701,5702,5703,5704,5705,5706,5707,5708,5709,5710,5711,5712, # 1008
+5713,5714,5715,5716,5717,5718,5719,5720,5721,5722,5723,5724,5725,5726,5727,5728, # 1024
+5729,5730,5731,5732,5733,5734,5735,5736,5737,5738,5739,5740,5741,5742,5743,5744, # 1040
+5745,5746,5747,5748,5749,5750,5751,5752,5753,5754,5755,5756,5757,5758,5759,5760, # 1056
+5761,5762,5763,5764,5765,5766,5767,5768,5769,5770,5771,5772,5773,5774,5775,5776, # 1072
+5777,5778,5779,5780,5781,5782,5783,5784,5785,5786,5787,5788,5789,5790,5791,5792, # 1088
+5793,5794,5795,5796,5797,5798,5799,5800,5801,5802,5803,5804,5805,5806,5807,5808, # 1104
+5809,5810,5811,5812,5813,5814,5815,5816,5817,5818,5819,5820,5821,5822,5823,5824, # 1120
+5825,5826,5827,5828,5829,5830,5831,5832,5833,5834,5835,5836,5837,5838,5839,5840, # 1136
+5841,5842,5843,5844,5845,5846,5847,5848,5849,5850,5851,5852,5853,5854,5855,5856, # 1152
+5857,5858,5859,5860,5861,5862,5863,5864,5865,5866,5867,5868,5869,5870,5871,5872, # 1168
+5873,5874,5875,5876,5877,5878,5879,5880,5881,5882,5883,5884,5885,5886,5887,5888, # 1184
+5889,5890,5891,5892,5893,5894,5895,5896,5897,5898,5899,5900,5901,5902,5903,5904, # 1200
+5905,5906,5907,5908,5909,5910,5911,5912,5913,5914,5915,5916,5917,5918,5919,5920, # 1216
+5921,5922,5923,5924,5925,5926,5927,5928,5929,5930,5931,5932,5933,5934,5935,5936, # 1232
+5937,5938,5939,5940,5941,5942,5943,5944,5945,5946,5947,5948,5949,5950,5951,5952, # 1248
+5953,5954,5955,5956,5957,5958,5959,5960,5961,5962,5963,5964,5965,5966,5967,5968, # 1264
+5969,5970,5971,5972,5973,5974,5975,5976,5977,5978,5979,5980,5981,5982,5983,5984, # 1280
+5985,5986,5987,5988,5989,5990,5991,5992,5993,5994,5995,5996,5997,5998,5999,6000, # 1296
+6001,6002,6003,6004,6005,6006,6007,6008,6009,6010,6011,6012,6013,6014,6015,6016, # 1312
+6017,6018,6019,6020,6021,6022,6023,6024,6025,6026,6027,6028,6029,6030,6031,6032, # 1328
+6033,6034,6035,6036,6037,6038,6039,6040,6041,6042,6043,6044,6045,6046,6047,6048, # 1344
+6049,6050,6051,6052,6053,6054,6055,6056,6057,6058,6059,6060,6061,6062,6063,6064, # 1360
+6065,6066,6067,6068,6069,6070,6071,6072,6073,6074,6075,6076,6077,6078,6079,6080, # 1376
+6081,6082,6083,6084,6085,6086,6087,6088,6089,6090,6091,6092,6093,6094,6095,6096, # 1392
+6097,6098,6099,6100,6101,6102,6103,6104,6105,6106,6107,6108,6109,6110,6111,6112, # 1408
+6113,6114,2044,2060,4621, 997,1235, 473,1186,4622, 920,3378,6115,6116, 379,1108, # 1424
+4313,2657,2735,3934,6117,3809, 636,3233, 573,1026,3693,3435,2974,3300,2298,4105, # 1440
+ 854,2937,2463, 393,2581,2417, 539, 752,1280,2750,2480, 140,1161, 440, 708,1569, # 1456
+ 665,2497,1746,1291,1523,3000, 164,1603, 847,1331, 537,1997, 486, 508,1693,2418, # 1472
+1970,2227, 878,1220, 299,1030, 969, 652,2751, 624,1137,3301,2619,  65,3302,2045, # 1488
+1761,1859,3120,1930,3694,3516, 663,1767, 852, 835,3695, 269, 767,2826,2339,1305, # 1504
+ 896,1150, 770,1616,6118, 506,1502,2075,1012,2519, 775,2520,2975,2340,2938,4314, # 1520
+3028,2086,1224,1943,2286,6119,3072,4315,2240,1273,1987,3935,1557, 175, 597, 985, # 1536
+3517,2419,2521,1416,3029, 585, 938,1931,1007,1052,1932,1685,6120,3379,4316,4623, # 1552
+ 804, 599,3121,1333,2128,2539,1159,1554,2032,3810, 687,2033,2904, 952, 675,1467, # 1568
+3436,6121,2241,1096,1786,2440,1543,1924, 980,1813,2228, 781,2692,1879, 728,1918, # 1584
+3696,4624, 548,1950,4625,1809,1088,1356,3303,2522,1944, 502, 972, 373, 513,2827, # 1600
+ 586,2377,2391,1003,1976,1631,6122,2464,1084, 648,1776,4626,2141, 324, 962,2012, # 1616
+2177,2076,1384, 742,2178,1448,1173,1810, 222, 102, 301, 445, 125,2420, 662,2498, # 1632
+ 277, 200,1476,1165,1068, 224,2562,1378,1446, 450,1880, 659, 791, 582,4627,2939, # 1648
+3936,1516,1274, 555,2099,3697,1020,1389,1526,3380,1762,1723,1787,2229, 412,2114, # 1664
+1900,2392,3518, 512,2597, 427,1925,2341,3122,1653,1686,2465,2499, 697, 330, 273, # 1680
+ 380,2162, 951, 832, 780, 991,1301,3073, 965,2270,3519, 668,2523,2636,1286, 535, # 1696
+1407, 518, 671, 957,2658,2378, 267, 611,2197,3030,6123, 248,2299, 967,1799,2356, # 1712
+ 850,1418,3437,1876,1256,1480,2828,1718,6124,6125,1755,1664,2405,6126,4628,2879, # 1728
+2829, 499,2179, 676,4629, 557,2329,2214,2090, 325,3234, 464, 811,3001, 992,2342, # 1744
+2481,1232,1469, 303,2242, 466,1070,2163, 603,1777,2091,4630,2752,4631,2714, 322, # 1760
+2659,1964,1768, 481,2188,1463,2330,2857,3600,2092,3031,2421,4632,2318,2070,1849, # 1776
+2598,4633,1302,2254,1668,1701,2422,3811,2905,3032,3123,2046,4106,1763,1694,4634, # 1792
+1604, 943,1724,1454, 917, 868,2215,1169,2940, 552,1145,1800,1228,1823,1955, 316, # 1808
+1080,2510, 361,1807,2830,4107,2660,3381,1346,1423,1134,4108,6127, 541,1263,1229, # 1824
+1148,2540, 545, 465,1833,2880,3438,1901,3074,2482, 816,3937, 713,1788,2500, 122, # 1840
+1575, 195,1451,2501,1111,6128, 859, 374,1225,2243,2483,4317, 390,1033,3439,3075, # 1856
+2524,1687, 266, 793,1440,2599, 946, 779, 802, 507, 897,1081, 528,2189,1292, 711, # 1872
+1866,1725,1167,1640, 753, 398,2661,1053, 246, 348,4318, 137,1024,3440,1600,2077, # 1888
+2129, 825,4319, 698, 238, 521, 187,2300,1157,2423,1641,1605,1464,1610,1097,2541, # 1904
+1260,1436, 759,2255,1814,2150, 705,3235, 409,2563,3304, 561,3033,2005,2564, 726, # 1920
+1956,2343,3698,4109, 949,3812,3813,3520,1669, 653,1379,2525, 881,2198, 632,2256, # 1936
+1027, 778,1074, 733,1957, 514,1481,2466, 554,2180, 702,3938,1606,1017,1398,6129, # 1952
+1380,3521, 921, 993,1313, 594, 449,1489,1617,1166, 768,1426,1360, 495,1794,3601, # 1968
+1177,3602,1170,4320,2344, 476, 425,3167,4635,3168,1424, 401,2662,1171,3382,1998, # 1984
+1089,4110, 477,3169, 474,6130,1909, 596,2831,1842, 494, 693,1051,1028,1207,3076, # 2000
+ 606,2115, 727,2790,1473,1115, 743,3522, 630, 805,1532,4321,2021, 366,1057, 838, # 2016
+ 684,1114,2142,4322,2050,1492,1892,1808,2271,3814,2424,1971,1447,1373,3305,1090, # 2032
+1536,3939,3523,3306,1455,2199, 336, 369,2331,1035, 584,2393, 902, 718,2600,6131, # 2048
+2753, 463,2151,1149,1611,2467, 715,1308,3124,1268, 343,1413,3236,1517,1347,2663, # 2064
+2093,3940,2022,1131,1553,2100,2941,1427,3441,2942,1323,2484,6132,1980, 872,2368, # 2080
+2441,2943, 320,2369,2116,1082, 679,1933,3941,2791,3815, 625,1143,2023, 422,2200, # 2096
+3816,6133, 730,1695, 356,2257,1626,2301,2858,2637,1627,1778, 937, 883,2906,2693, # 2112
+3002,1769,1086, 400,1063,1325,3307,2792,4111,3077, 456,2345,1046, 747,6134,1524, # 2128
+ 884,1094,3383,1474,2164,1059, 974,1688,2181,2258,1047, 345,1665,1187, 358, 875, # 2144
+3170, 305, 660,3524,2190,1334,1135,3171,1540,1649,2542,1527, 927, 968,2793, 885, # 2160
+1972,1850, 482, 500,2638,1218,1109,1085,2543,1654,2034, 876,  78,2287,1482,1277, # 2176
+ 861,1675,1083,1779, 724,2754, 454, 397,1132,1612,2332, 893, 672,1237, 257,2259, # 2192
+2370, 135,3384, 337,2244, 547, 352, 340, 709,2485,1400, 788,1138,2511, 540, 772, # 2208
+1682,2260,2272,2544,2013,1843,1902,4636,1999,1562,2288,4637,2201,1403,1533, 407, # 2224
+ 576,3308,1254,2071, 978,3385, 170, 136,1201,3125,2664,3172,2394, 213, 912, 873, # 2240
+3603,1713,2202, 699,3604,3699, 813,3442, 493, 531,1054, 468,2907,1483, 304, 281, # 2256
+4112,1726,1252,2094, 339,2319,2130,2639, 756,1563,2944, 748, 571,2976,1588,2425, # 2272
+2715,1851,1460,2426,1528,1392,1973,3237, 288,3309, 685,3386, 296, 892,2716,2216, # 2288
+1570,2245, 722,1747,2217, 905,3238,1103,6135,1893,1441,1965, 251,1805,2371,3700, # 2304
+2601,1919,1078,  75,2182,1509,1592,1270,2640,4638,2152,6136,3310,3817, 524, 706, # 2320
+1075, 292,3818,1756,2602, 317,  98,3173,3605,3525,1844,2218,3819,2502, 814, 567, # 2336
+ 385,2908,1534,6137, 534,1642,3239, 797,6138,1670,1529, 953,4323, 188,1071, 538, # 2352
+ 178, 729,3240,2109,1226,1374,2000,2357,2977, 731,2468,1116,2014,2051,6139,1261, # 2368
+1593, 803,2859,2736,3443, 556, 682, 823,1541,6140,1369,2289,1706,2794, 845, 462, # 2384
+2603,2665,1361, 387, 162,2358,1740, 739,1770,1720,1304,1401,3241,1049, 627,1571, # 2400
+2427,3526,1877,3942,1852,1500, 431,1910,1503, 677, 297,2795, 286,1433,1038,1198, # 2416
+2290,1133,1596,4113,4639,2469,1510,1484,3943,6141,2442, 108, 712,4640,2372, 866, # 2432
+3701,2755,3242,1348, 834,1945,1408,3527,2395,3243,1811, 824, 994,1179,2110,1548, # 2448
+1453, 790,3003, 690,4324,4325,2832,2909,3820,1860,3821, 225,1748, 310, 346,1780, # 2464
+2470, 821,1993,2717,2796, 828, 877,3528,2860,2471,1702,2165,2910,2486,1789, 453, # 2480
+ 359,2291,1676,  73,1164,1461,1127,3311, 421, 604, 314,1037, 589, 116,2487, 737, # 2496
+ 837,1180, 111, 244, 735,6142,2261,1861,1362, 986, 523, 418, 581,2666,3822, 103, # 2512
+ 855, 503,1414,1867,2488,1091, 657,1597, 979, 605,1316,4641,1021,2443,2078,2001, # 2528
+1209,  96, 587,2166,1032, 260,1072,2153, 173,  94, 226,3244, 819,2006,4642,4114, # 2544
+2203, 231,1744, 782,  97,2667, 786,3387, 887, 391, 442,2219,4326,1425,6143,2694, # 2560
+ 633,1544,1202, 483,2015, 592,2052,1958,2472,1655, 419, 129,4327,3444,3312,1714, # 2576
+1257,3078,4328,1518,1098, 865,1310,1019,1885,1512,1734, 469,2444, 148, 773, 436, # 2592
+1815,1868,1128,1055,4329,1245,2756,3445,2154,1934,1039,4643, 579,1238, 932,2320, # 2608
+ 353, 205, 801, 115,2428, 944,2321,1881, 399,2565,1211, 678, 766,3944, 335,2101, # 2624
+1459,1781,1402,3945,2737,2131,1010, 844, 981,1326,1013, 550,1816,1545,2620,1335, # 2640
+1008, 371,2881, 936,1419,1613,3529,1456,1395,2273,1834,2604,1317,2738,2503, 416, # 2656
+1643,4330, 806,1126, 229, 591,3946,1314,1981,1576,1837,1666, 347,1790, 977,3313, # 2672
+ 764,2861,1853, 688,2429,1920,1462,  77, 595, 415,2002,3034, 798,1192,4115,6144, # 2688
+2978,4331,3035,2695,2582,2072,2566, 430,2430,1727, 842,1396,3947,3702, 613, 377, # 2704
+ 278, 236,1417,3388,3314,3174, 757,1869, 107,3530,6145,1194, 623,2262, 207,1253, # 2720
+2167,3446,3948, 492,1117,1935, 536,1838,2757,1246,4332, 696,2095,2406,1393,1572, # 2736
+3175,1782, 583, 190, 253,1390,2230, 830,3126,3389, 934,3245,1703,1749,2979,1870, # 2752
+2545,1656,2204, 869,2346,4116,3176,1817, 496,1764,4644, 942,1504, 404,1903,1122, # 2768
+1580,3606,2945,1022, 515, 372,1735, 955,2431,3036,6146,2797,1110,2302,2798, 617, # 2784
+6147, 441, 762,1771,3447,3607,3608,1904, 840,3037,  86, 939,1385, 572,1370,2445, # 2800
+1336, 114,3703, 898, 294, 203,3315, 703,1583,2274, 429, 961,4333,1854,1951,3390, # 2816
+2373,3704,4334,1318,1381, 966,1911,2322,1006,1155, 309, 989, 458,2718,1795,1372, # 2832
+1203, 252,1689,1363,3177, 517,1936, 168,1490, 562, 193,3823,1042,4117,1835, 551, # 2848
+ 470,4645, 395, 489,3448,1871,1465,2583,2641, 417,1493, 279,1295, 511,1236,1119, # 2864
+  72,1231,1982,1812,3004, 871,1564, 984,3449,1667,2696,2096,4646,2347,2833,1673, # 2880
+3609, 695,3246,2668, 807,1183,4647, 890, 388,2333,1801,1457,2911,1765,1477,1031, # 2896
+3316,3317,1278,3391,2799,2292,2526, 163,3450,4335,2669,1404,1802,6148,2323,2407, # 2912
+1584,1728,1494,1824,1269, 298, 909,3318,1034,1632, 375, 776,1683,2061, 291, 210, # 2928
+1123, 809,1249,1002,2642,3038, 206,1011,2132, 144, 975, 882,1565, 342, 667, 754, # 2944
+1442,2143,1299,2303,2062, 447, 626,2205,1221,2739,2912,1144,1214,2206,2584, 760, # 2960
+1715, 614, 950,1281,2670,2621, 810, 577,1287,2546,4648, 242,2168, 250,2643, 691, # 2976
+ 123,2644, 647, 313,1029, 689,1357,2946,1650, 216, 771,1339,1306, 808,2063, 549, # 2992
+ 913,1371,2913,2914,6149,1466,1092,1174,1196,1311,2605,2396,1783,1796,3079, 406, # 3008
+2671,2117,3949,4649, 487,1825,2220,6150,2915, 448,2348,1073,6151,2397,1707, 130, # 3024
+ 900,1598, 329, 176,1959,2527,1620,6152,2275,4336,3319,1983,2191,3705,3610,2155, # 3040
+3706,1912,1513,1614,6153,1988, 646, 392,2304,1589,3320,3039,1826,1239,1352,1340, # 3056
+2916, 505,2567,1709,1437,2408,2547, 906,6154,2672, 384,1458,1594,1100,1329, 710, # 3072
+ 423,3531,2064,2231,2622,1989,2673,1087,1882, 333, 841,3005,1296,2882,2379, 580, # 3088
+1937,1827,1293,2585, 601, 574, 249,1772,4118,2079,1120, 645, 901,1176,1690, 795, # 3104
+2207, 478,1434, 516,1190,1530, 761,2080, 930,1264, 355, 435,1552, 644,1791, 987, # 3120
+ 220,1364,1163,1121,1538, 306,2169,1327,1222, 546,2645, 218, 241, 610,1704,3321, # 3136
+1984,1839,1966,2528, 451,6155,2586,3707,2568, 907,3178, 254,2947, 186,1845,4650, # 3152
+ 745, 432,1757, 428,1633, 888,2246,2221,2489,3611,2118,1258,1265, 956,3127,1784, # 3168
+4337,2490, 319, 510, 119, 457,3612, 274,2035,2007,4651,1409,3128, 970,2758, 590, # 3184
+2800, 661,2247,4652,2008,3950,1420,1549,3080,3322,3951,1651,1375,2111, 485,2491, # 3200
+1429,1156,6156,2548,2183,1495, 831,1840,2529,2446, 501,1657, 307,1894,3247,1341, # 3216
+ 666, 899,2156,1539,2549,1559, 886, 349,2208,3081,2305,1736,3824,2170,2759,1014, # 3232
+1913,1386, 542,1397,2948, 490, 368, 716, 362, 159, 282,2569,1129,1658,1288,1750, # 3248
+2674, 276, 649,2016, 751,1496, 658,1818,1284,1862,2209,2087,2512,3451, 622,2834, # 3264
+ 376, 117,1060,2053,1208,1721,1101,1443, 247,1250,3179,1792,3952,2760,2398,3953, # 3280
+6157,2144,3708, 446,2432,1151,2570,3452,2447,2761,2835,1210,2448,3082, 424,2222, # 3296
+1251,2449,2119,2836, 504,1581,4338, 602, 817, 857,3825,2349,2306, 357,3826,1470, # 3312
+1883,2883, 255, 958, 929,2917,3248, 302,4653,1050,1271,1751,2307,1952,1430,2697, # 3328
+2719,2359, 354,3180, 777, 158,2036,4339,1659,4340,4654,2308,2949,2248,1146,2232, # 3344
+3532,2720,1696,2623,3827,6158,3129,1550,2698,1485,1297,1428, 637, 931,2721,2145, # 3360
+ 914,2550,2587,  81,2450, 612, 827,2646,1242,4655,1118,2884, 472,1855,3181,3533, # 3376
+3534, 569,1353,2699,1244,1758,2588,4119,2009,2762,2171,3709,1312,1531,6159,1152, # 3392
+1938, 134,1830, 471,3710,2276,1112,1535,3323,3453,3535, 982,1337,2950, 488, 826, # 3408
+ 674,1058,1628,4120,2017, 522,2399, 211, 568,1367,3454, 350, 293,1872,1139,3249, # 3424
+1399,1946,3006,1300,2360,3324, 588, 736,6160,2606, 744, 669,3536,3828,6161,1358, # 3440
+ 199, 723, 848, 933, 851,1939,1505,1514,1338,1618,1831,4656,1634,3613, 443,2740, # 3456
+3829, 717,1947, 491,1914,6162,2551,1542,4121,1025,6163,1099,1223, 198,3040,2722, # 3472
+ 370, 410,1905,2589, 998,1248,3182,2380, 519,1449,4122,1710, 947, 928,1153,4341, # 3488
+2277, 344,2624,1511, 615, 105, 161,1212,1076,1960,3130,2054,1926,1175,1906,2473, # 3504
+ 414,1873,2801,6164,2309, 315,1319,3325, 318,2018,2146,2157, 963, 631, 223,4342, # 3520
+4343,2675, 479,3711,1197,2625,3712,2676,2361,6165,4344,4123,6166,2451,3183,1886, # 3536
+2184,1674,1330,1711,1635,1506, 799, 219,3250,3083,3954,1677,3713,3326,2081,3614, # 3552
+1652,2073,4657,1147,3041,1752, 643,1961, 147,1974,3955,6167,1716,2037, 918,3007, # 3568
+1994, 120,1537, 118, 609,3184,4345, 740,3455,1219, 332,1615,3830,6168,1621,2980, # 3584
+1582, 783, 212, 553,2350,3714,1349,2433,2082,4124, 889,6169,2310,1275,1410, 973, # 3600
+ 166,1320,3456,1797,1215,3185,2885,1846,2590,2763,4658, 629, 822,3008, 763, 940, # 3616
+1990,2862, 439,2409,1566,1240,1622, 926,1282,1907,2764, 654,2210,1607, 327,1130, # 3632
+3956,1678,1623,6170,2434,2192, 686, 608,3831,3715, 903,3957,3042,6171,2741,1522, # 3648
+1915,1105,1555,2552,1359, 323,3251,4346,3457, 738,1354,2553,2311,2334,1828,2003, # 3664
+3832,1753,2351,1227,6172,1887,4125,1478,6173,2410,1874,1712,1847, 520,1204,2607, # 3680
+ 264,4659, 836,2677,2102, 600,4660,3833,2278,3084,6174,4347,3615,1342, 640, 532, # 3696
+ 543,2608,1888,2400,2591,1009,4348,1497, 341,1737,3616,2723,1394, 529,3252,1321, # 3712
+ 983,4661,1515,2120, 971,2592, 924, 287,1662,3186,4349,2700,4350,1519, 908,1948, # 3728
+2452, 156, 796,1629,1486,2223,2055, 694,4126,1259,1036,3392,1213,2249,2742,1889, # 3744
+1230,3958,1015, 910, 408, 559,3617,4662, 746, 725, 935,4663,3959,3009,1289, 563, # 3760
+ 867,4664,3960,1567,2981,2038,2626, 988,2263,2381,4351, 143,2374, 704,1895,6175, # 3776
+1188,3716,2088, 673,3085,2362,4352, 484,1608,1921,2765,2918, 215, 904,3618,3537, # 3792
+ 894, 509, 976,3043,2701,3961,4353,2837,2982, 498,6176,6177,1102,3538,1332,3393, # 3808
+1487,1636,1637, 233, 245,3962, 383, 650, 995,3044, 460,1520,1206,2352, 749,3327, # 3824
+ 530, 700, 389,1438,1560,1773,3963,2264, 719,2951,2724,3834, 870,1832,1644,1000, # 3840
+ 839,2474,3717, 197,1630,3394, 365,2886,3964,1285,2133, 734, 922, 818,1106, 732, # 3856
+ 480,2083,1774,3458, 923,2279,1350, 221,3086,  85,2233,2234,3835,1585,3010,2147, # 3872
+1387,1705,2382,1619,2475, 133, 239,2802,1991,1016,2084,2383, 411,2838,1113, 651, # 3888
+1985,1160,3328, 990,1863,3087,1048,1276,2647, 265,2627,1599,3253,2056, 150, 638, # 3904
+2019, 656, 853, 326,1479, 680,1439,4354,1001,1759, 413,3459,3395,2492,1431, 459, # 3920
+4355,1125,3329,2265,1953,1450,2065,2863, 849, 351,2678,3131,3254,3255,1104,1577, # 3936
+ 227,1351,1645,2453,2193,1421,2887, 812,2121, 634,  95,2435, 201,2312,4665,1646, # 3952
+1671,2743,1601,2554,2702,2648,2280,1315,1366,2089,3132,1573,3718,3965,1729,1189, # 3968
+ 328,2679,1077,1940,1136, 558,1283, 964,1195, 621,2074,1199,1743,3460,3619,1896, # 3984
+1916,1890,3836,2952,1154,2112,1064, 862, 378,3011,2066,2113,2803,1568,2839,6178, # 4000
+3088,2919,1941,1660,2004,1992,2194, 142, 707,1590,1708,1624,1922,1023,1836,1233, # 4016
+1004,2313, 789, 741,3620,6179,1609,2411,1200,4127,3719,3720,4666,2057,3721, 593, # 4032
+2840, 367,2920,1878,6180,3461,1521, 628,1168, 692,2211,2649, 300, 720,2067,2571, # 4048
+2953,3396, 959,2504,3966,3539,3462,1977, 701,6181, 954,1043, 800, 681, 183,3722, # 4064
+1803,1730,3540,4128,2103, 815,2314, 174, 467, 230,2454,1093,2134, 755,3541,3397, # 4080
+1141,1162,6182,1738,2039, 270,3256,2513,1005,1647,2185,3837, 858,1679,1897,1719, # 4096
+2954,2324,1806, 402, 670, 167,4129,1498,2158,2104, 750,6183, 915, 189,1680,1551, # 4112
+ 455,4356,1501,2455, 405,1095,2955, 338,1586,1266,1819, 570, 641,1324, 237,1556, # 4128
+2650,1388,3723,6184,1368,2384,1343,1978,3089,2436, 879,3724, 792,1191, 758,3012, # 4144
+1411,2135,1322,4357, 240,4667,1848,3725,1574,6185, 420,3045,1546,1391, 714,4358, # 4160
+1967, 941,1864, 863, 664, 426, 560,1731,2680,1785,2864,1949,2363, 403,3330,1415, # 4176
+1279,2136,1697,2335, 204, 721,2097,3838,  90,6186,2085,2505, 191,3967, 124,2148, # 4192
+1376,1798,1178,1107,1898,1405, 860,4359,1243,1272,2375,2983,1558,2456,1638, 113, # 4208
+3621, 578,1923,2609, 880, 386,4130, 784,2186,2266,1422,2956,2172,1722, 497, 263, # 4224
+2514,1267,2412,2610, 177,2703,3542, 774,1927,1344, 616,1432,1595,1018, 172,4360, # 4240
+2325, 911,4361, 438,1468,3622, 794,3968,2024,2173,1681,1829,2957, 945, 895,3090, # 4256
+ 575,2212,2476, 475,2401,2681, 785,2744,1745,2293,2555,1975,3133,2865, 394,4668, # 4272
+3839, 635,4131, 639, 202,1507,2195,2766,1345,1435,2572,3726,1908,1184,1181,2457, # 4288
+3727,3134,4362, 843,2611, 437, 916,4669, 234, 769,1884,3046,3047,3623, 833,6187, # 4304
+1639,2250,2402,1355,1185,2010,2047, 999, 525,1732,1290,1488,2612, 948,1578,3728, # 4320
+2413,2477,1216,2725,2159, 334,3840,1328,3624,2921,1525,4132, 564,1056, 891,4363, # 4336
+1444,1698,2385,2251,3729,1365,2281,2235,1717,6188, 864,3841,2515, 444, 527,2767, # 4352
+2922,3625, 544, 461,6189, 566, 209,2437,3398,2098,1065,2068,3331,3626,3257,2137, # 4368  #last 512
+)
+
+
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/jisfreq.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/jisfreq.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..dd224596e0bc768bdfbd1295b30f18d0bbd02da3
GIT binary patch
literal 44543
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
I5WpP*06>Lfwg3PC

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/jpcntx.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/jpcntx.py
new file mode 100644
index 0000000..20044e4
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/jpcntx.py
@@ -0,0 +1,233 @@
+######################## BEGIN LICENSE BLOCK ########################
+# The Original Code is Mozilla Communicator client code.
+#
+# The Initial Developer of the Original Code is
+# Netscape Communications Corporation.
+# Portions created by the Initial Developer are Copyright (C) 1998
+# the Initial Developer. All Rights Reserved.
+#
+# Contributor(s):
+#   Mark Pilgrim - port to Python
+#
+# This library is free software; you can redistribute it and/or
+# modify it under the terms of the GNU Lesser General Public
+# License as published by the Free Software Foundation; either
+# version 2.1 of the License, or (at your option) any later version.
+#
+# This library is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+# Lesser General Public License for more details.
+#
+# You should have received a copy of the GNU Lesser General Public
+# License along with this library; if not, write to the Free Software
+# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
+# 02110-1301  USA
+######################### END LICENSE BLOCK #########################
+
+
+# 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),
+)
+
+class JapaneseContextAnalysis(object):
+    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
+        self.reset()
+
+    def reset(self):
+        self._total_rel = 0  # total sequence received
+        # category counters, each integer counts sequence in its category
+        self._rel_sample = [0] * self.NUM_OF_CATEGORY
+        # if last byte in current buffer is not the last byte of a character,
+        # we need to know how many bytes to skip in next buffer
+        self._need_to_skip_char_num = 0
+        self._last_char_order = -1  # The order of previous char
+        # If this flag is set to True, detection is done and conclusion has
+        # been made
+        self._done = False
+
+    def feed(self, byte_str, num_bytes):
+        if self._done:
+            return
+
+        # The buffer we got is byte oriented, and a character may span in more than one
+        # buffers. In case the last one or two byte in last buffer is not
+        # complete, we record how many byte needed to complete that character
+        # and skip these bytes here.  We can choose to record those bytes as
+        # well and analyse the character once it is complete, but since a
+        # character will not make much difference, by simply skipping
+        # this character will simply our logic and improve performance.
+        i = self._need_to_skip_char_num
+        while i < num_bytes:
+            order, char_len = self.get_order(byte_str[i:i + 2])
+            i += char_len
+            if i > num_bytes:
+                self._need_to_skip_char_num = i - num_bytes
+                self._last_char_order = -1
+            else:
+                if (order != -1) and (self._last_char_order != -1):
+                    self._total_rel += 1
+                    if self._total_rel > self.MAX_REL_THRESHOLD:
+                        self._done = True
+                        break
+                    self._rel_sample[jp2CharContext[self._last_char_order][order]] += 1
+                self._last_char_order = order
+
+    def got_enough_data(self):
+        return self._total_rel > self.ENOUGH_REL_THRESHOLD
+
+    def get_confidence(self):
+        # 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
+
+    def get_order(self, byte_str):
+        return -1, 1
+
+class SJISContextAnalysis(JapaneseContextAnalysis):
+    def __init__(self):
+        super(SJISContextAnalysis, self).__init__()
+        self._charset_name = "SHIFT_JIS"
+
+    @property
+    def charset_name(self):
+        return self._charset_name
+
+    def get_order(self, byte_str):
+        if not byte_str:
+            return -1, 1
+        # find out current char's byte length
+        first_char = byte_str[0]
+        if (0x81 <= first_char <= 0x9F) or (0xE0 <= first_char <= 0xFC):
+            char_len = 2
+            if (first_char == 0x87) or (0xFA <= first_char <= 0xFC):
+                self._charset_name = "CP932"
+        else:
+            char_len = 1
+
+        # return its order if it is hiragana
+        if len(byte_str) > 1:
+            second_char = byte_str[1]
+            if (first_char == 202) and (0x9F <= second_char <= 0xF1):
+                return second_char - 0x9F, char_len
+
+        return -1, char_len
+
+class EUCJPContextAnalysis(JapaneseContextAnalysis):
+    def get_order(self, byte_str):
+        if not byte_str:
+            return -1, 1
+        # find out current char's byte length
+        first_char = byte_str[0]
+        if (first_char == 0x8E) or (0xA1 <= first_char <= 0xFE):
+            char_len = 2
+        elif first_char == 0x8F:
+            char_len = 3
+        else:
+            char_len = 1
+
+        # return its order if it is hiragana
+        if len(byte_str) > 1:
+            second_char = byte_str[1]
+            if (first_char == 0xA4) and (0xA1 <= second_char <= 0xF3):
+                return second_char - 0xA1, char_len
+
+        return -1, char_len
+
+
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/jpcntx.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/jpcntx.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..41f674c9e98f75461778494cbcf1fce27b93cb8a
GIT binary patch
literal 25988
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

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/langbulgarianmodel.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/langbulgarianmodel.py
new file mode 100644
index 0000000..2aa4fb2
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/langbulgarianmodel.py
@@ -0,0 +1,228 @@
+######################## BEGIN LICENSE BLOCK ########################
+# The Original Code is Mozilla Communicator client code.
+#
+# The Initial Developer of the Original Code is
+# Netscape Communications Corporation.
+# Portions created by the Initial Developer are Copyright (C) 1998
+# the Initial Developer. All Rights Reserved.
+#
+# Contributor(s):
+#   Mark Pilgrim - port to Python
+#
+# This library is free software; you can redistribute it and/or
+# modify it under the terms of the GNU Lesser General Public
+# License as published by the Free Software Foundation; either
+# version 2.1 of the License, or (at your option) any later version.
+#
+# This library is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+# Lesser General Public License for more details.
+#
+# You should have received a copy of the GNU Lesser General Public
+# License along with this library; if not, write to the Free Software
+# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
+# 02110-1301  USA
+######################### END LICENSE BLOCK #########################
+
+# 255: Control characters that usually does not exist in any text
+# 254: Carriage/Return
+# 253: symbol (punctuation) that does not belong to word
+# 252: 0 - 9
+
+# Character Mapping Table:
+# this table is modified base on win1251BulgarianCharToOrderMap, so
+# only number <64 is sure valid
+
+Latin5_BulgarianCharToOrderMap = (
+255,255,255,255,255,255,255,255,255,255,254,255,255,254,255,255,  # 00
+255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,  # 10
+253,253,253,253,253,253,253,253,253,253,253,253,253,253,253,253,  # 20
+252,252,252,252,252,252,252,252,252,252,253,253,253,253,253,253,  # 30
+253, 77, 90, 99,100, 72,109,107,101, 79,185, 81,102, 76, 94, 82,  # 40
+110,186,108, 91, 74,119, 84, 96,111,187,115,253,253,253,253,253,  # 50
+253, 65, 69, 70, 66, 63, 68,112,103, 92,194,104, 95, 86, 87, 71,  # 60
+116,195, 85, 93, 97,113,196,197,198,199,200,253,253,253,253,253,  # 70
+194,195,196,197,198,199,200,201,202,203,204,205,206,207,208,209,  # 80
+210,211,212,213,214,215,216,217,218,219,220,221,222,223,224,225,  # 90
+ 81,226,227,228,229,230,105,231,232,233,234,235,236, 45,237,238,  # a0
+ 31, 32, 35, 43, 37, 44, 55, 47, 40, 59, 33, 46, 38, 36, 41, 30,  # b0
+ 39, 28, 34, 51, 48, 49, 53, 50, 54, 57, 61,239, 67,240, 60, 56,  # c0
+  1, 18,  9, 20, 11,  3, 23, 15,  2, 26, 12, 10, 14,  6,  4, 13,  # d0
+  7,  8,  5, 19, 29, 25, 22, 21, 27, 24, 17, 75, 52,241, 42, 16,  # e0
+ 62,242,243,244, 58,245, 98,246,247,248,249,250,251, 91,252,253,  # f0
+)
+
+win1251BulgarianCharToOrderMap = (
+255,255,255,255,255,255,255,255,255,255,254,255,255,254,255,255,  # 00
+255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,  # 10
+253,253,253,253,253,253,253,253,253,253,253,253,253,253,253,253,  # 20
+252,252,252,252,252,252,252,252,252,252,253,253,253,253,253,253,  # 30
+253, 77, 90, 99,100, 72,109,107,101, 79,185, 81,102, 76, 94, 82,  # 40
+110,186,108, 91, 74,119, 84, 96,111,187,115,253,253,253,253,253,  # 50
+253, 65, 69, 70, 66, 63, 68,112,103, 92,194,104, 95, 86, 87, 71,  # 60
+116,195, 85, 93, 97,113,196,197,198,199,200,253,253,253,253,253,  # 70
+206,207,208,209,210,211,212,213,120,214,215,216,217,218,219,220,  # 80
+221, 78, 64, 83,121, 98,117,105,222,223,224,225,226,227,228,229,  # 90
+ 88,230,231,232,233,122, 89,106,234,235,236,237,238, 45,239,240,  # a0
+ 73, 80,118,114,241,242,243,244,245, 62, 58,246,247,248,249,250,  # b0
+ 31, 32, 35, 43, 37, 44, 55, 47, 40, 59, 33, 46, 38, 36, 41, 30,  # c0
+ 39, 28, 34, 51, 48, 49, 53, 50, 54, 57, 61,251, 67,252, 60, 56,  # d0
+  1, 18,  9, 20, 11,  3, 23, 15,  2, 26, 12, 10, 14,  6,  4, 13,  # e0
+  7,  8,  5, 19, 29, 25, 22, 21, 27, 24, 17, 75, 52,253, 42, 16,  # f0
+)
+
+# Model Table:
+# total sequences: 100%
+# first 512 sequences: 96.9392%
+# first 1024 sequences:3.0618%
+# rest  sequences:     0.2992%
+# negative sequences:  0.0020%
+BulgarianLangModel = (
+0,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,2,3,3,3,3,3,3,3,3,2,3,3,3,3,3,
+3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,0,3,3,3,2,2,3,2,2,1,2,2,
+3,1,3,3,2,3,3,3,3,3,3,3,3,3,3,3,3,0,3,3,3,3,3,3,3,3,3,3,0,3,0,1,
+0,0,0,0,0,0,0,0,0,0,1,0,1,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,
+3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,2,3,2,3,3,3,3,3,3,3,3,0,3,1,0,
+0,1,0,0,0,0,0,0,0,0,1,1,0,1,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,
+3,2,2,2,3,3,3,3,3,3,3,3,3,3,3,3,3,1,3,2,3,3,3,3,3,3,3,3,0,3,0,0,
+0,0,0,0,0,0,0,0,0,0,1,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
+3,2,3,3,2,3,3,3,3,3,3,3,3,3,3,3,3,1,3,2,3,3,3,3,3,3,3,3,0,3,0,0,
+0,0,0,0,0,0,0,0,0,0,1,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
+3,3,3,3,3,3,3,3,3,3,3,2,3,2,2,1,3,3,3,3,2,2,2,1,1,2,0,1,0,1,0,0,
+0,0,0,0,0,0,0,0,0,0,2,0,0,0,0,0,0,0,0,0,2,0,0,0,0,0,0,0,0,0,0,1,
+3,3,3,3,3,3,3,2,3,2,2,3,3,1,1,2,3,3,2,3,3,3,3,2,1,2,0,2,0,3,0,0,
+0,0,0,0,0,0,0,1,0,0,2,0,0,0,0,0,0,0,0,0,2,0,0,0,0,0,0,0,0,0,0,1,
+3,3,3,3,3,3,3,1,3,3,3,3,3,2,3,2,3,3,3,3,3,2,3,3,1,3,0,3,0,2,0,0,
+0,0,0,0,0,0,0,0,0,0,2,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,1,
+3,3,3,3,3,3,3,3,1,3,3,2,3,3,3,1,3,3,2,3,2,2,2,0,0,2,0,2,0,2,0,0,
+0,0,0,0,0,0,0,0,0,0,2,0,0,0,0,0,0,0,0,0,2,0,0,0,0,0,0,0,0,0,0,1,
+3,3,3,3,3,3,3,3,3,0,3,3,3,2,2,3,3,3,1,2,2,3,2,1,1,2,0,2,0,0,0,0,
+1,0,0,0,0,0,0,0,0,0,2,0,0,1,0,0,1,0,0,0,1,0,0,0,0,0,0,0,0,0,0,1,
+3,3,3,3,3,3,3,2,3,3,1,2,3,2,2,2,3,3,3,3,3,2,2,3,1,2,0,2,1,2,0,0,
+0,0,0,0,0,0,0,0,0,0,3,0,0,1,0,0,0,0,0,0,2,0,0,0,0,0,0,0,0,0,0,1,
+3,3,3,3,3,1,3,3,3,3,3,2,3,3,3,2,3,3,2,3,2,2,2,3,1,2,0,1,0,1,0,0,
+0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,1,
+3,3,3,3,3,3,3,3,3,3,3,1,1,1,2,2,1,3,1,3,2,2,3,0,0,1,0,1,0,1,0,0,
+0,0,0,1,0,0,0,0,1,0,2,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,1,
+3,3,3,3,3,2,2,3,2,2,3,1,2,1,1,1,2,3,1,3,1,2,2,0,1,1,1,1,0,1,0,0,
+0,0,0,0,0,0,0,0,0,0,2,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,1,
+3,3,3,3,3,1,3,2,2,3,3,1,2,3,1,1,3,3,3,3,1,2,2,1,1,1,0,2,0,2,0,1,
+0,0,0,0,0,0,0,0,0,0,2,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,1,
+3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,1,2,2,3,3,3,2,2,1,1,2,0,2,0,1,0,0,
+0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,1,
+3,0,1,2,1,3,3,2,3,3,3,3,3,2,3,2,1,0,3,1,2,1,2,1,2,3,2,1,0,1,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,
+1,1,1,2,3,3,3,3,3,3,3,3,3,3,3,3,0,0,3,1,3,3,2,3,3,2,2,2,0,1,0,0,
+0,0,0,0,0,0,0,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,
+2,3,3,3,3,0,3,3,3,3,3,2,1,1,2,1,3,3,0,3,1,1,1,1,3,2,0,1,0,0,0,0,
+0,0,0,0,0,0,0,0,0,0,2,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,1,
+3,3,2,2,2,3,3,3,3,3,3,3,3,3,3,3,1,1,3,1,3,3,2,3,2,2,2,3,0,2,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,
+3,3,3,3,3,2,3,3,2,2,3,2,1,1,1,1,1,3,1,3,1,1,0,0,0,1,0,0,0,1,0,0,
+0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,
+3,3,3,3,3,2,3,2,0,3,2,0,3,0,2,0,0,2,1,3,1,0,0,1,0,0,0,1,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,1,
+3,3,3,3,2,1,1,1,1,2,1,1,2,1,1,1,2,2,1,2,1,1,1,0,1,1,0,1,0,1,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,1,
+3,3,3,3,2,1,3,1,1,2,1,3,2,1,1,0,1,2,3,2,1,1,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,
+2,3,3,3,3,2,2,1,0,1,0,0,1,0,0,0,2,1,0,3,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,1,
+3,3,3,2,3,2,3,3,1,3,2,1,1,1,2,1,1,2,1,3,0,1,0,0,0,1,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,
+3,1,1,2,2,3,3,2,3,2,2,2,3,1,2,2,1,1,2,1,1,2,2,0,1,1,0,1,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,
+3,3,3,3,2,1,3,1,0,2,2,1,3,2,1,0,0,2,0,2,0,1,0,0,0,0,0,0,0,1,0,0,
+0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,1,
+3,3,3,3,3,3,1,2,0,2,3,1,2,3,2,0,1,3,1,2,1,1,1,0,0,1,0,0,2,2,2,3,
+2,2,2,2,1,2,1,1,2,2,1,1,2,0,1,1,1,0,0,1,1,0,0,1,1,0,0,0,1,1,0,1,
+3,3,3,3,3,2,1,2,2,1,2,0,2,0,1,0,1,2,1,2,1,1,0,0,0,1,0,1,0,0,0,0,
+0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,2,0,0,0,0,0,0,0,0,0,0,1,
+3,3,2,3,3,1,1,3,1,0,3,2,1,0,0,0,1,2,0,2,0,1,0,0,0,1,0,1,2,1,2,2,
+1,1,1,1,1,1,1,2,2,2,1,1,1,1,1,1,1,0,1,2,1,1,1,0,0,0,0,0,1,1,0,0,
+3,1,0,1,0,2,3,2,2,2,3,2,2,2,2,2,1,0,2,1,2,1,1,1,0,1,2,1,2,2,2,1,
+1,1,2,2,2,2,1,2,1,1,0,1,2,1,2,2,2,1,1,1,0,1,1,1,1,2,0,1,0,0,0,0,
+2,3,2,3,3,0,0,2,1,0,2,1,0,0,0,0,2,3,0,2,0,0,0,0,0,1,0,0,2,0,1,2,
+2,1,2,1,2,2,1,1,1,2,1,1,1,0,1,2,2,1,1,1,1,1,0,1,1,1,0,0,1,2,0,0,
+3,3,2,2,3,0,2,3,1,1,2,0,0,0,1,0,0,2,0,2,0,0,0,1,0,1,0,1,2,0,2,2,
+1,1,1,1,2,1,0,1,2,2,2,1,1,1,1,1,1,1,0,1,1,1,0,0,0,0,0,0,1,1,0,0,
+2,3,2,3,3,0,0,3,0,1,1,0,1,0,0,0,2,2,1,2,0,0,0,0,0,0,0,0,2,0,1,2,
+2,2,1,1,1,1,1,2,2,2,1,0,2,0,1,0,1,0,0,1,0,1,0,0,1,0,0,0,0,1,0,0,
+3,3,3,3,2,2,2,2,2,0,2,1,1,1,1,2,1,2,1,1,0,2,0,1,0,1,0,0,2,0,1,2,
+1,1,1,1,1,1,1,2,2,1,1,0,2,0,1,0,2,0,0,1,1,1,0,0,2,0,0,0,1,1,0,0,
+2,3,3,3,3,1,0,0,0,0,0,0,0,0,0,0,2,0,0,1,1,0,0,0,0,0,0,1,2,0,1,2,
+2,2,2,1,1,2,1,1,2,2,2,1,2,0,1,1,1,1,1,1,0,1,1,1,1,0,0,1,1,1,0,0,
+2,3,3,3,3,0,2,2,0,2,1,0,0,0,1,1,1,2,0,2,0,0,0,3,0,0,0,0,2,0,2,2,
+1,1,1,2,1,2,1,1,2,2,2,1,2,0,1,1,1,0,1,1,1,1,0,2,1,0,0,0,1,1,0,0,
+2,3,3,3,3,0,2,1,0,0,2,0,0,0,0,0,1,2,0,2,0,0,0,0,0,0,0,0,2,0,1,2,
+1,1,1,2,1,1,1,1,2,2,2,0,1,0,1,1,1,0,0,1,1,1,0,0,1,0,0,0,0,1,0,0,
+3,3,2,2,3,0,1,0,1,0,0,0,0,0,0,0,1,1,0,3,0,0,0,0,0,0,0,0,1,0,2,2,
+1,1,1,1,1,2,1,1,2,2,1,2,2,1,0,1,1,1,1,1,0,1,0,0,1,0,0,0,1,1,0,0,
+3,1,0,1,0,2,2,2,2,3,2,1,1,1,2,3,0,0,1,0,2,1,1,0,1,1,1,1,2,1,1,1,
+1,2,2,1,2,1,2,2,1,1,0,1,2,1,2,2,1,1,1,0,0,1,1,1,2,1,0,1,0,0,0,0,
+2,1,0,1,0,3,1,2,2,2,2,1,2,2,1,1,1,0,2,1,2,2,1,1,2,1,1,0,2,1,1,1,
+1,2,2,2,2,2,2,2,1,2,0,1,1,0,2,1,1,1,1,1,0,0,1,1,1,1,0,1,0,0,0,0,
+2,1,1,1,1,2,2,2,2,1,2,2,2,1,2,2,1,1,2,1,2,3,2,2,1,1,1,1,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,2,2,3,2,0,1,2,0,1,2,1,1,0,1,0,1,2,1,2,0,0,0,1,1,0,0,0,1,0,0,2,
+1,1,0,0,1,1,0,1,1,1,1,0,2,0,1,1,1,0,0,1,1,0,0,0,0,1,0,0,0,1,0,0,
+2,0,0,0,0,1,2,2,2,2,2,2,2,1,2,1,1,1,1,1,1,1,0,1,1,1,1,1,2,1,1,1,
+1,2,2,2,2,1,1,2,1,2,1,1,1,0,2,1,2,1,1,1,0,2,1,1,1,1,0,1,0,0,0,0,
+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,1,0,1,0,
+1,1,0,1,0,1,1,1,1,1,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
+2,2,2,3,2,0,0,0,0,1,0,0,0,0,0,0,1,1,0,2,0,0,0,0,0,0,0,0,1,0,1,2,
+1,1,1,1,1,1,0,0,2,2,2,2,2,0,1,1,0,1,1,1,1,1,0,0,1,0,0,0,1,1,0,1,
+2,3,1,2,1,0,1,1,0,2,2,2,0,0,1,0,0,1,1,1,1,0,0,0,0,0,0,0,1,0,1,2,
+1,1,1,1,2,1,1,1,1,1,1,1,1,0,1,1,0,1,0,1,0,1,0,0,1,0,0,0,0,1,0,0,
+2,2,2,2,2,0,0,2,0,0,2,0,0,0,0,0,0,1,0,1,0,0,0,0,0,0,0,0,2,0,2,2,
+1,1,1,1,1,0,0,1,2,1,1,0,1,0,1,0,0,0,0,1,1,0,0,0,0,0,0,0,0,0,0,0,
+1,2,2,2,2,0,0,2,0,1,1,0,0,0,1,0,0,2,0,2,0,0,0,0,0,0,0,0,0,0,1,1,
+0,0,0,1,1,1,1,1,1,1,1,1,1,0,1,0,0,1,0,0,1,0,0,0,0,0,0,0,0,0,0,0,
+1,2,2,3,2,0,0,1,0,0,1,0,0,0,0,0,0,1,0,2,0,0,0,1,0,0,0,0,0,0,0,2,
+1,1,0,0,1,0,0,0,1,1,0,0,1,0,1,1,0,0,0,1,1,0,0,0,0,0,0,0,0,0,0,0,
+2,1,2,2,2,1,2,1,2,2,1,1,2,1,1,1,0,1,1,1,1,2,0,1,0,1,1,1,1,0,1,1,
+1,1,2,1,1,1,1,1,1,0,0,1,2,1,1,1,1,1,1,0,0,1,1,1,0,0,0,0,0,0,0,0,
+1,0,0,1,3,1,1,0,0,0,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,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
+2,2,2,2,1,0,0,1,0,2,0,0,0,0,0,1,1,1,0,1,0,0,0,0,0,0,0,0,2,0,0,1,
+0,2,0,1,0,0,1,1,2,0,1,0,1,0,1,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,
+1,2,2,2,2,0,1,1,0,2,1,0,1,1,1,0,0,1,0,2,0,1,0,0,0,0,0,0,0,0,0,1,
+0,1,0,0,1,0,0,0,1,1,0,0,1,0,0,1,0,0,0,1,1,0,0,0,0,0,0,0,0,0,0,0,
+2,2,2,2,2,0,0,1,0,0,0,1,0,1,0,0,0,1,0,1,0,0,0,0,0,0,0,0,0,0,0,1,
+0,1,0,1,1,1,0,0,1,1,1,0,1,0,0,0,0,0,0,1,1,0,0,0,0,0,0,0,0,0,0,0,
+2,0,1,0,0,1,2,1,1,1,1,1,1,2,2,1,0,0,1,0,1,0,0,0,0,1,1,1,1,0,0,0,
+1,1,2,1,1,1,1,0,0,0,1,1,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
+2,2,1,2,1,0,0,1,0,0,0,0,0,0,0,0,1,1,0,1,0,0,0,0,0,0,0,0,0,0,0,1,
+0,0,0,0,0,0,0,0,1,1,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
+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,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,1,2,0,0,0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,1,0,0,0,
+0,1,1,0,1,1,1,0,0,1,0,0,1,0,1,0,0,0,1,0,0,0,0,0,1,0,0,0,0,0,0,0,
+1,0,1,0,0,1,1,1,1,1,1,1,1,1,1,1,0,0,1,0,2,0,0,2,0,1,0,0,1,0,0,1,
+1,1,0,0,1,1,0,1,0,0,0,1,0,0,1,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,
+0,0,0,0,0,0,1,1,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,1,0,
+1,1,1,1,1,1,1,2,0,0,0,0,0,0,2,1,0,1,1,0,0,1,1,1,0,1,0,0,0,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,0,0,0,0,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,1,1,1,1,1,1,1,1,1,1,1,1,1,1,0,1,0,1,1,0,1,1,1,1,1,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,1,
+)
+
+Latin5BulgarianModel = {
+  'char_to_order_map': Latin5_BulgarianCharToOrderMap,
+  'precedence_matrix': BulgarianLangModel,
+  'typical_positive_ratio': 0.969392,
+  'keep_english_letter': False,
+  'charset_name': "ISO-8859-5",
+  'language': 'Bulgairan',
+}
+
+Win1251BulgarianModel = {
+  'char_to_order_map': win1251BulgarianCharToOrderMap,
+  'precedence_matrix': BulgarianLangModel,
+  'typical_positive_ratio': 0.969392,
+  'keep_english_letter': False,
+  'charset_name': "windows-1251",
+  'language': 'Bulgarian',
+}
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/langbulgarianmodel.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/langbulgarianmodel.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..20d9952bd2c19078a5efcb5fd9884e27bceae470
GIT binary patch
literal 25011
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
F2LQZ27PJ5W

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/langcyrillicmodel.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/langcyrillicmodel.py
new file mode 100644
index 0000000..e5f9a1f
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/langcyrillicmodel.py
@@ -0,0 +1,333 @@
+######################## BEGIN LICENSE BLOCK ########################
+# The Original Code is Mozilla Communicator client code.
+#
+# The Initial Developer of the Original Code is
+# Netscape Communications Corporation.
+# Portions created by the Initial Developer are Copyright (C) 1998
+# the Initial Developer. All Rights Reserved.
+#
+# Contributor(s):
+#   Mark Pilgrim - port to Python
+#
+# This library is free software; you can redistribute it and/or
+# modify it under the terms of the GNU Lesser General Public
+# License as published by the Free Software Foundation; either
+# version 2.1 of the License, or (at your option) any later version.
+#
+# This library is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+# Lesser General Public License for more details.
+#
+# You should have received a copy of the GNU Lesser General Public
+# License along with this library; if not, write to the Free Software
+# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
+# 02110-1301  USA
+######################### END LICENSE BLOCK #########################
+
+# KOI8-R language model
+# Character Mapping Table:
+KOI8R_char_to_order_map = (
+255,255,255,255,255,255,255,255,255,255,254,255,255,254,255,255,  # 00
+255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,  # 10
+253,253,253,253,253,253,253,253,253,253,253,253,253,253,253,253,  # 20
+252,252,252,252,252,252,252,252,252,252,253,253,253,253,253,253,  # 30
+253,142,143,144,145,146,147,148,149,150,151,152, 74,153, 75,154,  # 40
+155,156,157,158,159,160,161,162,163,164,165,253,253,253,253,253,  # 50
+253, 71,172, 66,173, 65,174, 76,175, 64,176,177, 77, 72,178, 69,  # 60
+ 67,179, 78, 73,180,181, 79,182,183,184,185,253,253,253,253,253,  # 70
+191,192,193,194,195,196,197,198,199,200,201,202,203,204,205,206,  # 80
+207,208,209,210,211,212,213,214,215,216,217,218,219,220,221,222,  # 90
+223,224,225, 68,226,227,228,229,230,231,232,233,234,235,236,237,  # a0
+238,239,240,241,242,243,244,245,246,247,248,249,250,251,252,253,  # b0
+ 27,  3, 21, 28, 13,  2, 39, 19, 26,  4, 23, 11,  8, 12,  5,  1,  # c0
+ 15, 16,  9,  7,  6, 14, 24, 10, 17, 18, 20, 25, 30, 29, 22, 54,  # d0
+ 59, 37, 44, 58, 41, 48, 53, 46, 55, 42, 60, 36, 49, 38, 31, 34,  # e0
+ 35, 43, 45, 32, 40, 52, 56, 33, 61, 62, 51, 57, 47, 63, 50, 70,  # f0
+)
+
+win1251_char_to_order_map = (
+255,255,255,255,255,255,255,255,255,255,254,255,255,254,255,255,  # 00
+255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,  # 10
+253,253,253,253,253,253,253,253,253,253,253,253,253,253,253,253,  # 20
+252,252,252,252,252,252,252,252,252,252,253,253,253,253,253,253,  # 30
+253,142,143,144,145,146,147,148,149,150,151,152, 74,153, 75,154,  # 40
+155,156,157,158,159,160,161,162,163,164,165,253,253,253,253,253,  # 50
+253, 71,172, 66,173, 65,174, 76,175, 64,176,177, 77, 72,178, 69,  # 60
+ 67,179, 78, 73,180,181, 79,182,183,184,185,253,253,253,253,253,  # 70
+191,192,193,194,195,196,197,198,199,200,201,202,203,204,205,206,
+207,208,209,210,211,212,213,214,215,216,217,218,219,220,221,222,
+223,224,225,226,227,228,229,230,231,232,233,234,235,236,237,238,
+239,240,241,242,243,244,245,246, 68,247,248,249,250,251,252,253,
+ 37, 44, 33, 46, 41, 48, 56, 51, 42, 60, 36, 49, 38, 31, 34, 35,
+ 45, 32, 40, 52, 53, 55, 58, 50, 57, 63, 70, 62, 61, 47, 59, 43,
+  3, 21, 10, 19, 13,  2, 24, 20,  4, 23, 11,  8, 12,  5,  1, 15,
+  9,  7,  6, 14, 39, 26, 28, 22, 25, 29, 54, 18, 17, 30, 27, 16,
+)
+
+latin5_char_to_order_map = (
+255,255,255,255,255,255,255,255,255,255,254,255,255,254,255,255,  # 00
+255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,  # 10
+253,253,253,253,253,253,253,253,253,253,253,253,253,253,253,253,  # 20
+252,252,252,252,252,252,252,252,252,252,253,253,253,253,253,253,  # 30
+253,142,143,144,145,146,147,148,149,150,151,152, 74,153, 75,154,  # 40
+155,156,157,158,159,160,161,162,163,164,165,253,253,253,253,253,  # 50
+253, 71,172, 66,173, 65,174, 76,175, 64,176,177, 77, 72,178, 69,  # 60
+ 67,179, 78, 73,180,181, 79,182,183,184,185,253,253,253,253,253,  # 70
+191,192,193,194,195,196,197,198,199,200,201,202,203,204,205,206,
+207,208,209,210,211,212,213,214,215,216,217,218,219,220,221,222,
+223,224,225,226,227,228,229,230,231,232,233,234,235,236,237,238,
+ 37, 44, 33, 46, 41, 48, 56, 51, 42, 60, 36, 49, 38, 31, 34, 35,
+ 45, 32, 40, 52, 53, 55, 58, 50, 57, 63, 70, 62, 61, 47, 59, 43,
+  3, 21, 10, 19, 13,  2, 24, 20,  4, 23, 11,  8, 12,  5,  1, 15,
+  9,  7,  6, 14, 39, 26, 28, 22, 25, 29, 54, 18, 17, 30, 27, 16,
+239, 68,240,241,242,243,244,245,246,247,248,249,250,251,252,255,
+)
+
+macCyrillic_char_to_order_map = (
+255,255,255,255,255,255,255,255,255,255,254,255,255,254,255,255,  # 00
+255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,  # 10
+253,253,253,253,253,253,253,253,253,253,253,253,253,253,253,253,  # 20
+252,252,252,252,252,252,252,252,252,252,253,253,253,253,253,253,  # 30
+253,142,143,144,145,146,147,148,149,150,151,152, 74,153, 75,154,  # 40
+155,156,157,158,159,160,161,162,163,164,165,253,253,253,253,253,  # 50
+253, 71,172, 66,173, 65,174, 76,175, 64,176,177, 77, 72,178, 69,  # 60
+ 67,179, 78, 73,180,181, 79,182,183,184,185,253,253,253,253,253,  # 70
+ 37, 44, 33, 46, 41, 48, 56, 51, 42, 60, 36, 49, 38, 31, 34, 35,
+ 45, 32, 40, 52, 53, 55, 58, 50, 57, 63, 70, 62, 61, 47, 59, 43,
+191,192,193,194,195,196,197,198,199,200,201,202,203,204,205,206,
+207,208,209,210,211,212,213,214,215,216,217,218,219,220,221,222,
+223,224,225,226,227,228,229,230,231,232,233,234,235,236,237,238,
+239,240,241,242,243,244,245,246,247,248,249,250,251,252, 68, 16,
+  3, 21, 10, 19, 13,  2, 24, 20,  4, 23, 11,  8, 12,  5,  1, 15,
+  9,  7,  6, 14, 39, 26, 28, 22, 25, 29, 54, 18, 17, 30, 27,255,
+)
+
+IBM855_char_to_order_map = (
+255,255,255,255,255,255,255,255,255,255,254,255,255,254,255,255,  # 00
+255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,  # 10
+253,253,253,253,253,253,253,253,253,253,253,253,253,253,253,253,  # 20
+252,252,252,252,252,252,252,252,252,252,253,253,253,253,253,253,  # 30
+253,142,143,144,145,146,147,148,149,150,151,152, 74,153, 75,154,  # 40
+155,156,157,158,159,160,161,162,163,164,165,253,253,253,253,253,  # 50
+253, 71,172, 66,173, 65,174, 76,175, 64,176,177, 77, 72,178, 69,  # 60
+ 67,179, 78, 73,180,181, 79,182,183,184,185,253,253,253,253,253,  # 70
+191,192,193,194, 68,195,196,197,198,199,200,201,202,203,204,205,
+206,207,208,209,210,211,212,213,214,215,216,217, 27, 59, 54, 70,
+  3, 37, 21, 44, 28, 58, 13, 41,  2, 48, 39, 53, 19, 46,218,219,
+220,221,222,223,224, 26, 55,  4, 42,225,226,227,228, 23, 60,229,
+230,231,232,233,234,235, 11, 36,236,237,238,239,240,241,242,243,
+  8, 49, 12, 38,  5, 31,  1, 34, 15,244,245,246,247, 35, 16,248,
+ 43,  9, 45,  7, 32,  6, 40, 14, 52, 24, 56, 10, 33, 17, 61,249,
+250, 18, 62, 20, 51, 25, 57, 30, 47, 29, 63, 22, 50,251,252,255,
+)
+
+IBM866_char_to_order_map = (
+255,255,255,255,255,255,255,255,255,255,254,255,255,254,255,255,  # 00
+255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,  # 10
+253,253,253,253,253,253,253,253,253,253,253,253,253,253,253,253,  # 20
+252,252,252,252,252,252,252,252,252,252,253,253,253,253,253,253,  # 30
+253,142,143,144,145,146,147,148,149,150,151,152, 74,153, 75,154,  # 40
+155,156,157,158,159,160,161,162,163,164,165,253,253,253,253,253,  # 50
+253, 71,172, 66,173, 65,174, 76,175, 64,176,177, 77, 72,178, 69,  # 60
+ 67,179, 78, 73,180,181, 79,182,183,184,185,253,253,253,253,253,  # 70
+ 37, 44, 33, 46, 41, 48, 56, 51, 42, 60, 36, 49, 38, 31, 34, 35,
+ 45, 32, 40, 52, 53, 55, 58, 50, 57, 63, 70, 62, 61, 47, 59, 43,
+  3, 21, 10, 19, 13,  2, 24, 20,  4, 23, 11,  8, 12,  5,  1, 15,
+191,192,193,194,195,196,197,198,199,200,201,202,203,204,205,206,
+207,208,209,210,211,212,213,214,215,216,217,218,219,220,221,222,
+223,224,225,226,227,228,229,230,231,232,233,234,235,236,237,238,
+  9,  7,  6, 14, 39, 26, 28, 22, 25, 29, 54, 18, 17, 30, 27, 16,
+239, 68,240,241,242,243,244,245,246,247,248,249,250,251,252,255,
+)
+
+# Model Table:
+# total sequences: 100%
+# first 512 sequences: 97.6601%
+# first 1024 sequences: 2.3389%
+# rest  sequences:      0.1237%
+# negative sequences:   0.0009%
+RussianLangModel = (
+0,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,1,1,3,3,3,3,1,3,3,3,2,3,2,3,3,
+3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,0,3,2,2,2,2,2,0,0,2,
+3,3,3,2,3,3,3,3,3,3,3,3,3,3,2,3,3,0,0,3,3,3,3,3,3,3,3,3,2,3,2,0,
+0,0,0,0,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,
+3,3,3,2,2,3,3,3,3,3,3,3,3,3,2,3,3,0,0,3,3,3,3,3,3,3,3,2,3,3,1,0,
+0,0,0,0,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,
+3,2,3,2,3,3,3,3,3,3,3,3,3,3,3,3,3,0,0,3,3,3,3,3,3,3,3,3,3,3,2,1,
+0,0,0,0,0,0,0,2,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
+3,3,3,3,3,3,3,3,3,3,3,3,3,3,2,3,3,0,0,3,3,3,3,3,3,3,3,3,3,3,2,1,
+0,0,0,0,0,1,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,
+3,3,3,3,3,3,3,3,2,2,2,3,1,3,3,1,3,3,3,3,2,2,3,0,2,2,2,3,3,2,1,0,
+0,0,0,0,0,0,0,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,
+3,3,3,3,3,3,2,3,3,3,3,3,2,2,3,2,3,3,3,2,1,2,2,0,1,2,2,2,2,2,2,0,
+0,0,0,0,0,0,0,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,0,0,0,0,0,0,0,0,0,
+3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,2,2,2,3,0,2,2,3,3,2,1,2,0,
+0,0,0,0,0,0,0,2,0,0,0,0,0,0,0,0,0,0,0,1,0,0,2,0,0,0,0,0,0,0,0,0,
+3,3,3,3,3,3,2,3,3,1,2,3,2,2,3,2,3,3,3,3,2,2,3,0,3,2,2,3,1,1,1,0,
+0,0,0,0,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,
+3,3,3,3,3,3,3,3,2,2,3,3,3,3,3,2,3,3,3,3,2,2,2,0,3,3,3,2,2,2,2,0,
+0,0,0,0,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,
+3,3,3,3,3,3,3,3,3,3,2,3,2,3,3,3,3,3,3,2,3,2,2,0,1,3,2,1,2,2,1,0,
+0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,0,0,0,0,0,0,0,0,0,
+3,3,3,3,3,3,3,3,3,3,3,2,1,1,3,0,1,1,1,1,2,1,1,0,2,2,2,1,2,0,1,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,
+3,3,3,3,3,3,2,3,3,2,2,2,2,1,3,2,3,2,3,2,1,2,2,0,1,1,2,1,2,1,2,0,
+0,0,0,0,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,
+3,3,3,3,3,3,3,3,3,3,3,3,2,2,3,2,3,3,3,2,2,2,2,0,2,2,2,2,3,1,1,0,
+0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,0,0,0,0,0,0,0,0,0,
+3,2,3,2,2,3,3,3,3,3,3,3,3,3,1,3,2,0,0,3,3,3,3,2,3,3,3,3,2,3,2,0,
+0,0,0,0,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,
+2,3,3,3,3,3,2,2,3,3,0,2,1,0,3,2,3,2,3,0,0,1,2,0,0,1,0,1,2,1,1,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,
+3,0,3,0,2,3,3,3,3,2,3,3,3,3,1,2,2,0,0,2,3,2,2,2,3,2,3,2,2,3,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,
+3,2,3,0,2,3,2,3,0,1,2,3,3,2,0,2,3,0,0,2,3,2,2,0,1,3,1,3,2,2,1,0,
+0,0,0,0,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,
+3,1,3,0,2,3,3,3,3,3,3,3,3,2,1,3,2,0,0,2,2,3,3,3,2,3,3,0,2,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,
+3,3,3,3,3,3,2,2,3,3,2,2,2,3,3,0,0,1,1,1,1,1,2,0,0,1,1,1,1,0,1,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,
+3,3,3,3,3,3,2,2,3,3,3,3,3,3,3,0,3,2,3,3,2,3,2,0,2,1,0,1,1,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,2,0,0,0,0,0,0,0,0,0,
+3,3,3,3,3,3,2,3,3,3,2,2,2,2,3,1,3,2,3,1,1,2,1,0,2,2,2,2,1,3,1,0,
+0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,0,0,0,0,0,0,0,0,0,
+2,2,3,3,3,3,3,1,2,2,1,3,1,0,3,0,0,3,0,0,0,1,1,0,1,2,1,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,
+3,2,2,1,1,3,3,3,2,2,1,2,2,3,1,1,2,0,0,2,2,1,3,0,0,2,1,1,2,1,1,0,
+0,0,0,0,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,
+3,2,3,3,3,3,1,2,2,2,1,2,1,3,3,1,1,2,1,2,1,2,2,0,2,0,0,1,1,0,1,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,
+2,3,3,3,3,3,2,1,3,2,2,3,2,0,3,2,0,3,0,1,0,1,1,0,0,1,1,1,1,0,1,0,
+0,0,0,0,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,
+3,3,2,3,3,3,2,2,2,3,3,1,2,1,2,1,0,1,0,1,1,0,1,0,0,2,1,1,1,0,1,0,
+0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,
+3,1,1,2,1,2,3,3,2,2,1,2,2,3,0,2,1,0,0,2,2,3,2,1,2,2,2,2,2,3,1,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,
+3,3,3,3,3,1,1,0,1,1,2,2,1,1,3,0,0,1,3,1,1,1,0,0,0,1,0,1,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,
+2,1,3,3,3,2,0,0,0,2,1,0,1,0,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,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
+2,0,1,0,0,2,3,2,2,2,1,2,2,2,1,2,1,0,0,1,1,1,0,2,0,1,1,1,0,0,1,1,
+1,0,0,0,0,0,1,2,0,0,0,0,0,1,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,
+2,3,3,3,3,0,0,0,0,1,0,0,0,0,3,0,1,2,1,0,0,0,0,0,0,0,1,1,0,0,1,1,
+1,0,1,0,1,2,0,0,1,1,2,1,0,1,1,1,1,0,1,1,1,1,0,1,0,0,1,0,0,1,1,0,
+2,2,3,2,2,2,3,1,2,2,2,2,2,2,2,2,1,1,1,1,1,1,1,0,1,0,1,1,1,0,2,1,
+1,1,1,1,1,1,1,1,2,1,1,1,1,1,1,1,1,1,1,0,1,0,1,1,0,1,1,1,0,1,1,0,
+3,3,3,2,2,2,2,3,2,2,1,1,2,2,2,2,1,1,3,1,2,1,2,0,0,1,1,0,1,0,2,1,
+1,1,1,1,1,2,1,0,1,1,1,1,0,1,0,0,1,1,0,0,1,0,1,0,0,1,0,0,0,1,1,0,
+2,0,0,1,0,3,2,2,2,2,1,2,1,2,1,2,0,0,0,2,1,2,2,1,1,2,2,0,1,1,0,2,
+1,1,1,1,1,0,1,1,1,2,1,1,1,2,1,0,1,2,1,1,1,1,0,1,1,1,0,0,1,0,0,1,
+1,3,2,2,2,1,1,1,2,3,0,0,0,0,2,0,2,2,1,0,0,0,0,0,0,1,0,0,0,0,1,1,
+1,0,1,1,0,1,0,1,1,0,1,1,0,2,0,0,1,1,0,0,1,0,0,0,0,0,0,0,0,1,1,0,
+2,3,2,3,2,1,2,2,2,2,1,0,0,0,2,0,0,1,1,0,0,0,0,0,0,0,1,1,0,0,2,1,
+1,1,2,1,0,2,0,0,1,0,1,0,0,1,0,0,1,1,0,1,1,0,0,0,0,0,1,0,0,0,0,0,
+3,0,0,1,0,2,2,2,3,2,2,2,2,2,2,2,0,0,0,2,1,2,1,1,1,2,2,0,0,0,1,2,
+1,1,1,1,1,0,1,2,1,1,1,1,1,1,1,0,1,1,1,1,1,1,0,1,1,1,1,1,1,0,0,1,
+2,3,2,3,3,2,0,1,1,1,0,0,1,0,2,0,1,1,3,1,0,0,0,0,0,0,0,1,0,0,2,1,
+1,1,1,1,1,1,1,0,1,0,1,1,1,1,0,1,1,1,0,0,1,1,0,1,0,0,0,0,0,0,1,0,
+2,3,3,3,3,1,2,2,2,2,0,1,1,0,2,1,1,1,2,1,0,1,1,0,0,1,0,1,0,0,2,0,
+0,0,0,0,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,
+2,3,3,3,2,0,0,1,1,2,2,1,0,0,2,0,1,1,3,0,0,1,0,0,0,0,0,1,0,1,2,1,
+1,1,2,0,1,1,1,0,1,0,1,1,0,1,0,1,1,1,1,0,1,0,0,0,0,0,0,1,0,1,1,0,
+1,3,2,3,2,1,0,0,2,2,2,0,1,0,2,0,1,1,1,0,1,0,0,0,3,0,1,1,0,0,2,1,
+1,1,1,0,1,1,0,0,0,0,1,1,0,1,0,0,2,1,1,0,1,0,0,0,1,0,1,0,0,1,1,0,
+3,1,2,1,1,2,2,2,2,2,2,1,2,2,1,1,0,0,0,2,2,2,0,0,0,1,2,1,0,1,0,1,
+2,1,1,1,1,1,1,1,1,1,1,1,1,1,1,0,2,1,1,1,0,1,0,1,1,0,1,1,1,0,0,1,
+3,0,0,0,0,2,0,1,1,1,1,1,1,1,0,1,0,0,0,1,1,1,0,1,0,1,1,0,0,1,0,1,
+1,1,0,0,1,0,0,0,1,0,1,1,0,0,1,0,1,0,1,0,0,0,0,1,0,0,0,1,0,0,0,1,
+1,3,3,2,2,0,0,0,2,2,0,0,0,1,2,0,1,1,2,0,0,0,0,0,0,0,0,1,0,0,2,1,
+0,1,1,0,0,1,1,0,0,0,1,1,0,1,1,0,1,1,0,0,1,0,0,0,0,0,0,0,0,0,1,0,
+2,3,2,3,2,0,0,0,0,1,1,0,0,0,2,0,2,0,2,0,0,0,0,0,1,0,0,1,0,0,1,1,
+1,1,2,0,1,2,1,0,1,1,2,1,1,1,1,1,2,1,1,0,1,0,0,1,1,1,1,1,0,1,1,0,
+1,3,2,2,2,1,0,0,2,2,1,0,1,2,2,0,0,1,0,0,0,0,0,0,0,0,0,1,0,0,1,1,
+0,0,1,1,0,1,1,0,0,1,1,0,1,1,0,0,1,1,0,0,1,0,0,0,0,0,0,0,0,0,0,0,
+1,0,0,1,0,2,3,1,2,2,2,2,2,2,1,1,0,0,0,1,0,1,0,2,1,1,1,0,0,0,0,1,
+1,1,0,1,1,0,1,1,1,1,0,0,0,1,0,0,0,1,0,0,0,0,0,0,0,0,0,0,1,0,0,0,
+2,0,2,0,0,1,0,3,2,1,2,1,2,2,0,1,0,0,0,2,1,0,0,2,1,1,1,1,0,2,0,2,
+2,1,1,1,1,1,1,1,1,1,1,1,1,2,1,0,1,1,1,1,0,0,0,1,1,1,1,0,1,0,0,1,
+1,2,2,2,2,1,0,0,1,0,0,0,0,0,2,0,1,1,1,1,0,0,0,0,1,0,1,2,0,0,2,0,
+1,0,1,1,1,2,1,0,1,0,1,1,0,0,1,0,1,1,1,0,1,0,0,0,1,0,0,1,0,1,1,0,
+2,1,2,2,2,0,3,0,1,1,0,0,0,0,2,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,1,
+0,0,0,1,1,1,0,0,1,0,1,0,0,0,0,0,1,0,0,0,1,0,0,0,0,0,0,0,0,1,0,0,
+1,2,2,3,2,2,0,0,1,1,2,0,1,2,1,0,1,0,1,0,0,1,0,0,0,0,0,0,0,0,0,1,
+0,1,1,0,0,1,1,0,0,1,1,0,0,1,1,0,1,1,0,0,1,0,0,0,0,0,0,0,0,1,1,0,
+2,2,1,1,2,1,2,2,2,2,2,1,2,2,0,1,0,0,0,1,2,2,2,1,2,1,1,1,1,1,2,1,
+1,1,1,1,1,1,1,1,1,1,0,0,1,1,1,0,1,1,1,0,0,0,0,1,1,1,0,1,1,0,0,1,
+1,2,2,2,2,0,1,0,2,2,0,0,0,0,2,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,2,0,
+0,0,1,0,0,1,0,0,0,0,1,0,1,1,0,0,1,1,0,0,1,0,0,0,0,0,0,0,0,0,0,0,
+0,0,2,0,0,0,0,0,0,0,0,0,0,0,0,0,2,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,
+1,2,2,2,2,0,0,0,2,2,2,0,1,0,1,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,1,1,
+0,1,1,0,0,1,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,
+1,2,2,2,2,0,0,0,0,1,0,0,1,1,2,0,0,0,0,1,0,1,0,0,1,0,0,2,0,0,0,1,
+0,0,1,0,0,1,0,0,0,1,1,0,0,0,0,0,1,0,0,1,1,0,0,0,0,0,0,0,0,0,0,0,
+1,2,2,2,1,1,2,0,2,1,1,1,1,0,2,2,0,0,0,0,0,0,0,0,0,1,1,0,0,0,1,1,
+0,0,1,0,1,1,0,0,0,0,1,0,0,0,0,0,1,1,0,0,1,0,0,0,0,0,0,0,0,0,0,0,
+1,0,2,1,2,0,0,0,0,0,1,0,0,0,1,0,0,0,1,0,0,0,0,0,0,0,0,1,0,0,0,0,
+0,0,1,0,1,1,0,0,0,0,1,0,0,0,0,0,1,0,0,0,1,0,0,0,0,0,0,0,0,0,1,0,
+1,0,0,0,0,2,0,1,2,1,0,1,1,1,0,1,0,0,0,1,0,1,0,0,1,0,1,0,0,0,0,1,
+0,0,0,0,0,1,0,0,1,1,0,0,1,1,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,1,
+2,2,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,1,
+1,0,0,0,1,0,0,0,1,1,0,0,0,0,0,0,0,1,0,0,0,0,0,1,0,0,1,0,0,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,1,
+1,1,1,0,1,0,1,0,0,1,1,1,1,0,0,0,1,0,0,0,0,1,0,0,0,1,0,1,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,1,
+1,1,0,1,1,0,1,0,1,0,0,0,0,1,1,0,1,1,0,0,0,0,0,1,0,1,1,0,1,0,0,0,
+0,1,1,1,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,
+0,0,0,0,0,1,0,0,0,0,1,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,1,0,0,
+)
+
+Koi8rModel = {
+  'char_to_order_map': KOI8R_char_to_order_map,
+  'precedence_matrix': RussianLangModel,
+  'typical_positive_ratio': 0.976601,
+  'keep_english_letter': False,
+  'charset_name': "KOI8-R",
+  'language': 'Russian',
+}
+
+Win1251CyrillicModel = {
+  'char_to_order_map': win1251_char_to_order_map,
+  'precedence_matrix': RussianLangModel,
+  'typical_positive_ratio': 0.976601,
+  'keep_english_letter': False,
+  'charset_name': "windows-1251",
+  'language': 'Russian',
+}
+
+Latin5CyrillicModel = {
+  'char_to_order_map': latin5_char_to_order_map,
+  'precedence_matrix': RussianLangModel,
+  'typical_positive_ratio': 0.976601,
+  'keep_english_letter': False,
+  'charset_name': "ISO-8859-5",
+  'language': 'Russian',
+}
+
+MacCyrillicModel = {
+  'char_to_order_map': macCyrillic_char_to_order_map,
+  'precedence_matrix': RussianLangModel,
+  'typical_positive_ratio': 0.976601,
+  'keep_english_letter': False,
+  'charset_name': "MacCyrillic",
+  'language': 'Russian',
+}
+
+Ibm866Model = {
+  'char_to_order_map': IBM866_char_to_order_map,
+  'precedence_matrix': RussianLangModel,
+  'typical_positive_ratio': 0.976601,
+  'keep_english_letter': False,
+  'charset_name': "IBM866",
+  'language': 'Russian',
+}
+
+Ibm855Model = {
+  'char_to_order_map': IBM855_char_to_order_map,
+  'precedence_matrix': RussianLangModel,
+  'typical_positive_ratio': 0.976601,
+  'keep_english_letter': False,
+  'charset_name': "IBM855",
+  'language': 'Russian',
+}
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/langcyrillicmodel.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/langcyrillicmodel.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..1ac7100183bd05dba53dd5ec3c1e319a9c65355b
GIT binary patch
literal 30731
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
LMs_&lq6!ZH(B<bp

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/langgreekmodel.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/langgreekmodel.py
new file mode 100644
index 0000000..5332221
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/langgreekmodel.py
@@ -0,0 +1,225 @@
+######################## BEGIN LICENSE BLOCK ########################
+# The Original Code is Mozilla Communicator client code.
+#
+# The Initial Developer of the Original Code is
+# Netscape Communications Corporation.
+# Portions created by the Initial Developer are Copyright (C) 1998
+# the Initial Developer. All Rights Reserved.
+#
+# Contributor(s):
+#   Mark Pilgrim - port to Python
+#
+# This library is free software; you can redistribute it and/or
+# modify it under the terms of the GNU Lesser General Public
+# License as published by the Free Software Foundation; either
+# version 2.1 of the License, or (at your option) any later version.
+#
+# This library is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+# Lesser General Public License for more details.
+#
+# You should have received a copy of the GNU Lesser General Public
+# License along with this library; if not, write to the Free Software
+# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
+# 02110-1301  USA
+######################### END LICENSE BLOCK #########################
+
+# 255: Control characters that usually does not exist in any text
+# 254: Carriage/Return
+# 253: symbol (punctuation) that does not belong to word
+# 252: 0 - 9
+
+# Character Mapping Table:
+Latin7_char_to_order_map = (
+255,255,255,255,255,255,255,255,255,255,254,255,255,254,255,255,  # 00
+255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,  # 10
+253,253,253,253,253,253,253,253,253,253,253,253,253,253,253,253,  # 20
+252,252,252,252,252,252,252,252,252,252,253,253,253,253,253,253,  # 30
+253, 82,100,104, 94, 98,101,116,102,111,187,117, 92, 88,113, 85,  # 40
+ 79,118,105, 83, 67,114,119, 95, 99,109,188,253,253,253,253,253,  # 50
+253, 72, 70, 80, 81, 60, 96, 93, 89, 68,120, 97, 77, 86, 69, 55,  # 60
+ 78,115, 65, 66, 58, 76,106,103, 87,107,112,253,253,253,253,253,  # 70
+255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,  # 80
+255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,  # 90
+253,233, 90,253,253,253,253,253,253,253,253,253,253, 74,253,253,  # a0
+253,253,253,253,247,248, 61, 36, 46, 71, 73,253, 54,253,108,123,  # b0
+110, 31, 51, 43, 41, 34, 91, 40, 52, 47, 44, 53, 38, 49, 59, 39,  # c0
+ 35, 48,250, 37, 33, 45, 56, 50, 84, 57,120,121, 17, 18, 22, 15,  # d0
+124,  1, 29, 20, 21,  3, 32, 13, 25,  5, 11, 16, 10,  6, 30,  4,  # e0
+  9,  8, 14,  7,  2, 12, 28, 23, 42, 24, 64, 75, 19, 26, 27,253,  # f0
+)
+
+win1253_char_to_order_map = (
+255,255,255,255,255,255,255,255,255,255,254,255,255,254,255,255,  # 00
+255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,  # 10
+253,253,253,253,253,253,253,253,253,253,253,253,253,253,253,253,  # 20
+252,252,252,252,252,252,252,252,252,252,253,253,253,253,253,253,  # 30
+253, 82,100,104, 94, 98,101,116,102,111,187,117, 92, 88,113, 85,  # 40
+ 79,118,105, 83, 67,114,119, 95, 99,109,188,253,253,253,253,253,  # 50
+253, 72, 70, 80, 81, 60, 96, 93, 89, 68,120, 97, 77, 86, 69, 55,  # 60
+ 78,115, 65, 66, 58, 76,106,103, 87,107,112,253,253,253,253,253,  # 70
+255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,  # 80
+255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,  # 90
+253,233, 61,253,253,253,253,253,253,253,253,253,253, 74,253,253,  # a0
+253,253,253,253,247,253,253, 36, 46, 71, 73,253, 54,253,108,123,  # b0
+110, 31, 51, 43, 41, 34, 91, 40, 52, 47, 44, 53, 38, 49, 59, 39,  # c0
+ 35, 48,250, 37, 33, 45, 56, 50, 84, 57,120,121, 17, 18, 22, 15,  # d0
+124,  1, 29, 20, 21,  3, 32, 13, 25,  5, 11, 16, 10,  6, 30,  4,  # e0
+  9,  8, 14,  7,  2, 12, 28, 23, 42, 24, 64, 75, 19, 26, 27,253,  # f0
+)
+
+# Model Table:
+# total sequences: 100%
+# first 512 sequences: 98.2851%
+# first 1024 sequences:1.7001%
+# rest  sequences:     0.0359%
+# negative sequences:  0.0148%
+GreekLangModel = (
+0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
+0,0,0,0,0,0,0,0,0,0,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,2,2,3,3,3,3,3,3,3,3,1,3,3,3,0,2,2,3,3,0,3,0,3,2,0,3,3,3,0,
+3,0,0,0,2,0,0,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,3,3,3,3,3,0,3,3,0,3,2,3,3,0,3,2,3,3,3,0,0,3,0,3,0,3,3,2,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,2,0,0,0,0,0,0,0,0,
+0,2,3,2,2,3,3,3,3,3,3,3,3,0,3,3,3,3,0,2,3,3,0,3,3,3,3,2,3,3,3,0,
+2,0,0,0,2,0,0,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,2,3,3,2,3,3,3,3,3,3,3,3,3,3,3,3,0,2,1,3,3,3,3,2,3,3,2,3,3,2,0,
+0,0,0,0,2,0,0,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,3,3,3,3,0,3,3,3,3,3,3,0,3,3,0,3,3,3,3,3,3,3,3,3,3,0,3,2,3,3,0,
+2,0,1,0,2,0,0,0,0,0,2,0,0,0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,
+0,3,3,3,3,3,2,3,0,0,0,0,3,3,0,3,1,3,3,3,0,3,3,0,3,3,3,3,0,0,0,0,
+2,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,3,3,3,3,3,0,3,0,3,3,3,3,3,0,3,2,2,2,3,0,2,3,3,3,3,3,2,3,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,3,3,3,3,3,3,2,2,2,3,3,3,3,0,3,1,3,3,3,3,2,3,3,3,3,3,3,3,2,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,3,3,3,3,3,2,0,3,0,0,0,3,3,2,3,3,3,3,3,0,0,3,2,3,0,2,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,3,0,3,3,3,3,0,0,3,3,0,2,3,0,3,0,3,3,3,0,0,3,0,3,0,2,2,3,3,0,0,
+0,0,1,0,0,0,0,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,3,3,3,3,3,2,0,3,2,3,3,3,3,0,3,3,3,3,3,0,3,3,2,3,2,3,3,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,
+0,3,3,2,3,2,3,3,3,3,3,3,0,2,3,2,3,2,2,2,3,2,3,3,2,3,0,2,2,2,3,0,
+2,0,0,0,0,0,0,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,3,0,0,0,3,3,3,2,3,3,0,0,3,0,3,0,0,0,3,2,0,3,0,3,0,0,2,0,2,0,
+0,0,0,0,2,0,0,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,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
+0,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,3,3,3,3,0,3,3,3,3,3,3,0,3,3,0,3,0,0,0,3,3,0,3,3,3,0,0,1,2,3,0,
+3,0,0,0,0,0,0,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,3,3,3,3,3,2,0,0,3,2,2,3,3,0,3,3,3,3,3,2,1,3,0,3,2,3,3,2,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,3,3,0,2,3,3,3,3,3,3,0,0,3,0,3,0,0,0,3,3,0,3,2,3,0,0,3,3,3,0,
+3,0,0,0,2,0,0,0,0,0,3,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
+0,3,3,3,3,0,3,3,3,3,3,3,0,0,3,0,3,0,0,0,3,2,0,3,2,3,0,0,3,2,3,0,
+2,0,0,0,0,0,0,0,0,0,3,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
+0,0,3,1,2,2,3,3,3,3,3,3,0,2,3,0,3,0,0,0,3,3,0,3,0,2,0,0,2,3,1,0,
+2,0,0,0,0,0,0,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,3,0,3,3,3,3,0,3,0,3,3,2,3,0,3,3,3,3,3,3,0,3,3,3,0,2,3,0,0,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,3,0,3,3,3,0,0,3,0,0,0,3,3,0,3,0,2,3,3,0,0,3,0,3,0,3,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,3,0,0,0,3,3,3,3,3,3,0,0,3,0,2,0,0,0,3,3,0,3,0,3,0,0,2,0,2,0,
+0,0,0,0,1,0,0,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,3,3,3,3,3,3,0,3,0,2,0,3,2,0,3,2,3,2,3,0,0,3,2,3,2,3,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,3,0,0,2,3,3,3,3,3,0,0,0,3,0,2,1,0,0,3,2,2,2,0,3,0,0,2,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,3,0,3,3,3,2,0,3,0,3,0,3,3,0,2,1,2,3,3,0,0,3,0,3,0,3,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,2,3,3,3,0,3,3,3,3,3,3,0,2,3,0,3,0,0,0,2,1,0,2,2,3,0,0,2,2,2,0,
+0,0,0,0,0,0,0,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,3,0,0,2,3,3,3,2,3,0,0,1,3,0,2,0,0,0,0,3,0,1,0,2,0,0,1,1,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,3,3,3,3,3,1,0,3,0,0,0,3,2,0,3,2,3,3,3,0,0,3,0,3,2,2,2,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,3,0,3,3,3,0,0,3,0,0,0,0,2,0,2,3,3,2,2,2,2,3,0,2,0,2,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,0,
+0,3,3,3,3,2,0,0,0,0,0,0,2,3,0,2,0,2,3,2,0,0,3,0,3,0,3,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,3,2,3,3,2,2,3,0,2,0,3,0,0,0,2,0,0,0,0,1,2,0,2,0,2,0,
+0,2,0,2,0,2,2,0,0,1,0,2,2,2,0,2,2,2,0,2,2,2,0,0,2,0,0,1,0,0,0,0,
+0,2,0,3,3,2,0,0,0,0,0,0,1,3,0,2,0,2,2,2,0,0,2,0,3,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,0,
+0,3,0,2,3,2,0,2,2,0,2,0,2,2,0,2,0,2,2,2,0,0,0,0,0,0,2,3,0,0,0,2,
+0,1,2,0,0,0,0,2,2,0,0,0,2,1,0,2,2,0,0,0,0,0,0,1,0,2,0,0,0,0,0,0,
+0,0,2,1,0,2,3,2,2,3,2,3,2,0,0,3,3,3,0,0,3,2,0,0,0,1,1,0,2,0,2,2,
+0,2,0,2,0,2,2,0,0,2,0,2,2,2,0,2,2,2,2,0,0,2,0,0,0,2,0,1,0,0,0,0,
+0,3,0,3,3,2,2,0,3,0,0,0,2,2,0,2,2,2,1,2,0,0,1,2,2,0,0,3,0,0,0,2,
+0,1,2,0,0,0,1,2,0,0,0,0,0,0,0,2,2,0,1,0,0,2,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,0,0,0,
+0,0,0,0,0,0,0,0,0,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,3,3,2,2,0,0,0,2,0,2,3,3,0,2,0,0,0,0,0,0,2,2,2,0,2,2,0,2,0,2,
+0,2,2,0,0,2,2,2,2,1,0,0,2,2,0,2,0,0,2,0,0,0,0,0,0,2,0,0,0,0,0,0,
+0,2,0,3,2,3,0,0,0,3,0,0,2,2,0,2,0,2,2,2,0,0,2,0,0,0,0,0,0,0,0,2,
+0,0,2,2,0,0,2,2,2,0,0,0,0,0,0,2,0,0,0,2,0,0,0,0,0,0,0,0,0,0,0,0,
+0,0,2,0,0,3,2,0,2,2,2,2,2,0,0,0,2,0,0,0,0,2,0,1,0,0,2,0,1,0,0,0,
+0,2,2,2,0,2,2,0,1,2,0,2,2,2,0,2,2,2,2,1,2,2,0,0,2,0,0,0,0,0,0,0,
+0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,2,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,
+0,2,0,2,0,2,2,0,0,0,0,1,2,1,0,0,2,2,0,0,2,0,0,0,0,0,0,0,0,0,0,0,
+0,0,0,3,2,3,0,0,2,0,0,0,2,2,0,2,0,0,0,1,0,0,2,0,2,0,2,2,0,0,0,0,
+0,0,2,0,0,0,0,2,2,0,0,0,0,0,0,2,0,0,0,0,0,0,0,0,0,2,0,0,0,0,0,0,
+0,2,2,3,2,2,0,0,0,0,0,0,1,3,0,2,0,2,2,0,0,0,1,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,0,0,0,0,
+0,2,0,2,0,3,2,0,2,0,0,0,0,0,0,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,
+0,0,2,0,0,0,0,1,1,0,0,2,1,2,0,2,2,0,1,0,0,1,0,0,0,2,0,0,0,0,0,0,
+0,3,0,2,2,2,0,0,2,0,0,0,2,0,0,0,2,3,0,2,0,0,0,0,0,0,2,2,0,0,0,2,
+0,1,2,0,0,0,1,2,2,1,0,0,0,2,0,0,2,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,
+0,0,0,0,0,0,0,0,0,3,0,0,0,0,0,0,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
+0,2,1,2,0,2,2,0,2,0,0,2,0,0,0,0,1,2,1,0,2,1,0,0,0,0,0,0,0,0,0,0,
+0,0,2,0,0,0,3,1,2,2,0,2,0,0,0,0,2,0,0,0,2,0,0,3,0,0,0,0,2,2,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,2,1,0,2,0,1,2,0,0,0,0,0,0,0,0,0,0,0,0,0,2,0,0,1,0,0,0,0,0,0,2,
+0,2,2,0,0,2,2,2,2,2,0,1,2,0,0,0,2,2,0,1,0,2,0,0,2,2,0,0,0,0,0,0,
+0,0,0,0,1,0,0,0,0,0,0,0,3,0,0,2,0,0,0,0,0,0,0,0,2,0,2,0,0,0,0,2,
+0,1,2,0,0,0,0,2,2,1,0,1,0,1,0,2,2,2,1,0,0,0,0,0,0,1,0,0,0,0,0,0,
+0,2,0,1,2,0,0,0,0,0,0,0,0,0,0,2,0,0,2,2,0,0,0,0,1,0,0,0,0,0,0,2,
+0,2,2,0,0,0,0,2,2,0,0,0,0,0,0,2,0,0,0,0,0,0,0,0,0,2,0,0,2,0,0,0,
+0,2,2,2,2,0,0,0,3,0,0,0,0,0,0,0,0,2,0,0,0,0,0,0,2,0,0,0,0,0,0,1,
+0,0,2,0,0,0,0,1,2,0,0,0,0,0,0,2,2,1,1,0,0,0,0,0,0,1,0,0,0,0,0,0,
+0,2,0,2,2,2,0,0,2,0,0,0,0,0,0,0,2,2,2,0,0,0,2,0,0,0,0,0,0,0,0,2,
+0,0,1,0,0,0,0,2,1,0,0,0,0,0,0,1,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,
+0,3,0,2,0,0,0,0,0,0,0,0,2,0,0,0,0,0,2,0,0,0,0,0,0,0,2,0,0,0,0,2,
+0,0,2,0,0,0,0,2,2,0,0,0,0,1,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
+0,2,0,2,2,1,0,0,0,0,0,0,2,0,0,2,0,2,2,2,0,0,0,0,0,0,2,0,0,0,0,2,
+0,0,2,0,0,2,0,2,2,0,0,0,0,2,0,2,0,0,0,0,0,2,0,0,0,2,0,0,0,0,0,0,
+0,0,3,0,0,0,2,2,0,2,2,0,0,0,0,0,2,0,0,0,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,0,0,0,0,0,
+0,0,0,0,0,0,1,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,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,0,0,2,0,0,0,0,0,
+0,2,2,2,2,2,0,0,0,0,0,0,2,0,0,0,0,0,0,0,0,0,0,0,0,0,1,1,0,0,0,1,
+0,0,0,0,0,0,0,2,1,0,0,0,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,2,2,0,0,0,0,0,2,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,
+0,2,0,0,0,2,0,0,0,0,0,1,0,0,0,0,2,2,0,0,0,1,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,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,0,0,1,0,0,1,0,2,0,0,0,
+0,2,0,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,0,0,0,0,0,0,0,0,0,0,0,0,0,
+0,0,1,0,0,0,0,1,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,0,0,0,0,0,0,
+0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,1,0,0,2,0,2,0,0,0,
+0,0,0,0,0,0,0,0,2,1,0,0,0,0,0,0,2,0,0,0,1,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,0,0,0,0,0,0,0,
+0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
+0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
+0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
+0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
+)
+
+Latin7GreekModel = {
+  'char_to_order_map': Latin7_char_to_order_map,
+  'precedence_matrix': GreekLangModel,
+  'typical_positive_ratio': 0.982851,
+  'keep_english_letter': False,
+  'charset_name': "ISO-8859-7",
+  'language': 'Greek',
+}
+
+Win1253GreekModel = {
+  'char_to_order_map': win1253_char_to_order_map,
+  'precedence_matrix': GreekLangModel,
+  'typical_positive_ratio': 0.982851,
+  'keep_english_letter': False,
+  'charset_name': "windows-1253",
+  'language': 'Greek',
+}
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/langgreekmodel.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/langgreekmodel.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..d5ee880e969c67a7a652bfd9974f63f0a085193f
GIT binary patch
literal 24686
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
W10x$3e)-`p%f`&i$PR~GC_DgV!Nm9g

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/langhebrewmodel.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/langhebrewmodel.py
new file mode 100644
index 0000000..58f4c87
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/langhebrewmodel.py
@@ -0,0 +1,200 @@
+######################## BEGIN LICENSE BLOCK ########################
+# The Original Code is Mozilla Universal charset detector code.
+#
+# The Initial Developer of the Original Code is
+#          Simon Montagu
+# Portions created by the Initial Developer are Copyright (C) 2005
+# the Initial Developer. All Rights Reserved.
+#
+# Contributor(s):
+#   Mark Pilgrim - port to Python
+#   Shy Shalom - original C code
+#   Shoshannah Forbes - original C code (?)
+#
+# This library is free software; you can redistribute it and/or
+# modify it under the terms of the GNU Lesser General Public
+# License as published by the Free Software Foundation; either
+# version 2.1 of the License, or (at your option) any later version.
+#
+# This library is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+# Lesser General Public License for more details.
+#
+# You should have received a copy of the GNU Lesser General Public
+# License along with this library; if not, write to the Free Software
+# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
+# 02110-1301  USA
+######################### END LICENSE BLOCK #########################
+
+# 255: Control characters that usually does not exist in any text
+# 254: Carriage/Return
+# 253: symbol (punctuation) that does not belong to word
+# 252: 0 - 9
+
+# Windows-1255 language model
+# Character Mapping Table:
+WIN1255_CHAR_TO_ORDER_MAP = (
+255,255,255,255,255,255,255,255,255,255,254,255,255,254,255,255,  # 00
+255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,  # 10
+253,253,253,253,253,253,253,253,253,253,253,253,253,253,253,253,  # 20
+252,252,252,252,252,252,252,252,252,252,253,253,253,253,253,253,  # 30
+253, 69, 91, 79, 80, 92, 89, 97, 90, 68,111,112, 82, 73, 95, 85,  # 40
+ 78,121, 86, 71, 67,102,107, 84,114,103,115,253,253,253,253,253,  # 50
+253, 50, 74, 60, 61, 42, 76, 70, 64, 53,105, 93, 56, 65, 54, 49,  # 60
+ 66,110, 51, 43, 44, 63, 81, 77, 98, 75,108,253,253,253,253,253,  # 70
+124,202,203,204,205, 40, 58,206,207,208,209,210,211,212,213,214,
+215, 83, 52, 47, 46, 72, 32, 94,216,113,217,109,218,219,220,221,
+ 34,116,222,118,100,223,224,117,119,104,125,225,226, 87, 99,227,
+106,122,123,228, 55,229,230,101,231,232,120,233, 48, 39, 57,234,
+ 30, 59, 41, 88, 33, 37, 36, 31, 29, 35,235, 62, 28,236,126,237,
+238, 38, 45,239,240,241,242,243,127,244,245,246,247,248,249,250,
+  9,  8, 20, 16,  3,  2, 24, 14, 22,  1, 25, 15,  4, 11,  6, 23,
+ 12, 19, 13, 26, 18, 27, 21, 17,  7, 10,  5,251,252,128, 96,253,
+)
+
+# Model Table:
+# total sequences: 100%
+# first 512 sequences: 98.4004%
+# first 1024 sequences: 1.5981%
+# rest  sequences:      0.087%
+# negative sequences:   0.0015%
+HEBREW_LANG_MODEL = (
+0,3,3,3,3,3,3,3,3,3,3,2,3,3,3,3,3,3,3,3,3,3,3,2,3,2,1,2,0,1,0,0,
+3,0,3,1,0,0,1,3,2,0,1,1,2,0,2,2,2,1,1,1,1,2,1,1,1,2,0,0,2,2,0,1,
+3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,2,2,2,2,
+1,2,1,2,1,2,0,0,2,0,0,0,0,0,1,0,1,0,0,0,0,0,0,1,0,0,0,0,0,0,1,0,
+3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,2,2,2,
+1,2,1,3,1,1,0,0,2,0,0,0,1,0,1,0,1,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,
+3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,1,0,1,2,2,1,3,
+1,2,1,1,2,2,0,0,2,2,0,0,0,0,1,0,1,0,0,0,1,0,0,0,0,0,0,1,0,1,1,0,
+3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,2,3,3,2,2,2,2,3,2,
+1,2,1,2,2,2,0,0,1,0,0,0,0,0,1,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,1,0,
+3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,2,3,3,2,3,2,2,3,2,2,2,1,2,2,2,2,
+1,2,1,1,2,2,0,1,2,0,0,0,0,0,0,0,1,0,0,0,1,0,0,0,0,0,0,0,0,0,1,0,
+3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,2,0,2,2,2,2,2,
+0,2,0,2,2,2,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,1,0,
+3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,2,3,0,2,2,2,
+0,2,1,2,2,2,0,0,2,1,0,0,0,0,1,0,1,0,0,0,0,0,0,2,0,0,0,0,0,0,1,0,
+3,3,3,3,3,3,3,3,3,3,3,2,3,3,3,3,3,3,3,3,3,3,3,3,3,2,1,2,3,2,2,2,
+1,2,1,2,2,2,0,0,1,0,0,0,0,0,1,0,0,0,0,0,0,0,0,1,0,0,0,0,0,1,1,0,
+3,3,3,3,3,3,3,3,3,2,3,3,3,2,3,3,3,3,3,3,3,3,3,3,3,3,3,1,0,2,0,2,
+0,2,1,2,2,2,0,0,1,2,0,0,0,0,1,0,1,0,0,0,0,0,0,1,0,0,0,2,0,0,1,0,
+3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,2,3,2,3,2,2,3,2,1,2,1,1,1,
+0,1,1,1,1,1,3,0,1,0,0,0,0,2,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,
+3,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,0,1,1,0,1,1,0,0,1,0,0,1,0,0,0,0,
+0,0,1,0,0,0,0,0,2,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
+3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,2,2,2,2,2,2,2,
+0,2,0,1,2,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,1,0,
+3,3,3,3,3,3,3,3,3,2,3,3,3,2,1,2,3,3,2,3,3,3,3,2,3,2,1,2,0,2,1,2,
+0,2,0,2,2,2,0,0,1,2,0,0,0,0,1,0,1,0,0,0,0,0,0,0,0,0,0,1,0,0,1,0,
+3,3,3,3,3,3,3,3,3,2,3,3,3,1,2,2,3,3,2,3,2,3,2,2,3,1,2,2,0,2,2,2,
+0,2,1,2,2,2,0,0,1,2,0,0,0,0,1,0,0,0,0,0,1,0,0,1,0,0,0,1,0,0,1,0,
+3,3,3,3,3,3,3,3,3,3,3,3,3,2,3,3,3,2,3,3,2,2,2,3,3,3,3,1,3,2,2,2,
+0,2,0,1,2,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,1,0,
+3,3,3,3,3,3,3,3,3,3,3,3,3,3,2,2,3,3,3,2,3,2,2,2,1,2,2,0,2,2,2,2,
+0,2,0,2,2,2,0,0,1,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,
+3,3,3,3,3,3,3,3,3,3,3,2,3,3,3,1,3,2,3,3,2,3,3,2,2,1,2,2,2,2,2,2,
+0,2,1,2,1,2,0,0,1,0,0,0,0,0,1,0,0,0,0,0,1,0,0,1,0,0,0,0,0,0,1,0,
+3,3,3,3,3,3,2,3,2,3,3,2,3,3,3,3,2,3,2,3,3,3,3,3,2,2,2,2,2,2,2,1,
+0,2,0,1,2,1,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,1,0,
+3,3,3,3,3,3,3,3,3,2,1,2,3,3,3,3,3,3,3,2,3,2,3,2,1,2,3,0,2,1,2,2,
+0,2,1,1,2,1,0,0,1,0,0,0,0,0,1,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,2,0,
+3,3,3,3,3,3,3,3,3,2,3,3,3,3,2,1,3,1,2,2,2,1,2,3,3,1,2,1,2,2,2,2,
+0,1,1,1,1,1,0,0,0,0,0,0,0,0,1,0,0,0,0,0,1,0,0,2,0,0,0,0,0,0,0,0,
+3,3,3,3,3,3,3,3,3,3,0,2,3,3,3,1,3,3,3,1,2,2,2,2,1,1,2,2,2,2,2,2,
+0,2,0,1,1,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,1,0,
+3,3,3,3,3,3,2,3,3,3,2,2,3,3,3,2,1,2,3,2,3,2,2,2,2,1,2,1,1,1,2,2,
+0,2,1,1,1,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,1,0,
+3,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,0,1,0,0,0,1,0,0,0,0,0,
+1,0,1,0,0,0,0,0,2,0,0,0,0,0,1,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
+3,3,3,3,3,2,3,3,2,3,1,2,2,2,2,3,2,3,1,1,2,2,1,2,2,1,1,0,2,2,2,2,
+0,1,0,1,2,2,0,0,1,1,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,1,0,
+3,0,0,1,1,0,1,0,0,1,1,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,1,2,2,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,
+3,0,1,0,1,0,1,1,0,1,1,0,0,0,1,1,0,1,1,1,0,0,0,0,0,0,1,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,
+3,0,0,0,1,1,0,1,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,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,
+3,2,2,1,2,2,2,2,2,2,2,1,2,2,1,2,2,1,1,1,1,1,1,1,1,2,1,1,0,3,3,3,
+0,3,0,2,2,2,2,0,0,1,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,
+2,2,2,3,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,1,2,2,1,2,2,2,1,1,1,2,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,
+2,2,2,2,2,2,2,2,2,2,2,1,2,2,2,2,2,2,2,2,2,2,2,0,2,2,0,0,0,0,0,0,
+0,0,0,1,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,
+2,3,1,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,1,2,1,0,2,1,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,
+3,1,1,1,1,1,1,1,1,1,1,0,0,1,1,1,1,0,1,1,1,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,1,0,0,0,0,0,0,0,0,0,
+0,3,1,1,2,2,2,2,2,1,2,2,2,1,1,2,2,2,2,2,2,2,1,2,2,1,0,1,1,1,1,0,
+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,0,0,
+3,2,1,1,1,1,2,1,1,2,1,0,1,1,1,1,1,1,1,1,1,1,1,0,1,0,0,0,0,0,0,0,
+0,0,2,0,0,0,0,0,0,0,0,1,1,0,0,0,0,1,1,0,0,1,1,0,0,0,0,0,0,1,0,0,
+2,1,1,2,2,2,2,2,2,2,2,2,2,2,1,2,2,2,2,2,1,2,1,2,1,1,1,1,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,
+1,2,1,2,2,2,2,2,2,2,2,2,2,1,2,1,2,1,1,2,1,1,1,2,1,2,1,2,0,1,0,1,
+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,3,1,2,2,2,1,2,2,2,2,2,2,2,2,1,2,1,1,1,1,1,1,2,1,2,1,1,0,1,0,1,
+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,
+2,1,2,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,2,2,2,
+0,2,0,1,2,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,1,0,
+3,0,0,0,1,0,0,0,0,0,0,0,0,0,0,1,0,1,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,
+2,1,1,1,1,1,1,1,0,1,1,0,1,0,0,1,0,0,1,0,0,0,0,0,1,0,0,0,0,0,0,0,
+0,0,0,0,0,0,0,0,2,0,1,1,1,0,1,0,0,0,1,1,0,1,1,0,0,0,0,0,1,1,0,0,
+0,1,1,1,2,1,2,2,2,0,2,0,2,0,1,1,2,1,1,1,1,2,1,0,1,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,
+2,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,
+1,0,1,0,0,0,0,0,1,0,1,2,2,0,1,0,0,1,1,2,2,1,2,0,2,0,0,0,1,2,0,1,
+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,0,0,0,0,2,0,2,1,2,0,2,0,0,1,1,1,1,1,1,0,1,0,0,0,1,0,0,1,
+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,1,0,0,0,0,0,1,0,2,1,1,0,1,0,0,1,1,1,2,2,0,0,1,0,0,0,1,0,0,1,
+1,1,2,1,0,1,1,1,0,1,0,1,1,1,1,0,0,0,1,0,1,0,0,0,0,0,0,0,0,2,2,1,
+0,2,0,1,2,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,
+2,1,0,0,1,0,1,1,1,1,0,0,0,0,0,1,0,0,0,0,1,1,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,
+1,1,1,1,1,1,1,1,1,2,1,0,1,1,1,1,1,1,1,1,1,1,1,0,1,0,0,0,0,0,0,0,
+0,0,0,0,0,0,0,0,0,0,1,1,1,0,0,0,0,1,1,1,0,1,1,0,1,0,0,0,1,1,0,1,
+2,0,1,0,1,0,1,0,0,1,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,
+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,1,0,1,1,1,0,1,0,0,1,1,2,1,1,2,0,1,0,0,0,1,1,0,1,
+1,0,0,1,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,1,0,1,1,2,0,1,0,0,0,0,2,1,1,2,0,2,0,0,0,1,1,0,1,
+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,1,0,2,1,1,0,1,0,0,2,2,1,2,1,1,0,1,0,0,0,1,1,0,1,
+2,0,1,0,0,1,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,1,2,2,0,0,0,0,0,1,1,0,1,0,0,1,0,0,0,0,1,0,1,
+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,1,2,2,0,0,0,0,2,1,1,1,0,2,1,1,0,0,0,2,1,0,1,
+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,0,0,0,
+0,0,0,0,0,0,0,0,1,0,1,1,2,0,1,0,0,1,1,0,2,1,1,0,1,0,0,0,1,1,0,1,
+2,2,1,1,1,0,1,1,0,1,1,0,1,0,0,0,0,0,0,1,0,0,0,1,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,
+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,0,0,0,0,1,0,2,1,1,0,1,0,0,1,1,0,1,2,1,0,2,0,0,0,1,1,0,1,
+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,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
+0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
+0,0,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,0,0,0,0,
+0,1,0,0,2,0,2,1,1,0,1,0,1,0,0,1,0,0,0,0,1,0,0,0,1,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,
+1,0,0,1,0,0,1,0,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,0,0,1,0,1,1,2,0,1,0,0,1,1,1,0,1,0,0,1,0,0,0,1,0,0,1,
+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,0,0,0,
+1,0,0,0,0,0,0,0,1,0,1,1,0,0,1,0,0,2,1,1,1,1,1,0,1,0,0,0,0,1,0,1,
+0,1,1,1,2,1,1,1,1,0,1,1,1,1,1,1,1,1,1,1,1,1,0,1,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,
+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,1,2,1,0,0,0,0,0,1,1,1,1,1,0,1,0,0,0,1,1,0,0,
+)
+
+Win1255HebrewModel = {
+  'char_to_order_map': WIN1255_CHAR_TO_ORDER_MAP,
+  'precedence_matrix': HEBREW_LANG_MODEL,
+  'typical_positive_ratio': 0.984004,
+  'keep_english_letter': False,
+  'charset_name': "windows-1255",
+  'language': 'Hebrew',
+}
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/langhebrewmodel.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/langhebrewmodel.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..2bc69363e6f13098c5c1a56930129a1c8bef36ce
GIT binary patch
literal 23497
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
LY|PAz>~IJG7Ov5_

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/langhungarianmodel.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/langhungarianmodel.py
new file mode 100644
index 0000000..bb7c095
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/langhungarianmodel.py
@@ -0,0 +1,225 @@
+######################## BEGIN LICENSE BLOCK ########################
+# The Original Code is Mozilla Communicator client code.
+#
+# The Initial Developer of the Original Code is
+# Netscape Communications Corporation.
+# Portions created by the Initial Developer are Copyright (C) 1998
+# the Initial Developer. All Rights Reserved.
+#
+# Contributor(s):
+#   Mark Pilgrim - port to Python
+#
+# This library is free software; you can redistribute it and/or
+# modify it under the terms of the GNU Lesser General Public
+# License as published by the Free Software Foundation; either
+# version 2.1 of the License, or (at your option) any later version.
+#
+# This library is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+# Lesser General Public License for more details.
+#
+# You should have received a copy of the GNU Lesser General Public
+# License along with this library; if not, write to the Free Software
+# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
+# 02110-1301  USA
+######################### END LICENSE BLOCK #########################
+
+# 255: Control characters that usually does not exist in any text
+# 254: Carriage/Return
+# 253: symbol (punctuation) that does not belong to word
+# 252: 0 - 9
+
+# Character Mapping Table:
+Latin2_HungarianCharToOrderMap = (
+255,255,255,255,255,255,255,255,255,255,254,255,255,254,255,255,  # 00
+255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,  # 10
+253,253,253,253,253,253,253,253,253,253,253,253,253,253,253,253,  # 20
+252,252,252,252,252,252,252,252,252,252,253,253,253,253,253,253,  # 30
+253, 28, 40, 54, 45, 32, 50, 49, 38, 39, 53, 36, 41, 34, 35, 47,
+ 46, 71, 43, 33, 37, 57, 48, 64, 68, 55, 52,253,253,253,253,253,
+253,  2, 18, 26, 17,  1, 27, 12, 20,  9, 22,  7,  6, 13,  4,  8,
+ 23, 67, 10,  5,  3, 21, 19, 65, 62, 16, 11,253,253,253,253,253,
+159,160,161,162,163,164,165,166,167,168,169,170,171,172,173,174,
+175,176,177,178,179,180,181,182,183,184,185,186,187,188,189,190,
+191,192,193,194,195,196,197, 75,198,199,200,201,202,203,204,205,
+ 79,206,207,208,209,210,211,212,213,214,215,216,217,218,219,220,
+221, 51, 81,222, 78,223,224,225,226, 44,227,228,229, 61,230,231,
+232,233,234, 58,235, 66, 59,236,237,238, 60, 69, 63,239,240,241,
+ 82, 14, 74,242, 70, 80,243, 72,244, 15, 83, 77, 84, 30, 76, 85,
+245,246,247, 25, 73, 42, 24,248,249,250, 31, 56, 29,251,252,253,
+)
+
+win1250HungarianCharToOrderMap = (
+255,255,255,255,255,255,255,255,255,255,254,255,255,254,255,255,  # 00
+255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,  # 10
+253,253,253,253,253,253,253,253,253,253,253,253,253,253,253,253,  # 20
+252,252,252,252,252,252,252,252,252,252,253,253,253,253,253,253,  # 30
+253, 28, 40, 54, 45, 32, 50, 49, 38, 39, 53, 36, 41, 34, 35, 47,
+ 46, 72, 43, 33, 37, 57, 48, 64, 68, 55, 52,253,253,253,253,253,
+253,  2, 18, 26, 17,  1, 27, 12, 20,  9, 22,  7,  6, 13,  4,  8,
+ 23, 67, 10,  5,  3, 21, 19, 65, 62, 16, 11,253,253,253,253,253,
+161,162,163,164,165,166,167,168,169,170,171,172,173,174,175,176,
+177,178,179,180, 78,181, 69,182,183,184,185,186,187,188,189,190,
+191,192,193,194,195,196,197, 76,198,199,200,201,202,203,204,205,
+ 81,206,207,208,209,210,211,212,213,214,215,216,217,218,219,220,
+221, 51, 83,222, 80,223,224,225,226, 44,227,228,229, 61,230,231,
+232,233,234, 58,235, 66, 59,236,237,238, 60, 70, 63,239,240,241,
+ 84, 14, 75,242, 71, 82,243, 73,244, 15, 85, 79, 86, 30, 77, 87,
+245,246,247, 25, 74, 42, 24,248,249,250, 31, 56, 29,251,252,253,
+)
+
+# Model Table:
+# total sequences: 100%
+# first 512 sequences: 94.7368%
+# first 1024 sequences:5.2623%
+# rest  sequences:     0.8894%
+# negative sequences:  0.0009%
+HungarianLangModel = (
+0,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,1,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,
+3,3,3,3,3,3,3,3,3,3,2,3,3,3,3,3,3,3,3,2,2,3,3,1,1,2,2,2,2,2,1,2,
+3,2,2,3,3,3,3,3,2,3,3,3,3,3,3,1,2,3,3,3,3,2,3,3,1,1,3,3,0,1,1,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,2,0,
+3,2,1,3,3,3,3,3,2,3,3,3,3,3,1,1,2,3,3,3,3,3,3,3,1,1,3,2,0,1,1,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,1,0,
+3,3,3,3,3,3,3,3,3,3,3,1,1,2,3,3,3,1,3,3,3,3,3,1,3,3,2,2,0,3,2,3,
+0,0,0,0,0,0,0,0,0,0,3,0,0,0,0,0,0,0,0,0,0,0,0,0,2,0,0,0,0,0,0,0,
+3,3,3,3,3,3,2,3,3,3,2,3,3,2,3,3,3,3,3,2,3,3,2,2,3,2,3,2,0,3,2,2,
+0,0,0,0,0,0,0,0,0,0,2,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,1,0,
+3,3,3,3,3,3,2,3,3,3,3,3,2,3,3,3,1,2,3,2,2,3,1,2,3,3,2,2,0,3,3,3,
+0,0,0,0,0,0,0,0,0,0,2,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,
+3,3,3,3,3,3,3,3,3,3,2,2,3,3,3,3,3,3,2,3,3,3,3,2,3,3,3,3,0,2,3,2,
+0,0,0,1,1,0,0,0,0,0,3,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,
+3,3,3,3,3,3,3,3,3,3,3,1,1,1,3,3,2,1,3,2,2,3,2,1,3,2,2,1,0,3,3,1,
+0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,
+3,2,2,3,3,3,3,3,1,2,3,3,3,3,1,2,1,3,3,3,3,2,2,3,1,1,3,2,0,1,1,1,
+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,1,0,
+3,3,3,3,3,3,3,3,2,2,3,3,3,3,3,2,1,3,3,3,3,3,2,2,1,3,3,3,0,1,1,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,1,0,0,0,0,0,1,0,
+3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,2,3,3,3,2,3,3,2,3,3,3,2,0,3,2,3,
+0,0,0,0,0,0,0,0,0,0,2,0,0,0,0,0,0,0,0,0,0,0,0,0,2,0,0,0,0,0,1,0,
+3,3,3,3,3,3,2,3,3,3,2,3,2,3,3,3,1,3,2,2,2,3,1,1,3,3,1,1,0,3,3,2,
+0,0,0,0,0,0,0,0,0,0,2,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,
+3,3,3,3,3,3,3,2,3,3,3,2,3,2,3,3,3,2,3,3,3,3,3,1,2,3,2,2,0,2,2,2,
+0,0,0,0,0,0,0,0,0,0,2,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,
+3,3,3,2,2,2,3,1,3,3,2,2,1,3,3,3,1,1,3,1,2,3,2,3,2,2,2,1,0,2,2,2,
+0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,2,0,0,0,0,0,0,0,
+3,1,1,3,3,3,3,3,1,2,3,3,3,3,1,2,1,3,3,3,2,2,3,2,1,0,3,2,0,1,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,
+3,1,1,3,3,3,3,3,1,2,3,3,3,3,1,1,0,3,3,3,3,0,2,3,0,0,2,1,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,
+3,3,3,3,3,3,2,2,3,3,2,2,2,2,3,3,0,1,2,3,2,3,2,2,3,2,1,2,0,2,2,2,
+0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,2,0,0,0,0,0,0,0,
+3,3,3,3,3,3,1,2,3,3,3,2,1,2,3,3,2,2,2,3,2,3,3,1,3,3,1,1,0,2,3,2,
+0,0,0,0,0,0,0,0,0,0,2,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,
+3,3,3,1,2,2,2,2,3,3,3,1,1,1,3,3,1,1,3,1,1,3,2,1,2,3,1,1,0,2,2,2,
+0,0,0,0,0,0,0,0,0,0,2,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,
+3,3,3,2,1,2,1,1,3,3,1,1,1,1,3,3,1,1,2,2,1,2,1,1,2,2,1,1,0,2,2,1,
+0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,
+3,3,3,1,1,2,1,1,3,3,1,0,1,1,3,3,2,0,1,1,2,3,1,0,2,2,1,0,0,1,3,2,
+0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,
+3,2,1,3,3,3,3,3,1,2,3,2,3,3,2,1,1,3,2,3,2,1,2,2,0,1,2,1,0,0,1,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,1,0,
+3,3,3,3,2,2,2,2,3,1,2,2,1,1,3,3,0,3,2,1,2,3,2,1,3,3,1,1,0,2,1,3,
+0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,
+3,3,3,2,2,2,3,2,3,3,3,2,1,1,3,3,1,1,1,2,2,3,2,3,2,2,2,1,0,2,2,1,
+0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,
+1,0,0,3,3,3,3,3,0,0,3,3,2,3,0,0,0,2,3,3,1,0,1,2,0,0,1,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,
+3,1,2,3,3,3,3,3,1,2,3,3,2,2,1,1,0,3,3,2,2,1,2,2,1,0,2,2,0,1,1,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,
+3,3,2,2,1,3,1,2,3,3,2,2,1,1,2,2,1,1,1,1,3,2,1,1,1,1,2,1,0,1,2,1,
+0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,1,0,0,0,0,0,0,0,0,0,
+2,3,3,1,1,1,1,1,3,3,3,0,1,1,3,3,1,1,1,1,1,2,2,0,3,1,1,2,0,2,1,1,
+0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,
+3,1,0,1,2,1,2,2,0,1,2,3,1,2,0,0,0,2,1,1,1,1,1,2,0,0,1,1,0,0,0,0,
+1,2,1,2,2,2,1,2,1,2,0,2,0,2,2,1,1,2,1,1,2,1,1,1,0,1,0,0,0,1,1,0,
+1,1,1,2,3,2,3,3,0,1,2,2,3,1,0,1,0,2,1,2,2,0,1,1,0,0,1,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,
+1,0,0,3,3,2,2,1,0,0,3,2,3,2,0,0,0,1,1,3,0,0,1,1,0,0,2,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,
+3,1,1,2,2,3,3,1,0,1,3,2,3,1,1,1,0,1,1,1,1,1,3,1,0,0,2,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,0,
+3,1,1,1,2,2,2,1,0,1,2,3,3,2,0,0,0,2,1,1,1,2,1,1,1,0,1,1,1,0,0,0,
+1,2,2,2,2,2,1,1,1,2,0,2,1,1,1,1,1,2,1,1,1,1,1,1,0,1,1,1,0,0,1,1,
+3,2,2,1,0,0,1,1,2,2,0,3,0,1,2,1,1,0,0,1,1,1,0,1,1,1,1,0,2,1,1,1,
+2,2,1,1,1,2,1,2,1,1,1,1,1,1,1,2,1,1,1,2,3,1,1,1,1,1,1,1,1,1,0,1,
+2,3,3,0,1,0,0,0,3,3,1,0,0,1,2,2,1,0,0,0,0,2,0,0,1,1,1,0,2,1,1,1,
+2,1,1,1,1,1,1,2,1,1,0,1,1,0,1,1,1,0,1,2,1,1,0,1,1,1,1,1,1,1,0,1,
+2,3,3,0,1,0,0,0,2,2,0,0,0,0,1,2,2,0,0,0,0,1,0,0,1,1,0,0,2,0,1,0,
+2,1,1,1,1,2,1,1,1,1,1,1,1,2,1,1,1,1,1,1,1,1,1,2,0,1,1,1,1,1,0,1,
+3,2,2,0,1,0,1,0,2,3,2,0,0,1,2,2,1,0,0,1,1,1,0,0,2,1,0,1,2,2,1,1,
+2,1,1,1,1,1,1,2,1,1,1,1,1,1,0,2,1,0,1,1,0,1,1,1,0,1,1,2,1,1,0,1,
+2,2,2,0,0,1,0,0,2,2,1,1,0,0,2,1,1,0,0,0,1,2,0,0,2,1,0,0,2,1,1,1,
+2,1,1,1,1,2,1,2,1,1,1,2,2,1,1,2,1,1,1,2,1,1,1,1,1,1,1,1,1,1,0,1,
+1,2,3,0,0,0,1,0,3,2,1,0,0,1,2,1,1,0,0,0,0,2,1,0,1,1,0,0,2,1,2,1,
+1,1,0,0,0,1,0,1,1,1,1,1,2,0,0,1,0,0,0,2,0,0,1,1,1,1,1,1,1,1,0,1,
+3,0,0,2,1,2,2,1,0,0,2,1,2,2,0,0,0,2,1,1,1,0,1,1,0,0,1,1,2,0,0,0,
+1,2,1,2,2,1,1,2,1,2,0,1,1,1,1,1,1,1,1,1,2,1,1,0,0,1,1,1,1,0,0,1,
+1,3,2,0,0,0,1,0,2,2,2,0,0,0,2,2,1,0,0,0,0,3,1,1,1,1,0,0,2,1,1,1,
+2,1,0,1,1,1,0,1,1,1,1,1,1,1,0,2,1,0,0,1,0,1,1,0,1,1,1,1,1,1,0,1,
+2,3,2,0,0,0,1,0,2,2,0,0,0,0,2,1,1,0,0,0,0,2,1,0,1,1,0,0,2,1,1,0,
+2,1,1,1,1,2,1,2,1,2,0,1,1,1,0,2,1,1,1,2,1,1,1,1,0,1,1,1,1,1,0,1,
+3,1,1,2,2,2,3,2,1,1,2,2,1,1,0,1,0,2,2,1,1,1,1,1,0,0,1,1,0,1,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,
+2,2,2,0,0,0,0,0,2,2,0,0,0,0,2,2,1,0,0,0,1,1,0,0,1,2,0,0,2,1,1,1,
+2,2,1,1,1,2,1,2,1,1,0,1,1,1,1,2,1,1,1,2,1,1,1,1,0,1,2,1,1,1,0,1,
+1,0,0,1,2,3,2,1,0,0,2,0,1,1,0,0,0,1,1,1,1,0,1,1,0,0,1,0,0,0,0,0,
+1,2,1,2,1,2,1,1,1,2,0,2,1,1,1,0,1,2,0,0,1,1,1,0,0,0,0,0,0,0,0,0,
+2,3,2,0,0,0,0,0,1,1,2,1,0,0,1,1,1,0,0,0,0,2,0,0,1,1,0,0,2,1,1,1,
+2,1,1,1,1,1,1,2,1,0,1,1,1,1,0,2,1,1,1,1,1,1,0,1,0,1,1,1,1,1,0,1,
+1,2,2,0,1,1,1,0,2,2,2,0,0,0,3,2,1,0,0,0,1,1,0,0,1,1,0,1,1,1,0,0,
+1,1,0,1,1,1,1,1,1,1,1,2,1,1,1,1,1,1,1,2,1,1,1,0,0,1,1,1,0,1,0,1,
+2,1,0,2,1,1,2,2,1,1,2,1,1,1,0,0,0,1,1,0,1,1,1,1,0,0,1,1,1,0,0,0,
+1,2,2,2,2,2,1,1,1,2,0,2,1,1,1,1,1,1,1,1,1,1,1,1,0,1,1,0,0,0,1,0,
+1,2,3,0,0,0,1,0,2,2,0,0,0,0,2,2,0,0,0,0,0,1,0,0,1,0,0,0,2,0,1,0,
+2,1,1,1,1,1,0,2,0,0,0,1,2,1,1,1,1,0,1,2,0,1,0,1,0,1,1,1,0,1,0,1,
+2,2,2,0,0,0,1,0,2,1,2,0,0,0,1,1,2,0,0,0,0,1,0,0,1,1,0,0,2,1,0,1,
+2,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,2,0,1,1,1,1,1,0,1,
+1,2,2,0,0,0,1,0,2,2,2,0,0,0,1,1,0,0,0,0,0,1,1,0,2,0,0,1,1,1,0,1,
+1,0,1,1,1,1,1,1,0,1,1,1,1,0,0,1,0,0,1,1,0,1,0,1,1,1,1,1,0,0,0,1,
+1,0,0,1,0,1,2,1,0,0,1,1,1,2,0,0,0,1,1,0,1,0,1,1,0,0,1,0,0,0,0,0,
+0,2,1,2,1,1,1,1,1,2,0,2,0,1,1,0,1,2,1,0,1,1,1,0,0,0,0,0,0,1,0,0,
+2,1,1,0,1,2,0,0,1,1,1,0,0,0,1,1,0,0,0,0,0,1,0,0,1,0,0,0,2,1,0,1,
+2,2,1,1,1,1,1,2,1,1,0,1,1,1,1,2,1,1,1,2,1,1,0,1,0,1,1,1,1,1,0,1,
+1,2,2,0,0,0,0,0,1,1,0,0,0,0,2,1,0,0,0,0,0,2,0,0,2,2,0,0,2,0,0,1,
+2,1,1,1,1,1,1,1,0,1,1,0,1,1,0,1,0,0,0,1,1,1,1,0,0,1,1,1,1,0,0,1,
+1,1,2,0,0,3,1,0,2,1,1,1,0,0,1,1,1,0,0,0,1,1,0,0,0,1,0,0,1,0,1,0,
+1,2,1,0,1,1,1,2,1,1,0,1,1,1,1,1,0,0,0,1,1,1,1,1,0,1,0,0,0,1,0,0,
+2,1,1,0,0,0,0,0,1,0,0,0,0,0,0,0,0,1,0,1,0,0,0,1,0,0,0,0,2,0,0,0,
+2,1,1,1,1,1,1,1,1,1,0,1,1,1,1,1,1,1,1,1,2,1,1,0,0,1,1,1,1,1,0,1,
+2,1,1,1,2,1,1,1,0,1,1,2,1,0,0,0,0,1,1,1,1,0,1,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,
+1,1,0,1,1,1,1,1,0,0,1,1,2,1,0,0,0,1,1,0,0,0,1,1,0,0,1,0,1,0,0,0,
+1,2,1,1,1,1,1,1,1,1,0,1,0,1,1,1,1,1,1,0,1,1,1,0,0,0,0,0,0,1,0,0,
+2,0,0,0,1,1,1,1,0,0,1,1,0,0,0,0,0,1,1,1,2,0,0,1,0,0,1,0,1,0,0,0,
+0,1,1,1,1,1,1,1,1,2,0,1,1,1,1,0,1,1,1,0,1,1,1,0,0,0,0,0,0,0,0,0,
+1,0,0,1,1,1,1,1,0,0,2,1,0,1,0,0,0,1,0,1,0,0,0,0,0,0,1,0,0,0,0,0,
+0,1,1,1,1,1,1,0,1,1,0,1,0,1,1,0,1,1,0,0,1,1,1,0,0,0,0,0,0,0,0,0,
+1,0,0,1,1,1,0,0,0,0,1,0,2,0,0,0,0,0,0,0,0,0,2,0,0,0,0,0,0,0,0,0,
+0,1,1,1,1,1,0,0,1,1,0,1,0,1,0,0,1,1,1,0,1,1,1,0,0,0,0,0,0,0,0,0,
+0,0,0,1,0,0,0,0,0,0,1,1,2,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
+0,1,1,1,0,1,0,0,1,1,0,1,0,1,1,0,1,1,1,0,1,1,1,0,0,0,0,0,0,0,0,0,
+2,1,1,1,1,1,1,1,1,1,1,0,0,1,1,1,0,0,1,0,0,1,0,1,0,1,1,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,0,0,0,0,0,0,0,0,
+1,0,0,1,1,1,1,0,0,0,1,1,1,0,0,0,0,1,1,1,0,0,0,0,0,0,0,0,0,0,0,0,
+0,1,1,1,1,1,1,0,1,1,0,1,0,1,0,0,1,1,0,0,1,1,0,0,0,0,0,0,0,0,0,0,
+)
+
+Latin2HungarianModel = {
+  'char_to_order_map': Latin2_HungarianCharToOrderMap,
+  'precedence_matrix': HungarianLangModel,
+  'typical_positive_ratio': 0.947368,
+  'keep_english_letter': True,
+  'charset_name': "ISO-8859-2",
+  'language': 'Hungarian',
+}
+
+Win1250HungarianModel = {
+  'char_to_order_map': win1250HungarianCharToOrderMap,
+  'precedence_matrix': HungarianLangModel,
+  'typical_positive_ratio': 0.947368,
+  'keep_english_letter': True,
+  'charset_name': "windows-1250",
+  'language': 'Hungarian',
+}
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/langhungarianmodel.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/langhungarianmodel.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..2baaf9210a11837db7fb0fb13b332754bd020060
GIT binary patch
literal 24981
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
E07_*nj{pDw

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/langthaimodel.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/langthaimodel.py
new file mode 100644
index 0000000..15f94c2
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/langthaimodel.py
@@ -0,0 +1,199 @@
+######################## BEGIN LICENSE BLOCK ########################
+# The Original Code is Mozilla Communicator client code.
+#
+# The Initial Developer of the Original Code is
+# Netscape Communications Corporation.
+# Portions created by the Initial Developer are Copyright (C) 1998
+# the Initial Developer. All Rights Reserved.
+#
+# Contributor(s):
+#   Mark Pilgrim - port to Python
+#
+# This library is free software; you can redistribute it and/or
+# modify it under the terms of the GNU Lesser General Public
+# License as published by the Free Software Foundation; either
+# version 2.1 of the License, or (at your option) any later version.
+#
+# This library is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+# Lesser General Public License for more details.
+#
+# You should have received a copy of the GNU Lesser General Public
+# License along with this library; if not, write to the Free Software
+# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
+# 02110-1301  USA
+######################### END LICENSE BLOCK #########################
+
+# 255: Control characters that usually does not exist in any text
+# 254: Carriage/Return
+# 253: symbol (punctuation) that does not belong to word
+# 252: 0 - 9
+
+# The following result for thai was collected from a limited sample (1M).
+
+# Character Mapping Table:
+TIS620CharToOrderMap = (
+255,255,255,255,255,255,255,255,255,255,254,255,255,254,255,255,  # 00
+255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,  # 10
+253,253,253,253,253,253,253,253,253,253,253,253,253,253,253,253,  # 20
+252,252,252,252,252,252,252,252,252,252,253,253,253,253,253,253,  # 30
+253,182,106,107,100,183,184,185,101, 94,186,187,108,109,110,111,  # 40
+188,189,190, 89, 95,112,113,191,192,193,194,253,253,253,253,253,  # 50
+253, 64, 72, 73,114, 74,115,116,102, 81,201,117, 90,103, 78, 82,  # 60
+ 96,202, 91, 79, 84,104,105, 97, 98, 92,203,253,253,253,253,253,  # 70
+209,210,211,212,213, 88,214,215,216,217,218,219,220,118,221,222,
+223,224, 99, 85, 83,225,226,227,228,229,230,231,232,233,234,235,
+236,  5, 30,237, 24,238, 75,  8, 26, 52, 34, 51,119, 47, 58, 57,
+ 49, 53, 55, 43, 20, 19, 44, 14, 48,  3, 17, 25, 39, 62, 31, 54,
+ 45,  9, 16,  2, 61, 15,239, 12, 42, 46, 18, 21, 76,  4, 66, 63,
+ 22, 10,  1, 36, 23, 13, 40, 27, 32, 35, 86,240,241,242,243,244,
+ 11, 28, 41, 29, 33,245, 50, 37,  6,  7, 67, 77, 38, 93,246,247,
+ 68, 56, 59, 65, 69, 60, 70, 80, 71, 87,248,249,250,251,252,253,
+)
+
+# Model Table:
+# total sequences: 100%
+# first 512 sequences: 92.6386%
+# first 1024 sequences:7.3177%
+# rest  sequences:     1.0230%
+# negative sequences:  0.0436%
+ThaiLangModel = (
+0,1,3,3,3,3,0,0,3,3,0,3,3,0,3,3,3,3,3,3,3,3,0,0,3,3,3,0,3,3,3,3,
+0,3,3,0,0,0,1,3,0,3,3,2,3,3,0,1,2,3,3,3,3,0,2,0,2,0,0,3,2,1,2,2,
+3,0,3,3,2,3,0,0,3,3,0,3,3,0,3,3,3,3,3,3,3,3,3,0,3,2,3,0,2,2,2,3,
+0,2,3,0,0,0,0,1,0,1,2,3,1,1,3,2,2,0,1,1,0,0,1,0,0,0,0,0,0,0,1,1,
+3,3,3,2,3,3,3,3,3,3,3,3,3,3,3,2,2,2,2,2,2,2,3,3,2,3,2,3,3,2,2,2,
+3,1,2,3,0,3,3,2,2,1,2,3,3,1,2,0,1,3,0,1,0,0,1,0,0,0,0,0,0,0,1,1,
+3,3,2,2,3,3,3,3,1,2,3,3,3,3,3,2,2,2,2,3,3,2,2,3,3,2,2,3,2,3,2,2,
+3,3,1,2,3,1,2,2,3,3,1,0,2,1,0,0,3,1,2,1,0,0,1,0,0,0,0,0,0,1,0,1,
+3,3,3,3,3,3,2,2,3,3,3,3,2,3,2,2,3,3,2,2,3,2,2,2,2,1,1,3,1,2,1,1,
+3,2,1,0,2,1,0,1,0,1,1,0,1,1,0,0,1,0,1,0,0,0,1,0,0,0,0,0,0,0,0,0,
+3,3,3,2,3,2,3,3,2,2,3,2,3,3,2,3,1,1,2,3,2,2,2,3,2,2,2,2,2,1,2,1,
+2,2,1,1,3,3,2,1,0,1,2,2,0,1,3,0,0,0,1,1,0,0,0,0,0,2,3,0,0,2,1,1,
+3,3,2,3,3,2,0,0,3,3,0,3,3,0,2,2,3,1,2,2,1,1,1,0,2,2,2,0,2,2,1,1,
+0,2,1,0,2,0,0,2,0,1,0,0,1,0,0,0,1,1,1,1,0,0,0,0,0,0,0,0,0,0,1,0,
+3,3,2,3,3,2,0,0,3,3,0,2,3,0,2,1,2,2,2,2,1,2,0,0,2,2,2,0,2,2,1,1,
+0,2,1,0,2,0,0,2,0,1,1,0,1,0,0,0,0,0,0,1,0,0,1,0,0,0,0,0,0,0,0,0,
+3,3,2,3,2,3,2,0,2,2,1,3,2,1,3,2,1,2,3,2,2,3,0,2,3,2,2,1,2,2,2,2,
+1,2,2,0,0,0,0,2,0,1,2,0,1,1,1,0,1,0,3,1,1,0,0,0,0,0,0,0,0,0,1,0,
+3,3,2,3,3,2,3,2,2,2,3,2,2,3,2,2,1,2,3,2,2,3,1,3,2,2,2,3,2,2,2,3,
+3,2,1,3,0,1,1,1,0,2,1,1,1,1,1,0,1,0,1,1,0,0,0,0,0,0,0,0,0,2,0,0,
+1,0,0,3,0,3,3,3,3,3,0,0,3,0,2,2,3,3,3,3,3,0,0,0,1,1,3,0,0,0,0,2,
+0,0,1,0,0,0,0,0,0,0,2,3,0,0,0,3,0,2,0,0,0,0,0,3,0,0,0,0,0,0,0,0,
+2,0,3,3,3,3,0,0,2,3,0,0,3,0,3,3,2,3,3,3,3,3,0,0,3,3,3,0,0,0,3,3,
+0,0,3,0,0,0,0,2,0,0,2,1,1,3,0,0,1,0,0,2,3,0,1,0,0,0,0,0,0,0,1,0,
+3,3,3,3,2,3,3,3,3,3,3,3,1,2,1,3,3,2,2,1,2,2,2,3,1,1,2,0,2,1,2,1,
+2,2,1,0,0,0,1,1,0,1,0,1,1,0,0,0,0,0,1,1,0,0,1,0,0,0,0,0,0,0,0,0,
+3,0,2,1,2,3,3,3,0,2,0,2,2,0,2,1,3,2,2,1,2,1,0,0,2,2,1,0,2,1,2,2,
+0,1,1,0,0,0,0,1,0,1,1,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,
+3,3,3,3,2,1,3,3,1,1,3,0,2,3,1,1,3,2,1,1,2,0,2,2,3,2,1,1,1,1,1,2,
+3,0,0,1,3,1,2,1,2,0,3,0,0,0,1,0,3,0,0,0,0,0,0,0,0,0,0,0,0,1,0,0,
+3,3,1,1,3,2,3,3,3,1,3,2,1,3,2,1,3,2,2,2,2,1,3,3,1,2,1,3,1,2,3,0,
+2,1,1,3,2,2,2,1,2,1,0,0,1,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,
+3,3,2,3,2,3,3,2,3,2,3,2,3,3,2,1,0,3,2,2,2,1,2,2,2,1,2,2,1,2,1,1,
+2,2,2,3,0,1,3,1,1,1,1,0,1,1,0,2,1,0,2,0,0,0,0,0,0,0,0,0,0,0,0,0,
+3,3,3,3,2,3,2,2,1,1,3,2,3,2,3,2,0,3,2,2,1,2,0,2,2,2,1,2,2,2,2,1,
+3,2,1,2,2,1,0,2,0,1,0,0,1,1,0,0,0,0,0,1,1,0,1,0,0,0,0,0,0,0,0,1,
+3,3,3,3,3,2,3,1,2,3,3,2,2,3,0,1,1,2,0,3,3,2,2,3,0,1,1,3,0,0,0,0,
+3,1,0,3,3,0,2,0,2,1,0,0,3,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
+3,3,3,2,3,2,3,3,0,1,3,1,1,2,1,2,1,1,3,1,1,0,2,3,1,1,1,1,1,1,1,1,
+3,1,1,2,2,2,2,1,1,1,0,0,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,
+3,2,2,1,1,2,1,3,3,2,3,2,2,3,2,2,3,1,2,2,1,2,0,3,2,1,2,2,2,2,2,1,
+3,2,1,2,2,2,1,1,1,1,0,0,1,1,0,0,0,0,2,0,0,0,0,0,0,0,0,0,0,0,0,0,
+3,3,3,3,3,3,3,3,1,3,3,0,2,1,0,3,2,0,0,3,1,0,1,1,0,1,0,0,0,0,0,1,
+1,0,0,1,0,3,2,0,0,0,0,0,0,0,0,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
+3,0,2,2,2,3,0,0,1,3,0,3,2,0,3,2,2,3,3,3,3,3,1,0,2,2,2,0,2,2,1,2,
+0,2,3,0,0,0,0,1,0,1,0,0,1,1,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,
+3,0,2,3,1,3,3,2,3,3,0,3,3,0,3,2,2,3,2,3,3,3,0,0,2,2,3,0,1,1,1,3,
+0,0,3,0,0,0,2,2,0,1,3,0,1,2,2,2,3,0,0,0,0,0,1,0,0,0,0,0,0,0,0,1,
+3,2,3,3,2,0,3,3,2,2,3,1,3,2,1,3,2,0,1,2,2,0,2,3,2,1,0,3,0,0,0,0,
+3,0,0,2,3,1,3,0,0,3,0,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
+3,1,3,2,2,2,1,2,0,1,3,1,1,3,1,3,0,0,2,1,1,1,1,2,1,1,1,0,2,1,0,1,
+1,2,0,0,0,3,1,1,0,0,0,0,1,0,1,0,0,1,0,1,0,0,0,0,0,3,1,0,0,0,1,0,
+3,3,3,3,2,2,2,2,2,1,3,1,1,1,2,0,1,1,2,1,2,1,3,2,0,0,3,1,1,1,1,1,
+3,1,0,2,3,0,0,0,3,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,2,3,0,3,3,0,2,0,0,0,0,0,0,0,3,0,0,1,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,2,3,1,3,0,0,1,2,0,0,2,0,3,3,2,3,3,3,2,3,0,0,2,2,2,0,0,0,2,2,
+0,0,1,0,0,0,0,3,0,0,0,0,2,0,0,0,0,0,0,0,0,0,2,0,0,0,0,0,0,0,0,0,
+0,0,0,3,0,2,0,0,0,0,0,0,0,0,0,0,1,2,3,1,3,3,0,0,1,0,3,0,0,0,0,0,
+0,0,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,
+3,3,1,2,3,1,2,3,1,0,3,0,2,2,1,0,2,1,1,2,0,1,0,0,1,1,1,1,0,1,0,0,
+1,0,0,0,0,1,1,0,3,0,0,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
+3,3,3,3,2,1,0,1,1,1,3,1,2,2,2,2,2,2,1,1,1,1,0,3,1,0,1,3,1,1,1,1,
+1,1,0,2,0,1,3,1,1,0,0,1,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,2,0,1,
+3,0,2,2,1,3,3,2,3,3,0,1,1,0,2,2,1,2,1,3,3,1,0,0,3,2,0,0,0,0,2,1,
+0,1,0,0,0,0,1,2,0,1,1,3,1,1,2,2,1,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,
+0,0,3,0,0,1,0,0,0,3,0,0,3,0,3,1,0,1,1,1,3,2,0,0,0,3,0,0,0,0,2,0,
+0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,0,2,0,0,0,0,0,0,0,0,0,
+3,3,1,3,2,1,3,3,1,2,2,0,1,2,1,0,1,2,0,0,0,0,0,3,0,0,0,3,0,0,0,0,
+3,0,0,1,1,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,
+3,0,1,2,0,3,3,3,2,2,0,1,1,0,1,3,0,0,0,2,2,0,0,0,0,3,1,0,1,0,0,0,
+0,0,0,0,0,0,0,0,0,1,0,1,0,0,0,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
+3,0,2,3,1,2,0,0,2,1,0,3,1,0,1,2,0,1,1,1,1,3,0,0,3,1,1,0,2,2,1,1,
+0,2,0,0,0,0,0,1,0,1,0,0,1,1,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
+3,0,0,3,1,2,0,0,2,2,0,1,2,0,1,0,1,3,1,2,1,0,0,0,2,0,3,0,0,0,1,0,
+0,1,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,
+3,0,1,1,2,2,0,0,0,2,0,2,1,0,1,1,0,1,1,1,2,1,0,0,1,1,1,0,2,1,1,1,
+0,1,1,0,0,0,0,0,0,1,0,0,1,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,1,0,1,
+0,0,0,2,0,1,3,1,1,1,1,0,0,0,0,3,2,0,1,0,0,0,1,2,0,0,0,1,0,0,0,0,
+0,0,0,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,3,3,3,3,1,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,
+1,0,2,3,2,2,0,0,0,1,0,0,0,0,2,3,2,1,2,2,3,0,0,0,2,3,1,0,0,0,1,1,
+0,0,1,0,0,0,0,0,0,0,1,0,0,1,0,0,0,0,0,1,1,0,1,0,0,0,0,0,0,0,0,0,
+3,3,2,2,0,1,0,0,0,0,2,0,2,0,1,0,0,0,1,1,0,0,0,2,1,0,1,0,1,1,0,0,
+0,1,0,2,0,0,1,0,3,0,1,0,0,0,2,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
+3,3,1,0,0,1,0,0,0,0,0,1,1,2,0,0,0,0,1,0,0,1,3,1,0,0,0,0,1,1,0,0,
+0,1,0,0,0,0,3,0,0,0,0,0,0,3,0,0,0,0,0,0,0,3,0,0,0,0,0,0,0,0,0,0,
+3,3,1,1,1,1,2,3,0,0,2,1,1,1,1,1,0,2,1,1,0,0,0,2,1,0,1,2,1,1,0,1,
+2,1,0,3,0,0,0,0,3,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
+1,3,1,0,0,0,0,0,0,0,3,0,0,0,3,0,0,0,0,0,0,0,0,1,1,0,0,0,0,0,0,1,
+0,0,0,2,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,3,2,0,0,0,0,0,0,1,2,1,0,1,1,0,2,0,0,1,0,0,2,0,0,0,0,0,0,0,0,0,
+0,0,0,0,0,0,2,0,0,0,1,3,0,1,0,0,0,2,0,0,0,0,0,0,0,1,2,0,0,0,0,0,
+3,3,0,0,1,1,2,0,0,1,2,1,0,1,1,1,0,1,1,0,0,2,1,1,0,1,0,0,1,1,1,0,
+0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,3,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,
+2,2,2,1,0,0,0,0,1,0,0,0,0,3,0,0,0,0,0,0,0,0,0,3,0,0,0,0,0,0,0,0,
+2,0,0,0,0,0,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,
+2,3,0,0,1,1,0,0,0,2,0,0,0,0,0,0,0,2,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,0,0,0,0,0,0,0,0,0,0,0,
+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,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,1,0,1,2,0,1,2,0,0,1,1,0,2,0,1,0,0,1,0,0,0,0,1,0,0,0,2,0,0,0,0,
+1,0,0,1,0,1,1,0,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,1,0,0,0,0,0,0,0,1,1,0,1,1,0,2,1,3,0,0,0,0,1,1,0,0,0,0,0,0,0,3,
+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,0,0,0,0,0,2,0,0,0,0,0,0,0,0,
+0,0,0,0,0,0,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,
+2,0,1,0,1,0,0,2,0,0,2,0,0,1,1,2,0,0,1,1,0,0,0,1,0,0,0,1,1,0,0,0,
+1,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,0,0,0,0,0,0,0,0,0,
+1,0,0,3,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,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,
+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,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,0,0,1,1,0,0,0,
+2,0,0,0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,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,0,
+2,0,0,0,0,2,0,0,0,0,0,0,0,2,0,0,0,0,0,0,0,1,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,
+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,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,0,1,3,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,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,0,0,1,0,0,0,0,
+1,0,0,0,0,0,0,0,0,1,0,0,0,0,2,0,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,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
+0,0,1,1,0,0,2,1,0,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,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,
+2,0,0,0,0,0,0,0,0,0,0,0,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,0,0,0,0,0,0,0,0,0,0,0,0,0,
+)
+
+TIS620ThaiModel = {
+  'char_to_order_map': TIS620CharToOrderMap,
+  'precedence_matrix': ThaiLangModel,
+  'typical_positive_ratio': 0.926386,
+  'keep_english_letter': False,
+  'charset_name': "TIS-620",
+  'language': 'Thai',
+}
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/langthaimodel.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/langthaimodel.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..2a3a3e8e38386300898cff99796a23105f947ae1
GIT binary patch
literal 23476
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
CH_syg

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/langturkishmodel.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/langturkishmodel.py
new file mode 100644
index 0000000..a427a45
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/langturkishmodel.py
@@ -0,0 +1,193 @@
+# -*- coding: utf-8 -*-
+######################## BEGIN LICENSE BLOCK ########################
+# The Original Code is Mozilla Communicator client code.
+#
+# The Initial Developer of the Original Code is
+# Netscape Communications Corporation.
+# Portions created by the Initial Developer are Copyright (C) 1998
+# the Initial Developer. All Rights Reserved.
+#
+# Contributor(s):
+#   Mark Pilgrim - port to Python
+#   Özgür Baskın - Turkish Language Model
+#
+# 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 #########################
+
+# 255: Control characters that usually does not exist in any text
+# 254: Carriage/Return
+# 253: symbol (punctuation) that does not belong to word
+# 252: 0 - 9
+
+# Character Mapping Table:
+Latin5_TurkishCharToOrderMap = (
+255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,
+255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,
+255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,
+255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,
+255, 23, 37, 47, 39, 29, 52, 36, 45, 53, 60, 16, 49, 20, 46, 42,
+ 48, 69, 44, 35, 31, 51, 38, 62, 65, 43, 56,255,255,255,255,255,
+255,  1, 21, 28, 12,  2, 18, 27, 25,  3, 24, 10,  5, 13,  4, 15,
+ 26, 64,  7,  8,  9, 14, 32, 57, 58, 11, 22,255,255,255,255,255,
+180,179,178,177,176,175,174,173,172,171,170,169,168,167,166,165,
+164,163,162,161,160,159,101,158,157,156,155,154,153,152,151,106,
+150,149,148,147,146,145,144,100,143,142,141,140,139,138,137,136,
+ 94, 80, 93,135,105,134,133, 63,132,131,130,129,128,127,126,125,
+124,104, 73, 99, 79, 85,123, 54,122, 98, 92,121,120, 91,103,119,
+ 68,118,117, 97,116,115, 50, 90,114,113,112,111, 55, 41, 40, 86,
+ 89, 70, 59, 78, 71, 82, 88, 33, 77, 66, 84, 83,110, 75, 61, 96,
+ 30, 67,109, 74, 87,102, 34, 95, 81,108, 76, 72, 17,  6, 19,107,
+)
+
+TurkishLangModel = (
+3,2,3,3,3,1,3,3,3,3,3,3,3,3,2,1,1,3,3,1,3,3,0,3,3,3,3,3,0,3,1,3,
+3,2,1,0,0,1,1,0,0,0,1,0,0,1,1,1,1,0,0,0,0,0,0,0,2,2,0,0,1,0,0,1,
+3,2,2,3,3,0,3,3,3,3,3,3,3,2,3,1,0,3,3,1,3,3,0,3,3,3,3,3,0,3,0,3,
+3,1,1,0,1,0,1,0,0,0,0,0,0,1,1,1,1,0,0,0,0,0,0,0,2,2,0,0,0,1,0,1,
+3,3,2,3,3,0,3,3,3,3,3,3,3,2,3,1,1,3,3,0,3,3,1,2,3,3,3,3,0,3,0,3,
+3,1,1,0,0,0,1,0,0,0,0,1,1,0,1,2,1,0,0,0,1,0,0,0,0,2,0,0,0,0,0,1,
+3,3,3,3,3,3,2,3,3,3,3,3,3,3,3,1,3,3,2,0,3,2,1,2,2,1,3,3,0,0,0,2,
+2,2,0,1,0,0,1,0,0,1,1,0,0,0,0,0,0,0,0,0,0,0,0,1,0,1,1,0,1,0,0,1,
+3,3,3,2,3,3,1,2,3,3,3,3,3,3,3,1,3,2,1,0,3,2,0,1,2,3,3,2,1,0,0,2,
+2,1,0,0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,2,0,2,0,0,0,
+1,0,1,3,3,1,3,3,3,3,3,3,3,1,2,0,0,2,3,0,2,3,0,0,2,2,2,3,0,3,0,1,
+2,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,
+3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,0,3,3,3,0,3,2,0,2,3,2,3,3,1,0,0,2,
+3,2,0,0,1,0,0,0,0,0,0,2,0,0,1,0,0,0,0,0,0,0,0,0,1,1,1,0,2,0,0,1,
+3,3,3,2,3,3,2,3,3,3,3,2,3,3,3,0,3,3,0,0,2,1,0,0,2,3,2,2,0,0,0,2,
+2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,1,0,0,0,1,0,1,0,2,0,0,1,
+3,3,3,2,3,3,3,3,3,3,3,2,3,3,3,0,3,2,0,1,3,2,1,1,3,2,3,2,1,0,0,2,
+2,2,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,1,0,0,0,0,0,
+3,3,3,2,3,3,3,3,3,3,3,2,3,3,3,0,3,2,2,0,2,3,0,0,2,2,2,2,0,0,0,2,
+3,3,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,2,0,1,0,0,0,
+3,3,3,3,3,3,3,2,2,2,2,3,2,3,3,0,3,3,1,1,2,2,0,0,2,2,3,2,0,0,1,3,
+0,3,1,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,1,0,0,0,0,1,
+3,3,3,2,3,3,3,2,1,2,2,3,2,3,3,0,3,2,0,0,1,1,0,1,1,2,1,2,0,0,0,1,
+0,3,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,1,0,1,0,1,0,0,0,
+3,3,3,2,3,3,2,3,2,2,2,3,3,3,3,1,3,1,1,0,3,2,1,1,3,3,2,3,1,0,0,1,
+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,1,0,2,0,0,1,
+3,2,2,3,3,0,3,3,3,3,3,3,3,2,2,1,0,3,3,1,3,3,0,1,3,3,2,3,0,3,0,3,
+2,0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,
+2,2,2,3,3,0,3,3,3,3,3,3,3,3,3,0,0,3,2,0,3,3,0,3,2,3,3,3,0,3,1,3,
+2,0,0,0,0,0,0,0,0,0,0,1,0,1,2,0,1,0,0,0,0,0,0,0,2,2,0,0,1,0,0,1,
+3,3,3,1,2,3,3,1,0,0,1,0,0,3,3,2,3,0,0,2,0,0,2,0,2,0,0,0,2,0,2,0,
+0,3,1,0,1,0,0,0,2,2,1,0,1,1,2,1,2,2,2,0,2,1,1,0,0,0,2,0,0,0,0,0,
+1,2,1,3,3,0,3,3,3,3,3,2,3,0,0,0,0,2,3,0,2,3,1,0,2,3,1,3,0,3,0,2,
+3,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,
+3,3,3,1,3,3,2,2,3,2,2,0,1,2,3,0,1,2,1,0,1,0,0,0,1,0,2,2,0,0,0,1,
+1,1,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,1,1,0,0,1,0,0,0,
+3,3,3,1,3,3,1,1,3,3,1,1,3,3,1,0,2,1,2,0,2,1,0,0,1,1,2,1,0,0,0,2,
+2,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,
+3,3,3,1,0,2,1,3,0,0,2,0,0,3,3,0,3,0,0,1,0,1,2,0,0,1,1,2,2,0,1,0,
+0,1,2,1,1,0,1,0,1,1,1,1,1,0,1,1,1,2,2,1,2,0,1,0,0,0,0,0,0,1,0,0,
+3,3,3,2,3,2,3,3,0,2,2,2,3,3,3,0,3,0,0,0,2,2,0,1,2,1,1,1,0,0,0,1,
+0,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,1,0,0,0,
+3,3,3,3,3,3,2,1,2,2,3,3,3,3,2,0,2,0,0,0,2,2,0,0,2,1,3,3,0,0,1,1,
+1,1,0,0,1,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,1,0,0,0,
+1,1,2,3,3,0,3,3,3,3,3,3,2,2,0,2,0,2,3,2,3,2,2,2,2,2,2,2,1,3,2,3,
+2,0,2,1,2,2,2,2,1,1,2,2,1,2,2,1,2,0,0,2,1,1,0,2,1,0,0,1,0,0,0,1,
+2,3,3,1,1,1,0,1,1,1,2,3,2,1,1,0,0,0,0,0,0,0,0,0,0,1,0,1,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,
+3,3,3,2,2,2,3,2,3,2,2,1,3,3,3,0,2,1,2,0,2,1,0,0,1,1,1,1,1,0,0,1,
+2,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,1,0,2,0,1,0,0,0,
+3,3,3,2,3,3,3,3,3,2,3,1,2,3,3,1,2,0,0,0,0,0,0,0,3,2,1,1,0,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,1,0,0,0,0,0,0,
+3,3,3,2,2,3,3,2,1,1,1,1,1,3,3,0,3,1,0,0,1,1,0,0,3,1,2,1,0,0,0,0,
+0,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,1,0,0,0,0,0,
+3,3,3,2,2,3,2,2,2,3,2,1,1,3,3,0,3,0,0,0,0,1,0,0,3,1,1,2,0,0,0,1,
+1,0,0,1,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,1,
+1,1,1,3,3,0,3,3,3,3,3,2,2,2,1,2,0,2,1,2,2,1,1,0,1,2,2,2,2,2,2,2,
+0,0,2,1,2,1,2,1,0,1,1,3,1,2,1,1,2,0,0,2,0,1,0,1,0,1,0,0,0,1,0,1,
+3,3,3,1,3,3,3,0,1,1,0,2,2,3,1,0,3,0,0,0,1,0,0,0,1,0,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,0,0,0,0,0,0,
+3,3,2,0,0,2,2,1,0,0,1,0,0,3,3,1,3,0,0,1,1,0,2,0,3,0,0,0,2,0,1,1,
+0,1,2,0,1,2,2,0,2,2,2,2,1,0,2,1,1,0,2,0,2,1,2,0,0,0,0,0,0,0,0,0,
+3,3,3,1,3,2,3,2,0,2,2,2,1,3,2,0,2,1,2,0,1,2,0,0,1,0,2,2,0,0,0,2,
+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,1,1,0,1,0,0,0,
+3,3,3,0,3,3,1,1,2,3,1,0,3,2,3,0,3,0,0,0,1,0,0,0,1,0,1,0,0,0,0,0,
+1,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,3,3,0,3,3,2,3,3,2,2,0,0,0,0,1,2,0,1,3,0,0,0,3,1,1,0,3,0,2,
+2,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,
+3,3,3,1,2,2,1,0,3,1,1,1,1,3,3,2,3,0,0,1,0,1,2,0,2,2,0,2,2,0,2,1,
+0,2,2,1,1,1,1,0,2,1,1,0,1,1,1,1,2,1,2,1,2,0,1,0,1,0,0,0,0,0,0,0,
+3,3,3,0,1,1,3,0,0,1,1,0,0,2,2,0,3,0,0,1,1,0,1,0,0,0,0,0,2,0,0,0,
+0,3,1,0,1,0,1,0,2,0,0,1,0,1,0,1,1,1,2,1,1,0,2,0,0,0,0,0,0,0,0,0,
+3,3,3,0,2,0,2,0,1,1,1,0,0,3,3,0,2,0,0,1,0,0,2,1,1,0,1,0,1,0,1,0,
+0,2,0,1,2,0,2,0,2,1,1,0,1,0,2,1,1,0,2,1,1,0,1,0,0,0,1,1,0,0,0,0,
+3,2,3,0,1,0,0,0,0,0,0,0,0,1,2,0,1,0,0,1,0,0,1,0,0,0,0,0,2,0,0,0,
+0,0,1,1,0,0,1,0,1,0,0,1,0,0,0,2,1,0,1,0,2,0,0,0,0,0,0,0,0,0,0,0,
+3,3,3,0,0,2,3,0,0,1,0,1,0,2,3,2,3,0,0,1,3,0,2,1,0,0,0,0,2,0,1,0,
+0,2,1,0,0,1,1,0,2,1,0,0,1,0,0,1,1,0,1,1,2,0,1,0,0,0,0,1,0,0,0,0,
+3,2,2,0,0,1,1,0,0,0,0,0,0,3,1,1,1,0,0,0,0,0,1,0,0,0,0,0,2,0,1,0,
+0,1,0,0,0,0,0,0,1,0,0,0,0,0,0,0,1,0,0,0,1,0,1,0,0,0,0,0,0,0,0,0,
+0,0,0,3,3,0,2,3,2,2,1,2,2,1,1,2,0,1,3,2,2,2,0,0,2,2,0,0,0,1,2,1,
+3,0,2,1,1,0,1,1,1,0,1,2,2,2,1,1,2,0,0,0,0,1,0,1,1,0,0,0,0,0,0,0,
+0,1,1,2,3,0,3,3,3,2,2,2,2,1,0,1,0,1,0,1,2,2,0,0,2,2,1,3,1,1,2,1,
+0,0,1,1,2,0,1,1,0,0,1,2,0,2,1,1,2,0,0,1,0,0,0,1,0,1,0,1,0,0,0,0,
+3,3,2,0,0,3,1,0,0,0,0,0,0,3,2,1,2,0,0,1,0,0,2,0,0,0,0,0,2,0,1,0,
+0,2,1,1,0,0,1,0,1,2,0,0,1,1,0,0,2,1,1,1,1,0,2,0,0,0,0,0,0,0,0,0,
+3,3,2,0,0,1,0,0,0,0,1,0,0,3,3,2,2,0,0,1,0,0,2,0,1,0,0,0,2,0,1,0,
+0,0,1,1,0,0,2,0,2,1,0,0,1,1,2,1,2,0,2,1,2,1,1,1,0,0,1,1,0,0,0,0,
+3,3,2,0,0,2,2,0,0,0,1,1,0,2,2,1,3,1,0,1,0,1,2,0,0,0,0,0,1,0,1,0,
+0,1,1,0,0,0,0,0,1,0,0,1,0,0,0,1,1,0,1,0,1,0,0,0,0,0,0,0,0,0,0,0,
+3,3,3,2,0,0,0,1,0,0,1,0,0,2,3,1,2,0,0,1,0,0,2,0,0,0,1,0,2,0,2,0,
+0,1,1,2,2,1,2,0,2,1,1,0,0,1,1,0,1,1,1,1,2,1,1,0,0,0,0,0,0,0,0,0,
+3,3,3,0,2,1,2,1,0,0,1,1,0,3,3,1,2,0,0,1,0,0,2,0,2,0,1,1,2,0,0,0,
+0,0,1,1,1,1,2,0,1,1,0,1,1,1,1,0,0,0,1,1,1,0,1,0,0,0,1,0,0,0,0,0,
+3,3,3,0,2,2,3,2,0,0,1,0,0,2,3,1,0,0,0,0,0,0,2,0,2,0,0,0,2,0,0,0,
+0,1,1,0,0,0,1,0,0,1,0,1,1,0,1,0,1,1,1,0,1,0,0,0,0,0,0,0,0,0,0,0,
+3,2,3,0,0,0,0,0,0,0,1,0,0,2,2,2,2,0,0,1,0,0,2,0,0,0,0,0,2,0,1,0,
+0,0,2,1,1,0,1,0,2,1,1,0,0,1,1,2,1,0,2,0,2,0,1,0,0,0,2,0,0,0,0,0,
+0,0,0,2,2,0,2,1,1,1,1,2,2,0,0,1,0,1,0,0,1,3,0,0,0,0,1,0,0,2,1,0,
+0,0,1,0,1,0,0,0,0,0,2,1,0,1,0,0,0,0,0,0,0,0,0,2,0,0,0,0,0,0,0,0,
+2,0,0,2,3,0,2,3,1,2,2,0,2,0,0,2,0,2,1,1,1,2,1,0,0,1,2,1,1,2,1,0,
+1,0,2,0,1,0,1,1,0,0,2,2,1,2,1,1,2,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,
+3,3,3,0,2,1,2,0,0,0,1,0,0,3,2,0,1,0,0,1,0,0,2,0,0,0,1,2,1,0,1,0,
+0,0,0,0,1,0,1,0,0,1,0,0,0,0,1,0,1,0,1,1,1,0,1,0,0,0,0,0,0,0,0,0,
+0,0,0,2,2,0,2,2,1,1,0,1,1,1,1,1,0,0,1,2,1,1,1,0,1,0,0,0,1,1,1,1,
+0,0,2,1,0,1,1,1,0,1,1,2,1,2,1,1,2,0,1,1,2,1,0,2,0,0,0,0,0,0,0,0,
+3,2,2,0,0,2,0,0,0,0,0,0,0,2,2,0,2,0,0,1,0,0,2,0,0,0,0,0,2,0,0,0,
+0,2,1,0,0,0,0,0,1,0,0,0,0,0,0,0,1,0,0,0,1,0,1,0,0,0,0,0,0,0,0,0,
+0,0,0,3,2,0,2,2,0,1,1,0,1,0,0,1,0,0,0,1,0,1,0,0,0,0,0,1,0,0,0,0,
+2,0,1,0,1,0,1,1,0,0,1,2,0,1,0,1,1,0,0,1,0,1,0,2,0,0,0,0,0,0,0,0,
+2,2,2,0,1,1,0,0,0,1,0,0,0,1,2,0,1,0,0,1,0,0,1,0,0,0,0,1,2,0,1,0,
+0,0,1,0,0,0,1,0,0,1,0,0,0,0,0,0,1,0,1,0,2,0,0,0,0,0,0,0,0,0,0,0,
+2,2,2,2,1,0,1,1,1,0,0,0,0,1,2,0,0,1,0,0,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,0,0,0,0,0,0,2,0,0,0,0,0,0,0,
+1,1,2,0,1,0,0,0,1,0,1,0,0,0,1,0,0,1,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,1,0,0,0,0,0,2,0,0,0,0,0,1,
+0,0,1,2,2,0,2,1,2,1,1,2,2,0,0,0,0,1,0,0,1,1,0,0,2,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,1,0,0,0,
+2,2,2,0,0,0,1,0,0,0,0,0,0,2,2,1,1,0,0,0,0,0,1,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,0,0,0,0,0,0,0,0,0,0,0,0,0,
+0,0,0,1,1,0,0,0,1,0,0,0,1,0,0,0,0,0,0,0,1,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,
+2,2,2,0,1,0,1,0,0,0,0,0,0,1,1,0,0,0,0,0,0,0,1,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,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,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,2,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,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
+)
+
+Latin5TurkishModel = {
+  'char_to_order_map': Latin5_TurkishCharToOrderMap,
+  'precedence_matrix': TurkishLangModel,
+  'typical_positive_ratio': 0.970290,
+  'keep_english_letter': True,
+  'charset_name': "ISO-8859-9",
+  'language': 'Turkish',
+}
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/langturkishmodel.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/langturkishmodel.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..235aa4e0ccbcf89a216278fff6d3ed8582b87249
GIT binary patch
literal 23493
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

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/latin1prober.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/latin1prober.py
new file mode 100644
index 0000000..7d1e8c2
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/latin1prober.py
@@ -0,0 +1,145 @@
+######################## BEGIN LICENSE BLOCK ########################
+# The Original Code is Mozilla Universal charset detector code.
+#
+# The Initial Developer of the Original Code is
+# Netscape Communications Corporation.
+# Portions created by the Initial Developer are Copyright (C) 2001
+# the Initial Developer. All Rights Reserved.
+#
+# Contributor(s):
+#   Mark Pilgrim - port to Python
+#   Shy Shalom - original C code
+#
+# This library is free software; you can redistribute it and/or
+# modify it under the terms of the GNU Lesser General Public
+# License as published by the Free Software Foundation; either
+# version 2.1 of the License, or (at your option) any later version.
+#
+# This library is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+# Lesser General Public License for more details.
+#
+# You should have received a copy of the GNU Lesser General Public
+# License along with this library; if not, write to the Free Software
+# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
+# 02110-1301  USA
+######################### END LICENSE BLOCK #########################
+
+from .charsetprober import CharSetProber
+from .enums import ProbingState
+
+FREQ_CAT_NUM = 4
+
+UDF = 0  # undefined
+OTH = 1  # other
+ASC = 2  # ascii capital letter
+ASS = 3  # ascii small letter
+ACV = 4  # accent capital vowel
+ACO = 5  # accent capital other
+ASV = 6  # accent small vowel
+ASO = 7  # accent small other
+CLASS_NUM = 8  # total classes
+
+Latin1_CharToClass = (
+    OTH, OTH, OTH, OTH, OTH, OTH, OTH, OTH,   # 00 - 07
+    OTH, OTH, OTH, OTH, OTH, OTH, OTH, OTH,   # 08 - 0F
+    OTH, OTH, OTH, OTH, OTH, OTH, OTH, OTH,   # 10 - 17
+    OTH, OTH, OTH, OTH, OTH, OTH, OTH, OTH,   # 18 - 1F
+    OTH, OTH, OTH, OTH, OTH, OTH, OTH, OTH,   # 20 - 27
+    OTH, OTH, OTH, OTH, OTH, OTH, OTH, OTH,   # 28 - 2F
+    OTH, OTH, OTH, OTH, OTH, OTH, OTH, OTH,   # 30 - 37
+    OTH, OTH, OTH, OTH, OTH, OTH, OTH, OTH,   # 38 - 3F
+    OTH, ASC, ASC, ASC, ASC, ASC, ASC, ASC,   # 40 - 47
+    ASC, ASC, ASC, ASC, ASC, ASC, ASC, ASC,   # 48 - 4F
+    ASC, ASC, ASC, ASC, ASC, ASC, ASC, ASC,   # 50 - 57
+    ASC, ASC, ASC, OTH, OTH, OTH, OTH, OTH,   # 58 - 5F
+    OTH, ASS, ASS, ASS, ASS, ASS, ASS, ASS,   # 60 - 67
+    ASS, ASS, ASS, ASS, ASS, ASS, ASS, ASS,   # 68 - 6F
+    ASS, ASS, ASS, ASS, ASS, ASS, ASS, ASS,   # 70 - 77
+    ASS, ASS, ASS, OTH, OTH, OTH, OTH, OTH,   # 78 - 7F
+    OTH, UDF, OTH, ASO, OTH, OTH, OTH, OTH,   # 80 - 87
+    OTH, OTH, ACO, OTH, ACO, UDF, ACO, UDF,   # 88 - 8F
+    UDF, OTH, OTH, OTH, OTH, OTH, OTH, OTH,   # 90 - 97
+    OTH, OTH, ASO, OTH, ASO, UDF, ASO, ACO,   # 98 - 9F
+    OTH, OTH, OTH, OTH, OTH, OTH, OTH, OTH,   # A0 - A7
+    OTH, OTH, OTH, OTH, OTH, OTH, OTH, OTH,   # A8 - AF
+    OTH, OTH, OTH, OTH, OTH, OTH, OTH, OTH,   # B0 - B7
+    OTH, OTH, OTH, OTH, OTH, OTH, OTH, OTH,   # B8 - BF
+    ACV, ACV, ACV, ACV, ACV, ACV, ACO, ACO,   # C0 - C7
+    ACV, ACV, ACV, ACV, ACV, ACV, ACV, ACV,   # C8 - CF
+    ACO, ACO, ACV, ACV, ACV, ACV, ACV, OTH,   # D0 - D7
+    ACV, ACV, ACV, ACV, ACV, ACO, ACO, ACO,   # D8 - DF
+    ASV, ASV, ASV, ASV, ASV, ASV, ASO, ASO,   # E0 - E7
+    ASV, ASV, ASV, ASV, ASV, ASV, ASV, ASV,   # E8 - EF
+    ASO, ASO, ASV, ASV, ASV, ASV, ASV, OTH,   # F0 - F7
+    ASV, ASV, ASV, ASV, ASV, ASO, ASO, ASO,   # F8 - FF
+)
+
+# 0 : illegal
+# 1 : very unlikely
+# 2 : normal
+# 3 : very likely
+Latin1ClassModel = (
+# UDF OTH ASC ASS ACV ACO ASV ASO
+    0,  0,  0,  0,  0,  0,  0,  0,  # UDF
+    0,  3,  3,  3,  3,  3,  3,  3,  # OTH
+    0,  3,  3,  3,  3,  3,  3,  3,  # ASC
+    0,  3,  3,  3,  1,  1,  3,  3,  # ASS
+    0,  3,  3,  3,  1,  2,  1,  2,  # ACV
+    0,  3,  3,  3,  3,  3,  3,  3,  # ACO
+    0,  3,  1,  3,  1,  1,  1,  3,  # ASV
+    0,  3,  1,  3,  1,  1,  3,  3,  # ASO
+)
+
+
+class Latin1Prober(CharSetProber):
+    def __init__(self):
+        super(Latin1Prober, self).__init__()
+        self._last_char_class = None
+        self._freq_counter = None
+        self.reset()
+
+    def reset(self):
+        self._last_char_class = OTH
+        self._freq_counter = [0] * FREQ_CAT_NUM
+        CharSetProber.reset(self)
+
+    @property
+    def charset_name(self):
+        return "ISO-8859-1"
+
+    @property
+    def language(self):
+        return ""
+
+    def feed(self, byte_str):
+        byte_str = self.filter_with_english_letters(byte_str)
+        for c in byte_str:
+            char_class = Latin1_CharToClass[c]
+            freq = Latin1ClassModel[(self._last_char_class * CLASS_NUM)
+                                    + char_class]
+            if freq == 0:
+                self._state = ProbingState.NOT_ME
+                break
+            self._freq_counter[freq] += 1
+            self._last_char_class = char_class
+
+        return self.state
+
+    def get_confidence(self):
+        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
+        # lower the confidence of latin1 so that other more accurate
+        # detector can take priority.
+        confidence = confidence * 0.73
+        return confidence
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/latin1prober.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/latin1prober.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..15b1f017a113b66f23da4078ec15580a389b4c06
GIT binary patch
literal 4117
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
T(IB$~BPCFdlYtQ#vatXF?t%(r

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/mbcharsetprober.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/mbcharsetprober.py
new file mode 100644
index 0000000..6256ecf
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/mbcharsetprober.py
@@ -0,0 +1,91 @@
+######################## BEGIN LICENSE BLOCK ########################
+# The Original Code is Mozilla Universal charset detector code.
+#
+# The Initial Developer of the Original Code is
+# Netscape Communications Corporation.
+# Portions created by the Initial Developer are Copyright (C) 2001
+# the Initial Developer. All Rights Reserved.
+#
+# Contributor(s):
+#   Mark Pilgrim - port to Python
+#   Shy Shalom - original C code
+#   Proofpoint, Inc.
+#
+# This library is free software; you can redistribute it and/or
+# modify it under the terms of the GNU Lesser General Public
+# License as published by the Free Software Foundation; either
+# version 2.1 of the License, or (at your option) any later version.
+#
+# This library is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+# Lesser General Public License for more details.
+#
+# You should have received a copy of the GNU Lesser General Public
+# License along with this library; if not, write to the Free Software
+# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
+# 02110-1301  USA
+######################### END LICENSE BLOCK #########################
+
+from .charsetprober import CharSetProber
+from .enums import ProbingState, MachineState
+
+
+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 reset(self):
+        super(MultiByteCharSetProber, self).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
+
+    @property
+    def language(self):
+        raise NotImplementedError
+
+    def feed(self, byte_str):
+        for i in range(len(byte_str)):
+            coding_state = self.coding_sm.next_state(byte_str[i])
+            if coding_state == MachineState.ERROR:
+                self.logger.debug('%s %s prober hit error at byte %s',
+                                  self.charset_name, self.language, i)
+                self._state = ProbingState.NOT_ME
+                break
+            elif coding_state == MachineState.ITS_ME:
+                self._state = ProbingState.FOUND_IT
+                break
+            elif coding_state == MachineState.START:
+                char_len = self.coding_sm.get_current_charlen()
+                if i == 0:
+                    self._last_char[1] = byte_str[0]
+                    self.distribution_analyzer.feed(self._last_char, char_len)
+                else:
+                    self.distribution_analyzer.feed(byte_str[i - 1:i + 1],
+                                                    char_len)
+
+        self._last_char[0] = byte_str[-1]
+
+        if self.state == ProbingState.DETECTING:
+            if (self.distribution_analyzer.got_enough_data() and
+                    (self.get_confidence() > self.SHORTCUT_THRESHOLD)):
+                self._state = ProbingState.FOUND_IT
+
+        return self.state
+
+    def get_confidence(self):
+        return self.distribution_analyzer.get_confidence()
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/mbcharsetprober.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/mbcharsetprober.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..4df9de8278ecfa265dc6956a9e1d86525587079a
GIT binary patch
literal 3171
zcmZSn%**AGdLky70ScHI7#JKF7#NB{L<$2#3L`@f14Aw&Llh$eBZ$w$ki*1~%ghkP
z%#h2%5XHj4n8M7E%E*w$$dJOq(89pb%)k&C#mbPv$`Gu<#=yXk$;iOKpaCLEco`TN
zoHG)Of>TQZit>|Ei!_)R7#K=;7#J8p{LH-c;F83WRIq?=Vsb`iUMfUDjDdl{w=}0D
z)2Xr~6~zR&!$BrFfgB#pz`&5o0CH~%149%OLkc^{6D^D&x27<GTo}d5kjlo8!VF?J
zGcrW6gSimLGcrVRfZX1~z!1gBkirI16UD_46s*AkGF*Xyfq_dwK|uk#Yrs;;Ag6#Z
zC@h^py6ix{WMC*^WT;_aXl7!_Vgfm-hLNF}fe{p_H4F^#EDR|OAnABkh7=|cN@oId
z*+AmK8X&X$O1K#q7;+Nx(&N)Ib4pT+GC`51!45K=6=Y9oL26MDNM#AgvGMVld6^~g
z@g*z_3=Dqxd8s9$3=9k@nZ+eVnMtK3nfZC~iFt`Rl~t)lC7cWl49WQ^nR)5)#knP1
z3=9nMIf=z3@yQv9&`1IqQk<HT76f8wfGq|Q#bpc(4EhB{nPrJ3srqG!Mfz#^IVq_{
z#rjDp`sGPUdAX*!#YTon=IK@G7N!>EIayU^1|X20ryrtUkXfLcnO9trn3JRHR_5Vp
z8~_pm<M^`Fyp;SReUJ-MQcLu6lR&KE)RF>l%F!#R3<9Mtb&$V7zGYyPWaMPzWK0I7
zG!O=b132^}K;eTL`ppasj5Q1lS<DPYI-pR_Vg|(tNHh-|30W)*MXq2879@!jMo_dt
z<AoIxFQ9n#gTw>KIYFR!fJ6a^Rg_wsS`q{b+#rw}gFpcb&I&=Gm>e9T2+DoBpil%c
z7#M{aIT;1O7#@<K&;*Ah$oVA<3{8v>zk|g6z}_hl1}Cu+&)kBX)ZEm(lGGH}qN4mF
zu;k$JE4W~RCZqVg#N1R<kiS7u$iPH`Z-YSP*kJP-D1Cv7hSJ3JR7)gpfqVx_ilEd9
zjzmy-T*1az0?84K49#HV68njvmI<8XnLzoXhLNF$i9xcNk)f8Ep@x~EgoPoCl_8sn
zp(q!uh>al&T&{w05eHa=6QrS;g@Lhziy?~}BoxoX5Kt%#)6EOk-NOKq=EIcc2TKcs
zB(j(ovIIc&NG%J<%oHZD)B}bZMo_sZ39?cURD9cjSV9b05KV#%H7uaQm9dZ&oVOto
zU~i-_Gf31hfwYJ#!W0QJ6bdthgN$ThfEmfe05(zt>_$<rtw}Jm#6S)zf^fw_Y>?#=
z4B0FUMM+>U!~9g3#0V`!L>PiKKtb<UtjNH?pjxb;TC4ymy%aJsOB7N;IYc3`L?NlN
zBvnDR7+i{gVuvB~|NsC0H6%gh7D#_lVqSV`38*~FNzDV7Cg2h}FSVj1z8F+t27w~E
z1f<k8D9Ask1Qgdf`RVDYMPR{{)TGk%AU*~Lh9G_r0m`>vHGcjf@xHELCd42x(=#L(
zBnnDUZvLTuF7cirU}J(q9D_o@IXykKBtE&cs3<iLQbT~8#RW1Mqz7Exq@|{&fHi^L
z2d-XRTti%)Lp=T5OF)iD&o7Bj&C4%M&xlV+EJ-W@xejb>eqLH;N@`wmYKag714FQf
ze^7{XXh?jBN04i<hrf>tI7Gok3b>L3g<X7cNl^*NQ<;zq4z0&PAp=$e%JK0zsd<B=
zyp>^KV6X*cP(4un$tcMv#>mge!zj$i!^i?=fk=>uAfqIcG$S9AAd?UyKcgt45SB6u
zR1$#_A_GGfs5QY53@(=Z!0jqXl>=(AfCa%}HaLO+<fbT45P;Gx1EZe?s5S&gRXn&@
zj*kZ?@c8)L{FKt1)cE)kP#Y&cJ|#anK0XM<2G{*Tpc)ITt)M8sAhoEZ5-E{`f;k9e
z5yH!0)<8B`Kv`G`<Zn=FXJck#;$h?D;Ai1y;gt0Qx0S&yWKeR2w{wC(i3FUJQu9i4
mi-SPP9Gu<3jSR4l5X1ob4IB+NkodBb1NjluP847iV+H`?(90$O

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/mbcsgroupprober.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/mbcsgroupprober.py
new file mode 100644
index 0000000..530abe7
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/mbcsgroupprober.py
@@ -0,0 +1,54 @@
+######################## BEGIN LICENSE BLOCK ########################
+# The Original Code is Mozilla Universal charset detector code.
+#
+# The Initial Developer of the Original Code is
+# Netscape Communications Corporation.
+# Portions created by the Initial Developer are Copyright (C) 2001
+# the Initial Developer. All Rights Reserved.
+#
+# Contributor(s):
+#   Mark Pilgrim - port to Python
+#   Shy Shalom - original C code
+#   Proofpoint, Inc.
+#
+# This library is free software; you can redistribute it and/or
+# modify it under the terms of the GNU Lesser General Public
+# License as published by the Free Software Foundation; either
+# version 2.1 of the License, or (at your option) any later version.
+#
+# This library is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+# Lesser General Public License for more details.
+#
+# You should have received a copy of the GNU Lesser General Public
+# License along with this library; if not, write to the Free Software
+# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
+# 02110-1301  USA
+######################### END LICENSE BLOCK #########################
+
+from .charsetgroupprober import CharSetGroupProber
+from .utf8prober import UTF8Prober
+from .sjisprober import SJISProber
+from .eucjpprober import EUCJPProber
+from .gb2312prober import GB2312Prober
+from .euckrprober import EUCKRProber
+from .cp949prober import CP949Prober
+from .big5prober import Big5Prober
+from .euctwprober import EUCTWProber
+
+
+class MBCSGroupProber(CharSetGroupProber):
+    def __init__(self, lang_filter=None):
+        super(MBCSGroupProber, self).__init__(lang_filter=lang_filter)
+        self.probers = [
+            UTF8Prober(),
+            SJISProber(),
+            EUCJPProber(),
+            GB2312Prober(),
+            EUCKRProber(),
+            CP949Prober(),
+            Big5Prober(),
+            EUCTWProber()
+        ]
+        self.reset()
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/mbcsgroupprober.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/mbcsgroupprober.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..1f6b864ddd893576abc836d6783375096dcb0dc7
GIT binary patch
literal 1477
zcmZSn%**AGdLky70ScHI7#JKF7#NCIF)%QsFfgPrGUPBY<T5fuF)}cM_)H8rObofq
z3{lJwJ~KlO3qvj|Lli57&%%(y#*oX-5XBDRvohpxFywMFL~%m+Yz#SE47uD4QQQzd
zJ3|f+LoP2v6fcC&!H~npkju{y#Sh_gGUNy_<O(uG2{JIIa51DZGNdswq;NB|FfcST
zFhoWPF{JP?1Z(gzFfe2?GB7Y`fQS+y1_lP_jKreg)Drii{L+GeqWq-PB8VIp0|P^7
zh?@nvSg@C8FtQjo0|SF=sIyl9vLFuw1B1Jhk+Go>vM5xkcM!UubAY9ZC9)vMa;MC6
zQ)Dry?vQYZU<p411B0)Vb1;(2;qk-7z`)=HiXRaM28L7yP_(2lf+DJg5fmjs!5SbH
z$shuRIY8k6Ql7xTz)-@#P{PPi!@$tY#E``VirN}RhGqsv#u8>wSeCGWNmek)1}53T
zBnOz}1e07KGMxitN<24+%;EuwfRYBpYQGYYcXAT*(&N)Ib4pT+z)@4e3UWkgL26MD
zC&(orcg4qN=4F<|#|MF8EC}S<AW-THVqsul2m+}OVgs?*K?F#B35Znyj>uxLc}1zk
zsU=|lmVopWr{<&ufx=e<l$OCnaTx;xgML9#W?5oMs(x8wk$zf!PD*M~v3^pDetA+-
zUao0wv5{etd3sg4g{eh(PF9tf0SKh$>4)eSWESXV<`tJD=H%$Qm3ep?2Y`gYIKC`3
zFD1W7KRF|@C?&N-KQ}44I31MGAnwyEs0;$76fKaiK{3U^D9Oaehz$9e{4_wWE&+Kh
zK0YroH#I)K1myhq_}u)I(i{*Mq`)sfFBNPU*hdIrApOS4z`&ph@*61D*ckmZgh7!C
z%5<OrDNZdx3X336Y=AvhT9Re~2_JBjgT;!oGK-;NAhW=UC$%&=s{kqpN)aWXpiEB!
zWjd%RC|qDlvx}gDpd<qpOfIlAv4jeOk`UOUq|9_vs2C_6ffc5fCYO{$1wqjOPMe4j
b2D1h*n88WI29g-;<Uqj<3Sj|8G{_79J32zM

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/mbcssm.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/mbcssm.py
new file mode 100644
index 0000000..8360d0f
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/mbcssm.py
@@ -0,0 +1,572 @@
+######################## BEGIN LICENSE BLOCK ########################
+# The Original Code is mozilla.org code.
+#
+# The Initial Developer of the Original Code is
+# Netscape Communications Corporation.
+# Portions created by the Initial Developer are Copyright (C) 1998
+# the Initial Developer. All Rights Reserved.
+#
+# Contributor(s):
+#   Mark Pilgrim - port to Python
+#
+# This library is free software; you can redistribute it and/or
+# modify it under the terms of the GNU Lesser General Public
+# License as published by the Free Software Foundation; either
+# version 2.1 of the License, or (at your option) any later version.
+#
+# This library is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+# Lesser General Public License for more details.
+#
+# You should have received a copy of the GNU Lesser General Public
+# License along with this library; if not, write to the Free Software
+# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
+# 02110-1301  USA
+######################### END LICENSE BLOCK #########################
+
+from .enums import MachineState
+
+# BIG5
+
+BIG5_CLS = (
+    1,1,1,1,1,1,1,1,  # 00 - 07    #allow 0x00 as legal value
+    1,1,1,1,1,1,0,0,  # 08 - 0f
+    1,1,1,1,1,1,1,1,  # 10 - 17
+    1,1,1,0,1,1,1,1,  # 18 - 1f
+    1,1,1,1,1,1,1,1,  # 20 - 27
+    1,1,1,1,1,1,1,1,  # 28 - 2f
+    1,1,1,1,1,1,1,1,  # 30 - 37
+    1,1,1,1,1,1,1,1,  # 38 - 3f
+    2,2,2,2,2,2,2,2,  # 40 - 47
+    2,2,2,2,2,2,2,2,  # 48 - 4f
+    2,2,2,2,2,2,2,2,  # 50 - 57
+    2,2,2,2,2,2,2,2,  # 58 - 5f
+    2,2,2,2,2,2,2,2,  # 60 - 67
+    2,2,2,2,2,2,2,2,  # 68 - 6f
+    2,2,2,2,2,2,2,2,  # 70 - 77
+    2,2,2,2,2,2,2,1,  # 78 - 7f
+    4,4,4,4,4,4,4,4,  # 80 - 87
+    4,4,4,4,4,4,4,4,  # 88 - 8f
+    4,4,4,4,4,4,4,4,  # 90 - 97
+    4,4,4,4,4,4,4,4,  # 98 - 9f
+    4,3,3,3,3,3,3,3,  # a0 - a7
+    3,3,3,3,3,3,3,3,  # a8 - af
+    3,3,3,3,3,3,3,3,  # b0 - b7
+    3,3,3,3,3,3,3,3,  # b8 - bf
+    3,3,3,3,3,3,3,3,  # c0 - c7
+    3,3,3,3,3,3,3,3,  # c8 - cf
+    3,3,3,3,3,3,3,3,  # d0 - d7
+    3,3,3,3,3,3,3,3,  # d8 - df
+    3,3,3,3,3,3,3,3,  # e0 - e7
+    3,3,3,3,3,3,3,3,  # e8 - ef
+    3,3,3,3,3,3,3,3,  # f0 - f7
+    3,3,3,3,3,3,3,0  # f8 - ff
+)
+
+BIG5_ST = (
+    MachineState.ERROR,MachineState.START,MachineState.START,     3,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,#00-07
+    MachineState.ERROR,MachineState.ERROR,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ERROR,#08-0f
+    MachineState.ERROR,MachineState.START,MachineState.START,MachineState.START,MachineState.START,MachineState.START,MachineState.START,MachineState.START#10-17
+)
+
+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'}
+
+# CP949
+
+CP949_CLS  = (
+    1,1,1,1,1,1,1,1, 1,1,1,1,1,1,0,0,  # 00 - 0f
+    1,1,1,1,1,1,1,1, 1,1,1,0,1,1,1,1,  # 10 - 1f
+    1,1,1,1,1,1,1,1, 1,1,1,1,1,1,1,1,  # 20 - 2f
+    1,1,1,1,1,1,1,1, 1,1,1,1,1,1,1,1,  # 30 - 3f
+    1,4,4,4,4,4,4,4, 4,4,4,4,4,4,4,4,  # 40 - 4f
+    4,4,5,5,5,5,5,5, 5,5,5,1,1,1,1,1,  # 50 - 5f
+    1,5,5,5,5,5,5,5, 5,5,5,5,5,5,5,5,  # 60 - 6f
+    5,5,5,5,5,5,5,5, 5,5,5,1,1,1,1,1,  # 70 - 7f
+    0,6,6,6,6,6,6,6, 6,6,6,6,6,6,6,6,  # 80 - 8f
+    6,6,6,6,6,6,6,6, 6,6,6,6,6,6,6,6,  # 90 - 9f
+    6,7,7,7,7,7,7,7, 7,7,7,7,7,8,8,8,  # a0 - af
+    7,7,7,7,7,7,7,7, 7,7,7,7,7,7,7,7,  # b0 - bf
+    7,7,7,7,7,7,9,2, 2,3,2,2,2,2,2,2,  # c0 - cf
+    2,2,2,2,2,2,2,2, 2,2,2,2,2,2,2,2,  # d0 - df
+    2,2,2,2,2,2,2,2, 2,2,2,2,2,2,2,2,  # e0 - ef
+    2,2,2,2,2,2,2,2, 2,2,2,2,2,2,2,0,  # f0 - ff
+)
+
+CP949_ST = (
+#cls=    0      1      2      3      4      5      6      7      8      9  # previous state =
+    MachineState.ERROR,MachineState.START,     3,MachineState.ERROR,MachineState.START,MachineState.START,     4,     5,MachineState.ERROR,     6, # MachineState.START
+    MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR, # MachineState.ERROR
+    MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME, # MachineState.ITS_ME
+    MachineState.ERROR,MachineState.ERROR,MachineState.START,MachineState.START,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.START,MachineState.START,MachineState.START, # 3
+    MachineState.ERROR,MachineState.ERROR,MachineState.START,MachineState.START,MachineState.START,MachineState.START,MachineState.START,MachineState.START,MachineState.START,MachineState.START, # 4
+    MachineState.ERROR,MachineState.START,MachineState.START,MachineState.START,MachineState.START,MachineState.START,MachineState.START,MachineState.START,MachineState.START,MachineState.START, # 5
+    MachineState.ERROR,MachineState.START,MachineState.START,MachineState.START,MachineState.START,MachineState.ERROR,MachineState.ERROR,MachineState.START,MachineState.START,MachineState.START, # 6
+)
+
+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'}
+
+# EUC-JP
+
+EUCJP_CLS = (
+    4,4,4,4,4,4,4,4,  # 00 - 07
+    4,4,4,4,4,4,5,5,  # 08 - 0f
+    4,4,4,4,4,4,4,4,  # 10 - 17
+    4,4,4,5,4,4,4,4,  # 18 - 1f
+    4,4,4,4,4,4,4,4,  # 20 - 27
+    4,4,4,4,4,4,4,4,  # 28 - 2f
+    4,4,4,4,4,4,4,4,  # 30 - 37
+    4,4,4,4,4,4,4,4,  # 38 - 3f
+    4,4,4,4,4,4,4,4,  # 40 - 47
+    4,4,4,4,4,4,4,4,  # 48 - 4f
+    4,4,4,4,4,4,4,4,  # 50 - 57
+    4,4,4,4,4,4,4,4,  # 58 - 5f
+    4,4,4,4,4,4,4,4,  # 60 - 67
+    4,4,4,4,4,4,4,4,  # 68 - 6f
+    4,4,4,4,4,4,4,4,  # 70 - 77
+    4,4,4,4,4,4,4,4,  # 78 - 7f
+    5,5,5,5,5,5,5,5,  # 80 - 87
+    5,5,5,5,5,5,1,3,  # 88 - 8f
+    5,5,5,5,5,5,5,5,  # 90 - 97
+    5,5,5,5,5,5,5,5,  # 98 - 9f
+    5,2,2,2,2,2,2,2,  # a0 - a7
+    2,2,2,2,2,2,2,2,  # a8 - af
+    2,2,2,2,2,2,2,2,  # b0 - b7
+    2,2,2,2,2,2,2,2,  # b8 - bf
+    2,2,2,2,2,2,2,2,  # c0 - c7
+    2,2,2,2,2,2,2,2,  # c8 - cf
+    2,2,2,2,2,2,2,2,  # d0 - d7
+    2,2,2,2,2,2,2,2,  # d8 - df
+    0,0,0,0,0,0,0,0,  # e0 - e7
+    0,0,0,0,0,0,0,0,  # e8 - ef
+    0,0,0,0,0,0,0,0,  # f0 - f7
+    0,0,0,0,0,0,0,5  # f8 - ff
+)
+
+EUCJP_ST = (
+          3,     4,     3,     5,MachineState.START,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,#00-07
+     MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,#08-0f
+     MachineState.ITS_ME,MachineState.ITS_ME,MachineState.START,MachineState.ERROR,MachineState.START,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,#10-17
+     MachineState.ERROR,MachineState.ERROR,MachineState.START,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,     3,MachineState.ERROR,#18-1f
+          3,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.START,MachineState.START,MachineState.START,MachineState.START#20-27
+)
+
+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'}
+
+# EUC-KR
+
+EUCKR_CLS  = (
+    1,1,1,1,1,1,1,1,  # 00 - 07
+    1,1,1,1,1,1,0,0,  # 08 - 0f
+    1,1,1,1,1,1,1,1,  # 10 - 17
+    1,1,1,0,1,1,1,1,  # 18 - 1f
+    1,1,1,1,1,1,1,1,  # 20 - 27
+    1,1,1,1,1,1,1,1,  # 28 - 2f
+    1,1,1,1,1,1,1,1,  # 30 - 37
+    1,1,1,1,1,1,1,1,  # 38 - 3f
+    1,1,1,1,1,1,1,1,  # 40 - 47
+    1,1,1,1,1,1,1,1,  # 48 - 4f
+    1,1,1,1,1,1,1,1,  # 50 - 57
+    1,1,1,1,1,1,1,1,  # 58 - 5f
+    1,1,1,1,1,1,1,1,  # 60 - 67
+    1,1,1,1,1,1,1,1,  # 68 - 6f
+    1,1,1,1,1,1,1,1,  # 70 - 77
+    1,1,1,1,1,1,1,1,  # 78 - 7f
+    0,0,0,0,0,0,0,0,  # 80 - 87
+    0,0,0,0,0,0,0,0,  # 88 - 8f
+    0,0,0,0,0,0,0,0,  # 90 - 97
+    0,0,0,0,0,0,0,0,  # 98 - 9f
+    0,2,2,2,2,2,2,2,  # a0 - a7
+    2,2,2,2,2,3,3,3,  # a8 - af
+    2,2,2,2,2,2,2,2,  # b0 - b7
+    2,2,2,2,2,2,2,2,  # b8 - bf
+    2,2,2,2,2,2,2,2,  # c0 - c7
+    2,3,2,2,2,2,2,2,  # c8 - cf
+    2,2,2,2,2,2,2,2,  # d0 - d7
+    2,2,2,2,2,2,2,2,  # d8 - df
+    2,2,2,2,2,2,2,2,  # e0 - e7
+    2,2,2,2,2,2,2,2,  # e8 - ef
+    2,2,2,2,2,2,2,2,  # f0 - f7
+    2,2,2,2,2,2,2,0   # f8 - ff
+)
+
+EUCKR_ST = (
+    MachineState.ERROR,MachineState.START,     3,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,#00-07
+    MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ERROR,MachineState.ERROR,MachineState.START,MachineState.START #08-0f
+)
+
+EUCKR_CHAR_LEN_TABLE = (0, 1, 2, 0)
+
+EUCKR_SM_MODEL = {'class_table': EUCKR_CLS,
+                'class_factor': 4,
+                'state_table': EUCKR_ST,
+                'char_len_table': EUCKR_CHAR_LEN_TABLE,
+                'name': 'EUC-KR'}
+
+# EUC-TW
+
+EUCTW_CLS = (
+    2,2,2,2,2,2,2,2,  # 00 - 07
+    2,2,2,2,2,2,0,0,  # 08 - 0f
+    2,2,2,2,2,2,2,2,  # 10 - 17
+    2,2,2,0,2,2,2,2,  # 18 - 1f
+    2,2,2,2,2,2,2,2,  # 20 - 27
+    2,2,2,2,2,2,2,2,  # 28 - 2f
+    2,2,2,2,2,2,2,2,  # 30 - 37
+    2,2,2,2,2,2,2,2,  # 38 - 3f
+    2,2,2,2,2,2,2,2,  # 40 - 47
+    2,2,2,2,2,2,2,2,  # 48 - 4f
+    2,2,2,2,2,2,2,2,  # 50 - 57
+    2,2,2,2,2,2,2,2,  # 58 - 5f
+    2,2,2,2,2,2,2,2,  # 60 - 67
+    2,2,2,2,2,2,2,2,  # 68 - 6f
+    2,2,2,2,2,2,2,2,  # 70 - 77
+    2,2,2,2,2,2,2,2,  # 78 - 7f
+    0,0,0,0,0,0,0,0,  # 80 - 87
+    0,0,0,0,0,0,6,0,  # 88 - 8f
+    0,0,0,0,0,0,0,0,  # 90 - 97
+    0,0,0,0,0,0,0,0,  # 98 - 9f
+    0,3,4,4,4,4,4,4,  # a0 - a7
+    5,5,1,1,1,1,1,1,  # a8 - af
+    1,1,1,1,1,1,1,1,  # b0 - b7
+    1,1,1,1,1,1,1,1,  # b8 - bf
+    1,1,3,1,3,3,3,3,  # c0 - c7
+    3,3,3,3,3,3,3,3,  # c8 - cf
+    3,3,3,3,3,3,3,3,  # d0 - d7
+    3,3,3,3,3,3,3,3,  # d8 - df
+    3,3,3,3,3,3,3,3,  # e0 - e7
+    3,3,3,3,3,3,3,3,  # e8 - ef
+    3,3,3,3,3,3,3,3,  # f0 - f7
+    3,3,3,3,3,3,3,0   # f8 - ff
+)
+
+EUCTW_ST = (
+    MachineState.ERROR,MachineState.ERROR,MachineState.START,     3,     3,     3,     4,MachineState.ERROR,#00-07
+    MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ITS_ME,MachineState.ITS_ME,#08-0f
+    MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ERROR,MachineState.START,MachineState.ERROR,#10-17
+    MachineState.START,MachineState.START,MachineState.START,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,#18-1f
+         5,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.START,MachineState.ERROR,MachineState.START,MachineState.START,#20-27
+    MachineState.START,MachineState.ERROR,MachineState.START,MachineState.START,MachineState.START,MachineState.START,MachineState.START,MachineState.START #28-2f
+)
+
+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'}
+
+# GB2312
+
+GB2312_CLS = (
+    1,1,1,1,1,1,1,1,  # 00 - 07
+    1,1,1,1,1,1,0,0,  # 08 - 0f
+    1,1,1,1,1,1,1,1,  # 10 - 17
+    1,1,1,0,1,1,1,1,  # 18 - 1f
+    1,1,1,1,1,1,1,1,  # 20 - 27
+    1,1,1,1,1,1,1,1,  # 28 - 2f
+    3,3,3,3,3,3,3,3,  # 30 - 37
+    3,3,1,1,1,1,1,1,  # 38 - 3f
+    2,2,2,2,2,2,2,2,  # 40 - 47
+    2,2,2,2,2,2,2,2,  # 48 - 4f
+    2,2,2,2,2,2,2,2,  # 50 - 57
+    2,2,2,2,2,2,2,2,  # 58 - 5f
+    2,2,2,2,2,2,2,2,  # 60 - 67
+    2,2,2,2,2,2,2,2,  # 68 - 6f
+    2,2,2,2,2,2,2,2,  # 70 - 77
+    2,2,2,2,2,2,2,4,  # 78 - 7f
+    5,6,6,6,6,6,6,6,  # 80 - 87
+    6,6,6,6,6,6,6,6,  # 88 - 8f
+    6,6,6,6,6,6,6,6,  # 90 - 97
+    6,6,6,6,6,6,6,6,  # 98 - 9f
+    6,6,6,6,6,6,6,6,  # a0 - a7
+    6,6,6,6,6,6,6,6,  # a8 - af
+    6,6,6,6,6,6,6,6,  # b0 - b7
+    6,6,6,6,6,6,6,6,  # b8 - bf
+    6,6,6,6,6,6,6,6,  # c0 - c7
+    6,6,6,6,6,6,6,6,  # c8 - cf
+    6,6,6,6,6,6,6,6,  # d0 - d7
+    6,6,6,6,6,6,6,6,  # d8 - df
+    6,6,6,6,6,6,6,6,  # e0 - e7
+    6,6,6,6,6,6,6,6,  # e8 - ef
+    6,6,6,6,6,6,6,6,  # f0 - f7
+    6,6,6,6,6,6,6,0   # f8 - ff
+)
+
+GB2312_ST = (
+    MachineState.ERROR,MachineState.START,MachineState.START,MachineState.START,MachineState.START,MachineState.START,     3,MachineState.ERROR,#00-07
+    MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ITS_ME,MachineState.ITS_ME,#08-0f
+    MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ERROR,MachineState.ERROR,MachineState.START,#10-17
+         4,MachineState.ERROR,MachineState.START,MachineState.START,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,#18-1f
+    MachineState.ERROR,MachineState.ERROR,     5,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ITS_ME,MachineState.ERROR,#20-27
+    MachineState.ERROR,MachineState.ERROR,MachineState.START,MachineState.START,MachineState.START,MachineState.START,MachineState.START,MachineState.START #28-2f
+)
+
+# To be accurate, the length of class 6 can be either 2 or 4.
+# But it is not necessary to discriminate between the two since
+# it is used for frequency analysis only, and we are validating
+# each code range there as well. So it is safe to set it to be
+# 2 here.
+GB2312_CHAR_LEN_TABLE = (0, 1, 1, 1, 1, 1, 2)
+
+GB2312_SM_MODEL = {'class_table': GB2312_CLS,
+                   'class_factor': 7,
+                   'state_table': GB2312_ST,
+                   'char_len_table': GB2312_CHAR_LEN_TABLE,
+                   'name': 'GB2312'}
+
+# Shift_JIS
+
+SJIS_CLS = (
+    1,1,1,1,1,1,1,1,  # 00 - 07
+    1,1,1,1,1,1,0,0,  # 08 - 0f
+    1,1,1,1,1,1,1,1,  # 10 - 17
+    1,1,1,0,1,1,1,1,  # 18 - 1f
+    1,1,1,1,1,1,1,1,  # 20 - 27
+    1,1,1,1,1,1,1,1,  # 28 - 2f
+    1,1,1,1,1,1,1,1,  # 30 - 37
+    1,1,1,1,1,1,1,1,  # 38 - 3f
+    2,2,2,2,2,2,2,2,  # 40 - 47
+    2,2,2,2,2,2,2,2,  # 48 - 4f
+    2,2,2,2,2,2,2,2,  # 50 - 57
+    2,2,2,2,2,2,2,2,  # 58 - 5f
+    2,2,2,2,2,2,2,2,  # 60 - 67
+    2,2,2,2,2,2,2,2,  # 68 - 6f
+    2,2,2,2,2,2,2,2,  # 70 - 77
+    2,2,2,2,2,2,2,1,  # 78 - 7f
+    3,3,3,3,3,2,2,3,  # 80 - 87
+    3,3,3,3,3,3,3,3,  # 88 - 8f
+    3,3,3,3,3,3,3,3,  # 90 - 97
+    3,3,3,3,3,3,3,3,  # 98 - 9f
+    #0xa0 is illegal in sjis encoding, but some pages does
+    #contain such byte. We need to be more error forgiven.
+    2,2,2,2,2,2,2,2,  # a0 - a7
+    2,2,2,2,2,2,2,2,  # a8 - af
+    2,2,2,2,2,2,2,2,  # b0 - b7
+    2,2,2,2,2,2,2,2,  # b8 - bf
+    2,2,2,2,2,2,2,2,  # c0 - c7
+    2,2,2,2,2,2,2,2,  # c8 - cf
+    2,2,2,2,2,2,2,2,  # d0 - d7
+    2,2,2,2,2,2,2,2,  # d8 - df
+    3,3,3,3,3,3,3,3,  # e0 - e7
+    3,3,3,3,3,4,4,4,  # e8 - ef
+    3,3,3,3,3,3,3,3,  # f0 - f7
+    3,3,3,3,3,0,0,0)  # f8 - ff
+
+
+SJIS_ST = (
+    MachineState.ERROR,MachineState.START,MachineState.START,     3,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,#00-07
+    MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,#08-0f
+    MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ERROR,MachineState.ERROR,MachineState.START,MachineState.START,MachineState.START,MachineState.START #10-17
+)
+
+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'}
+
+# UCS2-BE
+
+UCS2BE_CLS = (
+    0,0,0,0,0,0,0,0,  # 00 - 07
+    0,0,1,0,0,2,0,0,  # 08 - 0f
+    0,0,0,0,0,0,0,0,  # 10 - 17
+    0,0,0,3,0,0,0,0,  # 18 - 1f
+    0,0,0,0,0,0,0,0,  # 20 - 27
+    0,3,3,3,3,3,0,0,  # 28 - 2f
+    0,0,0,0,0,0,0,0,  # 30 - 37
+    0,0,0,0,0,0,0,0,  # 38 - 3f
+    0,0,0,0,0,0,0,0,  # 40 - 47
+    0,0,0,0,0,0,0,0,  # 48 - 4f
+    0,0,0,0,0,0,0,0,  # 50 - 57
+    0,0,0,0,0,0,0,0,  # 58 - 5f
+    0,0,0,0,0,0,0,0,  # 60 - 67
+    0,0,0,0,0,0,0,0,  # 68 - 6f
+    0,0,0,0,0,0,0,0,  # 70 - 77
+    0,0,0,0,0,0,0,0,  # 78 - 7f
+    0,0,0,0,0,0,0,0,  # 80 - 87
+    0,0,0,0,0,0,0,0,  # 88 - 8f
+    0,0,0,0,0,0,0,0,  # 90 - 97
+    0,0,0,0,0,0,0,0,  # 98 - 9f
+    0,0,0,0,0,0,0,0,  # a0 - a7
+    0,0,0,0,0,0,0,0,  # a8 - af
+    0,0,0,0,0,0,0,0,  # b0 - b7
+    0,0,0,0,0,0,0,0,  # b8 - bf
+    0,0,0,0,0,0,0,0,  # c0 - c7
+    0,0,0,0,0,0,0,0,  # c8 - cf
+    0,0,0,0,0,0,0,0,  # d0 - d7
+    0,0,0,0,0,0,0,0,  # d8 - df
+    0,0,0,0,0,0,0,0,  # e0 - e7
+    0,0,0,0,0,0,0,0,  # e8 - ef
+    0,0,0,0,0,0,0,0,  # f0 - f7
+    0,0,0,0,0,0,4,5   # f8 - ff
+)
+
+UCS2BE_ST  = (
+          5,     7,     7,MachineState.ERROR,     4,     3,MachineState.ERROR,MachineState.ERROR,#00-07
+     MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,#08-0f
+     MachineState.ITS_ME,MachineState.ITS_ME,     6,     6,     6,     6,MachineState.ERROR,MachineState.ERROR,#10-17
+          6,     6,     6,     6,     6,MachineState.ITS_ME,     6,     6,#18-1f
+          6,     6,     6,     6,     5,     7,     7,MachineState.ERROR,#20-27
+          5,     8,     6,     6,MachineState.ERROR,     6,     6,     6,#28-2f
+          6,     6,     6,     6,MachineState.ERROR,MachineState.ERROR,MachineState.START,MachineState.START #30-37
+)
+
+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'}
+
+# UCS2-LE
+
+UCS2LE_CLS = (
+    0,0,0,0,0,0,0,0,  # 00 - 07
+    0,0,1,0,0,2,0,0,  # 08 - 0f
+    0,0,0,0,0,0,0,0,  # 10 - 17
+    0,0,0,3,0,0,0,0,  # 18 - 1f
+    0,0,0,0,0,0,0,0,  # 20 - 27
+    0,3,3,3,3,3,0,0,  # 28 - 2f
+    0,0,0,0,0,0,0,0,  # 30 - 37
+    0,0,0,0,0,0,0,0,  # 38 - 3f
+    0,0,0,0,0,0,0,0,  # 40 - 47
+    0,0,0,0,0,0,0,0,  # 48 - 4f
+    0,0,0,0,0,0,0,0,  # 50 - 57
+    0,0,0,0,0,0,0,0,  # 58 - 5f
+    0,0,0,0,0,0,0,0,  # 60 - 67
+    0,0,0,0,0,0,0,0,  # 68 - 6f
+    0,0,0,0,0,0,0,0,  # 70 - 77
+    0,0,0,0,0,0,0,0,  # 78 - 7f
+    0,0,0,0,0,0,0,0,  # 80 - 87
+    0,0,0,0,0,0,0,0,  # 88 - 8f
+    0,0,0,0,0,0,0,0,  # 90 - 97
+    0,0,0,0,0,0,0,0,  # 98 - 9f
+    0,0,0,0,0,0,0,0,  # a0 - a7
+    0,0,0,0,0,0,0,0,  # a8 - af
+    0,0,0,0,0,0,0,0,  # b0 - b7
+    0,0,0,0,0,0,0,0,  # b8 - bf
+    0,0,0,0,0,0,0,0,  # c0 - c7
+    0,0,0,0,0,0,0,0,  # c8 - cf
+    0,0,0,0,0,0,0,0,  # d0 - d7
+    0,0,0,0,0,0,0,0,  # d8 - df
+    0,0,0,0,0,0,0,0,  # e0 - e7
+    0,0,0,0,0,0,0,0,  # e8 - ef
+    0,0,0,0,0,0,0,0,  # f0 - f7
+    0,0,0,0,0,0,4,5   # f8 - ff
+)
+
+UCS2LE_ST = (
+          6,     6,     7,     6,     4,     3,MachineState.ERROR,MachineState.ERROR,#00-07
+     MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,#08-0f
+     MachineState.ITS_ME,MachineState.ITS_ME,     5,     5,     5,MachineState.ERROR,MachineState.ITS_ME,MachineState.ERROR,#10-17
+          5,     5,     5,MachineState.ERROR,     5,MachineState.ERROR,     6,     6,#18-1f
+          7,     6,     8,     8,     5,     5,     5,MachineState.ERROR,#20-27
+          5,     5,     5,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,     5,     5,#28-2f
+          5,     5,     5,MachineState.ERROR,     5,MachineState.ERROR,MachineState.START,MachineState.START #30-37
+)
+
+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'}
+
+# UTF-8
+
+UTF8_CLS = (
+    1,1,1,1,1,1,1,1,  # 00 - 07  #allow 0x00 as a legal value
+    1,1,1,1,1,1,0,0,  # 08 - 0f
+    1,1,1,1,1,1,1,1,  # 10 - 17
+    1,1,1,0,1,1,1,1,  # 18 - 1f
+    1,1,1,1,1,1,1,1,  # 20 - 27
+    1,1,1,1,1,1,1,1,  # 28 - 2f
+    1,1,1,1,1,1,1,1,  # 30 - 37
+    1,1,1,1,1,1,1,1,  # 38 - 3f
+    1,1,1,1,1,1,1,1,  # 40 - 47
+    1,1,1,1,1,1,1,1,  # 48 - 4f
+    1,1,1,1,1,1,1,1,  # 50 - 57
+    1,1,1,1,1,1,1,1,  # 58 - 5f
+    1,1,1,1,1,1,1,1,  # 60 - 67
+    1,1,1,1,1,1,1,1,  # 68 - 6f
+    1,1,1,1,1,1,1,1,  # 70 - 77
+    1,1,1,1,1,1,1,1,  # 78 - 7f
+    2,2,2,2,3,3,3,3,  # 80 - 87
+    4,4,4,4,4,4,4,4,  # 88 - 8f
+    4,4,4,4,4,4,4,4,  # 90 - 97
+    4,4,4,4,4,4,4,4,  # 98 - 9f
+    5,5,5,5,5,5,5,5,  # a0 - a7
+    5,5,5,5,5,5,5,5,  # a8 - af
+    5,5,5,5,5,5,5,5,  # b0 - b7
+    5,5,5,5,5,5,5,5,  # b8 - bf
+    0,0,6,6,6,6,6,6,  # c0 - c7
+    6,6,6,6,6,6,6,6,  # c8 - cf
+    6,6,6,6,6,6,6,6,  # d0 - d7
+    6,6,6,6,6,6,6,6,  # d8 - df
+    7,8,8,8,8,8,8,8,  # e0 - e7
+    8,8,8,8,8,9,8,8,  # e8 - ef
+    10,11,11,11,11,11,11,11,  # f0 - f7
+    12,13,13,13,14,15,0,0    # f8 - ff
+)
+
+UTF8_ST = (
+    MachineState.ERROR,MachineState.START,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,     12,   10,#00-07
+         9,     11,     8,     7,     6,     5,     4,    3,#08-0f
+    MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,#10-17
+    MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,#18-1f
+    MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,#20-27
+    MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,#28-2f
+    MachineState.ERROR,MachineState.ERROR,     5,     5,     5,     5,MachineState.ERROR,MachineState.ERROR,#30-37
+    MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,#38-3f
+    MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,     5,     5,     5,MachineState.ERROR,MachineState.ERROR,#40-47
+    MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,#48-4f
+    MachineState.ERROR,MachineState.ERROR,     7,     7,     7,     7,MachineState.ERROR,MachineState.ERROR,#50-57
+    MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,#58-5f
+    MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,     7,     7,MachineState.ERROR,MachineState.ERROR,#60-67
+    MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,#68-6f
+    MachineState.ERROR,MachineState.ERROR,     9,     9,     9,     9,MachineState.ERROR,MachineState.ERROR,#70-77
+    MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,#78-7f
+    MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,     9,MachineState.ERROR,MachineState.ERROR,#80-87
+    MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,#88-8f
+    MachineState.ERROR,MachineState.ERROR,    12,    12,    12,    12,MachineState.ERROR,MachineState.ERROR,#90-97
+    MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,#98-9f
+    MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,    12,MachineState.ERROR,MachineState.ERROR,#a0-a7
+    MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,#a8-af
+    MachineState.ERROR,MachineState.ERROR,    12,    12,    12,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,#b0-b7
+    MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,#b8-bf
+    MachineState.ERROR,MachineState.ERROR,MachineState.START,MachineState.START,MachineState.START,MachineState.START,MachineState.ERROR,MachineState.ERROR,#c0-c7
+    MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR #c8-cf
+)
+
+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'}
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/mbcssm.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/mbcssm.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..d8272559ea7f2d4a0edb21e5d49cfc8ca47139ec
GIT binary patch
literal 19168
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

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/sbcharsetprober.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/sbcharsetprober.py
new file mode 100644
index 0000000..0adb51d
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/sbcharsetprober.py
@@ -0,0 +1,132 @@
+######################## BEGIN LICENSE BLOCK ########################
+# The Original Code is Mozilla Universal charset detector code.
+#
+# The Initial Developer of the Original Code is
+# Netscape Communications Corporation.
+# Portions created by the Initial Developer are Copyright (C) 2001
+# the Initial Developer. All Rights Reserved.
+#
+# Contributor(s):
+#   Mark Pilgrim - port to Python
+#   Shy Shalom - original C code
+#
+# This library is free software; you can redistribute it and/or
+# modify it under the terms of the GNU Lesser General Public
+# License as published by the Free Software Foundation; either
+# version 2.1 of the License, or (at your option) any later version.
+#
+# This library is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+# Lesser General Public License for more details.
+#
+# You should have received a copy of the GNU Lesser General Public
+# License along with this library; if not, write to the Free Software
+# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
+# 02110-1301  USA
+######################### END LICENSE BLOCK #########################
+
+from .charsetprober import CharSetProber
+from .enums import CharacterCategory, ProbingState, SequenceLikelihood
+
+
+class SingleByteCharSetProber(CharSetProber):
+    SAMPLE_SIZE = 64
+    SB_ENOUGH_REL_THRESHOLD = 1024  #  0.25 * SAMPLE_SIZE^2
+    POSITIVE_SHORTCUT_THRESHOLD = 0.95
+    NEGATIVE_SHORTCUT_THRESHOLD = 0.05
+
+    def __init__(self, model, reversed=False, name_prober=None):
+        super(SingleByteCharSetProber, self).__init__()
+        self._model = model
+        # TRUE if we need to reverse every pair in the model lookup
+        self._reversed = 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.reset()
+
+    def reset(self):
+        super(SingleByteCharSetProber, self).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
+        # characters that fall in our sampling range
+        self._freq_char = 0
+
+    @property
+    def charset_name(self):
+        if self._name_prober:
+            return self._name_prober.charset_name
+        else:
+            return self._model['charset_name']
+
+    @property
+    def language(self):
+        if self._name_prober:
+            return self._name_prober.language
+        else:
+            return self._model.get('language')
+
+    def feed(self, byte_str):
+        if not self._model['keep_english_letter']:
+            byte_str = self.filter_international_words(byte_str)
+        if not byte_str:
+            return self.state
+        char_to_order_map = self._model['char_to_order_map']
+        for i, c in enumerate(byte_str):
+            # XXX: Order is in range 1-64, so one would think we want 0-63 here,
+            #      but that leads to 27 more test failures than before.
+            order = char_to_order_map[c]
+            # XXX: This was SYMBOL_CAT_ORDER before, with a value of 250, but
+            #      CharacterCategory.SYMBOL is actually 253, so we use CONTROL
+            #      to make it closer to the original intent. The only difference
+            #      is whether or not we count digits and control characters for
+            #      _total_char purposes.
+            if order < CharacterCategory.CONTROL:
+                self._total_char += 1
+            if order < self.SAMPLE_SIZE:
+                self._freq_char += 1
+                if self._last_order < self.SAMPLE_SIZE:
+                    self._total_seqs += 1
+                    if not self._reversed:
+                        i = (self._last_order * self.SAMPLE_SIZE) + order
+                        model = self._model['precedence_matrix'][i]
+                    else:  # reverse the order of the letters in the lookup
+                        i = (order * self.SAMPLE_SIZE) + self._last_order
+                        model = self._model['precedence_matrix'][i]
+                    self._seq_counters[model] += 1
+            self._last_order = order
+
+        charset_name = self._model['charset_name']
+        if self.state == ProbingState.DETECTING:
+            if self._total_seqs > self.SB_ENOUGH_REL_THRESHOLD:
+                confidence = self.get_confidence()
+                if confidence > self.POSITIVE_SHORTCUT_THRESHOLD:
+                    self.logger.debug('%s confidence = %s, we have a winner',
+                                      charset_name, confidence)
+                    self._state = ProbingState.FOUND_IT
+                elif confidence < self.NEGATIVE_SHORTCUT_THRESHOLD:
+                    self.logger.debug('%s confidence = %s, below negative '
+                                      'shortcut threshhold %s', charset_name,
+                                      confidence,
+                                      self.NEGATIVE_SHORTCUT_THRESHOLD)
+                    self._state = ProbingState.NOT_ME
+
+        return self.state
+
+    def get_confidence(self):
+        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 = r * self._freq_char / self._total_char
+            if r >= 1.0:
+                r = 0.99
+        return r
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/sbcharsetprober.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/sbcharsetprober.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..33b52554d306cb31ec6b086ac5a37a6b7d713f10
GIT binary patch
literal 4050
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

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/sbcsgroupprober.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/sbcsgroupprober.py
new file mode 100644
index 0000000..98e95dc
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/sbcsgroupprober.py
@@ -0,0 +1,73 @@
+######################## BEGIN LICENSE BLOCK ########################
+# The Original Code is Mozilla Universal charset detector code.
+#
+# The Initial Developer of the Original Code is
+# Netscape Communications Corporation.
+# Portions created by the Initial Developer are Copyright (C) 2001
+# the Initial Developer. All Rights Reserved.
+#
+# Contributor(s):
+#   Mark Pilgrim - port to Python
+#   Shy Shalom - original C code
+#
+# This library is free software; you can redistribute it and/or
+# modify it under the terms of the GNU Lesser General Public
+# License as published by the Free Software Foundation; either
+# version 2.1 of the License, or (at your option) any later version.
+#
+# This library is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+# Lesser General Public License for more details.
+#
+# You should have received a copy of the GNU Lesser General Public
+# License along with this library; if not, write to the Free Software
+# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
+# 02110-1301  USA
+######################### END LICENSE BLOCK #########################
+
+from .charsetgroupprober import CharSetGroupProber
+from .sbcharsetprober import SingleByteCharSetProber
+from .langcyrillicmodel import (Win1251CyrillicModel, Koi8rModel,
+                                Latin5CyrillicModel, MacCyrillicModel,
+                                Ibm866Model, Ibm855Model)
+from .langgreekmodel import Latin7GreekModel, Win1253GreekModel
+from .langbulgarianmodel import Latin5BulgarianModel, Win1251BulgarianModel
+# from .langhungarianmodel import Latin2HungarianModel, Win1250HungarianModel
+from .langthaimodel import TIS620ThaiModel
+from .langhebrewmodel import Win1255HebrewModel
+from .hebrewprober import HebrewProber
+from .langturkishmodel import Latin5TurkishModel
+
+
+class SBCSGroupProber(CharSetGroupProber):
+    def __init__(self):
+        super(SBCSGroupProber, self).__init__()
+        self.probers = [
+            SingleByteCharSetProber(Win1251CyrillicModel),
+            SingleByteCharSetProber(Koi8rModel),
+            SingleByteCharSetProber(Latin5CyrillicModel),
+            SingleByteCharSetProber(MacCyrillicModel),
+            SingleByteCharSetProber(Ibm866Model),
+            SingleByteCharSetProber(Ibm855Model),
+            SingleByteCharSetProber(Latin7GreekModel),
+            SingleByteCharSetProber(Win1253GreekModel),
+            SingleByteCharSetProber(Latin5BulgarianModel),
+            SingleByteCharSetProber(Win1251BulgarianModel),
+            # TODO: Restore Hungarian encodings (iso-8859-2 and windows-1250)
+            #       after we retrain model.
+            # SingleByteCharSetProber(Latin2HungarianModel),
+            # SingleByteCharSetProber(Win1250HungarianModel),
+            SingleByteCharSetProber(TIS620ThaiModel),
+            SingleByteCharSetProber(Latin5TurkishModel),
+        ]
+        hebrew_prober = HebrewProber()
+        logical_hebrew_prober = SingleByteCharSetProber(Win1255HebrewModel,
+                                                        False, hebrew_prober)
+        visual_hebrew_prober = SingleByteCharSetProber(Win1255HebrewModel, True,
+                                                       hebrew_prober)
+        hebrew_prober.set_model_probers(logical_hebrew_prober, visual_hebrew_prober)
+        self.probers.extend([hebrew_prober, logical_hebrew_prober,
+                             visual_hebrew_prober])
+
+        self.reset()
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/sbcsgroupprober.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/sbcsgroupprober.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..be6bdd019e8db7f0d2d9550c8bb1c64d3f521d60
GIT binary patch
literal 2070
zcmZSn%**AGdLky70ScHI7#JKF7#NDLFfcHrFfgPrGUPBY<T5fuF)}cM_)H8rObofq
z3{lJwJ~KlO3qvj|Lli4RE*nD>8$&KTLliqhE(b#t2SY9=Llh@NE*C=-7eqA+Lk>4X
zE)PQ#4?`|5LliGWl$9Zek0F<zA&Q?NSAZc(03yo9kR!;DE5r~b1mUwY<Onn5iZDcp
zK=>RCIid`?VhmAY5I!eEjyOZE1VfYr17ivoLn<Rf8Y4prH$w{pLo)+IWRxUB3J*iD
z1}_5xLnb2w1A_*LC=p^{U~tYzEDBC7aWBd*EeI&ePf9I<$cZyBFa&4jrRStNRhFbe
zRY4W7F)%Qch%hiPglFa%8krh8R~BXF<YXrM=BK3QlyEUHFnH%@S`<OJ!VC-yK8Yon
zd8Vk!1Q-|?d=ryV1-Tg*7(A15EzHaynqhoXQ!rnH31l-!C)h-D_oCF)Y_Lp;Alx~|
z2vLZ7kW0bpO`S?}(i4j^6Z0T?MB#c2QDq=Oz|X+I5aJnZW@HeOk(deA0+9fP8^r6T
z9;r!1spUv=JPZsB5J6~Q!9yD2gpksr?9Ac}u#OUt4Z%*%!APMGPmLgbPN38X@>wba
zC=sSGfFd-Ci6JN$?2u%T8Wsiy22i{@gVeqOg%1Nm2_r)d14A<tLlzS#{uxV{8A@0f
zni&~D3|1I}4aQ)HF*slhP8fp=#^8oAcwh`(7=sVS;0H0%c|dl@3ow)jg6yt^SSrL&
zBFs?3$k5EpP|E~%h7c$TK}DEBQdy!5HB1aO%pi9&)-W(+2{2@dfg~WJ>C7P0!4l#i
zgF!hG5)6JC5+HB0f&!qlAhjq6lt4;27#JAh<1_OzOXA~$Kmip5N<2ZJOdbRZvmlWA
zAW%{cVrO7r2m+}O;smik2{;Ip@`6B-83c-?5|EMtaP}w;;sYrH1$ha`2)D$X;?xq5
zi6KR$so->2oLUl}3(5=eP%R}OYf>vpQu9*4dWuquQ%f{JdcYcsQ*+WvKn7-jQxjBI
z2`G8y<fmsQC+5VX%7`#9FqCB$m!eB(fJ!njQC!Brz@T4Hlv$QolB!>pSfrnppOcbW
zRIHzrqF<hrl$UFoTWn;QWS(A?ZeeOso|9E&W&i@|dHNyx1(^l9nR&$}i8(pCZe<>x
z#sMH9Fpe)v%}dEI(ofDvEJ{f&(JxL)E=~s(9uTkU6;uX+vWE^RGC%|aqc9UEBL-yU
zWE5iJWMpIH0m}(6@-uQVX@DXJ8gY4vxvBB-;KC#x6quzssqyh(qrv_|5CiE`P(srN
z`4p72*ckmZq(BJ~<bP1`6sMLTg-j4AZooOdI0-5X2{Lfv1gD#v#Ju!mXjuwQKlqbu
z2`C|g^rVA|L5K!;Dh3zsAju?HnFmn-Pu$=H2U1Xyk(ddQ10{E`3qit=6bF$2rOgtM
zEJP6MZjkjQpdbJ#FDV6=YY_FIECbGkh-d<{1~9I`$;u`-KczG$)lL=^XP{^jU=(1~
PV-{l+V*;@R7zLOCQn=Q1

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/sjisprober.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/sjisprober.py
new file mode 100644
index 0000000..9e29623
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/sjisprober.py
@@ -0,0 +1,92 @@
+######################## BEGIN LICENSE BLOCK ########################
+# The Original Code is mozilla.org code.
+#
+# The Initial Developer of the Original Code is
+# Netscape Communications Corporation.
+# Portions created by the Initial Developer are Copyright (C) 1998
+# the Initial Developer. All Rights Reserved.
+#
+# Contributor(s):
+#   Mark Pilgrim - port to Python
+#
+# This library is free software; you can redistribute it and/or
+# modify it under the terms of the GNU Lesser General Public
+# License as published by the Free Software Foundation; either
+# version 2.1 of the License, or (at your option) any later version.
+#
+# This library is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+# Lesser General Public License for more details.
+#
+# You should have received a copy of the GNU Lesser General Public
+# License along with this library; if not, write to the Free Software
+# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
+# 02110-1301  USA
+######################### END LICENSE BLOCK #########################
+
+from .mbcharsetprober import MultiByteCharSetProber
+from .codingstatemachine import CodingStateMachine
+from .chardistribution import SJISDistributionAnalysis
+from .jpcntx import SJISContextAnalysis
+from .mbcssm import SJIS_SM_MODEL
+from .enums import ProbingState, MachineState
+
+
+class SJISProber(MultiByteCharSetProber):
+    def __init__(self):
+        super(SJISProber, self).__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()
+        self.context_analyzer.reset()
+
+    @property
+    def charset_name(self):
+        return self.context_analyzer.charset_name
+
+    @property
+    def language(self):
+        return "Japanese"
+
+    def feed(self, byte_str):
+        for i in range(len(byte_str)):
+            coding_state = self.coding_sm.next_state(byte_str[i])
+            if coding_state == MachineState.ERROR:
+                self.logger.debug('%s %s prober hit error at byte %s',
+                                  self.charset_name, self.language, i)
+                self._state = ProbingState.NOT_ME
+                break
+            elif coding_state == MachineState.ITS_ME:
+                self._state = ProbingState.FOUND_IT
+                break
+            elif 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.distribution_analyzer.feed(self._last_char, char_len)
+                else:
+                    self.context_analyzer.feed(byte_str[i + 1 - char_len:i + 3
+                                                        - char_len], char_len)
+                    self.distribution_analyzer.feed(byte_str[i - 1:i + 1],
+                                                    char_len)
+
+        self._last_char[0] = byte_str[-1]
+
+        if self.state == ProbingState.DETECTING:
+            if (self.context_analyzer.got_enough_data() and
+               (self.get_confidence() > self.SHORTCUT_THRESHOLD)):
+                self._state = ProbingState.FOUND_IT
+
+        return self.state
+
+    def get_confidence(self):
+        context_conf = self.context_analyzer.get_confidence()
+        distrib_conf = self.distribution_analyzer.get_confidence()
+        return max(context_conf, distrib_conf)
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/sjisprober.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/sjisprober.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..a0feb586f60cdf5d92a799c4276bd9cbbd529333
GIT binary patch
literal 3443
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
JFv6f1GXRUU{i*-}

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/universaldetector.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/universaldetector.py
new file mode 100644
index 0000000..7b4e92d
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/universaldetector.py
@@ -0,0 +1,286 @@
+######################## BEGIN LICENSE BLOCK ########################
+# The Original Code is Mozilla Universal charset detector code.
+#
+# The Initial Developer of the Original Code is
+# Netscape Communications Corporation.
+# Portions created by the Initial Developer are Copyright (C) 2001
+# the Initial Developer. All Rights Reserved.
+#
+# Contributor(s):
+#   Mark Pilgrim - port to Python
+#   Shy Shalom - original C code
+#
+# This library is free software; you can redistribute it and/or
+# modify it under the terms of the GNU Lesser General Public
+# License as published by the Free Software Foundation; either
+# version 2.1 of the License, or (at your option) any later version.
+#
+# This library is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+# Lesser General Public License for more details.
+#
+# You should have received a copy of the GNU Lesser General Public
+# License along with this library; if not, write to the Free Software
+# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
+# 02110-1301  USA
+######################### END LICENSE BLOCK #########################
+"""
+Module containing the UniversalDetector detector class, which is the primary
+class a user of ``chardet`` should use.
+
+:author: Mark Pilgrim (initial port to Python)
+:author: Shy Shalom (original C code)
+:author: Dan Blanchard (major refactoring for 3.0)
+:author: Ian Cordasco
+"""
+
+
+import codecs
+import logging
+import re
+
+from .charsetgroupprober import CharSetGroupProber
+from .enums import InputState, LanguageFilter, ProbingState
+from .escprober import EscCharSetProber
+from .latin1prober import Latin1Prober
+from .mbcsgroupprober import MBCSGroupProber
+from .sbcsgroupprober import SBCSGroupProber
+
+
+class UniversalDetector(object):
+    """
+    The ``UniversalDetector`` class underlies the ``chardet.detect`` function
+    and coordinates all of the different charset probers.
+
+    To get a ``dict`` containing an encoding and its confidence, you can simply
+    run:
+
+    .. code::
+
+            u = UniversalDetector()
+            u.feed(some_bytes)
+            u.close()
+            detected = u.result
+
+    """
+
+    MINIMUM_THRESHOLD = 0.20
+    HIGH_BYTE_DETECTOR = re.compile(b'[\x80-\xFF]')
+    ESC_DETECTOR = re.compile(b'(\033|~{)')
+    WIN_BYTE_DETECTOR = re.compile(b'[\x80-\x9F]')
+    ISO_WIN_MAP = {'iso-8859-1': 'Windows-1252',
+                   'iso-8859-2': 'Windows-1250',
+                   'iso-8859-5': 'Windows-1251',
+                   'iso-8859-6': 'Windows-1256',
+                   'iso-8859-7': 'Windows-1253',
+                   'iso-8859-8': 'Windows-1255',
+                   'iso-8859-9': 'Windows-1254',
+                   'iso-8859-13': 'Windows-1257'}
+
+    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
+        self.lang_filter = lang_filter
+        self.logger = logging.getLogger(__name__)
+        self._has_win_bytes = None
+        self.reset()
+
+    def reset(self):
+        """
+        Reset the UniversalDetector and all of its probers back to their
+        initial states.  This is called by ``__init__``, so you only need to
+        call this directly in between analyses of different documents.
+        """
+        self.result = {'encoding': None, 'confidence': 0.0, 'language': None}
+        self.done = False
+        self._got_data = False
+        self._has_win_bytes = False
+        self._input_state = InputState.PURE_ASCII
+        self._last_char = b''
+        if self._esc_charset_prober:
+            self._esc_charset_prober.reset()
+        for prober in self._charset_probers:
+            prober.reset()
+
+    def feed(self, byte_str):
+        """
+        Takes a chunk of a document and feeds it through all of the relevant
+        charset probers.
+
+        After calling ``feed``, you can check the value of the ``done``
+        attribute to see if you need to continue feeding the
+        ``UniversalDetector`` more data, or if it has made a prediction
+        (in the ``result`` attribute).
+
+        .. note::
+           You should always call ``close`` when you're done feeding in your
+           document if ``done`` is not already ``True``.
+        """
+        if self.done:
+            return
+
+        if not len(byte_str):
+            return
+
+        if not isinstance(byte_str, bytearray):
+            byte_str = bytearray(byte_str)
+
+        # First check for known BOMs, since these are guaranteed to be correct
+        if not self._got_data:
+            # If the data starts with BOM, we know it is UTF
+            if byte_str.startswith(codecs.BOM_UTF8):
+                # EF BB BF  UTF-8 with BOM
+                self.result = {'encoding': "UTF-8-SIG",
+                               'confidence': 1.0,
+                               'language': ''}
+            elif byte_str.startswith((codecs.BOM_UTF32_LE,
+                                      codecs.BOM_UTF32_BE)):
+                # FF FE 00 00  UTF-32, little-endian BOM
+                # 00 00 FE FF  UTF-32, big-endian BOM
+                self.result = {'encoding': "UTF-32",
+                               'confidence': 1.0,
+                               'language': ''}
+            elif byte_str.startswith(b'\xFE\xFF\x00\x00'):
+                # FE FF 00 00  UCS-4, unusual octet order BOM (3412)
+                self.result = {'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': ''}
+            elif byte_str.startswith((codecs.BOM_LE, codecs.BOM_BE)):
+                # FF FE  UTF-16, little endian BOM
+                # FE FF  UTF-16, big endian BOM
+                self.result = {'encoding': "UTF-16",
+                               'confidence': 1.0,
+                               'language': ''}
+
+            self._got_data = True
+            if self.result['encoding'] is not None:
+                self.done = True
+                return
+
+        # If none of those matched and we've only see ASCII so far, check
+        # for high bytes and escape sequences
+        if self._input_state == InputState.PURE_ASCII:
+            if self.HIGH_BYTE_DETECTOR.search(byte_str):
+                self._input_state = InputState.HIGH_BYTE
+            elif self._input_state == InputState.PURE_ASCII and \
+                    self.ESC_DETECTOR.search(self._last_char + byte_str):
+                self._input_state = InputState.ESC_ASCII
+
+        self._last_char = byte_str[-1:]
+
+        # If we've seen escape sequences, use the EscCharSetProber, which
+        # uses a simple state machine to check for known escape sequences in
+        # HZ and ISO-2022 encodings, since those are the only encodings that
+        # use such sequences.
+        if self._input_state == InputState.ESC_ASCII:
+            if not self._esc_charset_prober:
+                self._esc_charset_prober = EscCharSetProber(self.lang_filter)
+            if self._esc_charset_prober.feed(byte_str) == ProbingState.FOUND_IT:
+                self.result = {'encoding':
+                               self._esc_charset_prober.charset_name,
+                               'confidence':
+                               self._esc_charset_prober.get_confidence(),
+                               'language':
+                               self._esc_charset_prober.language}
+                self.done = True
+        # If we've seen high bytes (i.e., those with values greater than 127),
+        # we need to do more complicated checks using all our multi-byte and
+        # single-byte probers that are left.  The single-byte probers
+        # use character bigram distributions to determine the encoding, whereas
+        # the multi-byte probers use a combination of character unigram and
+        # bigram distributions.
+        elif self._input_state == InputState.HIGH_BYTE:
+            if not self._charset_probers:
+                self._charset_probers = [MBCSGroupProber(self.lang_filter)]
+                # If we're checking non-CJK encodings, use single-byte prober
+                if self.lang_filter & LanguageFilter.NON_CJK:
+                    self._charset_probers.append(SBCSGroupProber())
+                self._charset_probers.append(Latin1Prober())
+            for prober in self._charset_probers:
+                if prober.feed(byte_str) == ProbingState.FOUND_IT:
+                    self.result = {'encoding': prober.charset_name,
+                                   'confidence': prober.get_confidence(),
+                                   'language': prober.language}
+                    self.done = True
+                    break
+            if self.WIN_BYTE_DETECTOR.search(byte_str):
+                self._has_win_bytes = True
+
+    def close(self):
+        """
+        Stop analyzing the current document and come up with a final
+        prediction.
+
+        :returns:  The ``result`` attribute, a ``dict`` with the keys
+                   `encoding`, `confidence`, and `language`.
+        """
+        # Don't bother with checks if we're already done
+        if self.done:
+            return self.result
+        self.done = True
+
+        if not self._got_data:
+            self.logger.debug('no data received!')
+
+        # Default to ASCII if it is all we've seen so far
+        elif self._input_state == InputState.PURE_ASCII:
+            self.result = {'encoding': 'ascii',
+                           'confidence': 1.0,
+                           'language': ''}
+
+        # If we have seen non-ASCII, return the best that met MINIMUM_THRESHOLD
+        elif self._input_state == InputState.HIGH_BYTE:
+            prober_confidence = None
+            max_prober_confidence = 0.0
+            max_prober = None
+            for prober in self._charset_probers:
+                if not prober:
+                    continue
+                prober_confidence = prober.get_confidence()
+                if prober_confidence > max_prober_confidence:
+                    max_prober_confidence = prober_confidence
+                    max_prober = prober
+            if max_prober and (max_prober_confidence > self.MINIMUM_THRESHOLD):
+                charset_name = max_prober.charset_name
+                lower_charset_name = max_prober.charset_name.lower()
+                confidence = max_prober.get_confidence()
+                # Use Windows encoding name instead of ISO-8859 if we saw any
+                # extra Windows-specific bytes
+                if lower_charset_name.startswith('iso-8859'):
+                    if self._has_win_bytes:
+                        charset_name = self.ISO_WIN_MAP.get(lower_charset_name,
+                                                            charset_name)
+                self.result = {'encoding': charset_name,
+                               'confidence': confidence,
+                               'language': max_prober.language}
+
+        # Log all prober confidences if none met MINIMUM_THRESHOLD
+        if self.logger.getEffectiveLevel() == logging.DEBUG:
+            if self.result['encoding'] is None:
+                self.logger.debug('no probers hit minimum threshold')
+                for group_prober in self._charset_probers:
+                    if not group_prober:
+                        continue
+                    if isinstance(group_prober, CharSetGroupProber):
+                        for prober in group_prober.probers:
+                            self.logger.debug('%s %s confidence = %s',
+                                              prober.charset_name,
+                                              prober.language,
+                                              prober.get_confidence())
+                    else:
+                        self.logger.debug('%s %s confidence = %s',
+                                          prober.charset_name,
+                                          prober.language,
+                                          prober.get_confidence())
+        return self.result
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/universaldetector.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/universaldetector.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..92313baddfe4ac372e1b768d3b316e9d9e7a2c0e
GIT binary patch
literal 7403
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%0AZN@o1Xs~)3?=LgSsdW1Dg)g9fOZNn+AE9<
zdH=wsK(ugzwWKko@PL|7DIB2s2gGJ(sBi%*<7RM)wPdJeVW?qYC|<!(I1OC&vM^-v
zfNC&EkD!K$A)AGvXd0*{2Gw6I47JQ4m4(w7!fTiriqaTsn81edg4Lxl)-W?<@iEl0
zGC&wv{9v=#z+8yA><l$*3|RsU&^DDl*q4F~MGyw0MZ(5V!wPB#*0M4b+JmZBPzA{f
zsqopsZ9I_iBJfI{k)bdRqzqIUvM^+cf-Ef&W5|LuH_X9xHX}&8WC{;MHU~oyL<kbx
zT%dZBv0?()AD}>KVyNX{sNrBJ-pg3H8f0vV1c+NA335^q2UA5Hh?^zF;1a714nGEl
zEQnFups>v11Ct_P671(@76!(`YmDKAtHGWntadeHc%eBHv{}K(5De~Np!URqOY#dK
zU7IRsb*GSAS_B@aLaE1-^K(-bN(&S~rKLimLK<ku6kaVM>Nup@%c>}~q_iln*b3As
z0}ZlaR(3kb!(CvLL6vrPYGpCpXiz-}#R;%JRf3K}0-~Hs&;d6z5@4Mvq>8Fokb!|A
zFCSbxD-@+Br)HL=rYM3tR*A*QnVEQNE_lza7*t%rMrVpa#Z_KDZ17GYBeO&yH#09Y
zw=@^j#7QmA$j?bB7G+>yP%TzaMINP7uvJhk_R|1YkD$s5T(<=2fXY`;jT8jZ19n<U
zYEo%Bq(cX<E`szy>OjQ-q(n9aRUshX`Fi?!`iA<(hj;|J27CDXxCEJiq(EhHPJVf6
zQIIM~BdEd!52bhp`^STdXJ5wvaAldES^_TT!R2;(YKd!FT557hW?8CFYFTPd5U7#@
zyUE4XDbzhk8DtiyWCYg(kiKNG2G~^+AX`BWf`}s3BPAe@<tA1@2a1qoxEL515HjGJ
z0OEX*y<q2q2Z4%HOTd*BxM=~dy3#?z=THN|)drXt(9SG4n83rKcR&?L0w|a`IT_g*
zIYHF{vk)V=%3u~^WCKG1Fv-Kn!^p<S%P7jo$;i*h!_3df394SeYQ>l(7=;-@y<m_I
zesIMDVu>(;^sq6CGirdE070O>Gq^buAD;`Jg^7;`M^AiwN`7*De2@(&W<Zs9Q7TwG
zIX|}`Gbc4j7ZjNWAi@Gf*ntR;GH|+Z^zjJ-4U~hs=s}=rF~|d@o*wuB4+3RNV^CNt
zF)%Q&@v||pG4g{UD5TjLVUUZ7pO;gRGgku?P(fZGZ>oU^P#O#J1_cg?1#Jw06BZ;1
z2Z3S`9IL5$rMbo6Q5SF{2-2JarTWz3WT;wDqYIoebHFn$P*G4WECIFqa+8vak&Om5
zsK64%XcC~x9^A0XPs&P7E&=-y9MlM6U{g6L&}|^;%uWRq_@Gc_V+JK;9wq@s8E}FX
IU=&~m039r^X8-^I

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/utf8prober.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/utf8prober.py
new file mode 100644
index 0000000..6c3196c
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/utf8prober.py
@@ -0,0 +1,82 @@
+######################## BEGIN LICENSE BLOCK ########################
+# The Original Code is mozilla.org code.
+#
+# The Initial Developer of the Original Code is
+# Netscape Communications Corporation.
+# Portions created by the Initial Developer are Copyright (C) 1998
+# the Initial Developer. All Rights Reserved.
+#
+# Contributor(s):
+#   Mark Pilgrim - port to Python
+#
+# This library is free software; you can redistribute it and/or
+# modify it under the terms of the GNU Lesser General Public
+# License as published by the Free Software Foundation; either
+# version 2.1 of the License, or (at your option) any later version.
+#
+# This library is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+# Lesser General Public License for more details.
+#
+# You should have received a copy of the GNU Lesser General Public
+# License along with this library; if not, write to the Free Software
+# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
+# 02110-1301  USA
+######################### END LICENSE BLOCK #########################
+
+from .charsetprober import CharSetProber
+from .enums import ProbingState, MachineState
+from .codingstatemachine import CodingStateMachine
+from .mbcssm import UTF8_SM_MODEL
+
+
+
+class UTF8Prober(CharSetProber):
+    ONE_CHAR_PROB = 0.5
+
+    def __init__(self):
+        super(UTF8Prober, self).__init__()
+        self.coding_sm = CodingStateMachine(UTF8_SM_MODEL)
+        self._num_mb_chars = None
+        self.reset()
+
+    def reset(self):
+        super(UTF8Prober, self).reset()
+        self.coding_sm.reset()
+        self._num_mb_chars = 0
+
+    @property
+    def charset_name(self):
+        return "utf-8"
+
+    @property
+    def language(self):
+        return ""
+
+    def feed(self, byte_str):
+        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:
+                self._state = ProbingState.FOUND_IT
+                break
+            elif coding_state == MachineState.START:
+                if self.coding_sm.get_current_charlen() >= 2:
+                    self._num_mb_chars += 1
+
+        if self.state == ProbingState.DETECTING:
+            if self.get_confidence() > self.SHORTCUT_THRESHOLD:
+                self._state = ProbingState.FOUND_IT
+
+        return self.state
+
+    def get_confidence(self):
+        unlike = 0.99
+        if self._num_mb_chars < 6:
+            unlike *= self.ONE_CHAR_PROB ** self._num_mb_chars
+            return 1.0 - unlike
+        else:
+            return unlike
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/utf8prober.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/utf8prober.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..3d9e44394da32dc5787217e36c6e5de7dd10e218
GIT binary patch
literal 2892
zcmZSn%**AGdLky70ScHI7#JKF7#NBZ7#J8*7#LC*8FCmHav2$-7#SErd?tn*CWc&Q
zhA3u+To#5X7KkV_Lk=rLE*nD>8-&loki*W9%fS%E!N8cp%8<&)kjBW6!p6|Tz|hRV
z5E;eEkiyOotii#+z>vwvz`&pZB1(7}7#N&05{rUUO9G1WlTwQ`m>3usN_ZF;7(o2Y
zy!7Cb#FA97fNx@QMrK|rSOB712&6kd1*QtB03ru6IW)x0B0ktR-q+v7)u)7ufq?-e
z0x~$Y2=0H7g-#&<2QV-&q%wfKox;En#RLk776y>7Q<y-$h+<(#Wo1ZV2C<tNLH-7D
zSzugth7?v1JBkD9>nKi!pkNJl1_p+7NJu}hPX_rJgh65M46@S_<XZ-Y5=Mp^28L!P
zhAbvfXfc*BGnB9}G=oLsSwXQ<!@v;F4pNlG0alU1zz_`fsGkNW$P8AHX{80JML{4|
z2`HH3<1_OzOXA~$K(+<3fK+iZFfb&811!Ecw*(~Qm!Fpkj)nNV(%ksmr1<2F#G>L7
zkRe5>#i=D=JHRT7Q*+WZKt2Hz#f1zE4EhB{nPrJ3srqG!Mfz#^IVq_{#rjDp`sGPU
zdAX*!#YTon=IK@G7N!>EIayU^1|X20ryrtUkXfLcnO9trn3JRHR_5Vp8~_pm<M^`F
zyp;SReULj+QcLtpOVTU~z)3@|pfU&)oN6Gif;`B;D9p&u$jOKqthyl2Vg_ps149-w
zER0haLBSc%0t($=aI*8u1bYwU_aHU~1_p3Y262N}AnSra2?!h>L7?;r4hAqWKw$xL
zm<}i`KyC$v1ur5bK#2^Tz(8@F!pH#iU@^#Vr6p;)7GQ@D9?z73LKGC`#i=Fnd5O8H
zh9HlDvL*u)JbH0>sstQsU;?CKP(%(m1Lh>=rI#kAr<x-91>_}AoPaPmf^IP|FjP!u
zs9|JqiS1{oWdbG2ECz-wMur+DPzg}W%uvJ3P{IUCx!Ft%MRuT)A&V8HES`-appYFV
z&CURljs;6|U`lg>r6ENK149-Us1!+IWXNV^D4GUR&635<kix`Z&J@qhP&kdDkR61=
zK{<v8Y$PvO|7DQUEIyECkQ6^dHVZ@1Wv~L6orRYf@)*F%co>2;KxL0#Cdk*2QeOa;
zo500!UTQ^2d@-nm4+1Fx7dx&&LH<EOpqMNHC2T+cka%BLFcYE@%=8Qi28n{QrJH}K
zpG&-F2v~D)h+|Mli7=?pO)ZH}E-flb%_{+yX*sER;0z2_2DY+<lYxQ3#Wlp$ImFY?
zy@U^@DL*eQGbJ@IIkf~-zXW^u2ZcC?hQx<>1i1!#`1`nMfZ`6E%D}OlR9TW5UtCgD
z0&;RPBq2kKSdhmc84Z*=2d0<+m)&WpsVShUrdST-5Jp}`Ax3^i9!3^8Dat6xB*ZAn
zC<MuEpvVBl95{u7G^Q{z)G~r2l>wAWvKbhP3_)oYln7wr!j`p+p!%_fkwGH3hLIr{
zTt|Td%P)PM`@<@cb?@ynK~V~=4?oz0OI=8;@G>wk`1`rWJ9{_=#RmlWJ3-_?#R53O
zOY?Fvvr`8;FoUER7#Ms&*_jI*kZg?nj3SI2Od23AI5otBORxBNaPp3i&&^LM%}I@q
z4^jZ7dr<8Ku1~;93ySg!Qj1C|gFt={;s+^^2N57U5FQ1y1}5o%>px|XZ$Wv3jggIs
zlZ}&=pM{@=Q`isUWsuXM#Wtjp4g!S>IFF^~mF5<M^D!iEgEAAO?E%hxxscWzxN!oG
s;oPL;;^JIzI|Xbp*y9LdV1fV~Q8tiRw37h^1*pgoU=(8%U=&~h0Gv#KCIA2c

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/version.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/version.py
new file mode 100644
index 0000000..bb2a34a
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/version.py
@@ -0,0 +1,9 @@
+"""
+This module exists only to simplify retrieving the version number of chardet
+from within setup.py and from chardet subpackages.
+
+:author: Dan Blanchard (dan.blanchard@gmail.com)
+"""
+
+__version__ = "3.0.4"
+VERSION = __version__.split('.')
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/version.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/chardet/version.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..d78ea1a4e5ed42ea42d20628fdd4e5c97f27663b
GIT binary patch
literal 478
zcmZSn%**AGdLky70ScHH7#JKF7#ND>85kH+7#N}$7*ZG+q8J%c85y#e7*d!Rni(0Q
zm>E)-8G<!fKngcAFfee1WMmdA<mRW8=A<g5R%8~J6f5NC<y0z^<SP_s<`(2+rd28w
zrIr+Brj}*qr7M(Vq$-r978Pga=PBfs<|d^UDdeXqBxfWRrKFZ{r4{ApDwJoIWMt+k
z6sMMy7U&gJDkSEmD1arPsuYS#lL``(vlG)(i}kp;tP)F0GV+V86kHPX6r6Gr^T5g!
zG*S}t^pap)hxFXU%pASs{9H}0VpawQ24g(~J(Chf1_lN_Kd^5~*cliY;^R~DljGw{
zxWR0wJLBU^Kst&GaxzQ6s={1@f<68HG(Z7|Ad2%C7#Q>miZaU*OH%dA5{vZH@^eyB
zi;DG=QuND{lJas*bBm1(lg!hr(k)Ca%5$=+%nU#vJx@PGzaX<fH#4ueBrzvP*R9OM
x(>MSm1jg}Ysd*{+MfzZWrIzSJouyY$S;E1<z+jUL4tzT{P?Uh;g^h`g5da@Qhd2NL

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/colorama/__init__.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/colorama/__init__.py
new file mode 100644
index 0000000..2a3bf47
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/colorama/__init__.py
@@ -0,0 +1,6 @@
+# Copyright Jonathan Hartley 2013. BSD 3-Clause license, see LICENSE file.
+from .initialise import init, deinit, reinit, colorama_text
+from .ansi import Fore, Back, Style, Cursor
+from .ansitowin32 import AnsiToWin32
+
+__version__ = '0.4.1'
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/colorama/__init__.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/colorama/__init__.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..8f6de85751b81573d80509f878a790c8ab553d63
GIT binary patch
literal 530
zcmZSn%**AGdLky70ScHH7#JKF7#ND<7#J8*7#LC*8FCmHav2$-7#VVz7^0XMa+w*T
zm>F_e7@}Ah7(ptS7;;z{a@iQ7*cfuz8KT%3ayb~HI2dv{8KO8LDwr8^xEOM|8KSru
z7*kjnqIeimSQ&yf*cccXG8q{d7&KTI7#K=GL}p%QNeM_iB^Ayrf-rd*7#NcCbMlK4
za}(oBQY%Ujy4>=MQo-7t5|gt_SQ!`?f=eoMQo#l}mlhT07ioa3DdA>dU~tSU&J4*9
z&&)G6Dh8=E&@<69^wR*DUcv=(P+n$9W@1ieacU4KNP<8bgFvAY#0+y}VqS4(5XiMb
zAOnIx&JAJ*NrKD=NtWc7gUk=&fC<LOm!%dJXXfX{$7_I0MG(aW3=9nV1x1-<i6yD}
zWr;=lY56%RsYS*5Nh$i}NlAIRrn$vNhDqk>Rp}O{7UelvRb~btke;U>qF<0%pqrUj
zT#}fRqw7}Y;b|NI5(4A+vedkk{33l=km<+AgF-YuUaz3C1mrNA-29Z%oK!oI--<zg
LP-0YK6kq}XVwrIH

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/colorama/ansi.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/colorama/ansi.py
new file mode 100644
index 0000000..7877658
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/colorama/ansi.py
@@ -0,0 +1,102 @@
+# Copyright Jonathan Hartley 2013. BSD 3-Clause license, see LICENSE file.
+'''
+This module generates ANSI character codes to printing colors to terminals.
+See: http://en.wikipedia.org/wiki/ANSI_escape_code
+'''
+
+CSI = '\033['
+OSC = '\033]'
+BEL = '\007'
+
+
+def code_to_chars(code):
+    return CSI + str(code) + 'm'
+
+def set_title(title):
+    return OSC + '2;' + title + BEL
+
+def clear_screen(mode=2):
+    return CSI + str(mode) + 'J'
+
+def clear_line(mode=2):
+    return CSI + str(mode) + 'K'
+
+
+class AnsiCodes(object):
+    def __init__(self):
+        # the subclasses declare class attributes which are numbers.
+        # Upon instantiation we define instance attributes, which are the same
+        # as the class attributes but wrapped with the ANSI escape sequence
+        for name in dir(self):
+            if not name.startswith('_'):
+                value = getattr(self, name)
+                setattr(self, name, code_to_chars(value))
+
+
+class AnsiCursor(object):
+    def UP(self, n=1):
+        return CSI + str(n) + 'A'
+    def DOWN(self, n=1):
+        return CSI + str(n) + 'B'
+    def FORWARD(self, n=1):
+        return CSI + str(n) + 'C'
+    def BACK(self, n=1):
+        return CSI + str(n) + 'D'
+    def POS(self, x=1, y=1):
+        return CSI + str(y) + ';' + str(x) + 'H'
+
+
+class AnsiFore(AnsiCodes):
+    BLACK           = 30
+    RED             = 31
+    GREEN           = 32
+    YELLOW          = 33
+    BLUE            = 34
+    MAGENTA         = 35
+    CYAN            = 36
+    WHITE           = 37
+    RESET           = 39
+
+    # These are fairly well supported, but not part of the standard.
+    LIGHTBLACK_EX   = 90
+    LIGHTRED_EX     = 91
+    LIGHTGREEN_EX   = 92
+    LIGHTYELLOW_EX  = 93
+    LIGHTBLUE_EX    = 94
+    LIGHTMAGENTA_EX = 95
+    LIGHTCYAN_EX    = 96
+    LIGHTWHITE_EX   = 97
+
+
+class AnsiBack(AnsiCodes):
+    BLACK           = 40
+    RED             = 41
+    GREEN           = 42
+    YELLOW          = 43
+    BLUE            = 44
+    MAGENTA         = 45
+    CYAN            = 46
+    WHITE           = 47
+    RESET           = 49
+
+    # These are fairly well supported, but not part of the standard.
+    LIGHTBLACK_EX   = 100
+    LIGHTRED_EX     = 101
+    LIGHTGREEN_EX   = 102
+    LIGHTYELLOW_EX  = 103
+    LIGHTBLUE_EX    = 104
+    LIGHTMAGENTA_EX = 105
+    LIGHTCYAN_EX    = 106
+    LIGHTWHITE_EX   = 107
+
+
+class AnsiStyle(AnsiCodes):
+    BRIGHT    = 1
+    DIM       = 2
+    NORMAL    = 22
+    RESET_ALL = 0
+
+Fore   = AnsiFore()
+Back   = AnsiBack()
+Style  = AnsiStyle()
+Cursor = AnsiCursor()
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/colorama/ansi.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/colorama/ansi.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..1b3f20f94f5a6017fb31351bf4ebc67410e002f6
GIT binary patch
literal 5184
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

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/colorama/ansitowin32.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/colorama/ansitowin32.py
new file mode 100644
index 0000000..359c92b
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/colorama/ansitowin32.py
@@ -0,0 +1,257 @@
+# Copyright Jonathan Hartley 2013. BSD 3-Clause license, see LICENSE file.
+import re
+import sys
+import os
+
+from .ansi import AnsiFore, AnsiBack, AnsiStyle, Style
+from .winterm import WinTerm, WinColor, WinStyle
+from .win32 import windll, winapi_test
+
+
+winterm = None
+if windll is not None:
+    winterm = WinTerm()
+
+
+class StreamWrapper(object):
+    '''
+    Wraps a stream (such as stdout), acting as a transparent proxy for all
+    attribute access apart from method 'write()', which is delegated to our
+    Converter instance.
+    '''
+    def __init__(self, wrapped, converter):
+        # double-underscore everything to prevent clashes with names of
+        # attributes on the wrapped stream object.
+        self.__wrapped = wrapped
+        self.__convertor = converter
+
+    def __getattr__(self, name):
+        return getattr(self.__wrapped, name)
+
+    def __enter__(self, *args, **kwargs):
+        # special method lookup bypasses __getattr__/__getattribute__, see
+        # https://stackoverflow.com/questions/12632894/why-doesnt-getattr-work-with-exit
+        # thus, contextlib magic methods are not proxied via __getattr__
+        return self.__wrapped.__enter__(*args, **kwargs)
+
+    def __exit__(self, *args, **kwargs):
+        return self.__wrapped.__exit__(*args, **kwargs)
+
+    def write(self, text):
+        self.__convertor.write(text)
+
+    def isatty(self):
+        stream = self.__wrapped
+        if 'PYCHARM_HOSTED' in os.environ:
+            if stream is not None and (stream is sys.__stdout__ or stream is sys.__stderr__):
+                return True
+        try:
+            stream_isatty = stream.isatty
+        except AttributeError:
+            return False
+        else:
+            return stream_isatty()
+
+    @property
+    def closed(self):
+        stream = self.__wrapped
+        try:
+            return stream.closed
+        except AttributeError:
+            return True
+
+
+class AnsiToWin32(object):
+    '''
+    Implements a 'write()' method which, on Windows, will strip ANSI character
+    sequences from the text, and if outputting to a tty, will convert them into
+    win32 function calls.
+    '''
+    ANSI_CSI_RE = re.compile('\001?\033\\[((?:\\d|;)*)([a-zA-Z])\002?')   # Control Sequence Introducer
+    ANSI_OSC_RE = re.compile('\001?\033\\]((?:.|;)*?)(\x07)\002?')        # Operating System Command
+
+    def __init__(self, wrapped, convert=None, strip=None, autoreset=False):
+        # The wrapped stream (normally sys.stdout or sys.stderr)
+        self.wrapped = wrapped
+
+        # should we reset colors to defaults after every .write()
+        self.autoreset = autoreset
+
+        # create the proxy wrapping our output stream
+        self.stream = StreamWrapper(wrapped, self)
+
+        on_windows = os.name == 'nt'
+        # We test if the WinAPI works, because even if we are on Windows
+        # we may be using a terminal that doesn't support the WinAPI
+        # (e.g. Cygwin Terminal). In this case it's up to the terminal
+        # to support the ANSI codes.
+        conversion_supported = on_windows and winapi_test()
+
+        # 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())
+        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()
+        self.convert = convert
+
+        # dict of ansi codes to win32 functions and parameters
+        self.win32_calls = self.get_win32_calls()
+
+        # are we wrapping stderr?
+        self.on_stderr = self.wrapped is sys.stderr
+
+    def should_wrap(self):
+        '''
+        True if this class is actually needed. If false, then the output
+        stream will not be affected, nor will win32 calls be issued, so
+        wrapping stdout is not actually required. This will generally be
+        False on non-Windows platforms, unless optional functionality like
+        autoreset has been requested using kwargs to init()
+        '''
+        return self.convert or self.strip or self.autoreset
+
+    def get_win32_calls(self):
+        if self.convert and winterm:
+            return {
+                AnsiStyle.RESET_ALL: (winterm.reset_all, ),
+                AnsiStyle.BRIGHT: (winterm.style, WinStyle.BRIGHT),
+                AnsiStyle.DIM: (winterm.style, WinStyle.NORMAL),
+                AnsiStyle.NORMAL: (winterm.style, WinStyle.NORMAL),
+                AnsiFore.BLACK: (winterm.fore, WinColor.BLACK),
+                AnsiFore.RED: (winterm.fore, WinColor.RED),
+                AnsiFore.GREEN: (winterm.fore, WinColor.GREEN),
+                AnsiFore.YELLOW: (winterm.fore, WinColor.YELLOW),
+                AnsiFore.BLUE: (winterm.fore, WinColor.BLUE),
+                AnsiFore.MAGENTA: (winterm.fore, WinColor.MAGENTA),
+                AnsiFore.CYAN: (winterm.fore, WinColor.CYAN),
+                AnsiFore.WHITE: (winterm.fore, WinColor.GREY),
+                AnsiFore.RESET: (winterm.fore, ),
+                AnsiFore.LIGHTBLACK_EX: (winterm.fore, WinColor.BLACK, True),
+                AnsiFore.LIGHTRED_EX: (winterm.fore, WinColor.RED, True),
+                AnsiFore.LIGHTGREEN_EX: (winterm.fore, WinColor.GREEN, True),
+                AnsiFore.LIGHTYELLOW_EX: (winterm.fore, WinColor.YELLOW, True),
+                AnsiFore.LIGHTBLUE_EX: (winterm.fore, WinColor.BLUE, True),
+                AnsiFore.LIGHTMAGENTA_EX: (winterm.fore, WinColor.MAGENTA, True),
+                AnsiFore.LIGHTCYAN_EX: (winterm.fore, WinColor.CYAN, True),
+                AnsiFore.LIGHTWHITE_EX: (winterm.fore, WinColor.GREY, True),
+                AnsiBack.BLACK: (winterm.back, WinColor.BLACK),
+                AnsiBack.RED: (winterm.back, WinColor.RED),
+                AnsiBack.GREEN: (winterm.back, WinColor.GREEN),
+                AnsiBack.YELLOW: (winterm.back, WinColor.YELLOW),
+                AnsiBack.BLUE: (winterm.back, WinColor.BLUE),
+                AnsiBack.MAGENTA: (winterm.back, WinColor.MAGENTA),
+                AnsiBack.CYAN: (winterm.back, WinColor.CYAN),
+                AnsiBack.WHITE: (winterm.back, WinColor.GREY),
+                AnsiBack.RESET: (winterm.back, ),
+                AnsiBack.LIGHTBLACK_EX: (winterm.back, WinColor.BLACK, True),
+                AnsiBack.LIGHTRED_EX: (winterm.back, WinColor.RED, True),
+                AnsiBack.LIGHTGREEN_EX: (winterm.back, WinColor.GREEN, True),
+                AnsiBack.LIGHTYELLOW_EX: (winterm.back, WinColor.YELLOW, True),
+                AnsiBack.LIGHTBLUE_EX: (winterm.back, WinColor.BLUE, True),
+                AnsiBack.LIGHTMAGENTA_EX: (winterm.back, WinColor.MAGENTA, True),
+                AnsiBack.LIGHTCYAN_EX: (winterm.back, WinColor.CYAN, True),
+                AnsiBack.LIGHTWHITE_EX: (winterm.back, WinColor.GREY, True),
+            }
+        return dict()
+
+    def write(self, text):
+        if self.strip or self.convert:
+            self.write_and_convert(text)
+        else:
+            self.wrapped.write(text)
+            self.wrapped.flush()
+        if self.autoreset:
+            self.reset_all()
+
+
+    def reset_all(self):
+        if self.convert:
+            self.call_win32('m', (0,))
+        elif not self.strip and not self.stream.closed:
+            self.wrapped.write(Style.RESET_ALL)
+
+
+    def write_and_convert(self, text):
+        '''
+        Write the given text to our wrapped stream, stripping any ANSI
+        sequences from the text, and optionally converting them into win32
+        calls.
+        '''
+        cursor = 0
+        text = self.convert_osc(text)
+        for match in self.ANSI_CSI_RE.finditer(text):
+            start, end = match.span()
+            self.write_plain_text(text, cursor, start)
+            self.convert_ansi(*match.groups())
+            cursor = end
+        self.write_plain_text(text, cursor, len(text))
+
+
+    def write_plain_text(self, text, start, end):
+        if start < end:
+            self.wrapped.write(text[start:end])
+            self.wrapped.flush()
+
+
+    def convert_ansi(self, paramstring, command):
+        if self.convert:
+            params = self.extract_params(command, paramstring)
+            self.call_win32(command, params)
+
+
+    def extract_params(self, command, paramstring):
+        if command in 'Hf':
+            params = tuple(int(p) if len(p) != 0 else 1 for p in paramstring.split(';'))
+            while len(params) < 2:
+                # defaults:
+                params = params + (1,)
+        else:
+            params = tuple(int(p) for p in paramstring.split(';') if len(p) != 0)
+            if len(params) == 0:
+                # defaults:
+                if command in 'JKm':
+                    params = (0,)
+                elif command in 'ABCD':
+                    params = (1,)
+
+        return params
+
+
+    def call_win32(self, command, params):
+        if command == 'm':
+            for param in params:
+                if param in self.win32_calls:
+                    func_args = self.win32_calls[param]
+                    func = func_args[0]
+                    args = func_args[1:]
+                    kwargs = dict(on_stderr=self.on_stderr)
+                    func(*args, **kwargs)
+        elif command in 'J':
+            winterm.erase_screen(params[0], on_stderr=self.on_stderr)
+        elif command in 'K':
+            winterm.erase_line(params[0], on_stderr=self.on_stderr)
+        elif command in 'Hf':     # cursor position - absolute
+            winterm.set_cursor_position(params, on_stderr=self.on_stderr)
+        elif command in 'ABCD':   # cursor position - relative
+            n = params[0]
+            # A - up, B - down, C - forward, D - back
+            x, y = {'A': (0, -n), 'B': (0, n), 'C': (n, 0), 'D': (-n, 0)}[command]
+            winterm.cursor_adjust(x, y, on_stderr=self.on_stderr)
+
+
+    def convert_osc(self, text):
+        for match in self.ANSI_OSC_RE.finditer(text):
+            start, end = match.span()
+            text = text[:start] + text[end:]
+            paramstring, command = match.groups()
+            if command in '\x07':       # \x07 = BEL
+                params = paramstring.split(";")
+                # 0 - change title and icon (we will only change title)
+                # 1 - change icon (we don't support this)
+                # 2 - change title
+                if params[0] in '02':
+                    winterm.set_title(params[1])
+        return text
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/colorama/ansitowin32.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/colorama/ansitowin32.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..2c10ec42c4cc547296649038016de6a53ce7f0e8
GIT binary patch
literal 11113
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

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/colorama/initialise.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/colorama/initialise.py
new file mode 100644
index 0000000..430d066
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/colorama/initialise.py
@@ -0,0 +1,80 @@
+# Copyright Jonathan Hartley 2013. BSD 3-Clause license, see LICENSE file.
+import atexit
+import contextlib
+import sys
+
+from .ansitowin32 import AnsiToWin32
+
+
+orig_stdout = None
+orig_stderr = None
+
+wrapped_stdout = None
+wrapped_stderr = None
+
+atexit_done = False
+
+
+def reset_all():
+    if AnsiToWin32 is not None:    # Issue #74: objects might become None at exit
+        AnsiToWin32(orig_stdout).reset_all()
+
+
+def init(autoreset=False, convert=None, strip=None, wrap=True):
+
+    if not wrap and any([autoreset, convert, strip]):
+        raise ValueError('wrap=False conflicts with any other arg=True')
+
+    global wrapped_stdout, wrapped_stderr
+    global orig_stdout, orig_stderr
+
+    orig_stdout = sys.stdout
+    orig_stderr = sys.stderr
+
+    if sys.stdout is None:
+        wrapped_stdout = None
+    else:
+        sys.stdout = wrapped_stdout = \
+            wrap_stream(orig_stdout, convert, strip, autoreset, wrap)
+    if sys.stderr is None:
+        wrapped_stderr = None
+    else:
+        sys.stderr = wrapped_stderr = \
+            wrap_stream(orig_stderr, convert, strip, autoreset, wrap)
+
+    global atexit_done
+    if not atexit_done:
+        atexit.register(reset_all)
+        atexit_done = True
+
+
+def deinit():
+    if orig_stdout is not None:
+        sys.stdout = orig_stdout
+    if orig_stderr is not None:
+        sys.stderr = orig_stderr
+
+
+@contextlib.contextmanager
+def colorama_text(*args, **kwargs):
+    init(*args, **kwargs)
+    try:
+        yield
+    finally:
+        deinit()
+
+
+def reinit():
+    if wrapped_stdout is not None:
+        sys.stdout = wrapped_stdout
+    if wrapped_stderr is not None:
+        sys.stderr = wrapped_stderr
+
+
+def wrap_stream(stream, convert, strip, autoreset, wrap):
+    if wrap:
+        wrapper = AnsiToWin32(stream,
+            convert=convert, strip=strip, autoreset=autoreset)
+        if wrapper.should_wrap():
+            stream = wrapper.stream
+    return stream
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/colorama/initialise.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/colorama/initialise.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..365af227f1798edfcf5ed937154cc45152a5c713
GIT binary patch
literal 2683
zcmZSn%**AGdLky70SZ_d7#JKF7#NBdGB7ZtFfgPrGUPBYM8VmN3{i|QaVCZ+CWaIy
zh7@Lo9A<`G7KSJm2F4UdhD0`ywnTO?$pI!g8B)0z61f>tSQuIu7@~MU+!RKTR4Ok+
z3M)ek3quqiLkb&MmY*S&ks(WfA%z{pZDwSM5@bl>0I{Ql7*aUF3}KMoU=1z?28PW4
z|NsB@%VcC=V9)>&CEN@Q432rlnIZY%nR&)WaKAAzFfcfS{HDynz)%AAQZ^?;kvxc9
z!o<+b$dJX%(9FQVm<N^%2Ak%m!NS165CjUI5)jKTKQ9$*Lw-?adVFz7N`7fc2`2*s
zLs4pRYDs)zPL2jhErKX6Vqjp<FDS|^ODsv%FH0=aPs`6qNi8bYPfF1*PfE(mHO(zH
zGE6d0uS&NtwJ6WYsxmVGf%H865dDJ80^Q8K;*!Li99_3E4^QI&kPsNhm!;;V<QM5D
z=jY@XCFUmTXXa&=WG3ch7N_bJR0c6KFfa&#d<$|l10xS(GKc}fY_M=R&A`A=!_2@_
zqzwv!8U}_MMur+DhID37Sbzk<G1Sb+(8S1)$G}j+1PY);7BGVq6wMHk6b6QD4u+yo
zP`XIuV91kaDB)x%VS$<kGM1U4nU#U1goz=ZnIVw_svoMY2ds??ri~4&Hdcm2E`}0r
zhT`K4B|HpSybL9LAU86W@PkqnEWSVy>{qPAz`#&mlvrTvmY7qVs*s$YmzI;6TvDu1
zo>`KikeFAgkYAFKTBMLzlx`bRRGO+G07?#^;7ZJ^ECHpcu*96wRM(=S{Gt+&aB*dE
z2`J1UksSoG1;$S;DndyNsYOLW;55hwbwojG3M`R;k|oGp@x>)YsfoEIXi8v4C6=UC
zWR}FIfYKSrRtUd@1DwRtGmA@7i@<RUPK{vqgW?pN1QSb3^1;clgq?wbAvr&<EVZbl
z1eB$VONufJz&b!K81Tdib_poCih~lU6ez<m$uRP>ax!u<@iTHV%QJ#WW;RA%M$GJM
z0*Wti76oNr2~gUFBrQ-HWdS88khlRT34+8~L1{OIfdQ7EL4gX6L~u+6fw`dY3IgTg
zAW%3X!UxP6pd1WNV=1YiU@`^;6Ub$te9QyN%ithmU|;~neLhH56%r_*+{Vbz$H2f?
z#R&?DFvjo{28I$waJd$N6bhhJ93%=V+QdKwCx{D<mBgZSNNUe62Qk3`044@16nMc&
z8B)Z>m!wvdSb@9?4h$w<MrKA%CfcMBP(gs6LU=&o1+p3(A_!uj!UmLfi@+%aT(5y#
z22UZNY!8wL34&!oL=6i=kv%BG)PSq@8b(n4T?4MdYe1zwb1f@F4J$(yIK33vgV{_B
zwG0e}_Mlu;1Ik69B<B|ds#=1CLE#|?N<W}-5>iQmin-#9{L-A1cu-jbPQ{QCPXpwf
zAQ_MzRNX-$pu`KxgCHFRsYL@GvOyqUc!3fcD9RZa*%&z)MHzV*`584pZVdvJ-QcPs
zIX@4SCUY{Azy%4oGDyrT&Me6<2em!GK>|rdpd1D%V!$a2WG=X92G>$Spi~Yn)`LK`
z5h7!PYYC_&xrup+>8V9QlAsU-6`EjIBEkyH8mOcQN@g~>`6;D2sdgZ*7K7p$R8;XW
X2{5xUvN3@%GbgL43@5t~Cnq}qPdZ72

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/colorama/win32.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/colorama/win32.py
new file mode 100644
index 0000000..c2d8360
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/colorama/win32.py
@@ -0,0 +1,152 @@
+# Copyright Jonathan Hartley 2013. BSD 3-Clause license, see LICENSE file.
+
+# from winbase.h
+STDOUT = -11
+STDERR = -12
+
+try:
+    import ctypes
+    from ctypes import LibraryLoader
+    windll = LibraryLoader(ctypes.WinDLL)
+    from ctypes import wintypes
+except (AttributeError, ImportError):
+    windll = None
+    SetConsoleTextAttribute = lambda *_: None
+    winapi_test = lambda *_: None
+else:
+    from ctypes import byref, Structure, c_char, POINTER
+
+    COORD = wintypes._COORD
+
+    class CONSOLE_SCREEN_BUFFER_INFO(Structure):
+        """struct in wincon.h."""
+        _fields_ = [
+            ("dwSize", COORD),
+            ("dwCursorPosition", COORD),
+            ("wAttributes", wintypes.WORD),
+            ("srWindow", wintypes.SMALL_RECT),
+            ("dwMaximumWindowSize", COORD),
+        ]
+        def __str__(self):
+            return '(%d,%d,%d,%d,%d,%d,%d,%d,%d,%d,%d)' % (
+                self.dwSize.Y, self.dwSize.X
+                , self.dwCursorPosition.Y, self.dwCursorPosition.X
+                , self.wAttributes
+                , self.srWindow.Top, self.srWindow.Left, self.srWindow.Bottom, self.srWindow.Right
+                , self.dwMaximumWindowSize.Y, self.dwMaximumWindowSize.X
+            )
+
+    _GetStdHandle = windll.kernel32.GetStdHandle
+    _GetStdHandle.argtypes = [
+        wintypes.DWORD,
+    ]
+    _GetStdHandle.restype = wintypes.HANDLE
+
+    _GetConsoleScreenBufferInfo = windll.kernel32.GetConsoleScreenBufferInfo
+    _GetConsoleScreenBufferInfo.argtypes = [
+        wintypes.HANDLE,
+        POINTER(CONSOLE_SCREEN_BUFFER_INFO),
+    ]
+    _GetConsoleScreenBufferInfo.restype = wintypes.BOOL
+
+    _SetConsoleTextAttribute = windll.kernel32.SetConsoleTextAttribute
+    _SetConsoleTextAttribute.argtypes = [
+        wintypes.HANDLE,
+        wintypes.WORD,
+    ]
+    _SetConsoleTextAttribute.restype = wintypes.BOOL
+
+    _SetConsoleCursorPosition = windll.kernel32.SetConsoleCursorPosition
+    _SetConsoleCursorPosition.argtypes = [
+        wintypes.HANDLE,
+        COORD,
+    ]
+    _SetConsoleCursorPosition.restype = wintypes.BOOL
+
+    _FillConsoleOutputCharacterA = windll.kernel32.FillConsoleOutputCharacterA
+    _FillConsoleOutputCharacterA.argtypes = [
+        wintypes.HANDLE,
+        c_char,
+        wintypes.DWORD,
+        COORD,
+        POINTER(wintypes.DWORD),
+    ]
+    _FillConsoleOutputCharacterA.restype = wintypes.BOOL
+
+    _FillConsoleOutputAttribute = windll.kernel32.FillConsoleOutputAttribute
+    _FillConsoleOutputAttribute.argtypes = [
+        wintypes.HANDLE,
+        wintypes.WORD,
+        wintypes.DWORD,
+        COORD,
+        POINTER(wintypes.DWORD),
+    ]
+    _FillConsoleOutputAttribute.restype = wintypes.BOOL
+
+    _SetConsoleTitleW = windll.kernel32.SetConsoleTitleW
+    _SetConsoleTitleW.argtypes = [
+        wintypes.LPCWSTR
+    ]
+    _SetConsoleTitleW.restype = wintypes.BOOL
+
+    def _winapi_test(handle):
+        csbi = CONSOLE_SCREEN_BUFFER_INFO()
+        success = _GetConsoleScreenBufferInfo(
+            handle, byref(csbi))
+        return bool(success)
+
+    def winapi_test():
+        return any(_winapi_test(h) for h in
+                   (_GetStdHandle(STDOUT), _GetStdHandle(STDERR)))
+
+    def GetConsoleScreenBufferInfo(stream_id=STDOUT):
+        handle = _GetStdHandle(stream_id)
+        csbi = CONSOLE_SCREEN_BUFFER_INFO()
+        success = _GetConsoleScreenBufferInfo(
+            handle, byref(csbi))
+        return csbi
+
+    def SetConsoleTextAttribute(stream_id, attrs):
+        handle = _GetStdHandle(stream_id)
+        return _SetConsoleTextAttribute(handle, attrs)
+
+    def SetConsoleCursorPosition(stream_id, position, adjust=True):
+        position = COORD(*position)
+        # If the position is out of range, do nothing.
+        if position.Y <= 0 or position.X <= 0:
+            return
+        # Adjust for Windows' SetConsoleCursorPosition:
+        #    1. being 0-based, while ANSI is 1-based.
+        #    2. expecting (x,y), while ANSI uses (y,x).
+        adjusted_position = COORD(position.Y - 1, position.X - 1)
+        if adjust:
+            # Adjust for viewport's scroll position
+            sr = GetConsoleScreenBufferInfo(STDOUT).srWindow
+            adjusted_position.Y += sr.Top
+            adjusted_position.X += sr.Left
+        # Resume normal processing
+        handle = _GetStdHandle(stream_id)
+        return _SetConsoleCursorPosition(handle, adjusted_position)
+
+    def FillConsoleOutputCharacter(stream_id, char, length, start):
+        handle = _GetStdHandle(stream_id)
+        char = c_char(char.encode())
+        length = wintypes.DWORD(length)
+        num_written = wintypes.DWORD(0)
+        # Note that this is hard-coded for ANSI (vs wide) bytes.
+        success = _FillConsoleOutputCharacterA(
+            handle, char, length, start, byref(num_written))
+        return num_written.value
+
+    def FillConsoleOutputAttribute(stream_id, attr, length, start):
+        ''' FillConsoleOutputAttribute( hConsole, csbi.wAttributes, dwConSize, coordScreen, &cCharsWritten )'''
+        handle = _GetStdHandle(stream_id)
+        attribute = wintypes.WORD(attr)
+        length = wintypes.DWORD(length)
+        num_written = wintypes.DWORD(0)
+        # Note that this is hard-coded for ANSI (vs wide) bytes.
+        return _FillConsoleOutputAttribute(
+            handle, attribute, length, start, byref(num_written))
+
+    def SetConsoleTitle(title):
+        return _SetConsoleTitleW(title)
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/colorama/win32.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/colorama/win32.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..59d9891a4f09f96d5e341eb24dd505e0908f7d01
GIT binary patch
literal 5862
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

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/colorama/winterm.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/colorama/winterm.py
new file mode 100644
index 0000000..0fdb4ec
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/colorama/winterm.py
@@ -0,0 +1,169 @@
+# Copyright Jonathan Hartley 2013. BSD 3-Clause license, see LICENSE file.
+from . import win32
+
+
+# from wincon.h
+class WinColor(object):
+    BLACK   = 0
+    BLUE    = 1
+    GREEN   = 2
+    CYAN    = 3
+    RED     = 4
+    MAGENTA = 5
+    YELLOW  = 6
+    GREY    = 7
+
+# from wincon.h
+class WinStyle(object):
+    NORMAL              = 0x00 # dim text, dim background
+    BRIGHT              = 0x08 # bright text, dim background
+    BRIGHT_BACKGROUND   = 0x80 # dim text, bright background
+
+class WinTerm(object):
+
+    def __init__(self):
+        self._default = win32.GetConsoleScreenBufferInfo(win32.STDOUT).wAttributes
+        self.set_attrs(self._default)
+        self._default_fore = self._fore
+        self._default_back = self._back
+        self._default_style = self._style
+        # In order to emulate LIGHT_EX in windows, we borrow the BRIGHT style.
+        # So that LIGHT_EX colors and BRIGHT style do not clobber each other,
+        # we track them separately, since LIGHT_EX is overwritten by Fore/Back
+        # and BRIGHT is overwritten by Style codes.
+        self._light = 0
+
+    def get_attrs(self):
+        return self._fore + self._back * 16 + (self._style | self._light)
+
+    def set_attrs(self, value):
+        self._fore = value & 7
+        self._back = (value >> 4) & 7
+        self._style = value & (WinStyle.BRIGHT | WinStyle.BRIGHT_BACKGROUND)
+
+    def reset_all(self, on_stderr=None):
+        self.set_attrs(self._default)
+        self.set_console(attrs=self._default)
+        self._light = 0
+
+    def fore(self, fore=None, light=False, on_stderr=False):
+        if fore is None:
+            fore = self._default_fore
+        self._fore = fore
+        # Emulate LIGHT_EX with BRIGHT Style
+        if light:
+            self._light |= WinStyle.BRIGHT
+        else:
+            self._light &= ~WinStyle.BRIGHT
+        self.set_console(on_stderr=on_stderr)
+
+    def back(self, back=None, light=False, on_stderr=False):
+        if back is None:
+            back = self._default_back
+        self._back = back
+        # Emulate LIGHT_EX with BRIGHT_BACKGROUND Style
+        if light:
+            self._light |= WinStyle.BRIGHT_BACKGROUND
+        else:
+            self._light &= ~WinStyle.BRIGHT_BACKGROUND
+        self.set_console(on_stderr=on_stderr)
+
+    def style(self, style=None, on_stderr=False):
+        if style is None:
+            style = self._default_style
+        self._style = style
+        self.set_console(on_stderr=on_stderr)
+
+    def set_console(self, attrs=None, on_stderr=False):
+        if attrs is None:
+            attrs = self.get_attrs()
+        handle = win32.STDOUT
+        if on_stderr:
+            handle = win32.STDERR
+        win32.SetConsoleTextAttribute(handle, attrs)
+
+    def get_position(self, handle):
+        position = win32.GetConsoleScreenBufferInfo(handle).dwCursorPosition
+        # Because Windows coordinates are 0-based,
+        # and win32.SetConsoleCursorPosition expects 1-based.
+        position.X += 1
+        position.Y += 1
+        return position
+
+    def set_cursor_position(self, position=None, on_stderr=False):
+        if position is None:
+            # I'm not currently tracking the position, so there is no default.
+            # position = self.get_position()
+            return
+        handle = win32.STDOUT
+        if on_stderr:
+            handle = win32.STDERR
+        win32.SetConsoleCursorPosition(handle, position)
+
+    def cursor_adjust(self, x, y, on_stderr=False):
+        handle = win32.STDOUT
+        if on_stderr:
+            handle = win32.STDERR
+        position = self.get_position(handle)
+        adjusted_position = (position.Y + y, position.X + x)
+        win32.SetConsoleCursorPosition(handle, adjusted_position, adjust=False)
+
+    def erase_screen(self, mode=0, on_stderr=False):
+        # 0 should clear from the cursor to the end of the screen.
+        # 1 should clear from the cursor to the beginning of the screen.
+        # 2 should clear the entire screen, and move cursor to (1,1)
+        handle = win32.STDOUT
+        if on_stderr:
+            handle = win32.STDERR
+        csbi = win32.GetConsoleScreenBufferInfo(handle)
+        # get the number of character cells in the current buffer
+        cells_in_screen = csbi.dwSize.X * csbi.dwSize.Y
+        # get number of character cells before current cursor position
+        cells_before_cursor = csbi.dwSize.X * csbi.dwCursorPosition.Y + csbi.dwCursorPosition.X
+        if mode == 0:
+            from_coord = csbi.dwCursorPosition
+            cells_to_erase = cells_in_screen - cells_before_cursor
+        elif mode == 1:
+            from_coord = win32.COORD(0, 0)
+            cells_to_erase = cells_before_cursor
+        elif mode == 2:
+            from_coord = win32.COORD(0, 0)
+            cells_to_erase = cells_in_screen
+        else:
+            # invalid mode
+            return
+        # fill the entire screen with blanks
+        win32.FillConsoleOutputCharacter(handle, ' ', cells_to_erase, from_coord)
+        # now set the buffer's attributes accordingly
+        win32.FillConsoleOutputAttribute(handle, self.get_attrs(), cells_to_erase, from_coord)
+        if mode == 2:
+            # put the cursor where needed
+            win32.SetConsoleCursorPosition(handle, (1, 1))
+
+    def erase_line(self, mode=0, on_stderr=False):
+        # 0 should clear from the cursor to the end of the line.
+        # 1 should clear from the cursor to the beginning of the line.
+        # 2 should clear the entire line.
+        handle = win32.STDOUT
+        if on_stderr:
+            handle = win32.STDERR
+        csbi = win32.GetConsoleScreenBufferInfo(handle)
+        if mode == 0:
+            from_coord = csbi.dwCursorPosition
+            cells_to_erase = csbi.dwSize.X - csbi.dwCursorPosition.X
+        elif mode == 1:
+            from_coord = win32.COORD(0, csbi.dwCursorPosition.Y)
+            cells_to_erase = csbi.dwCursorPosition.X
+        elif mode == 2:
+            from_coord = win32.COORD(0, csbi.dwCursorPosition.Y)
+            cells_to_erase = csbi.dwSize.X
+        else:
+            # invalid mode
+            return
+        # fill the entire screen with blanks
+        win32.FillConsoleOutputCharacter(handle, ' ', cells_to_erase, from_coord)
+        # now set the buffer's attributes accordingly
+        win32.FillConsoleOutputAttribute(handle, self.get_attrs(), cells_to_erase, from_coord)
+
+    def set_title(self, title):
+        win32.SetConsoleTitle(title)
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/colorama/winterm.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/colorama/winterm.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..5c617fa1f247ea5a2f101569249d3be8389fc833
GIT binary patch
literal 6935
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
GF;)P&w3^!h

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/__init__.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/__init__.py
new file mode 100644
index 0000000..a786b4d
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/__init__.py
@@ -0,0 +1,23 @@
+# -*- coding: utf-8 -*-
+#
+# Copyright (C) 2012-2017 Vinay Sajip.
+# Licensed to the Python Software Foundation under a contributor agreement.
+# See LICENSE.txt and CONTRIBUTORS.txt.
+#
+import logging
+
+__version__ = '0.2.8'
+
+class DistlibException(Exception):
+    pass
+
+try:
+    from logging import NullHandler
+except ImportError: # pragma: no cover
+    class NullHandler(logging.Handler):
+        def handle(self, record): pass
+        def emit(self, record): pass
+        def createLock(self): self.lock = None
+
+logger = logging.getLogger(__name__)
+logger.addHandler(NullHandler())
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/__init__.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/__init__.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..f483f97af77027e2f78273d4367a6bc47230c887
GIT binary patch
literal 1623
zcmZSn%**AGdLky70SZ_d7#JKF7#NCs7#J8*7#LC*8FCmHq8J!bm>8lM8B&-TQkfXi
z7#UJn7+M$@ni&`(qnH^gMZii~K}vI37@}Ah7{l|l7+6wS8M3(;iZU1&85vX97*ZJ+
zve>|y+2NX581fhyB0w_i45=Ip&5R6DoD8X)3|U+ZsVpG#n;97xQy3Y7H8>a;7&8C=
z|Nq~w801I;JtIAf5&;GV2A9m@lAO#W*NWuSf|AVqJh)#N85kIxKz;#fO=SSNKPXrO
z<WUVK1_p)_kZ^o_USe))e0&KP0|P^Rd~SY9X-;Z<JVX^(DTpY}XJBB^FDS|^ODsv%
zFH0=aPs`6qNi8bYPfF1*PfE(mHO(zHGE6d0uS&NtwJ6WYsxmVGf%H865dDJ80^Q8K
z;*!Li99_3E4^QI&kPsNhm!;;V<QM6uK>VN|AD@|*SrQ+wS5O%QvX~p>e2`<=7&SoN
zDFF%imFDDlB<7{$q!tA+GcYh<dRUo(0TkMx2x9;RbrcgQB3l?3qL@Ju31YA?1O;n=
zb%TrtVUYRGAp2M#Q6CJp(GL<7AO$5LiQ?3pv=TN328N>4<ou!(h%Csd0})1Ghh%_*
zLI~t?kUNq=P6c6t{s{v4CkT|72G|!McckWKmI%ZB0CGDBgZu%G6JAK1)G#o_GlDW3
zEOI~!!13ajpO*?|<m4x3gJTZty#e+aC|4yHr6!i7`s62Pi@^M+0SfdWkOzZ69tZ-Z
zryzC)28JMz285fztbs^a;Cv+raxTbeY>b?YoQxWvyjKEpWlny2dS+faI5Wn_m!%dJ
zXXfX{$Cq$2FfhQ2A#nZ$n*&zonOl%wRN`7xlwSlk1Db)sdeT!%eDc%NQ;Wbs0#4K*
zD^iQVrBY%_3RE#TI1t1@1Pr*)w1E_pcA&5*1{J|POl(YI%*>1;jJ%Apto)1sXZLy<

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/_backport/__init__.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/_backport/__init__.py
new file mode 100644
index 0000000..f7dbf4c
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/_backport/__init__.py
@@ -0,0 +1,6 @@
+"""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/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/_backport/__init__.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/_backport/__init__.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..6d6de8a890cb04527e6b02bfdeb7ea125aa02151
GIT binary patch
literal 498
zcmZSn%**AGdLky70SXuy7#JKF7#NDV7#J8*7#N}$7*ZG+f;E^xV%&@j48Hj(r8%j^
z3d#8enW-rXX+`<D3IUZR8Tok%#tOwHiFqlBMJWn7nMp;7MVYC^Itpp|MGBdDC8<Su
zi8%_T#i<JUc{!DOTwI=cDVb%NDW!=y3duQ%#l@+`3W<3s3TdTz$t9WjdBqBeMX3sD
z`K5U&3YmEdDMotnNr}nX1^GoKdbyd!$$AP3o_Qsyc`2zWT&2Z{>8T2t#R?_)3W+)8
ziIv3)nYkd93MCntdFjOpxtYbqnR)3D*Ba{?LKr0(i6siTVE<Stlw_oGC6#98l;~#W
z=@*xz<YXo(<R@jNCYKZ|lxODTC?utVT%V$lnFeu{9+#g6D6~r085kJi<5TjJ<Ks0z
zp@<-gD;XFV^b3kI%Mwdc^~(~A^waWlQc{bG^^;Qc%afAwa!qrKjSQ2_)2q@gOfAZD
zvZ~AsKp;I&KSaMEvp_d9uec;JCr8(<%)`?-03-y)@nxxbDfvbEDVfD3IhjfN@SxF;
ekI&4@EQycTE2u2tU|?Xdf%wmk4HSPM*8u<!Pns$K

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/_backport/misc.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/_backport/misc.py
new file mode 100644
index 0000000..cfb318d
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/_backport/misc.py
@@ -0,0 +1,41 @@
+# -*- 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/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/_backport/misc.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/_backport/misc.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..2eee41970935ad4a804327b4abc93d6856dfce8e
GIT binary patch
literal 1616
zcmZSn%**AGdLky70SZ_d7#JKF7#NC=F)%QsFfc?hFr+Xtq%bk$Ffv3j!q`j<QA`Xe
z%nT_k3@NM(>C6mK%nX$xU|BYX92SOLR)#262FCC_Sq7F=Him32hN1)pMn=X|c7_yo
zh89MUY#t*+L?stPDhERp2Sa$C76VHvCs^flkV=rH91J;J47uD4QQQoSDVz)~3?P+Y
zZM+Prj0{;k3{gA`;dxRFEUCO;od>}>xxgxU7(gmhm>7aJxIzBWXJBA(N=(i!$S*1>
zR!GY)Qpn6p$t=rEDNW2#NX|(tE>100NX$!7NGr`tF3HT#E7r^W|NsAgzY;+P28QIs
z<c!q#w4(gn_~QK1qU6*P4zOrWPGV9Hgp*dBnwOlPlB&VTz`zg$3eIFE1_lOZ1_lNY
z?F@2+6axc84I@Jl4=AV#_(9=X%fwK_z)-`)ARep%QtMX&(w___^EE)mfQ3ug85kG}
zD&x~Kb5ct{k(82}RGMA_(vezG0#OH2TwKb)z@T4Hlv$QolB!>pSfrnppOcbWRIHzr
zqF<hrl$UFoTWn;QWS(A?ZeeOso|9E&W&i@|dHNyx1(^l9nR&$}i8(pCZe<>x#sMH9
zFpe)v%}dEI(oe}OF3HJE(vMGq2Bv;)W^uA!K_%GBps*@t0Xc+Gh!GqT;DB;YgalMF
z$ZsGFayK|cco`TNN*F*vP{PR242ms~w4Vkj$V#{v7#K2(!4AqxP7MMDImAqm_WY!*
zLE&wXd!<2<3vx08BixIiPyl-o6fnqMED{EJHyA3!1oCx}DM%=bnW2P*A&ZrvnSr61
zks-K*4U|ku*g<m5j0{;E3}VfU3{8xnd>IT5A-`gf&8ZaysmUb@NtGq3#R~aF3dJQw
zItqFDB?_v=8l0fS2qM6V2CM{}Xo^dUO4t|}7$9jDB2-yiBFezPke*rsN@c~B#U-h^
zVEN3v^b(L6A(aKGu0=)pMI|85l~fi$Qht1VUSe))d^{v>K(PeU4-y*`5d?}CB~S$M
zfYT*EBMT!xqc9U2qXr)+@qsc{e0)lNa(sLVNNIj?5R!OePELG0ICwI13qUc+Py#AW
zJaa+i2qY{(Arl`D&X4i&L7?OS4lKXKTxei{G$iNe<fKB%6>vHZ0$Ei8vdFQdq$o3~
zv;?9U5n^E0z-4D}zO~8CPbtkwwF9M;Vg&{U1~w)hMjj@9W@bhaMqWk%R%S*n5Y5EP
L!pz9a$jb--Z-sg-

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/_backport/shutil.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/_backport/shutil.py
new file mode 100644
index 0000000..159e49e
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/_backport/shutil.py
@@ -0,0 +1,761 @@
+# -*- 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
+import collections
+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, collections.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, collections.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/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/_backport/shutil.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/_backport/shutil.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..3d755a71fabf409ce79185eff4457b843343f4d2
GIT binary patch
literal 28427
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
XI8`}$nHeP+#TX@-*+A}N;$#N^T@0oa

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/_backport/sysconfig.cfg b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/_backport/sysconfig.cfg
new file mode 100644
index 0000000..1746bd0
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/_backport/sysconfig.cfg
@@ -0,0 +1,84 @@
+[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/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/_backport/sysconfig.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/_backport/sysconfig.py
new file mode 100644
index 0000000..1df3aba
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/_backport/sysconfig.py
@@ -0,0 +1,788 @@
+# -*- 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)
+
+ # FIXME don't rely on sys.version here, its format is an implementation detail
+ # of CPython, use sys.version_info or sys.hexversion
+_PY_VERSION = sys.version.split()[0]
+_PY_VERSION_SHORT = sys.version[:3]
+_PY_VERSION_SHORT_NO_DOT = _PY_VERSION[0] + _PY_VERSION[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/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/_backport/sysconfig.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/_backport/sysconfig.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..a78d9310b56aaf4277fa5af156ce64603ae2e20d
GIT binary patch
literal 22518
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
RC<kXVCnx73u({kki~#-b9W(#{

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/_backport/tarfile.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/_backport/tarfile.py
new file mode 100644
index 0000000..d66d856
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/_backport/tarfile.py
@@ -0,0 +1,2607 @@
+#-------------------------------------------------------------------
+# 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/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/_backport/tarfile.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/_backport/tarfile.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..4c6723f5436b9795e9c0e2dbc31a8cba5930e0f0
GIT binary patch
literal 86950
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
CyZXKW

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/compat.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/compat.py
new file mode 100644
index 0000000..ff328c8
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/compat.py
@@ -0,0 +1,1120 @@
+# -*- coding: utf-8 -*-
+#
+# Copyright (C) 2013-2017 Vinay Sajip.
+# Licensed to the Python Software Foundation under a contributor agreement.
+# See LICENSE.txt and CONTRIBUTORS.txt.
+#
+from __future__ import absolute_import
+
+import os
+import re
+import sys
+
+try:
+    import ssl
+except ImportError:  # pragma: no cover
+    ssl = None
+
+if sys.version_info[0] < 3:  # pragma: no cover
+    from StringIO import StringIO
+    string_types = basestring,
+    text_type = unicode
+    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)
+
+    def quote(s):
+        if isinstance(s, unicode):
+            s = s.encode('utf-8')
+        return _quote(s)
+
+    import urllib2
+    from urllib2 import (Request, urlopen, URLError, HTTPError,
+                         HTTPBasicAuthHandler, HTTPPasswordMgr,
+                         HTTPHandler, HTTPRedirectHandler,
+                         build_opener)
+    if ssl:
+        from urllib2 import HTTPSHandler
+    import httplib
+    import xmlrpclib
+    import Queue as queue
+    from HTMLParser import HTMLParser
+    import htmlentitydefs
+    raw_input = raw_input
+    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('^(.*)@(.*)$')
+
+        match = _userprog.match(host)
+        if match: return match.group(1, 2)
+        return None, host
+
+else:  # pragma: no cover
+    from io import StringIO
+    string_types = str,
+    text_type = str
+    from io import TextIOWrapper as file_type
+    import builtins
+    import configparser
+    import shutil
+    from urllib.parse import (urlparse, urlunparse, urljoin, splituser, quote,
+                              unquote, urlsplit, urlunsplit, splittype)
+    from urllib.request import (urlopen, urlretrieve, Request, url2pathname,
+                                pathname2url,
+                                HTTPBasicAuthHandler, HTTPPasswordMgr,
+                                HTTPHandler, HTTPRedirectHandler,
+                                build_opener)
+    if ssl:
+        from urllib.request import HTTPSHandler
+    from urllib.error import HTTPError, URLError, ContentTooShortError
+    import http.client as httplib
+    import urllib.request as urllib2
+    import xmlrpc.client as xmlrpclib
+    import queue
+    from html.parser import HTMLParser
+    import html.entities as htmlentitydefs
+    raw_input = input
+    from itertools import filterfalse
+    filter = filter
+
+try:
+    from ssl import match_hostname, CertificateError
+except ImportError: # pragma: no cover
+    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
+
+        parts = dn.split('.')
+        leftmost, remainder = parts[0], parts[1:]
+
+        wildcards = leftmost.count('*')
+        if wildcards > max_wildcards:
+            # Issue #17980: avoid denials of service by refusing more
+            # than one wildcard per fragment.  A survey of established
+            # policy among SSL implementations showed it to be a
+            # reasonable choice.
+            raise CertificateError(
+                "too many wildcards in certificate DNS name: " + repr(dn))
+
+        # speed up common case w/o wildcards
+        if not wildcards:
+            return dn.lower() == hostname.lower()
+
+        # RFC 6125, section 6.4.3, subitem 1.
+        # The client SHOULD NOT attempt to match a presented identifier in which
+        # the wildcard character comprises a label other than the left-most label.
+        if leftmost == '*':
+            # When '*' is a fragment by itself, it matches a non-empty dotless
+            # fragment.
+            pats.append('[^.]+')
+        elif leftmost.startswith('xn--') or hostname.startswith('xn--'):
+            # RFC 6125, section 6.4.3, subitem 3.
+            # The client SHOULD NOT attempt to match a presented identifier
+            # where the wildcard character is embedded within an A-label or
+            # U-label of an internationalized domain name.
+            pats.append(re.escape(leftmost))
+        else:
+            # Otherwise, '*' matches any dotless string, e.g. www*
+            pats.append(re.escape(leftmost).replace(r'\*', '[^.]*'))
+
+        # add the remaining fragments, ignore any wildcards
+        for frag in remainder:
+            pats.append(re.escape(frag))
+
+        pat = re.compile(r'\A' + r'\.'.join(pats) + r'\Z', re.IGNORECASE)
+        return pat.match(hostname)
+
+
+    def match_hostname(cert, hostname):
+        """Verify that *cert* (in decoded format as returned by
+        SSLSocket.getpeercert()) matches the *hostname*.  RFC 2818 and RFC 6125
+        rules are followed, but IP addresses are not accepted for *hostname*.
+
+        CertificateError is raised on failure. On success, the function
+        returns nothing.
+        """
+        if not cert:
+            raise ValueError("empty or no certificate, match_hostname needs a "
+                             "SSL socket or SSL context with either "
+                             "CERT_OPTIONAL or CERT_REQUIRED")
+        dnsnames = []
+        san = cert.get('subjectAltName', ())
+        for key, value in san:
+            if key == 'DNS':
+                if _dnsname_match(value, hostname):
+                    return
+                dnsnames.append(value)
+        if not dnsnames:
+            # The subject is only checked when there is no dNSName entry
+            # in subjectAltName
+            for sub in cert.get('subject', ()):
+                for key, value in sub:
+                    # XXX according to RFC 2818, the most specific Common Name
+                    # must be used.
+                    if key == 'commonName':
+                        if _dnsname_match(value, hostname):
+                            return
+                        dnsnames.append(value)
+        if len(dnsnames) > 1:
+            raise CertificateError("hostname %r "
+                "doesn't match either of %s"
+                % (hostname, ', '.join(map(repr, dnsnames))))
+        elif len(dnsnames) == 1:
+            raise CertificateError("hostname %r "
+                "doesn't match %r"
+                % (hostname, dnsnames[0]))
+        else:
+            raise CertificateError("no appropriate commonName or "
+                "subjectAltName fields were found")
+
+
+try:
+    from types import SimpleNamespace as Container
+except ImportError:  # pragma: no cover
+    class Container(object):
+        """
+        A generic container for when multiple values need to be returned
+        """
+        def __init__(self, **kwargs):
+            self.__dict__.update(kwargs)
+
+
+try:
+    from shutil import which
+except ImportError:  # pragma: no cover
+    # Implementation from Python 3.3
+    def which(cmd, mode=os.F_OK | os.X_OK, path=None):
+        """Given a command, mode, and a PATH string, return the path which
+        conforms to the given mode on the PATH, or None if there is no such
+        file.
+
+        `mode` defaults to os.F_OK | os.X_OK. `path` defaults to the result
+        of os.environ.get("PATH"), or can be overridden with a custom search
+        path.
+
+        """
+        # Check that a given file can be accessed with the correct mode.
+        # Additionally check that `file` is not a directory, as on Windows
+        # directories pass the os.access check.
+        def _access_check(fn, mode):
+            return (os.path.exists(fn) and os.access(fn, mode)
+                    and not os.path.isdir(fn))
+
+        # If we're given a path with a directory part, look it up directly rather
+        # than referring to PATH directories. This includes checking relative to the
+        # current directory, e.g. ./script
+        if os.path.dirname(cmd):
+            if _access_check(cmd, mode):
+                return cmd
+            return None
+
+        if path is None:
+            path = os.environ.get("PATH", os.defpath)
+        if not path:
+            return None
+        path = path.split(os.pathsep)
+
+        if sys.platform == "win32":
+            # The current directory takes precedence on Windows.
+            if not os.curdir in path:
+                path.insert(0, os.curdir)
+
+            # PATHEXT is necessary to check on Windows.
+            pathext = os.environ.get("PATHEXT", "").split(os.pathsep)
+            # See if the given file matches any of the expected path extensions.
+            # This will allow us to short circuit when given "python.exe".
+            # If it does match, only test that one, otherwise we have to try
+            # others.
+            if any(cmd.lower().endswith(ext.lower()) for ext in pathext):
+                files = [cmd]
+            else:
+                files = [cmd + ext for ext in pathext]
+        else:
+            # On other platforms you don't have things like PATHEXT to tell you
+            # what file suffixes are executable, so just pass on cmd as-is.
+            files = [cmd]
+
+        seen = set()
+        for dir in path:
+            normdir = os.path.normcase(dir)
+            if not normdir in seen:
+                seen.add(normdir)
+                for thefile in files:
+                    name = os.path.join(dir, thefile)
+                    if _access_check(name, mode):
+                        return name
+        return None
+
+
+# ZipFile is a context manager in 2.7, but not in 2.6
+
+from zipfile import ZipFile as BaseZipFile
+
+if hasattr(BaseZipFile, '__enter__'):  # pragma: no cover
+    ZipFile = BaseZipFile
+else:  # pragma: no cover
+    from zipfile import ZipExtFile as BaseZipExtFile
+
+    class ZipExtFile(BaseZipExtFile):
+        def __init__(self, base):
+            self.__dict__.update(base.__dict__)
+
+        def __enter__(self):
+            return self
+
+        def __exit__(self, *exc_info):
+            self.close()
+            # return None, so if an exception occurred, it will propagate
+
+    class ZipFile(BaseZipFile):
+        def __enter__(self):
+            return self
+
+        def __exit__(self, *exc_info):
+            self.close()
+            # return None, so if an exception occurred, it will propagate
+
+        def open(self, *args, **kwargs):
+            base = BaseZipFile.open(self, *args, **kwargs)
+            return ZipExtFile(base)
+
+try:
+    from platform import python_implementation
+except ImportError: # pragma: no cover
+    def python_implementation():
+        """Return a string identifying the Python implementation."""
+        if 'PyPy' in sys.version:
+            return 'PyPy'
+        if os.name == 'java':
+            return 'Jython'
+        if sys.version.startswith('IronPython'):
+            return 'IronPython'
+        return 'CPython'
+
+try:
+    import sysconfig
+except ImportError: # pragma: no cover
+    from ._backport import sysconfig
+
+try:
+    callable = callable
+except NameError:   # pragma: no cover
+    from collections import Callable
+
+    def callable(obj):
+        return isinstance(obj, Callable)
+
+
+try:
+    fsencode = os.fsencode
+    fsdecode = os.fsdecode
+except AttributeError:  # pragma: no cover
+    # Issue #99: on some systems (e.g. containerised),
+    # sys.getfilesystemencoding() returns None, and we need a real value,
+    # so fall back to utf-8. From the CPython 2.7 docs relating to Unix and
+    # sys.getfilesystemencoding(): the return value is "the user’s preference
+    # according to the result of nl_langinfo(CODESET), or None if the
+    # nl_langinfo(CODESET) failed."
+    _fsencoding = sys.getfilesystemencoding() or 'utf-8'
+    if _fsencoding == 'mbcs':
+        _fserrors = 'strict'
+    else:
+        _fserrors = 'surrogateescape'
+
+    def fsencode(filename):
+        if isinstance(filename, bytes):
+            return filename
+        elif isinstance(filename, text_type):
+            return filename.encode(_fsencoding, _fserrors)
+        else:
+            raise TypeError("expect bytes or str, not %s" %
+                            type(filename).__name__)
+
+    def fsdecode(filename):
+        if isinstance(filename, text_type):
+            return filename
+        elif isinstance(filename, bytes):
+            return filename.decode(_fsencoding, _fserrors)
+        else:
+            raise TypeError("expect bytes or str, not %s" %
+                            type(filename).__name__)
+
+try:
+    from tokenize import detect_encoding
+except ImportError: # pragma: no cover
+    from codecs import BOM_UTF8, lookup
+    import re
+
+    cookie_re = re.compile(r"coding[:=]\s*([-\w.]+)")
+
+    def _get_normal_name(orig_enc):
+        """Imitates get_normal_name in tokenizer.c."""
+        # Only care about the first 12 characters.
+        enc = orig_enc[:12].lower().replace("_", "-")
+        if enc == "utf-8" or enc.startswith("utf-8-"):
+            return "utf-8"
+        if enc in ("latin-1", "iso-8859-1", "iso-latin-1") or \
+           enc.startswith(("latin-1-", "iso-8859-1-", "iso-latin-1-")):
+            return "iso-8859-1"
+        return orig_enc
+
+    def detect_encoding(readline):
+        """
+        The detect_encoding() function is used to detect the encoding that should
+        be used to decode a Python source file.  It requires one argument, readline,
+        in the same way as the tokenize() generator.
+
+        It will call readline a maximum of twice, and return the encoding used
+        (as a string) and a list of any lines (left as bytes) it has read in.
+
+        It detects the encoding from the presence of a utf-8 bom or an encoding
+        cookie as specified in pep-0263.  If both a bom and a cookie are present,
+        but disagree, a SyntaxError will be raised.  If the encoding cookie is an
+        invalid charset, raise a SyntaxError.  Note that if a utf-8 bom is found,
+        'utf-8-sig' is returned.
+
+        If no encoding is specified, then the default of 'utf-8' will be returned.
+        """
+        try:
+            filename = readline.__self__.name
+        except AttributeError:
+            filename = None
+        bom_found = False
+        encoding = None
+        default = 'utf-8'
+        def read_or_stop():
+            try:
+                return readline()
+            except StopIteration:
+                return b''
+
+        def find_cookie(line):
+            try:
+                # Decode as UTF-8. Either the line is an encoding declaration,
+                # in which case it should be pure ASCII, or it must be UTF-8
+                # per default encoding.
+                line_string = line.decode('utf-8')
+            except UnicodeDecodeError:
+                msg = "invalid or missing encoding declaration"
+                if filename is not None:
+                    msg = '{} for {!r}'.format(msg, filename)
+                raise SyntaxError(msg)
+
+            matches = cookie_re.findall(line_string)
+            if not matches:
+                return None
+            encoding = _get_normal_name(matches[0])
+            try:
+                codec = lookup(encoding)
+            except LookupError:
+                # This behaviour mimics the Python interpreter
+                if filename is None:
+                    msg = "unknown encoding: " + encoding
+                else:
+                    msg = "unknown encoding for {!r}: {}".format(filename,
+                            encoding)
+                raise SyntaxError(msg)
+
+            if bom_found:
+                if codec.name != 'utf-8':
+                    # This behaviour mimics the Python interpreter
+                    if filename is None:
+                        msg = 'encoding problem: utf-8'
+                    else:
+                        msg = 'encoding problem for {!r}: utf-8'.format(filename)
+                    raise SyntaxError(msg)
+                encoding += '-sig'
+            return encoding
+
+        first = read_or_stop()
+        if first.startswith(BOM_UTF8):
+            bom_found = True
+            first = first[3:]
+            default = 'utf-8-sig'
+        if not first:
+            return default, []
+
+        encoding = find_cookie(first)
+        if encoding:
+            return encoding, [first]
+
+        second = read_or_stop()
+        if not second:
+            return default, [first]
+
+        encoding = find_cookie(second)
+        if encoding:
+            return encoding, [first, second]
+
+        return default, [first, second]
+
+# For converting & <-> &amp; etc.
+try:
+    from html import escape
+except ImportError:
+    from cgi import escape
+if sys.version_info[:2] < (3, 4):
+    unescape = HTMLParser().unescape
+else:
+    from html import unescape
+
+try:
+    from collections import ChainMap
+except ImportError: # pragma: no cover
+    from collections import MutableMapping
+
+    try:
+        from reprlib import recursive_repr as _recursive_repr
+    except ImportError:
+        def _recursive_repr(fillvalue='...'):
+            '''
+            Decorator to make a repr function return fillvalue for a recursive
+            call
+            '''
+
+            def decorating_function(user_function):
+                repr_running = set()
+
+                def wrapper(self):
+                    key = id(self), get_ident()
+                    if key in repr_running:
+                        return fillvalue
+                    repr_running.add(key)
+                    try:
+                        result = user_function(self)
+                    finally:
+                        repr_running.discard(key)
+                    return result
+
+                # Can't use functools.wraps() here because of bootstrap issues
+                wrapper.__module__ = getattr(user_function, '__module__')
+                wrapper.__doc__ = getattr(user_function, '__doc__')
+                wrapper.__name__ = getattr(user_function, '__name__')
+                wrapper.__annotations__ = getattr(user_function, '__annotations__', {})
+                return wrapper
+
+            return decorating_function
+
+    class ChainMap(MutableMapping):
+        ''' A ChainMap groups multiple dicts (or other mappings) together
+        to create a single, updateable view.
+
+        The underlying mappings are stored in a list.  That list is public and can
+        accessed or updated using the *maps* attribute.  There is no other state.
+
+        Lookups search the underlying mappings successively until a key is found.
+        In contrast, writes, updates, and deletions only operate on the first
+        mapping.
+
+        '''
+
+        def __init__(self, *maps):
+            '''Initialize a ChainMap by setting *maps* to the given mappings.
+            If no mappings are provided, a single empty dictionary is used.
+
+            '''
+            self.maps = list(maps) or [{}]          # always at least one map
+
+        def __missing__(self, key):
+            raise KeyError(key)
+
+        def __getitem__(self, key):
+            for mapping in self.maps:
+                try:
+                    return mapping[key]             # can't use 'key in mapping' with defaultdict
+                except KeyError:
+                    pass
+            return self.__missing__(key)            # support subclasses that define __missing__
+
+        def get(self, key, default=None):
+            return self[key] if key in self else default
+
+        def __len__(self):
+            return len(set().union(*self.maps))     # reuses stored hash values if possible
+
+        def __iter__(self):
+            return iter(set().union(*self.maps))
+
+        def __contains__(self, key):
+            return any(key in m for m in self.maps)
+
+        def __bool__(self):
+            return any(self.maps)
+
+        @_recursive_repr()
+        def __repr__(self):
+            return '{0.__class__.__name__}({1})'.format(
+                self, ', '.join(map(repr, self.maps)))
+
+        @classmethod
+        def fromkeys(cls, iterable, *args):
+            'Create a ChainMap with a single dict created from the iterable.'
+            return cls(dict.fromkeys(iterable, *args))
+
+        def copy(self):
+            'New ChainMap or subclass with a new copy of maps[0] and refs to maps[1:]'
+            return self.__class__(self.maps[0].copy(), *self.maps[1:])
+
+        __copy__ = copy
+
+        def new_child(self):                        # like Django's Context.push()
+            'New ChainMap with a new dict followed by all previous maps.'
+            return self.__class__({}, *self.maps)
+
+        @property
+        def parents(self):                          # like Django's Context.pop()
+            'New ChainMap from maps[1:].'
+            return self.__class__(*self.maps[1:])
+
+        def __setitem__(self, key, value):
+            self.maps[0][key] = value
+
+        def __delitem__(self, key):
+            try:
+                del self.maps[0][key]
+            except KeyError:
+                raise KeyError('Key not found in the first mapping: {!r}'.format(key))
+
+        def popitem(self):
+            'Remove and return an item pair from maps[0]. Raise KeyError is maps[0] is empty.'
+            try:
+                return self.maps[0].popitem()
+            except KeyError:
+                raise KeyError('No keys found in the first mapping.')
+
+        def pop(self, key, *args):
+            'Remove *key* from maps[0] and return its value. Raise KeyError if *key* not in maps[0].'
+            try:
+                return self.maps[0].pop(key, *args)
+            except KeyError:
+                raise KeyError('Key not found in the first mapping: {!r}'.format(key))
+
+        def clear(self):
+            'Clear maps[0], leaving maps[1:] intact.'
+            self.maps[0].clear()
+
+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
+
+try:
+    from collections import OrderedDict
+except ImportError: # pragma: no cover
+## {{{ http://code.activestate.com/recipes/576693/ (r9)
+# Backport of OrderedDict() class that runs on Python 2.4, 2.5, 2.6, 2.7 and pypy.
+# Passes Python2.7's test suite and incorporates all the latest updates.
+    try:
+        from thread import get_ident as _get_ident
+    except ImportError:
+        from dummy_thread import get_ident as _get_ident
+
+    try:
+        from _abcoll import KeysView, ValuesView, ItemsView
+    except ImportError:
+        pass
+
+
+    class OrderedDict(dict):
+        'Dictionary that remembers insertion order'
+        # An inherited dict maps keys to values.
+        # The inherited dict provides __getitem__, __len__, __contains__, and get.
+        # The remaining methods are order-aware.
+        # Big-O running times for all methods are the same as for regular dictionaries.
+
+        # The internal self.__map dictionary maps keys to links in a doubly linked list.
+        # The circular doubly linked list starts and ends with a sentinel element.
+        # The sentinel element never gets deleted (this simplifies the algorithm).
+        # Each link is stored as a list of length three:  [PREV, NEXT, KEY].
+
+        def __init__(self, *args, **kwds):
+            '''Initialize an ordered dictionary.  Signature is the same as for
+            regular dictionaries, but keyword arguments are not recommended
+            because their insertion order is arbitrary.
+
+            '''
+            if len(args) > 1:
+                raise TypeError('expected at most 1 arguments, got %d' % len(args))
+            try:
+                self.__root
+            except AttributeError:
+                self.__root = root = []                     # sentinel node
+                root[:] = [root, root, None]
+                self.__map = {}
+            self.__update(*args, **kwds)
+
+        def __setitem__(self, key, value, dict_setitem=dict.__setitem__):
+            'od.__setitem__(i, y) <==> od[i]=y'
+            # Setting a new item creates a new link which goes at the end of the linked
+            # list, and the inherited dictionary is updated with the new key/value pair.
+            if key not in self:
+                root = self.__root
+                last = root[0]
+                last[1] = root[0] = self.__map[key] = [last, root, key]
+            dict_setitem(self, key, value)
+
+        def __delitem__(self, key, dict_delitem=dict.__delitem__):
+            'od.__delitem__(y) <==> del od[y]'
+            # Deleting an existing item uses self.__map to find the link which is
+            # then removed by updating the links in the predecessor and successor nodes.
+            dict_delitem(self, key)
+            link_prev, link_next, key = self.__map.pop(key)
+            link_prev[1] = link_next
+            link_next[0] = link_prev
+
+        def __iter__(self):
+            'od.__iter__() <==> iter(od)'
+            root = self.__root
+            curr = root[1]
+            while curr is not root:
+                yield curr[2]
+                curr = curr[1]
+
+        def __reversed__(self):
+            'od.__reversed__() <==> reversed(od)'
+            root = self.__root
+            curr = root[0]
+            while curr is not root:
+                yield curr[2]
+                curr = curr[0]
+
+        def clear(self):
+            'od.clear() -> None.  Remove all items from od.'
+            try:
+                for node in self.__map.itervalues():
+                    del node[:]
+                root = self.__root
+                root[:] = [root, root, None]
+                self.__map.clear()
+            except AttributeError:
+                pass
+            dict.clear(self)
+
+        def popitem(self, last=True):
+            '''od.popitem() -> (k, v), return and remove a (key, value) pair.
+            Pairs are returned in LIFO order if last is true or FIFO order if false.
+
+            '''
+            if not self:
+                raise KeyError('dictionary is empty')
+            root = self.__root
+            if last:
+                link = root[0]
+                link_prev = link[0]
+                link_prev[1] = root
+                root[0] = link_prev
+            else:
+                link = root[1]
+                link_next = link[1]
+                root[1] = link_next
+                link_next[0] = root
+            key = link[2]
+            del self.__map[key]
+            value = dict.pop(self, key)
+            return key, value
+
+        # -- the following methods do not depend on the internal structure --
+
+        def keys(self):
+            'od.keys() -> list of keys in od'
+            return list(self)
+
+        def values(self):
+            'od.values() -> list of values in od'
+            return [self[key] for key in self]
+
+        def items(self):
+            'od.items() -> list of (key, value) pairs in od'
+            return [(key, self[key]) for key in self]
+
+        def iterkeys(self):
+            'od.iterkeys() -> an iterator over the keys in od'
+            return iter(self)
+
+        def itervalues(self):
+            'od.itervalues -> an iterator over the values in od'
+            for k in self:
+                yield self[k]
+
+        def iteritems(self):
+            'od.iteritems -> an iterator over the (key, value) items in od'
+            for k in self:
+                yield (k, self[k])
+
+        def update(*args, **kwds):
+            '''od.update(E, **F) -> None.  Update od from dict/iterable E and F.
+
+            If E is a dict instance, does:           for k in E: od[k] = E[k]
+            If E has a .keys() method, does:         for k in E.keys(): od[k] = E[k]
+            Or if E is an iterable of items, does:   for k, v in E: od[k] = v
+            In either case, this is followed by:     for k, v in F.items(): od[k] = v
+
+            '''
+            if len(args) > 2:
+                raise TypeError('update() takes at most 2 positional '
+                                'arguments (%d given)' % (len(args),))
+            elif not args:
+                raise TypeError('update() takes at least 1 argument (0 given)')
+            self = args[0]
+            # Make progressively weaker assumptions about "other"
+            other = ()
+            if len(args) == 2:
+                other = args[1]
+            if isinstance(other, dict):
+                for key in other:
+                    self[key] = other[key]
+            elif hasattr(other, 'keys'):
+                for key in other.keys():
+                    self[key] = other[key]
+            else:
+                for key, value in other:
+                    self[key] = value
+            for key, value in kwds.items():
+                self[key] = value
+
+        __update = update  # let subclasses override update without breaking __init__
+
+        __marker = object()
+
+        def pop(self, key, default=__marker):
+            '''od.pop(k[,d]) -> v, remove specified key and return the corresponding value.
+            If key is not found, d is returned if given, otherwise KeyError is raised.
+
+            '''
+            if key in self:
+                result = self[key]
+                del self[key]
+                return result
+            if default is self.__marker:
+                raise KeyError(key)
+            return default
+
+        def setdefault(self, key, default=None):
+            'od.setdefault(k[,d]) -> od.get(k,d), also set od[k]=d if k not in od'
+            if key in self:
+                return self[key]
+            self[key] = default
+            return default
+
+        def __repr__(self, _repr_running=None):
+            'od.__repr__() <==> repr(od)'
+            if not _repr_running: _repr_running = {}
+            call_key = id(self), _get_ident()
+            if call_key in _repr_running:
+                return '...'
+            _repr_running[call_key] = 1
+            try:
+                if not self:
+                    return '%s()' % (self.__class__.__name__,)
+                return '%s(%r)' % (self.__class__.__name__, self.items())
+            finally:
+                del _repr_running[call_key]
+
+        def __reduce__(self):
+            'Return state information for pickling'
+            items = [[k, self[k]] for k in self]
+            inst_dict = vars(self).copy()
+            for k in vars(OrderedDict()):
+                inst_dict.pop(k, None)
+            if inst_dict:
+                return (self.__class__, (items,), inst_dict)
+            return self.__class__, (items,)
+
+        def copy(self):
+            'od.copy() -> a shallow copy of od'
+            return self.__class__(self)
+
+        @classmethod
+        def fromkeys(cls, iterable, value=None):
+            '''OD.fromkeys(S[, v]) -> New ordered dictionary with keys from S
+            and values equal to v (which defaults to None).
+
+            '''
+            d = cls()
+            for key in iterable:
+                d[key] = value
+            return d
+
+        def __eq__(self, other):
+            '''od.__eq__(y) <==> od==y.  Comparison to another OD is order-sensitive
+            while comparison to a regular mapping is order-insensitive.
+
+            '''
+            if isinstance(other, OrderedDict):
+                return len(self)==len(other) and self.items() == other.items()
+            return dict.__eq__(self, other)
+
+        def __ne__(self, other):
+            return not self == other
+
+        # -- the following methods are only used in Python 2.7 --
+
+        def viewkeys(self):
+            "od.viewkeys() -> a set-like object providing a view on od's keys"
+            return KeysView(self)
+
+        def viewvalues(self):
+            "od.viewvalues() -> an object providing a view on od's values"
+            return ValuesView(self)
+
+        def viewitems(self):
+            "od.viewitems() -> a set-like object providing a view on od's items"
+            return ItemsView(self)
+
+try:
+    from logging.config import BaseConfigurator, valid_ident
+except ImportError: # pragma: no cover
+    IDENTIFIER = re.compile('^[a-z_][a-z0-9_]*$', re.I)
+
+
+    def valid_ident(s):
+        m = IDENTIFIER.match(s)
+        if not m:
+            raise ValueError('Not a valid Python identifier: %r' % s)
+        return True
+
+
+    # The ConvertingXXX classes are wrappers around standard Python containers,
+    # and they serve to convert any suitable values in the container. The
+    # conversion converts base dicts, lists and tuples to their wrapped
+    # equivalents, whereas strings which match a conversion format are converted
+    # appropriately.
+    #
+    # Each wrapper should have a configurator attribute holding the actual
+    # configurator to use for conversion.
+
+    class ConvertingDict(dict):
+        """A converting dictionary wrapper."""
+
+        def __getitem__(self, key):
+            value = dict.__getitem__(self, key)
+            result = self.configurator.convert(value)
+            #If the converted value is different, save for next time
+            if value is not result:
+                self[key] = result
+                if type(result) in (ConvertingDict, ConvertingList,
+                                    ConvertingTuple):
+                    result.parent = self
+                    result.key = key
+            return result
+
+        def get(self, key, default=None):
+            value = dict.get(self, key, default)
+            result = self.configurator.convert(value)
+            #If the converted value is different, save for next time
+            if value is not result:
+                self[key] = result
+                if type(result) in (ConvertingDict, ConvertingList,
+                                    ConvertingTuple):
+                    result.parent = self
+                    result.key = key
+            return result
+
+    def pop(self, key, default=None):
+        value = dict.pop(self, key, default)
+        result = self.configurator.convert(value)
+        if value is not result:
+            if type(result) in (ConvertingDict, ConvertingList,
+                                ConvertingTuple):
+                result.parent = self
+                result.key = key
+        return result
+
+    class ConvertingList(list):
+        """A converting list wrapper."""
+        def __getitem__(self, key):
+            value = list.__getitem__(self, key)
+            result = self.configurator.convert(value)
+            #If the converted value is different, save for next time
+            if value is not result:
+                self[key] = result
+                if type(result) in (ConvertingDict, ConvertingList,
+                                    ConvertingTuple):
+                    result.parent = self
+                    result.key = key
+            return result
+
+        def pop(self, idx=-1):
+            value = list.pop(self, idx)
+            result = self.configurator.convert(value)
+            if value is not result:
+                if type(result) in (ConvertingDict, ConvertingList,
+                                    ConvertingTuple):
+                    result.parent = self
+            return result
+
+    class ConvertingTuple(tuple):
+        """A converting tuple wrapper."""
+        def __getitem__(self, key):
+            value = tuple.__getitem__(self, key)
+            result = self.configurator.convert(value)
+            if value is not result:
+                if type(result) in (ConvertingDict, ConvertingList,
+                                    ConvertingTuple):
+                    result.parent = self
+                    result.key = key
+            return result
+
+    class BaseConfigurator(object):
+        """
+        The configurator base class which defines some useful defaults.
+        """
+
+        CONVERT_PATTERN = re.compile(r'^(?P<prefix>[a-z]+)://(?P<suffix>.*)$')
+
+        WORD_PATTERN = re.compile(r'^\s*(\w+)\s*')
+        DOT_PATTERN = re.compile(r'^\.\s*(\w+)\s*')
+        INDEX_PATTERN = re.compile(r'^\[\s*(\w+)\s*\]\s*')
+        DIGIT_PATTERN = re.compile(r'^\d+$')
+
+        value_converters = {
+            'ext' : 'ext_convert',
+            'cfg' : 'cfg_convert',
+        }
+
+        # We might want to use a different one, e.g. importlib
+        importer = staticmethod(__import__)
+
+        def __init__(self, config):
+            self.config = ConvertingDict(config)
+            self.config.configurator = self
+
+        def resolve(self, s):
+            """
+            Resolve strings to objects using standard import and attribute
+            syntax.
+            """
+            name = s.split('.')
+            used = name.pop(0)
+            try:
+                found = self.importer(used)
+                for frag in name:
+                    used += '.' + frag
+                    try:
+                        found = getattr(found, frag)
+                    except AttributeError:
+                        self.importer(used)
+                        found = getattr(found, frag)
+                return found
+            except ImportError:
+                e, tb = sys.exc_info()[1:]
+                v = ValueError('Cannot resolve %r: %s' % (s, e))
+                v.__cause__, v.__traceback__ = e, tb
+                raise v
+
+        def ext_convert(self, value):
+            """Default converter for the ext:// protocol."""
+            return self.resolve(value)
+
+        def cfg_convert(self, value):
+            """Default converter for the cfg:// protocol."""
+            rest = value
+            m = self.WORD_PATTERN.match(rest)
+            if m is None:
+                raise ValueError("Unable to convert %r" % value)
+            else:
+                rest = rest[m.end():]
+                d = self.config[m.groups()[0]]
+                #print d, rest
+                while rest:
+                    m = self.DOT_PATTERN.match(rest)
+                    if m:
+                        d = d[m.groups()[0]]
+                    else:
+                        m = self.INDEX_PATTERN.match(rest)
+                        if m:
+                            idx = m.groups()[0]
+                            if not self.DIGIT_PATTERN.match(idx):
+                                d = d[idx]
+                            else:
+                                try:
+                                    n = int(idx) # try as number first (most likely)
+                                    d = d[n]
+                                except TypeError:
+                                    d = d[idx]
+                    if m:
+                        rest = rest[m.end():]
+                    else:
+                        raise ValueError('Unable to convert '
+                                         '%r at %r' % (value, rest))
+            #rest should be empty
+            return d
+
+        def convert(self, value):
+            """
+            Convert values to an appropriate type. dicts, lists and tuples are
+            replaced by their converting alternatives. Strings are checked to
+            see if they have a conversion format and are converted if they do.
+            """
+            if not isinstance(value, ConvertingDict) and isinstance(value, dict):
+                value = ConvertingDict(value)
+                value.configurator = self
+            elif not isinstance(value, ConvertingList) and isinstance(value, list):
+                value = ConvertingList(value)
+                value.configurator = self
+            elif not isinstance(value, ConvertingTuple) and\
+                     isinstance(value, tuple):
+                value = ConvertingTuple(value)
+                value.configurator = self
+            elif isinstance(value, string_types):
+                m = self.CONVERT_PATTERN.match(value)
+                if m:
+                    d = m.groupdict()
+                    prefix = d['prefix']
+                    converter = self.value_converters.get(prefix, None)
+                    if converter:
+                        suffix = d['suffix']
+                        converter = getattr(self, converter)
+                        value = converter(suffix)
+            return value
+
+        def configure_custom(self, config):
+            """Configure an object with a user-supplied factory."""
+            c = config.pop('()')
+            if not callable(c):
+                c = self.resolve(c)
+            props = config.pop('.', None)
+            # Check for valid identifiers
+            kwargs = dict([(k, config[k]) for k in config if valid_ident(k)])
+            result = c(**kwargs)
+            if props:
+                for name, value in props.items():
+                    setattr(result, name, value)
+            return result
+
+        def as_tuple(self, value):
+            """Utility function which converts lists to tuples."""
+            if isinstance(value, list):
+                value = tuple(value)
+            return value
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/compat.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/compat.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..faa239a47d952a810525bf5ddcd2e9332ff7106b
GIT binary patch
literal 44256
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

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/database.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/database.py
new file mode 100644
index 0000000..b13cdac
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/database.py
@@ -0,0 +1,1339 @@
+# -*- coding: utf-8 -*-
+#
+# Copyright (C) 2012-2017 The Python Software Foundation.
+# See LICENSE.txt and CONTRIBUTORS.txt.
+#
+"""PEP 376 implementation."""
+
+from __future__ import unicode_literals
+
+import base64
+import codecs
+import contextlib
+import hashlib
+import logging
+import os
+import posixpath
+import sys
+import zipimport
+
+from . import DistlibException, resources
+from .compat import StringIO
+from .version import get_scheme, UnsupportedVersionError
+from .metadata import (Metadata, METADATA_FILENAME, WHEEL_METADATA_FILENAME,
+                       LEGACY_METADATA_FILENAME)
+from .util import (parse_requirement, cached_property, parse_name_and_version,
+                   read_exports, write_exports, CSVReader, CSVWriter)
+
+
+__all__ = ['Distribution', 'BaseInstalledDistribution',
+           'InstalledDistribution', 'EggInfoDistribution',
+           'DistributionPath']
+
+
+logger = logging.getLogger(__name__)
+
+EXPORTS_FILENAME = 'pydist-exports.json'
+COMMANDS_FILENAME = 'pydist-commands.json'
+
+DIST_FILES = ('INSTALLER', METADATA_FILENAME, 'RECORD', 'REQUESTED',
+              'RESOURCES', EXPORTS_FILENAME, 'SHARED')
+
+DISTINFO_EXT = '.dist-info'
+
+
+class _Cache(object):
+    """
+    A simple cache mapping names and .dist-info paths to distributions
+    """
+    def __init__(self):
+        """
+        Initialise an instance. There is normally one for each DistributionPath.
+        """
+        self.name = {}
+        self.path = {}
+        self.generated = False
+
+    def clear(self):
+        """
+        Clear the cache, setting it to its initial state.
+        """
+        self.name.clear()
+        self.path.clear()
+        self.generated = False
+
+    def add(self, dist):
+        """
+        Add a distribution to the cache.
+        :param dist: The distribution to add.
+        """
+        if dist.path not in self.path:
+            self.path[dist.path] = dist
+            self.name.setdefault(dist.key, []).append(dist)
+
+
+class DistributionPath(object):
+    """
+    Represents a set of distributions installed on a path (typically sys.path).
+    """
+    def __init__(self, path=None, include_egg=False):
+        """
+        Create an instance from a path, optionally including legacy (distutils/
+        setuptools/distribute) distributions.
+        :param path: The path to use, as a list of directories. If not specified,
+                     sys.path is used.
+        :param include_egg: If True, this instance will look for and return legacy
+                            distributions as well as those based on PEP 376.
+        """
+        if path is None:
+            path = sys.path
+        self.path = path
+        self._include_dist = True
+        self._include_egg = include_egg
+
+        self._cache = _Cache()
+        self._cache_egg = _Cache()
+        self._cache_enabled = True
+        self._scheme = get_scheme('default')
+
+    def _get_cache_enabled(self):
+        return self._cache_enabled
+
+    def _set_cache_enabled(self, value):
+        self._cache_enabled = value
+
+    cache_enabled = property(_get_cache_enabled, _set_cache_enabled)
+
+    def clear_cache(self):
+        """
+        Clears the internal cache.
+        """
+        self._cache.clear()
+        self._cache_egg.clear()
+
+
+    def _yield_distributions(self):
+        """
+        Yield .dist-info and/or .egg(-info) distributions.
+        """
+        # We need to check if we've seen some resources already, because on
+        # some Linux systems (e.g. some Debian/Ubuntu variants) there are
+        # symlinks which alias other files in the environment.
+        seen = set()
+        for path in self.path:
+            finder = resources.finder_for_path(path)
+            if finder is None:
+                continue
+            r = finder.find('')
+            if not r or not r.is_container:
+                continue
+            rset = sorted(r.resources)
+            for entry in rset:
+                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
+
+                    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)
+
+    def _generate_cache(self):
+        """
+        Scan the path for distributions and populate the cache with
+        those that are found.
+        """
+        gen_dist = not self._cache.generated
+        gen_egg = self._include_egg and not self._cache_egg.generated
+        if gen_dist or gen_egg:
+            for dist in self._yield_distributions():
+                if isinstance(dist, InstalledDistribution):
+                    self._cache.add(dist)
+                else:
+                    self._cache_egg.add(dist)
+
+            if gen_dist:
+                self._cache.generated = True
+            if gen_egg:
+                self._cache_egg.generated = True
+
+    @classmethod
+    def distinfo_dirname(cls, name, version):
+        """
+        The *name* and *version* parameters are converted into their
+        filename-escaped form, i.e. any ``'-'`` characters are replaced
+        with ``'_'`` other than the one in ``'dist-info'`` and the one
+        separating the name from the version number.
+
+        :parameter name: is converted to a standard distribution name by replacing
+                         any runs of non- alphanumeric characters with a single
+                         ``'-'``.
+        :type name: string
+        :parameter version: is converted to a standard version string. Spaces
+                            become dots, and all other non-alphanumeric characters
+                            (except dots) become dashes, with runs of multiple
+                            dashes condensed to a single dash.
+        :type version: string
+        :returns: directory name
+        :rtype: string"""
+        name = name.replace('-', '_')
+        return '-'.join([name, version]) + DISTINFO_EXT
+
+    def get_distributions(self):
+        """
+        Provides an iterator that looks for distributions and returns
+        :class:`InstalledDistribution` or
+        :class:`EggInfoDistribution` instances for each one of them.
+
+        :rtype: iterator of :class:`InstalledDistribution` and
+                :class:`EggInfoDistribution` instances
+        """
+        if not self._cache_enabled:
+            for dist in self._yield_distributions():
+                yield dist
+        else:
+            self._generate_cache()
+
+            for dist in self._cache.path.values():
+                yield dist
+
+            if self._include_egg:
+                for dist in self._cache_egg.path.values():
+                    yield dist
+
+    def get_distribution(self, name):
+        """
+        Looks for a named distribution on the path.
+
+        This function only returns the first result found, as no more than one
+        value is expected. If nothing is found, ``None`` is returned.
+
+        :rtype: :class:`InstalledDistribution`, :class:`EggInfoDistribution`
+                or ``None``
+        """
+        result = None
+        name = name.lower()
+        if not self._cache_enabled:
+            for dist in self._yield_distributions():
+                if dist.key == name:
+                    result = dist
+                    break
+        else:
+            self._generate_cache()
+
+            if name in self._cache.name:
+                result = self._cache.name[name][0]
+            elif self._include_egg and name in self._cache_egg.name:
+                result = self._cache_egg.name[name][0]
+        return result
+
+    def provides_distribution(self, name, version=None):
+        """
+        Iterates over all distributions to find which distributions provide *name*.
+        If a *version* is provided, it will be used to filter the results.
+
+        This function only returns the first result found, since no more than
+        one values are expected. If the directory is not found, returns ``None``.
+
+        :parameter version: a version specifier that indicates the version
+                            required, conforming to the format in ``PEP-345``
+
+        :type name: string
+        :type version: string
+        """
+        matcher = None
+        if version is not None:
+            try:
+                matcher = self._scheme.matcher('%s (%s)' % (name, version))
+            except ValueError:
+                raise DistlibException('invalid name or version: %r, %r' %
+                                      (name, version))
+
+        for dist in self.get_distributions():
+            # We hit a problem on Travis where enum34 was installed and doesn't
+            # have a provides attribute ...
+            if not hasattr(dist, 'provides'):
+                logger.debug('No "provides": %s', dist)
+            else:
+                provided = dist.provides
+
+                for p in provided:
+                    p_name, p_ver = parse_name_and_version(p)
+                    if matcher is None:
+                        if p_name == name:
+                            yield dist
+                            break
+                    else:
+                        if p_name == name and matcher.match(p_ver):
+                            yield dist
+                            break
+
+    def get_file_path(self, name, relative_path):
+        """
+        Return the path to a resource file.
+        """
+        dist = self.get_distribution(name)
+        if dist is None:
+            raise LookupError('no distribution named %r found' % name)
+        return dist.get_resource_path(relative_path)
+
+    def get_exported_entries(self, category, name=None):
+        """
+        Return all of the exported entries in a particular category.
+
+        :param category: The category to search for entries.
+        :param name: If specified, only entries with that name are returned.
+        """
+        for dist in self.get_distributions():
+            r = dist.exports
+            if category in r:
+                d = r[category]
+                if name is not None:
+                    if name in d:
+                        yield d[name]
+                else:
+                    for v in d.values():
+                        yield v
+
+
+class Distribution(object):
+    """
+    A base class for distributions, whether installed or from indexes.
+    Either way, it must have some metadata, so that's all that's needed
+    for construction.
+    """
+
+    build_time_dependency = False
+    """
+    Set to True if it's known to be only a build-time dependency (i.e.
+    not needed after installation).
+    """
+
+    requested = False
+    """A boolean that indicates whether the ``REQUESTED`` metadata file is
+    present (in other words, whether the package was installed by user
+    request or it was installed as a dependency)."""
+
+    def __init__(self, metadata):
+        """
+        Initialise an instance.
+        :param metadata: The instance of :class:`Metadata` describing this
+        distribution.
+        """
+        self.metadata = metadata
+        self.name = metadata.name
+        self.key = self.name.lower()    # for case-insensitive comparisons
+        self.version = metadata.version
+        self.locator = None
+        self.digest = None
+        self.extras = None      # additional features requested
+        self.context = None     # environment marker overrides
+        self.download_urls = set()
+        self.digests = {}
+
+    @property
+    def source_url(self):
+        """
+        The source archive download URL for this distribution.
+        """
+        return self.metadata.source_url
+
+    download_url = source_url   # Backward compatibility
+
+    @property
+    def name_and_version(self):
+        """
+        A utility property which displays the name and version in parentheses.
+        """
+        return '%s (%s)' % (self.name, self.version)
+
+    @property
+    def provides(self):
+        """
+        A set of distribution names and versions provided by this distribution.
+        :return: A set of "name (version)" strings.
+        """
+        plist = self.metadata.provides
+        s = '%s (%s)' % (self.name, self.version)
+        if s not in plist:
+            plist.append(s)
+        return plist
+
+    def _get_requirements(self, req_attr):
+        md = self.metadata
+        logger.debug('Getting requirements from metadata %r', md.todict())
+        reqts = getattr(md, req_attr)
+        return set(md.get_requirements(reqts, extras=self.extras,
+                                       env=self.context))
+
+    @property
+    def run_requires(self):
+        return self._get_requirements('run_requires')
+
+    @property
+    def meta_requires(self):
+        return self._get_requirements('meta_requires')
+
+    @property
+    def build_requires(self):
+        return self._get_requirements('build_requires')
+
+    @property
+    def test_requires(self):
+        return self._get_requirements('test_requires')
+
+    @property
+    def dev_requires(self):
+        return self._get_requirements('dev_requires')
+
+    def matches_requirement(self, req):
+        """
+        Say if this instance matches (fulfills) a requirement.
+        :param req: The requirement to match.
+        :rtype req: str
+        :return: True if it matches, else False.
+        """
+        # Requirement may contain extras - parse to lose those
+        # from what's passed to the matcher
+        r = parse_requirement(req)
+        scheme = get_scheme(self.metadata.scheme)
+        try:
+            matcher = scheme.matcher(r.requirement)
+        except UnsupportedVersionError:
+            # XXX compat-mode if cannot read the version
+            logger.warning('could not read version %r - using name only',
+                           req)
+            name = req.split()[0]
+            matcher = scheme.matcher(name)
+
+        name = matcher.key   # case-insensitive
+
+        result = False
+        for p in self.provides:
+            p_name, p_ver = parse_name_and_version(p)
+            if p_name != name:
+                continue
+            try:
+                result = matcher.match(p_ver)
+                break
+            except UnsupportedVersionError:
+                pass
+        return result
+
+    def __repr__(self):
+        """
+        Return a textual representation of this instance,
+        """
+        if self.source_url:
+            suffix = ' [%s]' % self.source_url
+        else:
+            suffix = ''
+        return '<Distribution %s (%s)%s>' % (self.name, self.version, suffix)
+
+    def __eq__(self, other):
+        """
+        See if this distribution is the same as another.
+        :param other: The distribution to compare with. To be equal to one
+                      another. distributions must have the same type, name,
+                      version and source_url.
+        :return: True if it is the same, else False.
+        """
+        if type(other) is not type(self):
+            result = False
+        else:
+            result = (self.name == other.name and
+                      self.version == other.version and
+                      self.source_url == other.source_url)
+        return result
+
+    def __hash__(self):
+        """
+        Compute hash in a way which matches the equality test.
+        """
+        return hash(self.name) + hash(self.version) + hash(self.source_url)
+
+
+class BaseInstalledDistribution(Distribution):
+    """
+    This is the base class for installed distributions (whether PEP 376 or
+    legacy).
+    """
+
+    hasher = None
+
+    def __init__(self, metadata, path, env=None):
+        """
+        Initialise an instance.
+        :param metadata: An instance of :class:`Metadata` which describes the
+                         distribution. This will normally have been initialised
+                         from a metadata file in the ``path``.
+        :param path:     The path of the ``.dist-info`` or ``.egg-info``
+                         directory for the distribution.
+        :param env:      This is normally the :class:`DistributionPath`
+                         instance where this distribution was found.
+        """
+        super(BaseInstalledDistribution, self).__init__(metadata)
+        self.path = path
+        self.dist_path = env
+
+    def get_hash(self, data, hasher=None):
+        """
+        Get the hash of some data, using a particular hash algorithm, if
+        specified.
+
+        :param data: The data to be hashed.
+        :type data: bytes
+        :param hasher: The name of a hash implementation, supported by hashlib,
+                       or ``None``. Examples of valid values are ``'sha1'``,
+                       ``'sha224'``, ``'sha384'``, '``sha256'``, ``'md5'`` and
+                       ``'sha512'``. If no hasher is specified, the ``hasher``
+                       attribute of the :class:`InstalledDistribution` instance
+                       is used. If the hasher is determined to be ``None``, MD5
+                       is used as the hashing algorithm.
+        :returns: The hash of the data. If a hasher was explicitly specified,
+                  the returned hash will be prefixed with the specified hasher
+                  followed by '='.
+        :rtype: str
+        """
+        if hasher is None:
+            hasher = self.hasher
+        if hasher is None:
+            hasher = hashlib.md5
+            prefix = ''
+        else:
+            hasher = getattr(hashlib, hasher)
+            prefix = '%s=' % self.hasher
+        digest = hasher(data).digest()
+        digest = base64.urlsafe_b64encode(digest).rstrip(b'=').decode('ascii')
+        return '%s%s' % (prefix, digest)
+
+
+class InstalledDistribution(BaseInstalledDistribution):
+    """
+    Created with the *path* of the ``.dist-info`` directory provided to the
+    constructor. It reads the metadata contained in ``pydist.json`` when it is
+    instantiated., or uses a passed in Metadata instance (useful for when
+    dry-run mode is being used).
+    """
+
+    hasher = 'sha256'
+
+    def __init__(self, path, metadata=None, env=None):
+        self.modules = []
+        self.finder = finder = resources.finder_for_path(path)
+        if finder is None:
+            raise ValueError('finder unavailable for %s' % path)
+        if env and env._cache_enabled and path in env._cache.path:
+            metadata = env._cache.path[path].metadata
+        elif metadata is None:
+            r = finder.find(METADATA_FILENAME)
+            # Temporary - for Wheel 0.23 support
+            if r is None:
+                r = finder.find(WHEEL_METADATA_FILENAME)
+            # Temporary - for legacy support
+            if r is None:
+                r = finder.find('METADATA')
+            if r is None:
+                raise ValueError('no %s found in %s' % (METADATA_FILENAME,
+                                                        path))
+            with contextlib.closing(r.as_stream()) as stream:
+                metadata = Metadata(fileobj=stream, scheme='legacy')
+
+        super(InstalledDistribution, self).__init__(metadata, path, env)
+
+        if env and env._cache_enabled:
+            env._cache.add(self)
+
+        r = finder.find('REQUESTED')
+        self.requested = r is not None
+        p  = os.path.join(path, 'top_level.txt')
+        if os.path.exists(p):
+            with open(p, 'rb') as f:
+                data = f.read()
+            self.modules = data.splitlines()
+
+    def __repr__(self):
+        return '<InstalledDistribution %r %s at %r>' % (
+            self.name, self.version, self.path)
+
+    def __str__(self):
+        return "%s %s" % (self.name, self.version)
+
+    def _get_records(self):
+        """
+        Get the list of installed files for the distribution
+        :return: A list of tuples of path, hash and size. Note that hash and
+                 size might be ``None`` for some entries. The path is exactly
+                 as stored in the file (which is as in PEP 376).
+        """
+        results = []
+        r = self.get_distinfo_resource('RECORD')
+        with contextlib.closing(r.as_stream()) as stream:
+            with CSVReader(stream=stream) as record_reader:
+                # Base location is parent dir of .dist-info dir
+                #base_location = os.path.dirname(self.path)
+                #base_location = os.path.abspath(base_location)
+                for row in record_reader:
+                    missing = [None for i in range(len(row), 3)]
+                    path, checksum, size = row + missing
+                    #if not os.path.isabs(path):
+                    #    path = path.replace('/', os.sep)
+                    #    path = os.path.join(base_location, path)
+                    results.append((path, checksum, size))
+        return results
+
+    @cached_property
+    def exports(self):
+        """
+        Return the information exported by this distribution.
+        :return: A dictionary of exports, mapping an export category to a dict
+                 of :class:`ExportEntry` instances describing the individual
+                 export entries, and keyed by name.
+        """
+        result = {}
+        r = self.get_distinfo_resource(EXPORTS_FILENAME)
+        if r:
+            result = self.read_exports()
+        return result
+
+    def read_exports(self):
+        """
+        Read exports data from a file in .ini format.
+
+        :return: A dictionary of exports, mapping an export category to a list
+                 of :class:`ExportEntry` instances describing the individual
+                 export entries.
+        """
+        result = {}
+        r = self.get_distinfo_resource(EXPORTS_FILENAME)
+        if r:
+            with contextlib.closing(r.as_stream()) as stream:
+                result = read_exports(stream)
+        return result
+
+    def write_exports(self, exports):
+        """
+        Write a dictionary of exports to a file in .ini format.
+        :param exports: A dictionary of exports, mapping an export category to
+                        a list of :class:`ExportEntry` instances describing the
+                        individual export entries.
+        """
+        rf = self.get_distinfo_file(EXPORTS_FILENAME)
+        with open(rf, 'w') as f:
+            write_exports(exports, f)
+
+    def get_resource_path(self, relative_path):
+        """
+        NOTE: This API may change in the future.
+
+        Return the absolute path to a resource file with the given relative
+        path.
+
+        :param relative_path: The path, relative to .dist-info, of the resource
+                              of interest.
+        :return: The absolute path where the resource is to be found.
+        """
+        r = self.get_distinfo_resource('RESOURCES')
+        with contextlib.closing(r.as_stream()) as stream:
+            with CSVReader(stream=stream) as resources_reader:
+                for relative, destination in resources_reader:
+                    if relative == relative_path:
+                        return destination
+        raise KeyError('no resource file with relative path %r '
+                       'is installed' % relative_path)
+
+    def list_installed_files(self):
+        """
+        Iterates over the ``RECORD`` entries and returns a tuple
+        ``(path, hash, size)`` for each line.
+
+        :returns: iterator of (path, hash, size)
+        """
+        for result in self._get_records():
+            yield result
+
+    def write_installed_files(self, paths, prefix, dry_run=False):
+        """
+        Writes the ``RECORD`` file, using the ``paths`` iterable passed in. Any
+        existing ``RECORD`` file is silently overwritten.
+
+        prefix is used to determine when to write absolute paths.
+        """
+        prefix = os.path.join(prefix, '')
+        base = os.path.dirname(self.path)
+        base_under_prefix = base.startswith(prefix)
+        base = os.path.join(base, '')
+        record_path = self.get_distinfo_file('RECORD')
+        logger.info('creating %s', record_path)
+        if dry_run:
+            return None
+        with CSVWriter(record_path) as writer:
+            for path in paths:
+                if os.path.isdir(path) or path.endswith(('.pyc', '.pyo')):
+                    # do not put size and hash, as in PEP-376
+                    hash_value = size = ''
+                else:
+                    size = '%d' % os.path.getsize(path)
+                    with open(path, 'rb') as fp:
+                        hash_value = self.get_hash(fp.read())
+                if path.startswith(base) or (base_under_prefix and
+                                             path.startswith(prefix)):
+                    path = os.path.relpath(path, base)
+                writer.writerow((path, hash_value, size))
+
+            # add the RECORD file itself
+            if record_path.startswith(base):
+                record_path = os.path.relpath(record_path, base)
+            writer.writerow((record_path, '', ''))
+        return record_path
+
+    def check_installed_files(self):
+        """
+        Checks that the hashes and sizes of the files in ``RECORD`` are
+        matched by the files themselves. Returns a (possibly empty) list of
+        mismatches. Each entry in the mismatch list will be a tuple consisting
+        of the path, 'exists', 'size' or 'hash' according to what didn't match
+        (existence is checked first, then size, then hash), the expected
+        value and the actual value.
+        """
+        mismatches = []
+        base = os.path.dirname(self.path)
+        record_path = self.get_distinfo_file('RECORD')
+        for path, hash_value, size in self.list_installed_files():
+            if not os.path.isabs(path):
+                path = os.path.join(base, path)
+            if path == record_path:
+                continue
+            if not os.path.exists(path):
+                mismatches.append((path, 'exists', True, False))
+            elif os.path.isfile(path):
+                actual_size = str(os.path.getsize(path))
+                if size and actual_size != size:
+                    mismatches.append((path, 'size', size, actual_size))
+                elif hash_value:
+                    if '=' in hash_value:
+                        hasher = hash_value.split('=', 1)[0]
+                    else:
+                        hasher = None
+
+                    with open(path, 'rb') as f:
+                        actual_hash = self.get_hash(f.read(), hasher)
+                        if actual_hash != hash_value:
+                            mismatches.append((path, 'hash', hash_value, actual_hash))
+        return mismatches
+
+    @cached_property
+    def shared_locations(self):
+        """
+        A dictionary of shared locations whose keys are in the set 'prefix',
+        'purelib', 'platlib', 'scripts', 'headers', 'data' and 'namespace'.
+        The corresponding value is the absolute path of that category for
+        this distribution, and takes into account any paths selected by the
+        user at installation time (e.g. via command-line arguments). In the
+        case of the 'namespace' key, this would be a list of absolute paths
+        for the roots of namespace packages in this distribution.
+
+        The first time this property is accessed, the relevant information is
+        read from the SHARED file in the .dist-info directory.
+        """
+        result = {}
+        shared_path = os.path.join(self.path, 'SHARED')
+        if os.path.isfile(shared_path):
+            with codecs.open(shared_path, 'r', encoding='utf-8') as f:
+                lines = f.read().splitlines()
+            for line in lines:
+                key, value = line.split('=', 1)
+                if key == 'namespace':
+                    result.setdefault(key, []).append(value)
+                else:
+                    result[key] = value
+        return result
+
+    def write_shared_locations(self, paths, dry_run=False):
+        """
+        Write shared location information to the SHARED file in .dist-info.
+        :param paths: A dictionary as described in the documentation for
+        :meth:`shared_locations`.
+        :param dry_run: If True, the action is logged but no file is actually
+                        written.
+        :return: The path of the file written to.
+        """
+        shared_path = os.path.join(self.path, 'SHARED')
+        logger.info('creating %s', shared_path)
+        if dry_run:
+            return None
+        lines = []
+        for key in ('prefix', 'lib', 'headers', 'scripts', 'data'):
+            path = paths[key]
+            if os.path.isdir(paths[key]):
+                lines.append('%s=%s' % (key,  path))
+        for ns in paths.get('namespace', ()):
+            lines.append('namespace=%s' % ns)
+
+        with codecs.open(shared_path, 'w', encoding='utf-8') as f:
+            f.write('\n'.join(lines))
+        return shared_path
+
+    def get_distinfo_resource(self, path):
+        if path not in DIST_FILES:
+            raise DistlibException('invalid path for a dist-info file: '
+                                   '%r at %r' % (path, self.path))
+        finder = resources.finder_for_path(self.path)
+        if finder is None:
+            raise DistlibException('Unable to get a finder for %s' % self.path)
+        return finder.find(path)
+
+    def get_distinfo_file(self, path):
+        """
+        Returns a path located under the ``.dist-info`` directory. Returns a
+        string representing the path.
+
+        :parameter path: a ``'/'``-separated path relative to the
+                         ``.dist-info`` directory or an absolute path;
+                         If *path* is an absolute path and doesn't start
+                         with the ``.dist-info`` directory path,
+                         a :class:`DistlibException` is raised
+        :type path: str
+        :rtype: str
+        """
+        # Check if it is an absolute path  # XXX use relpath, add tests
+        if path.find(os.sep) >= 0:
+            # it's an absolute path?
+            distinfo_dirname, path = path.split(os.sep)[-2:]
+            if distinfo_dirname != self.path.split(os.sep)[-1]:
+                raise DistlibException(
+                    'dist-info file %r does not belong to the %r %s '
+                    'distribution' % (path, self.name, self.version))
+
+        # The file must be relative
+        if path not in DIST_FILES:
+            raise DistlibException('invalid path for a dist-info file: '
+                                   '%r at %r' % (path, self.path))
+
+        return os.path.join(self.path, path)
+
+    def list_distinfo_files(self):
+        """
+        Iterates over the ``RECORD`` entries and returns paths for each line if
+        the path is pointing to a file located in the ``.dist-info`` directory
+        or one of its subdirectories.
+
+        :returns: iterator of paths
+        """
+        base = os.path.dirname(self.path)
+        for path, checksum, size in self._get_records():
+            # XXX add separator or use real relpath algo
+            if not os.path.isabs(path):
+                path = os.path.join(base, path)
+            if path.startswith(self.path):
+                yield path
+
+    def __eq__(self, other):
+        return (isinstance(other, InstalledDistribution) and
+                self.path == other.path)
+
+    # See http://docs.python.org/reference/datamodel#object.__hash__
+    __hash__ = object.__hash__
+
+
+class EggInfoDistribution(BaseInstalledDistribution):
+    """Created with the *path* of the ``.egg-info`` directory or file provided
+    to the constructor. It reads the metadata contained in the file itself, or
+    if the given path happens to be a directory, the metadata is read from the
+    file ``PKG-INFO`` under that directory."""
+
+    requested = True    # as we have no way of knowing, assume it was
+    shared_locations = {}
+
+    def __init__(self, path, env=None):
+        def set_name_and_version(s, n, v):
+            s.name = n
+            s.key = n.lower()   # for case-insensitive comparisons
+            s.version = v
+
+        self.path = path
+        self.dist_path = env
+        if env and env._cache_enabled and path in env._cache_egg.path:
+            metadata = env._cache_egg.path[path].metadata
+            set_name_and_version(self, metadata.name, metadata.version)
+        else:
+            metadata = self._get_metadata(path)
+
+            # Need to be set before caching
+            set_name_and_version(self, metadata.name, metadata.version)
+
+            if env and env._cache_enabled:
+                env._cache_egg.add(self)
+        super(EggInfoDistribution, self).__init__(metadata, path, env)
+
+    def _get_metadata(self, path):
+        requires = None
+
+        def parse_requires_data(data):
+            """Create a list of dependencies from a requires.txt file.
+
+            *data*: the contents of a setuptools-produced requires.txt file.
+            """
+            reqs = []
+            lines = data.splitlines()
+            for line in lines:
+                line = line.strip()
+                if line.startswith('['):
+                    logger.warning('Unexpected line: quitting requirement scan: %r',
+                                   line)
+                    break
+                r = parse_requirement(line)
+                if not r:
+                    logger.warning('Not recognised as a requirement: %r', line)
+                    continue
+                if r.extras:
+                    logger.warning('extra requirements in requires.txt are '
+                                   'not supported')
+                if not r.constraints:
+                    reqs.append(r.name)
+                else:
+                    cons = ', '.join('%s%s' % c for c in r.constraints)
+                    reqs.append('%s (%s)' % (r.name, cons))
+            return reqs
+
+        def parse_requires_path(req_path):
+            """Create a list of dependencies from a requires.txt file.
+
+            *req_path*: the path to a setuptools-produced requires.txt file.
+            """
+
+            reqs = []
+            try:
+                with codecs.open(req_path, 'r', 'utf-8') as fp:
+                    reqs = parse_requires_data(fp.read())
+            except IOError:
+                pass
+            return reqs
+
+        tl_path = tl_data = None
+        if path.endswith('.egg'):
+            if os.path.isdir(path):
+                p = os.path.join(path, 'EGG-INFO')
+                meta_path = os.path.join(p, 'PKG-INFO')
+                metadata = Metadata(path=meta_path, scheme='legacy')
+                req_path = os.path.join(p, 'requires.txt')
+                tl_path = os.path.join(p, 'top_level.txt')
+                requires = parse_requires_path(req_path)
+            else:
+                # FIXME handle the case where zipfile is not available
+                zipf = zipimport.zipimporter(path)
+                fileobj = StringIO(
+                    zipf.get_data('EGG-INFO/PKG-INFO').decode('utf8'))
+                metadata = Metadata(fileobj=fileobj, scheme='legacy')
+                try:
+                    data = zipf.get_data('EGG-INFO/requires.txt')
+                    tl_data = zipf.get_data('EGG-INFO/top_level.txt').decode('utf-8')
+                    requires = parse_requires_data(data.decode('utf-8'))
+                except IOError:
+                    requires = None
+        elif path.endswith('.egg-info'):
+            if os.path.isdir(path):
+                req_path = os.path.join(path, 'requires.txt')
+                requires = parse_requires_path(req_path)
+                path = os.path.join(path, 'PKG-INFO')
+                tl_path = os.path.join(path, 'top_level.txt')
+            metadata = Metadata(path=path, scheme='legacy')
+        else:
+            raise DistlibException('path must end with .egg-info or .egg, '
+                                   'got %r' % path)
+
+        if requires:
+            metadata.add_requirements(requires)
+        # look for top-level modules in top_level.txt, if present
+        if tl_data is None:
+            if tl_path is not None and os.path.exists(tl_path):
+                with open(tl_path, 'rb') as f:
+                    tl_data = f.read().decode('utf-8')
+        if not tl_data:
+            tl_data = []
+        else:
+            tl_data = tl_data.splitlines()
+        self.modules = tl_data
+        return metadata
+
+    def __repr__(self):
+        return '<EggInfoDistribution %r %s at %r>' % (
+            self.name, self.version, self.path)
+
+    def __str__(self):
+        return "%s %s" % (self.name, self.version)
+
+    def check_installed_files(self):
+        """
+        Checks that the hashes and sizes of the files in ``RECORD`` are
+        matched by the files themselves. Returns a (possibly empty) list of
+        mismatches. Each entry in the mismatch list will be a tuple consisting
+        of the path, 'exists', 'size' or 'hash' according to what didn't match
+        (existence is checked first, then size, then hash), the expected
+        value and the actual value.
+        """
+        mismatches = []
+        record_path = os.path.join(self.path, 'installed-files.txt')
+        if os.path.exists(record_path):
+            for path, _, _ in self.list_installed_files():
+                if path == record_path:
+                    continue
+                if not os.path.exists(path):
+                    mismatches.append((path, 'exists', True, False))
+        return mismatches
+
+    def list_installed_files(self):
+        """
+        Iterates over the ``installed-files.txt`` entries and returns a tuple
+        ``(path, hash, size)`` for each line.
+
+        :returns: a list of (path, hash, size)
+        """
+
+        def _md5(path):
+            f = open(path, 'rb')
+            try:
+                content = f.read()
+            finally:
+                f.close()
+            return hashlib.md5(content).hexdigest()
+
+        def _size(path):
+            return os.stat(path).st_size
+
+        record_path = os.path.join(self.path, 'installed-files.txt')
+        result = []
+        if os.path.exists(record_path):
+            with codecs.open(record_path, 'r', encoding='utf-8') as f:
+                for line in f:
+                    line = line.strip()
+                    p = os.path.normpath(os.path.join(self.path, line))
+                    # "./" is present as a marker between installed files
+                    # and installation metadata files
+                    if not os.path.exists(p):
+                        logger.warning('Non-existent file: %s', p)
+                        if p.endswith(('.pyc', '.pyo')):
+                            continue
+                        #otherwise fall through and fail
+                    if not os.path.isdir(p):
+                        result.append((p, _md5(p), _size(p)))
+            result.append((record_path, None, None))
+        return result
+
+    def list_distinfo_files(self, absolute=False):
+        """
+        Iterates over the ``installed-files.txt`` entries and returns paths for
+        each line if the path is pointing to a file located in the
+        ``.egg-info`` directory or one of its subdirectories.
+
+        :parameter absolute: If *absolute* is ``True``, each returned path is
+                          transformed into a local absolute path. Otherwise the
+                          raw value from ``installed-files.txt`` is returned.
+        :type absolute: boolean
+        :returns: iterator of paths
+        """
+        record_path = os.path.join(self.path, 'installed-files.txt')
+        if os.path.exists(record_path):
+            skip = True
+            with codecs.open(record_path, 'r', encoding='utf-8') as f:
+                for line in f:
+                    line = line.strip()
+                    if line == './':
+                        skip = False
+                        continue
+                    if not skip:
+                        p = os.path.normpath(os.path.join(self.path, line))
+                        if p.startswith(self.path):
+                            if absolute:
+                                yield p
+                            else:
+                                yield line
+
+    def __eq__(self, other):
+        return (isinstance(other, EggInfoDistribution) and
+                self.path == other.path)
+
+    # See http://docs.python.org/reference/datamodel#object.__hash__
+    __hash__ = object.__hash__
+
+new_dist_class = InstalledDistribution
+old_dist_class = EggInfoDistribution
+
+
+class DependencyGraph(object):
+    """
+    Represents a dependency graph between distributions.
+
+    The dependency relationships are stored in an ``adjacency_list`` that maps
+    distributions to a list of ``(other, label)`` tuples where  ``other``
+    is a distribution and the edge is labeled with ``label`` (i.e. the version
+    specifier, if such was provided). Also, for more efficient traversal, for
+    every distribution ``x``, a list of predecessors is kept in
+    ``reverse_list[x]``. An edge from distribution ``a`` to
+    distribution ``b`` means that ``a`` depends on ``b``. If any missing
+    dependencies are found, they are stored in ``missing``, which is a
+    dictionary that maps distributions to a list of requirements that were not
+    provided by any other distributions.
+    """
+
+    def __init__(self):
+        self.adjacency_list = {}
+        self.reverse_list = {}
+        self.missing = {}
+
+    def add_distribution(self, distribution):
+        """Add the *distribution* to the graph.
+
+        :type distribution: :class:`distutils2.database.InstalledDistribution`
+                            or :class:`distutils2.database.EggInfoDistribution`
+        """
+        self.adjacency_list[distribution] = []
+        self.reverse_list[distribution] = []
+        #self.missing[distribution] = []
+
+    def add_edge(self, x, y, label=None):
+        """Add an edge from distribution *x* to distribution *y* with the given
+        *label*.
+
+        :type x: :class:`distutils2.database.InstalledDistribution` or
+                 :class:`distutils2.database.EggInfoDistribution`
+        :type y: :class:`distutils2.database.InstalledDistribution` or
+                 :class:`distutils2.database.EggInfoDistribution`
+        :type label: ``str`` or ``None``
+        """
+        self.adjacency_list[x].append((y, label))
+        # multiple edges are allowed, so be careful
+        if x not in self.reverse_list[y]:
+            self.reverse_list[y].append(x)
+
+    def add_missing(self, distribution, requirement):
+        """
+        Add a missing *requirement* for the given *distribution*.
+
+        :type distribution: :class:`distutils2.database.InstalledDistribution`
+                            or :class:`distutils2.database.EggInfoDistribution`
+        :type requirement: ``str``
+        """
+        logger.debug('%s missing %r', distribution, requirement)
+        self.missing.setdefault(distribution, []).append(requirement)
+
+    def _repr_dist(self, dist):
+        return '%s %s' % (dist.name, dist.version)
+
+    def repr_node(self, dist, level=1):
+        """Prints only a subgraph"""
+        output = [self._repr_dist(dist)]
+        for other, label in self.adjacency_list[dist]:
+            dist = self._repr_dist(other)
+            if label is not None:
+                dist = '%s [%s]' % (dist, label)
+            output.append('    ' * level + str(dist))
+            suboutput = self.repr_node(other, level + 1)
+            subs = suboutput.split('\n')
+            output.extend(subs[1:])
+        return '\n'.join(output)
+
+    def to_dot(self, f, skip_disconnected=True):
+        """Writes a DOT output for the graph to the provided file *f*.
+
+        If *skip_disconnected* is set to ``True``, then all distributions
+        that are not dependent on any other distribution are skipped.
+
+        :type f: has to support ``file``-like operations
+        :type skip_disconnected: ``bool``
+        """
+        disconnected = []
+
+        f.write("digraph dependencies {\n")
+        for dist, adjs in self.adjacency_list.items():
+            if len(adjs) == 0 and not skip_disconnected:
+                disconnected.append(dist)
+            for other, label in adjs:
+                if not label is None:
+                    f.write('"%s" -> "%s" [label="%s"]\n' %
+                            (dist.name, other.name, label))
+                else:
+                    f.write('"%s" -> "%s"\n' % (dist.name, other.name))
+        if not skip_disconnected and len(disconnected) > 0:
+            f.write('subgraph disconnected {\n')
+            f.write('label = "Disconnected"\n')
+            f.write('bgcolor = red\n')
+
+            for dist in disconnected:
+                f.write('"%s"' % dist.name)
+                f.write('\n')
+            f.write('}\n')
+        f.write('}\n')
+
+    def topological_sort(self):
+        """
+        Perform a topological sort of the graph.
+        :return: A tuple, the first element of which is a topologically sorted
+                 list of distributions, and the second element of which is a
+                 list of distributions that cannot be sorted because they have
+                 circular dependencies and so form a cycle.
+        """
+        result = []
+        # Make a shallow copy of the adjacency list
+        alist = {}
+        for k, v in self.adjacency_list.items():
+            alist[k] = v[:]
+        while True:
+            # See what we can remove in this run
+            to_remove = []
+            for k, v in list(alist.items())[:]:
+                if not v:
+                    to_remove.append(k)
+                    del alist[k]
+            if not to_remove:
+                # What's left in alist (if anything) is a cycle.
+                break
+            # Remove from the adjacency list of others
+            for k, v in alist.items():
+                alist[k] = [(d, r) for d, r in v if d not in to_remove]
+            logger.debug('Moving to result: %s',
+                         ['%s (%s)' % (d.name, d.version) for d in to_remove])
+            result.extend(to_remove)
+        return result, list(alist.keys())
+
+    def __repr__(self):
+        """Representation of the graph"""
+        output = []
+        for dist, adjs in self.adjacency_list.items():
+            output.append(self.repr_node(dist))
+        return '\n'.join(output)
+
+
+def make_graph(dists, scheme='default'):
+    """Makes a dependency graph from the given distributions.
+
+    :parameter dists: a list of distributions
+    :type dists: list of :class:`distutils2.database.InstalledDistribution` and
+                 :class:`distutils2.database.EggInfoDistribution` instances
+    :rtype: a :class:`DependencyGraph` instance
+    """
+    scheme = get_scheme(scheme)
+    graph = DependencyGraph()
+    provided = {}  # maps names to lists of (version, dist) tuples
+
+    # first, build the graph and find out what's provided
+    for dist in dists:
+        graph.add_distribution(dist)
+
+        for p in dist.provides:
+            name, version = parse_name_and_version(p)
+            logger.debug('Add to provided: %s, %s, %s', name, version, dist)
+            provided.setdefault(name, []).append((version, dist))
+
+    # now make the edges
+    for dist in dists:
+        requires = (dist.run_requires | dist.meta_requires |
+                    dist.build_requires | dist.dev_requires)
+        for req in requires:
+            try:
+                matcher = scheme.matcher(req)
+            except UnsupportedVersionError:
+                # XXX compat-mode if cannot read the version
+                logger.warning('could not read version %r - using name only',
+                               req)
+                name = req.split()[0]
+                matcher = scheme.matcher(name)
+
+            name = matcher.key   # case-insensitive
+
+            matched = False
+            if name in provided:
+                for version, provider in provided[name]:
+                    try:
+                        match = matcher.match(version)
+                    except UnsupportedVersionError:
+                        match = False
+
+                    if match:
+                        graph.add_edge(dist, provider, req)
+                        matched = True
+                        break
+            if not matched:
+                graph.add_missing(dist, req)
+    return graph
+
+
+def get_dependent_dists(dists, dist):
+    """Recursively generate a list of distributions from *dists* that are
+    dependent on *dist*.
+
+    :param dists: a list of distributions
+    :param dist: a distribution, member of *dists* for which we are interested
+    """
+    if dist not in dists:
+        raise DistlibException('given distribution %r is not a member '
+                               'of the list' % dist.name)
+    graph = make_graph(dists)
+
+    dep = [dist]  # dependent distributions
+    todo = graph.reverse_list[dist]  # list of nodes we should inspect
+
+    while todo:
+        d = todo.pop()
+        dep.append(d)
+        for succ in graph.reverse_list[d]:
+            if succ not in dep:
+                todo.append(succ)
+
+    dep.pop(0)  # remove dist from dep, was there to prevent infinite loops
+    return dep
+
+
+def get_required_dists(dists, dist):
+    """Recursively generate a list of distributions from *dists* that are
+    required by *dist*.
+
+    :param dists: a list of distributions
+    :param dist: a distribution, member of *dists* for which we are interested
+    """
+    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
+    todo = graph.adjacency_list[dist]  # list of nodes we should inspect
+
+    while todo:
+        d = todo.pop()[0]
+        req.append(d)
+        for pred in graph.adjacency_list[d]:
+            if pred not in req:
+                todo.append(pred)
+
+    return req
+
+
+def make_dist(name, version, **kwargs):
+    """
+    A convenience method for making a dist given just a name and version.
+    """
+    summary = kwargs.pop('summary', 'Placeholder for summary')
+    md = Metadata(**kwargs)
+    md.name = name
+    md.version = version
+    md.summary = summary or 'Placeholder for summary'
+    return Distribution(md)
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/database.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/database.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..982d4b60e50e5c00706cf3a3066cf9d344f6c5e6
GIT binary patch
literal 53896
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

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/index.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/index.py
new file mode 100644
index 0000000..2406be2
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/index.py
@@ -0,0 +1,516 @@
+# -*- coding: utf-8 -*-
+#
+# Copyright (C) 2013 Vinay Sajip.
+# Licensed to the Python Software Foundation under a contributor agreement.
+# See LICENSE.txt and CONTRIBUTORS.txt.
+#
+import hashlib
+import logging
+import os
+import shutil
+import subprocess
+import tempfile
+try:
+    from threading import Thread
+except ImportError:
+    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
+
+logger = logging.getLogger(__name__)
+
+DEFAULT_INDEX = 'https://pypi.python.org/pypi'
+DEFAULT_REALM = 'pypi'
+
+class PackageIndex(object):
+    """
+    This class represents a package index compatible with PyPI, the Python
+    Package Index.
+    """
+
+    boundary = b'----------ThIs_Is_tHe_distlib_index_bouNdaRY_$'
+
+    def __init__(self, url=None):
+        """
+        Initialise an instance.
+
+        :param url: The URL of the index. If not specified, the URL for PyPI is
+                    used.
+        """
+        self.url = url or DEFAULT_INDEX
+        self.read_configuration()
+        scheme, netloc, path, params, query, frag = urlparse(self.url)
+        if params or query or frag or scheme not in ('http', 'https'):
+            raise DistlibException('invalid repository: %s' % self.url)
+        self.password_handler = None
+        self.ssl_verifier = None
+        self.gpg = None
+        self.gpg_home = None
+        with open(os.devnull, 'w') as sink:
+            # Use gpg by default rather than gpg2, as gpg2 insists on
+            # prompting for passwords
+            for s in ('gpg', 'gpg2'):
+                try:
+                    rc = subprocess.check_call([s, '--version'], stdout=sink,
+                                               stderr=sink)
+                    if rc == 0:
+                        self.gpg = s
+                        break
+                except OSError:
+                    pass
+
+    def _get_pypirc_command(self):
+        """
+        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)
+
+    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.
+        """
+        # get distutils to do the work
+        c = self._get_pypirc_command()
+        c.repository = self.url
+        cfg = c._read_pypirc()
+        self.username = cfg.get('username')
+        self.password = cfg.get('password')
+        self.realm = cfg.get('realm', 'pypi')
+        self.url = cfg.get('repository', self.url)
+
+    def save_configuration(self):
+        """
+        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)
+
+    def check_credentials(self):
+        """
+        Check that ``username`` and ``password`` have been set, and raise an
+        exception if not.
+        """
+        if self.username is None or self.password is None:
+            raise DistlibException('username and password must be set')
+        pm = HTTPPasswordMgr()
+        _, netloc, _, _, _, _ = urlparse(self.url)
+        pm.add_password(self.realm, netloc, self.username, self.password)
+        self.password_handler = HTTPBasicAuthHandler(pm)
+
+    def register(self, metadata):
+        """
+        Register a distribution on PyPI, using the provided metadata.
+
+        :param metadata: A :class:`Metadata` instance defining at least a name
+                         and version number for the distribution to be
+                         registered.
+        :return: The HTTP response received from PyPI upon submission of the
+                request.
+        """
+        self.check_credentials()
+        metadata.validate()
+        d = metadata.todict()
+        d[':action'] = 'verify'
+        request = self.encode_request(d.items(), [])
+        response = self.send_request(request)
+        d[':action'] = 'submit'
+        request = self.encode_request(d.items(), [])
+        return self.send_request(request)
+
+    def _reader(self, name, stream, outbuf):
+        """
+        Thread runner for reading lines of from a subprocess into a buffer.
+
+        :param name: The logical name of the stream (used for logging only).
+        :param stream: The stream to read from. This will typically a pipe
+                       connected to the output stream of a subprocess.
+        :param outbuf: The list to append the read lines to.
+        """
+        while True:
+            s = stream.readline()
+            if not s:
+                break
+            s = s.decode('utf-8').rstrip()
+            outbuf.append(s)
+            logger.debug('%s: %s' % (name, s))
+        stream.close()
+
+    def get_sign_command(self, filename, signer, sign_password,
+                         keystore=None):
+        """
+        Return a suitable command for signing a file.
+
+        :param filename: The pathname to the file to be signed.
+        :param signer: The identifier of the signer of the file.
+        :param sign_password: The passphrase for the signer's
+                              private key used for signing.
+        :param keystore: The path to a directory which contains the keys
+                         used in verification. If not specified, the
+                         instance's ``gpg_home`` attribute is used instead.
+        :return: The signing command as a list suitable to be
+                 passed to :class:`subprocess.Popen`.
+        """
+        cmd = [self.gpg, '--status-fd', '2', '--no-tty']
+        if keystore is None:
+            keystore = self.gpg_home
+        if keystore:
+            cmd.extend(['--homedir', keystore])
+        if sign_password is not None:
+            cmd.extend(['--batch', '--passphrase-fd', '0'])
+        td = tempfile.mkdtemp()
+        sf = os.path.join(td, os.path.basename(filename) + '.asc')
+        cmd.extend(['--detach-sign', '--armor', '--local-user',
+                    signer, '--output', sf, filename])
+        logger.debug('invoking: %s', ' '.join(cmd))
+        return cmd, sf
+
+    def run_command(self, cmd, input_data=None):
+        """
+        Run a command in a child process , passing it any input data specified.
+
+        :param cmd: The command to run.
+        :param input_data: If specified, this must be a byte string containing
+                           data to be sent to the child process.
+        :return: A tuple consisting of the subprocess' exit code, a list of
+                 lines read from the subprocess' ``stdout``, and a list of
+                 lines read from the subprocess' ``stderr``.
+        """
+        kwargs = {
+            'stdout': subprocess.PIPE,
+            'stderr': subprocess.PIPE,
+        }
+        if input_data is not None:
+            kwargs['stdin'] = subprocess.PIPE
+        stdout = []
+        stderr = []
+        p = subprocess.Popen(cmd, **kwargs)
+        # We don't use communicate() here because we may need to
+        # get clever with interacting with the command
+        t1 = Thread(target=self._reader, args=('stdout', p.stdout, stdout))
+        t1.start()
+        t2 = Thread(target=self._reader, args=('stderr', p.stderr, stderr))
+        t2.start()
+        if input_data is not None:
+            p.stdin.write(input_data)
+            p.stdin.close()
+
+        p.wait()
+        t1.join()
+        t2.join()
+        return p.returncode, stdout, stderr
+
+    def sign_file(self, filename, signer, sign_password, keystore=None):
+        """
+        Sign a file.
+
+        :param filename: The pathname to the file to be signed.
+        :param signer: The identifier of the signer of the file.
+        :param sign_password: The passphrase for the signer's
+                              private key used for signing.
+        :param keystore: The path to a directory which contains the keys
+                         used in signing. If not specified, the instance's
+                         ``gpg_home`` attribute is used instead.
+        :return: The absolute pathname of the file where the signature is
+                 stored.
+        """
+        cmd, sig_file = self.get_sign_command(filename, signer, sign_password,
+                                              keystore)
+        rc, stdout, stderr = self.run_command(cmd,
+                                              sign_password.encode('utf-8'))
+        if rc != 0:
+            raise DistlibException('sign command failed with error '
+                                   'code %s' % rc)
+        return sig_file
+
+    def upload_file(self, metadata, filename, signer=None, sign_password=None,
+                    filetype='sdist', pyversion='source', keystore=None):
+        """
+        Upload a release file to the index.
+
+        :param metadata: A :class:`Metadata` instance defining at least a name
+                         and version number for the file to be uploaded.
+        :param filename: The pathname of the file to be uploaded.
+        :param signer: The identifier of the signer of the file.
+        :param sign_password: The passphrase for the signer's
+                              private key used for signing.
+        :param filetype: The type of the file being uploaded. This is the
+                        distutils command which produced that file, e.g.
+                        ``sdist`` or ``bdist_wheel``.
+        :param pyversion: The version of Python which the release relates
+                          to. For code compatible with any Python, this would
+                          be ``source``, otherwise it would be e.g. ``3.2``.
+        :param keystore: The path to a directory which contains the keys
+                         used in signing. If not specified, the instance's
+                         ``gpg_home`` attribute is used instead.
+        :return: The HTTP response received from PyPI upon submission of the
+                request.
+        """
+        self.check_credentials()
+        if not os.path.exists(filename):
+            raise DistlibException('not found: %s' % filename)
+        metadata.validate()
+        d = metadata.todict()
+        sig_file = None
+        if signer:
+            if not self.gpg:
+                logger.warning('no signing program available - not signed')
+            else:
+                sig_file = self.sign_file(filename, signer, sign_password,
+                                          keystore)
+        with open(filename, 'rb') as f:
+            file_data = f.read()
+        md5_digest = hashlib.md5(file_data).hexdigest()
+        sha256_digest = hashlib.sha256(file_data).hexdigest()
+        d.update({
+            ':action': 'file_upload',
+            'protocol_version': '1',
+            'filetype': filetype,
+            'pyversion': pyversion,
+            'md5_digest': md5_digest,
+            'sha256_digest': sha256_digest,
+        })
+        files = [('content', os.path.basename(filename), file_data)]
+        if sig_file:
+            with open(sig_file, 'rb') as f:
+                sig_data = f.read()
+            files.append(('gpg_signature', os.path.basename(sig_file),
+                         sig_data))
+            shutil.rmtree(os.path.dirname(sig_file))
+        request = self.encode_request(d.items(), files)
+        return self.send_request(request)
+
+    def upload_documentation(self, metadata, doc_dir):
+        """
+        Upload documentation to the index.
+
+        :param metadata: A :class:`Metadata` instance defining at least a name
+                         and version number for the documentation to be
+                         uploaded.
+        :param doc_dir: The pathname of the directory which contains the
+                        documentation. This should be the directory that
+                        contains the ``index.html`` for the documentation.
+        :return: The HTTP response received from PyPI upon submission of the
+                request.
+        """
+        self.check_credentials()
+        if not os.path.isdir(doc_dir):
+            raise DistlibException('not a directory: %r' % doc_dir)
+        fn = os.path.join(doc_dir, 'index.html')
+        if not os.path.exists(fn):
+            raise DistlibException('not found: %r' % fn)
+        metadata.validate()
+        name, version = metadata.name, metadata.version
+        zip_data = zip_dir(doc_dir).getvalue()
+        fields = [(':action', 'doc_upload'),
+                  ('name', name), ('version', version)]
+        files = [('content', name, zip_data)]
+        request = self.encode_request(fields, files)
+        return self.send_request(request)
+
+    def get_verify_command(self, signature_filename, data_filename,
+                           keystore=None):
+        """
+        Return a suitable command for verifying a file.
+
+        :param signature_filename: The pathname to the file containing the
+                                   signature.
+        :param data_filename: The pathname to the file containing the
+                              signed data.
+        :param keystore: The path to a directory which contains the keys
+                         used in verification. If not specified, the
+                         instance's ``gpg_home`` attribute is used instead.
+        :return: The verifying command as a list suitable to be
+                 passed to :class:`subprocess.Popen`.
+        """
+        cmd = [self.gpg, '--status-fd', '2', '--no-tty']
+        if keystore is None:
+            keystore = self.gpg_home
+        if keystore:
+            cmd.extend(['--homedir', keystore])
+        cmd.extend(['--verify', signature_filename, data_filename])
+        logger.debug('invoking: %s', ' '.join(cmd))
+        return cmd
+
+    def verify_signature(self, signature_filename, data_filename,
+                         keystore=None):
+        """
+        Verify a signature for a file.
+
+        :param signature_filename: The pathname to the file containing the
+                                   signature.
+        :param data_filename: The pathname to the file containing the
+                              signed data.
+        :param keystore: The path to a directory which contains the keys
+                         used in verification. If not specified, the
+                         instance's ``gpg_home`` attribute is used instead.
+        :return: True if the signature was verified, else False.
+        """
+        if not self.gpg:
+            raise DistlibException('verification unavailable because gpg '
+                                   'unavailable')
+        cmd = self.get_verify_command(signature_filename, data_filename,
+                                      keystore)
+        rc, stdout, stderr = self.run_command(cmd)
+        if rc not in (0, 1):
+            raise DistlibException('verify command failed with error '
+                             'code %s' % rc)
+        return rc == 0
+
+    def download_file(self, url, destfile, digest=None, reporthook=None):
+        """
+        This is a convenience method for downloading a file from an URL.
+        Normally, this will be a file from the index, though currently
+        no check is made for this (i.e. a file can be downloaded from
+        anywhere).
+
+        The method is just like the :func:`urlretrieve` function in the
+        standard library, except that it allows digest computation to be
+        done during download and checking that the downloaded data
+        matched any expected value.
+
+        :param url: The URL of the file to be downloaded (assumed to be
+                    available via an HTTP GET request).
+        :param destfile: The pathname where the downloaded file is to be
+                         saved.
+        :param digest: If specified, this must be a (hasher, value)
+                       tuple, where hasher is the algorithm used (e.g.
+                       ``'md5'``) and ``value`` is the expected value.
+        :param reporthook: The same as for :func:`urlretrieve` in the
+                           standard library.
+        """
+        if digest is None:
+            digester = None
+            logger.debug('No digest specified')
+        else:
+            if isinstance(digest, (list, tuple)):
+                hasher, digest = digest
+            else:
+                hasher = 'md5'
+            digester = getattr(hashlib, hasher)()
+            logger.debug('Digest specified: %s' % digest)
+        # The following code is equivalent to urlretrieve.
+        # We need to do it this way so that we can compute the
+        # digest of the file as we go.
+        with open(destfile, 'wb') as dfp:
+            # addinfourl is not a context manager on 2.x
+            # so we have to use try/finally
+            sfp = self.send_request(Request(url))
+            try:
+                headers = sfp.info()
+                blocksize = 8192
+                size = -1
+                read = 0
+                blocknum = 0
+                if "content-length" in headers:
+                    size = int(headers["Content-Length"])
+                if reporthook:
+                    reporthook(blocknum, blocksize, size)
+                while True:
+                    block = sfp.read(blocksize)
+                    if not block:
+                        break
+                    read += len(block)
+                    dfp.write(block)
+                    if digester:
+                        digester.update(block)
+                    blocknum += 1
+                    if reporthook:
+                        reporthook(blocknum, blocksize, size)
+            finally:
+                sfp.close()
+
+        # check that we got the whole file, if we can
+        if size >= 0 and read < size:
+            raise DistlibException(
+                'retrieval incomplete: got only %d out of %d bytes'
+                % (read, size))
+        # if we have a digest, it must match.
+        if digester:
+            actual = digester.hexdigest()
+            if digest != actual:
+                raise DistlibException('%s digest mismatch for %s: expected '
+                                       '%s, got %s' % (hasher, destfile,
+                                                       digest, actual))
+            logger.debug('Digest verified: %s', digest)
+
+    def send_request(self, req):
+        """
+        Send a standard library :class:`Request` to PyPI and return its
+        response.
+
+        :param req: The request to send.
+        :return: The HTTP response from PyPI (a standard library HTTPResponse).
+        """
+        handlers = []
+        if self.password_handler:
+            handlers.append(self.password_handler)
+        if self.ssl_verifier:
+            handlers.append(self.ssl_verifier)
+        opener = build_opener(*handlers)
+        return opener.open(req)
+
+    def encode_request(self, fields, files):
+        """
+        Encode fields and files for posting to an HTTP server.
+
+        :param fields: The fields to send as a list of (fieldname, value)
+                       tuples.
+        :param files: The files to send as a list of (fieldname, filename,
+                      file_bytes) tuple.
+        """
+        # Adapted from packaging, which in turn was adapted from
+        # http://code.activestate.com/recipes/146306
+
+        parts = []
+        boundary = self.boundary
+        for k, values in fields:
+            if not isinstance(values, (list, tuple)):
+                values = [values]
+
+            for v in values:
+                parts.extend((
+                    b'--' + boundary,
+                    ('Content-Disposition: form-data; name="%s"' %
+                     k).encode('utf-8'),
+                    b'',
+                    v.encode('utf-8')))
+        for key, filename, value in files:
+            parts.extend((
+                b'--' + boundary,
+                ('Content-Disposition: form-data; name="%s"; filename="%s"' %
+                 (key, filename)).encode('utf-8'),
+                b'',
+                value))
+
+        parts.extend((b'--' + boundary + b'--', b''))
+
+        body = b'\r\n'.join(parts)
+        ct = b'multipart/form-data; boundary=' + boundary
+        headers = {
+            'Content-type': ct,
+            'Content-length': str(len(body))
+        }
+        return Request(self.url, body, headers)
+
+    def search(self, terms, operator=None):
+        if isinstance(terms, string_types):
+            terms = {'name': terms}
+        rpc_proxy = ServerProxy(self.url, timeout=3.0)
+        try:
+            return rpc_proxy.search(terms, operator or 'and')
+        finally:
+            rpc_proxy('close')()
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/index.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/index.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..9823366034b8118783d69e137a009e0662aab829
GIT binary patch
literal 20999
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

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/locators.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/locators.py
new file mode 100644
index 0000000..5c655c3
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/locators.py
@@ -0,0 +1,1295 @@
+# -*- coding: utf-8 -*-
+#
+# Copyright (C) 2012-2015 Vinay Sajip.
+# Licensed to the Python Software Foundation under a contributor agreement.
+# See LICENSE.txt and CONTRIBUTORS.txt.
+#
+
+import gzip
+from io import BytesIO
+import json
+import logging
+import os
+import posixpath
+import re
+try:
+    import threading
+except ImportError:  # pragma: no cover
+    import dummy_threading as threading
+import zlib
+
+from . import DistlibException
+from .compat import (urljoin, urlparse, urlunparse, url2pathname, pathname2url,
+                     queue, quote, unescape, string_types, 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 .version import get_scheme, UnsupportedVersionError
+from .wheel import Wheel, is_compatible
+
+logger = logging.getLogger(__name__)
+
+HASHER_HASH = re.compile(r'^(\w+)=([a-f0-9]+)')
+CHARSET = re.compile(r';\s*charset\s*=\s*(.*)\s*$', re.I)
+HTML_CONTENT_TYPE = re.compile('text/html|application/x(ht)?ml')
+DEFAULT_INDEX = 'https://pypi.python.org/pypi'
+
+def get_all_distribution_names(url=None):
+    """
+    Return all distribution names known by an index.
+    :param url: The URL of the index.
+    :return: A list of all known distribution names.
+    """
+    if url is None:
+        url = DEFAULT_INDEX
+    client = ServerProxy(url, timeout=3.0)
+    try:
+        return client.list_packages()
+    finally:
+        client('close')()
+
+class RedirectHandler(BaseRedirectHandler):
+    """
+    A class to work around a bug in some Python 3.2.x releases.
+    """
+    # There's a bug in the base version for some 3.2.x
+    # (e.g. 3.2.2 on Ubuntu Oneiric). If a Location header
+    # returns e.g. /abc, it bails because it says the scheme ''
+    # is bogus, when actually it should use the request's
+    # URL for the scheme. See Python issue #13696.
+    def http_error_302(self, req, fp, code, msg, headers):
+        # Some servers (incorrectly) return multiple Location headers
+        # (so probably same goes for URI).  Use first header.
+        newurl = None
+        for key in ('location', 'uri'):
+            if key in headers:
+                newurl = headers[key]
+                break
+        if newurl is None:  # pragma: no cover
+            return
+        urlparts = urlparse(newurl)
+        if urlparts.scheme == '':
+            newurl = urljoin(req.get_full_url(), newurl)
+            if hasattr(headers, 'replace_header'):
+                headers.replace_header(key, newurl)
+            else:
+                headers[key] = newurl
+        return BaseRedirectHandler.http_error_302(self, req, fp, code, msg,
+                                                  headers)
+
+    http_error_301 = http_error_303 = http_error_307 = http_error_302
+
+class Locator(object):
+    """
+    A base class for locators - things that locate distributions.
+    """
+    source_extensions = ('.tar.gz', '.tar.bz2', '.tar', '.zip', '.tgz', '.tbz')
+    binary_extensions = ('.egg', '.exe', '.whl')
+    excluded_extensions = ('.pdf',)
+
+    # A list of tags indicating which wheels you want to match. The default
+    # value of None matches against the tags compatible with the running
+    # Python. If you want to match other values, set wheel_tags on a locator
+    # instance to a list of tuples (pyver, abi, arch) which you want to match.
+    wheel_tags = None
+
+    downloadable_extensions = source_extensions + ('.whl',)
+
+    def __init__(self, scheme='default'):
+        """
+        Initialise an instance.
+        :param scheme: Because locators look for most recent versions, they
+                       need to know the version scheme to use. This specifies
+                       the current PEP-recommended scheme - use ``'legacy'``
+                       if you need to support existing distributions on PyPI.
+        """
+        self._cache = {}
+        self.scheme = scheme
+        # Because of bugs in some of the handlers on some of the platforms,
+        # we use our own opener rather than just using urlopen.
+        self.opener = build_opener(RedirectHandler())
+        # If get_project() is called from locate(), the matcher instance
+        # is set from the requirement passed to locate(). See issue #18 for
+        # why this can be useful to know.
+        self.matcher = None
+        self.errors = queue.Queue()
+
+    def get_errors(self):
+        """
+        Return any errors which have occurred.
+        """
+        result = []
+        while not self.errors.empty():  # pragma: no cover
+            try:
+                e = self.errors.get(False)
+                result.append(e)
+            except self.errors.Empty:
+                continue
+            self.errors.task_done()
+        return result
+
+    def clear_errors(self):
+        """
+        Clear any errors which may have been logged.
+        """
+        # Just get the errors and throw them away
+        self.get_errors()
+
+    def clear_cache(self):
+        self._cache.clear()
+
+    def _get_scheme(self):
+        return self._scheme
+
+    def _set_scheme(self, value):
+        self._scheme = value
+
+    scheme = property(_get_scheme, _set_scheme)
+
+    def _get_project(self, name):
+        """
+        For a given project, get a dictionary mapping available versions to Distribution
+        instances.
+
+        This should be implemented in subclasses.
+
+        If called from a locate() request, self.matcher will be set to a
+        matcher for the requirement to satisfy, otherwise it will be None.
+        """
+        raise NotImplementedError('Please implement in the subclass')
+
+    def get_distribution_names(self):
+        """
+        Return all the distribution names known to this locator.
+        """
+        raise NotImplementedError('Please implement in the subclass')
+
+    def get_project(self, name):
+        """
+        For a given project, get a dictionary mapping available versions to Distribution
+        instances.
+
+        This calls _get_project to do all the work, and just implements a caching layer on top.
+        """
+        if self._cache is None:  # pragma: no cover
+            result = self._get_project(name)
+        elif name in self._cache:
+            result = self._cache[name]
+        else:
+            self.clear_errors()
+            result = self._get_project(name)
+            self._cache[name] = result
+        return result
+
+    def score_url(self, url):
+        """
+        Give an url a score which can be used to choose preferred URLs
+        for a given project release.
+        """
+        t = urlparse(url)
+        basename = posixpath.basename(t.path)
+        compatible = True
+        is_wheel = basename.endswith('.whl')
+        is_downloadable = basename.endswith(self.downloadable_extensions)
+        if is_wheel:
+            compatible = is_compatible(Wheel(basename), self.wheel_tags)
+        return (t.scheme == 'https', 'pypi.python.org' in t.netloc,
+                is_downloadable, is_wheel, compatible, basename)
+
+    def prefer_url(self, url1, url2):
+        """
+        Choose one of two URLs where both are candidates for distribution
+        archives for the same version of a distribution (for example,
+        .tar.gz vs. zip).
+
+        The current implementation favours https:// URLs over http://, archives
+        from PyPI over those from other locations, wheel compatibility (if a
+        wheel) and then the archive name.
+        """
+        result = url2
+        if url1:
+            s1 = self.score_url(url1)
+            s2 = self.score_url(url2)
+            if s1 > s2:
+                result = url1
+            if result != url2:
+                logger.debug('Not replacing %r with %r', url1, url2)
+            else:
+                logger.debug('Replacing %r with %r', url1, url2)
+        return result
+
+    def split_filename(self, filename, project_name):
+        """
+        Attempt to split a filename in project name, version and Python version.
+        """
+        return split_filename(filename, project_name)
+
+    def convert_url_to_download_info(self, url, project_name):
+        """
+        See if a URL is a candidate for a download URL for a project (the URL
+        has typically been scraped from an HTML page).
+
+        If it is, a dictionary is returned with keys "name", "version",
+        "filename" and "url"; otherwise, None is returned.
+        """
+        def same_project(name1, name2):
+            return normalize_name(name1) == normalize_name(name2)
+
+        result = None
+        scheme, netloc, path, params, query, frag = urlparse(url)
+        if frag.lower().startswith('egg='):  # pragma: no cover
+            logger.debug('%s: version hint in fragment: %r',
+                         project_name, frag)
+        m = HASHER_HASH.match(frag)
+        if m:
+            algo, digest = m.groups()
+        else:
+            algo, digest = None, None
+        origpath = path
+        if path and path[-1] == '/':  # pragma: no cover
+            path = path[:-1]
+        if path.endswith('.whl'):
+            try:
+                wheel = Wheel(path)
+                if not is_compatible(wheel, self.wheel_tags):
+                    logger.debug('Wheel not compatible: %s', path)
+                else:
+                    if project_name is None:
+                        include = True
+                    else:
+                        include = same_project(wheel.name, project_name)
+                    if include:
+                        result = {
+                            'name': wheel.name,
+                            'version': wheel.version,
+                            'filename': wheel.filename,
+                            'url': urlunparse((scheme, netloc, origpath,
+                                               params, query, '')),
+                            'python-version': ', '.join(
+                                ['.'.join(list(v[2:])) for v in wheel.pyver]),
+                        }
+            except Exception as e:  # pragma: no cover
+                logger.warning('invalid path for wheel: %s', path)
+        elif not path.endswith(self.downloadable_extensions):  # pragma: no cover
+            logger.debug('Not downloadable: %s', path)
+        else:  # downloadable extension
+            path = filename = posixpath.basename(path)
+            for ext in self.downloadable_extensions:
+                if path.endswith(ext):
+                    path = path[:-len(ext)]
+                    t = self.split_filename(path, project_name)
+                    if not t:  # pragma: no cover
+                        logger.debug('No match for project/version: %s', path)
+                    else:
+                        name, version, pyver = t
+                        if not project_name or same_project(project_name, name):
+                            result = {
+                                'name': name,
+                                'version': version,
+                                'filename': filename,
+                                'url': urlunparse((scheme, netloc, origpath,
+                                                   params, query, '')),
+                                #'packagetype': 'sdist',
+                            }
+                            if pyver:  # pragma: no cover
+                                result['python-version'] = pyver
+                    break
+        if result and algo:
+            result['%s_digest' % algo] = digest
+        return result
+
+    def _get_digest(self, info):
+        """
+        Get a digest from a dictionary by looking at keys of the form
+        'algo_digest'.
+
+        Returns a 2-tuple (algo, digest) if found, else None. Currently
+        looks only for SHA256, then MD5.
+        """
+        result = None
+        for algo in ('sha256', 'md5'):
+            key = '%s_digest' % algo
+            if key in info:
+                result = (algo, info[key])
+                break
+        return result
+
+    def _update_version_data(self, result, info):
+        """
+        Update a result dictionary (the final result from _get_project) with a
+        dictionary for a specific version, which typically holds information
+        gleaned from a filename or URL for an archive for the distribution.
+        """
+        name = info.pop('name')
+        version = info.pop('version')
+        if version in result:
+            dist = result[version]
+            md = dist.metadata
+        else:
+            dist = make_dist(name, version, scheme=self.scheme)
+            md = dist.metadata
+        dist.digest = digest = self._get_digest(info)
+        url = info['url']
+        result['digests'][url] = digest
+        if md.source_url != info['url']:
+            md.source_url = self.prefer_url(md.source_url, url)
+            result['urls'].setdefault(version, set()).add(url)
+        dist.locator = self
+        result[version] = dist
+
+    def locate(self, requirement, prereleases=False):
+        """
+        Find the most recent distribution which matches the given
+        requirement.
+
+        :param requirement: A requirement of the form 'foo (1.0)' or perhaps
+                            'foo (>= 1.0, < 2.0, != 1.3)'
+        :param prereleases: If ``True``, allow pre-release versions
+                            to be located. Otherwise, pre-release versions
+                            are not returned.
+        :return: A :class:`Distribution` instance, or ``None`` if no such
+                 distribution could be located.
+        """
+        result = None
+        r = parse_requirement(requirement)
+        if r is None:  # pragma: no cover
+            raise DistlibException('Not a valid requirement: %r' % requirement)
+        scheme = get_scheme(self.scheme)
+        self.matcher = matcher = scheme.matcher(r.requirement)
+        logger.debug('matcher: %s (%s)', matcher, type(matcher).__name__)
+        versions = self.get_project(r.name)
+        if len(versions) > 2:   # urls and digests keys are present
+            # sometimes, versions are invalid
+            slist = []
+            vcls = matcher.version_class
+            for k in versions:
+                if k in ('urls', 'digests'):
+                    continue
+                try:
+                    if not matcher.match(k):
+                        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)
+                except Exception:  # pragma: no cover
+                    logger.warning('error matching %s with %r', matcher, k)
+                    pass # slist.append(k)
+            if len(slist) > 1:
+                slist = sorted(slist, key=scheme.key)
+            if slist:
+                logger.debug('sorted list: %s', slist)
+                version = slist[-1]
+                result = versions[version]
+        if result:
+            if r.extras:
+                result.extras = r.extras
+            result.download_urls = versions.get('urls', {}).get(version, set())
+            d = {}
+            sd = versions.get('digests', {})
+            for url in result.download_urls:
+                if url in sd:  # pragma: no cover
+                    d[url] = sd[url]
+            result.digests = d
+        self.matcher = None
+        return result
+
+
+class PyPIRPCLocator(Locator):
+    """
+    This locator uses XML-RPC to locate distributions. It therefore
+    cannot be used with simple mirrors (that only mirror file content).
+    """
+    def __init__(self, url, **kwargs):
+        """
+        Initialise an instance.
+
+        :param url: The URL to use for XML-RPC.
+        :param kwargs: Passed to the superclass constructor.
+        """
+        super(PyPIRPCLocator, self).__init__(**kwargs)
+        self.base_url = url
+        self.client = ServerProxy(url, timeout=3.0)
+
+    def get_distribution_names(self):
+        """
+        Return all the distribution names known to this locator.
+        """
+        return set(self.client.list_packages())
+
+    def _get_project(self, name):
+        result = {'urls': {}, 'digests': {}}
+        versions = self.client.package_releases(name, True)
+        for v in versions:
+            urls = self.client.release_urls(name, v)
+            data = self.client.release_data(name, v)
+            metadata = Metadata(scheme=self.scheme)
+            metadata.name = data['name']
+            metadata.version = data['version']
+            metadata.license = data.get('license')
+            metadata.keywords = data.get('keywords', [])
+            metadata.summary = data.get('summary')
+            dist = Distribution(metadata)
+            if urls:
+                info = urls[0]
+                metadata.source_url = info['url']
+                dist.digest = self._get_digest(info)
+                dist.locator = self
+                result[v] = dist
+                for info in urls:
+                    url = info['url']
+                    digest = self._get_digest(info)
+                    result['urls'].setdefault(v, set()).add(url)
+                    result['digests'][url] = digest
+        return result
+
+class PyPIJSONLocator(Locator):
+    """
+    This locator uses PyPI's JSON interface. It's very limited in functionality
+    and probably not worth using.
+    """
+    def __init__(self, url, **kwargs):
+        super(PyPIJSONLocator, self).__init__(**kwargs)
+        self.base_url = ensure_slash(url)
+
+    def get_distribution_names(self):
+        """
+        Return all the distribution names known to this locator.
+        """
+        raise NotImplementedError('Not available from this locator')
+
+    def _get_project(self, name):
+        result = {'urls': {}, 'digests': {}}
+        url = urljoin(self.base_url, '%s/json' % quote(name))
+        try:
+            resp = self.opener.open(url)
+            data = resp.read().decode() # for now
+            d = json.loads(data)
+            md = Metadata(scheme=self.scheme)
+            data = d['info']
+            md.name = data['name']
+            md.version = data['version']
+            md.license = data.get('license')
+            md.keywords = data.get('keywords', [])
+            md.summary = data.get('summary')
+            dist = Distribution(md)
+            dist.locator = self
+            urls = d['urls']
+            result[md.version] = dist
+            for info in d['urls']:
+                url = info['url']
+                dist.download_urls.add(url)
+                dist.digests[url] = self._get_digest(info)
+                result['urls'].setdefault(md.version, set()).add(url)
+                result['digests'][url] = self._get_digest(info)
+            # Now get other releases
+            for version, infos in d['releases'].items():
+                if version == md.version:
+                    continue    # already done
+                omd = Metadata(scheme=self.scheme)
+                omd.name = md.name
+                omd.version = version
+                odist = Distribution(omd)
+                odist.locator = self
+                result[version] = odist
+                for info in infos:
+                    url = info['url']
+                    odist.download_urls.add(url)
+                    odist.digests[url] = self._get_digest(info)
+                    result['urls'].setdefault(version, set()).add(url)
+                    result['digests'][url] = self._get_digest(info)
+#            for info in urls:
+#                md.source_url = info['url']
+#                dist.digest = self._get_digest(info)
+#                dist.locator = self
+#                for info in urls:
+#                    url = info['url']
+#                    result['urls'].setdefault(md.version, set()).add(url)
+#                    result['digests'][url] = self._get_digest(info)
+        except Exception as e:
+            self.errors.put(text_type(e))
+            logger.exception('JSON fetch failed: %s', e)
+        return result
+
+
+class Page(object):
+    """
+    This class represents a scraped HTML page.
+    """
+    # The following slightly hairy-looking regex just looks for the contents of
+    # an anchor link, which has an attribute "href" either immediately preceded
+    # or immediately followed by a "rel" attribute. The attribute values can be
+    # declared with double quotes, single quotes or no quotes - which leads to
+    # the length of the expression.
+    _href = re.compile("""
+(rel\\s*=\\s*(?:"(?P<rel1>[^"]*)"|'(?P<rel2>[^']*)'|(?P<rel3>[^>\\s\n]*))\\s+)?
+href\\s*=\\s*(?:"(?P<url1>[^"]*)"|'(?P<url2>[^']*)'|(?P<url3>[^>\\s\n]*))
+(\\s+rel\\s*=\\s*(?:"(?P<rel4>[^"]*)"|'(?P<rel5>[^']*)'|(?P<rel6>[^>\\s\n]*)))?
+""", re.I | re.S | re.X)
+    _base = re.compile(r"""<base\s+href\s*=\s*['"]?([^'">]+)""", re.I | re.S)
+
+    def __init__(self, data, url):
+        """
+        Initialise an instance with the Unicode page contents and the URL they
+        came from.
+        """
+        self.data = data
+        self.base_url = self.url = url
+        m = self._base.search(self.data)
+        if m:
+            self.base_url = m.group(1)
+
+    _clean_re = re.compile(r'[^a-z0-9$&+,/:;=?@.#%_\\|-]', re.I)
+
+    @cached_property
+    def links(self):
+        """
+        Return the URLs of all the links on a page together with information
+        about their "rel" attribute, for determining which ones to treat as
+        downloads and which ones to queue for further scraping.
+        """
+        def clean(url):
+            "Tidy up an URL."
+            scheme, netloc, path, params, query, frag = urlparse(url)
+            return urlunparse((scheme, netloc, quote(path),
+                               params, query, frag))
+
+        result = set()
+        for match in self._href.finditer(self.data):
+            d = match.groupdict('')
+            rel = (d['rel1'] or d['rel2'] or d['rel3'] or
+                   d['rel4'] or d['rel5'] or d['rel6'])
+            url = d['url1'] or d['url2'] or d['url3']
+            url = urljoin(self.base_url, url)
+            url = unescape(url)
+            url = self._clean_re.sub(lambda m: '%%%2x' % ord(m.group(0)), url)
+            result.add((url, rel))
+        # We sort the result, hoping to bring the most recent versions
+        # to the front
+        result = sorted(result, key=lambda t: t[0], reverse=True)
+        return result
+
+
+class SimpleScrapingLocator(Locator):
+    """
+    A locator which scrapes HTML pages to locate downloads for a distribution.
+    This runs multiple threads to do the I/O; performance is at least as good
+    as pip's PackageFinder, which works in an analogous fashion.
+    """
+
+    # These are used to deal with various Content-Encoding schemes.
+    decoders = {
+        'deflate': zlib.decompress,
+        'gzip': lambda b: gzip.GzipFile(fileobj=BytesIO(d)).read(),
+        'none': lambda b: b,
+    }
+
+    def __init__(self, url, timeout=None, num_workers=10, **kwargs):
+        """
+        Initialise an instance.
+        :param url: The root URL to use for scraping.
+        :param timeout: The timeout, in seconds, to be applied to requests.
+                        This defaults to ``None`` (no timeout specified).
+        :param num_workers: The number of worker threads you want to do I/O,
+                            This defaults to 10.
+        :param kwargs: Passed to the superclass.
+        """
+        super(SimpleScrapingLocator, self).__init__(**kwargs)
+        self.base_url = ensure_slash(url)
+        self.timeout = timeout
+        self._page_cache = {}
+        self._seen = set()
+        self._to_fetch = queue.Queue()
+        self._bad_hosts = set()
+        self.skip_externals = False
+        self.num_workers = num_workers
+        self._lock = threading.RLock()
+        # See issue #45: we need to be resilient when the locator is used
+        # in a thread, e.g. with concurrent.futures. We can't use self._lock
+        # as it is for coordinating our internal threads - the ones created
+        # in _prepare_threads.
+        self._gplock = threading.RLock()
+        self.platform_check = False  # See issue #112
+
+    def _prepare_threads(self):
+        """
+        Threads are created only when get_project is called, and terminate
+        before it returns. They are there primarily to parallelise I/O (i.e.
+        fetching web pages).
+        """
+        self._threads = []
+        for i in range(self.num_workers):
+            t = threading.Thread(target=self._fetch)
+            t.setDaemon(True)
+            t.start()
+            self._threads.append(t)
+
+    def _wait_threads(self):
+        """
+        Tell all the threads to terminate (by sending a sentinel value) and
+        wait for them to do so.
+        """
+        # Note that you need two loops, since you can't say which
+        # thread will get each sentinel
+        for t in self._threads:
+            self._to_fetch.put(None)    # sentinel
+        for t in self._threads:
+            t.join()
+        self._threads = []
+
+    def _get_project(self, name):
+        result = {'urls': {}, 'digests': {}}
+        with self._gplock:
+            self.result = result
+            self.project_name = name
+            url = urljoin(self.base_url, '%s/' % quote(name))
+            self._seen.clear()
+            self._page_cache.clear()
+            self._prepare_threads()
+            try:
+                logger.debug('Queueing %s', url)
+                self._to_fetch.put(url)
+                self._to_fetch.join()
+            finally:
+                self._wait_threads()
+            del self.result
+        return result
+
+    platform_dependent = re.compile(r'\b(linux_(i\d86|x86_64|arm\w+)|'
+                                    r'win(32|_amd64)|macosx_?\d+)\b', re.I)
+
+    def _is_platform_dependent(self, url):
+        """
+        Does an URL refer to a platform-specific download?
+        """
+        return self.platform_dependent.search(url)
+
+    def _process_download(self, url):
+        """
+        See if an URL is a suitable download for a project.
+
+        If it is, register information in the result dictionary (for
+        _get_project) about the specific version it's for.
+
+        Note that the return value isn't actually used other than as a boolean
+        value.
+        """
+        if self.platform_check and self._is_platform_dependent(url):
+            info = None
+        else:
+            info = self.convert_url_to_download_info(url, self.project_name)
+        logger.debug('process_download: %s -> %s', url, info)
+        if info:
+            with self._lock:    # needed because self.result is shared
+                self._update_version_data(self.result, info)
+        return info
+
+    def _should_queue(self, link, referrer, rel):
+        """
+        Determine whether a link URL from a referring page and with a
+        particular "rel" attribute should be queued for scraping.
+        """
+        scheme, netloc, path, _, _, _ = urlparse(link)
+        if path.endswith(self.source_extensions + self.binary_extensions +
+                         self.excluded_extensions):
+            result = False
+        elif self.skip_externals and not link.startswith(self.base_url):
+            result = False
+        elif not referrer.startswith(self.base_url):
+            result = False
+        elif rel not in ('homepage', 'download'):
+            result = False
+        elif scheme not in ('http', 'https', 'ftp'):
+            result = False
+        elif self._is_platform_dependent(link):
+            result = False
+        else:
+            host = netloc.split(':', 1)[0]
+            if host.lower() == 'localhost':
+                result = False
+            else:
+                result = True
+        logger.debug('should_queue: %s (%s) from %s -> %s', link, rel,
+                     referrer, result)
+        return result
+
+    def _fetch(self):
+        """
+        Get a URL to fetch from the work queue, get the HTML page, examine its
+        links for download candidates and candidates for further scraping.
+
+        This is a handy method to run in a thread.
+        """
+        while True:
+            url = self._to_fetch.get()
+            try:
+                if url:
+                    page = self.get_page(url)
+                    if page is None:    # e.g. after an error
+                        continue
+                    for link, rel in page.links:
+                        if link not in self._seen:
+                            try:
+                                self._seen.add(link)
+                                if (not self._process_download(link) and
+                                    self._should_queue(link, url, rel)):
+                                    logger.debug('Queueing %s from %s', link, url)
+                                    self._to_fetch.put(link)
+                            except MetadataInvalidError:  # e.g. invalid versions
+                                pass
+            except Exception as e:  # pragma: no cover
+                self.errors.put(text_type(e))
+            finally:
+                # always do this, to avoid hangs :-)
+                self._to_fetch.task_done()
+            if not url:
+                #logger.debug('Sentinel seen, quitting.')
+                break
+
+    def get_page(self, url):
+        """
+        Get the HTML for an URL, possibly from an in-memory cache.
+
+        XXX TODO Note: this cache is never actually cleared. It's assumed that
+        the data won't get stale over the lifetime of a locator instance (not
+        necessarily true for the default_locator).
+        """
+        # http://peak.telecommunity.com/DevCenter/EasyInstall#package-index-api
+        scheme, netloc, path, _, _, _ = urlparse(url)
+        if scheme == 'file' and os.path.isdir(url2pathname(path)):
+            url = urljoin(ensure_slash(url), 'index.html')
+
+        if url in self._page_cache:
+            result = self._page_cache[url]
+            logger.debug('Returning %s from cache: %s', url, result)
+        else:
+            host = netloc.split(':', 1)[0]
+            result = None
+            if host in self._bad_hosts:
+                logger.debug('Skipping %s due to bad host %s', url, host)
+            else:
+                req = Request(url, headers={'Accept-encoding': 'identity'})
+                try:
+                    logger.debug('Fetching %s', url)
+                    resp = self.opener.open(req, timeout=self.timeout)
+                    logger.debug('Fetched %s', url)
+                    headers = resp.info()
+                    content_type = headers.get('Content-Type', '')
+                    if HTML_CONTENT_TYPE.match(content_type):
+                        final_url = resp.geturl()
+                        data = resp.read()
+                        encoding = headers.get('Content-Encoding')
+                        if encoding:
+                            decoder = self.decoders[encoding]   # fail if not found
+                            data = decoder(data)
+                        encoding = 'utf-8'
+                        m = CHARSET.search(content_type)
+                        if m:
+                            encoding = m.group(1)
+                        try:
+                            data = data.decode(encoding)
+                        except UnicodeError:  # pragma: no cover
+                            data = data.decode('latin-1')    # fallback
+                        result = Page(data, final_url)
+                        self._page_cache[final_url] = result
+                except HTTPError as e:
+                    if e.code != 404:
+                        logger.exception('Fetch failed: %s: %s', url, e)
+                except URLError as e:  # pragma: no cover
+                    logger.exception('Fetch failed: %s: %s', url, e)
+                    with self._lock:
+                        self._bad_hosts.add(host)
+                except Exception as e:  # pragma: no cover
+                    logger.exception('Fetch failed: %s: %s', url, e)
+                finally:
+                    self._page_cache[url] = result   # even if None (failure)
+        return result
+
+    _distname_re = re.compile('<a href=[^>]*>([^<]+)<')
+
+    def get_distribution_names(self):
+        """
+        Return all the distribution names known to this locator.
+        """
+        result = set()
+        page = self.get_page(self.base_url)
+        if not page:
+            raise DistlibException('Unable to get %s' % self.base_url)
+        for match in self._distname_re.finditer(page.data):
+            result.add(match.group(1))
+        return result
+
+class DirectoryLocator(Locator):
+    """
+    This class locates distributions in a directory tree.
+    """
+
+    def __init__(self, path, **kwargs):
+        """
+        Initialise an instance.
+        :param path: The root of the directory tree to search.
+        :param kwargs: Passed to the superclass constructor,
+                       except for:
+                       * recursive - if True (the default), subdirectories are
+                         recursed into. If False, only the top-level directory
+                         is searched,
+        """
+        self.recursive = kwargs.pop('recursive', True)
+        super(DirectoryLocator, self).__init__(**kwargs)
+        path = os.path.abspath(path)
+        if not os.path.isdir(path):  # pragma: no cover
+            raise DistlibException('Not a directory: %r' % path)
+        self.base_dir = path
+
+    def should_include(self, filename, parent):
+        """
+        Should a filename be considered as a candidate for a distribution
+        archive? As well as the filename, the directory which contains it
+        is provided, though not used by the current implementation.
+        """
+        return filename.endswith(self.downloadable_extensions)
+
+    def _get_project(self, name):
+        result = {'urls': {}, 'digests': {}}
+        for root, dirs, files in os.walk(self.base_dir):
+            for fn in files:
+                if self.should_include(fn, root):
+                    fn = os.path.join(root, fn)
+                    url = urlunparse(('file', '',
+                                      pathname2url(os.path.abspath(fn)),
+                                      '', '', ''))
+                    info = self.convert_url_to_download_info(url, name)
+                    if info:
+                        self._update_version_data(result, info)
+            if not self.recursive:
+                break
+        return result
+
+    def get_distribution_names(self):
+        """
+        Return all the distribution names known to this locator.
+        """
+        result = set()
+        for root, dirs, files in os.walk(self.base_dir):
+            for fn in files:
+                if self.should_include(fn, root):
+                    fn = os.path.join(root, fn)
+                    url = urlunparse(('file', '',
+                                      pathname2url(os.path.abspath(fn)),
+                                      '', '', ''))
+                    info = self.convert_url_to_download_info(url, None)
+                    if info:
+                        result.add(info['name'])
+            if not self.recursive:
+                break
+        return result
+
+class JSONLocator(Locator):
+    """
+    This locator uses special extended metadata (not available on PyPI) and is
+    the basis of performant dependency resolution in distlib. Other locators
+    require archive downloads before dependencies can be determined! As you
+    might imagine, that can be slow.
+    """
+    def get_distribution_names(self):
+        """
+        Return all the distribution names known to this locator.
+        """
+        raise NotImplementedError('Not available from this locator')
+
+    def _get_project(self, name):
+        result = {'urls': {}, 'digests': {}}
+        data = get_project_data(name)
+        if data:
+            for info in data.get('files', []):
+                if info['ptype'] != 'sdist' or info['pyversion'] != 'source':
+                    continue
+                # We don't store summary in project metadata as it makes
+                # the data bigger for no benefit during dependency
+                # resolution
+                dist = make_dist(data['name'], info['version'],
+                                 summary=data.get('summary',
+                                                  'Placeholder for summary'),
+                                 scheme=self.scheme)
+                md = dist.metadata
+                md.source_url = info['url']
+                # TODO SHA256 digest
+                if 'digest' in info and info['digest']:
+                    dist.digest = ('md5', info['digest'])
+                md.dependencies = info.get('requirements', {})
+                dist.exports = info.get('exports', {})
+                result[dist.version] = dist
+                result['urls'].setdefault(dist.version, set()).add(info['url'])
+        return result
+
+class DistPathLocator(Locator):
+    """
+    This locator finds installed distributions in a path. It can be useful for
+    adding to an :class:`AggregatingLocator`.
+    """
+    def __init__(self, distpath, **kwargs):
+        """
+        Initialise an instance.
+
+        :param distpath: A :class:`DistributionPath` instance to search.
+        """
+        super(DistPathLocator, self).__init__(**kwargs)
+        assert isinstance(distpath, DistributionPath)
+        self.distpath = distpath
+
+    def _get_project(self, name):
+        dist = self.distpath.get_distribution(name)
+        if dist is None:
+            result = {'urls': {}, 'digests': {}}
+        else:
+            result = {
+                dist.version: dist,
+                'urls': {dist.version: set([dist.source_url])},
+                'digests': {dist.version: set([None])}
+            }
+        return result
+
+
+class AggregatingLocator(Locator):
+    """
+    This class allows you to chain and/or merge a list of locators.
+    """
+    def __init__(self, *locators, **kwargs):
+        """
+        Initialise an instance.
+
+        :param locators: The list of locators to search.
+        :param kwargs: Passed to the superclass constructor,
+                       except for:
+                       * merge - if False (the default), the first successful
+                         search from any of the locators is returned. If True,
+                         the results from all locators are merged (this can be
+                         slow).
+        """
+        self.merge = kwargs.pop('merge', False)
+        self.locators = locators
+        super(AggregatingLocator, self).__init__(**kwargs)
+
+    def clear_cache(self):
+        super(AggregatingLocator, self).clear_cache()
+        for locator in self.locators:
+            locator.clear_cache()
+
+    def _set_scheme(self, value):
+        self._scheme = value
+        for locator in self.locators:
+            locator.scheme = value
+
+    scheme = property(Locator.scheme.fget, _set_scheme)
+
+    def _get_project(self, name):
+        result = {}
+        for locator in self.locators:
+            d = locator.get_project(name)
+            if d:
+                if self.merge:
+                    files = result.get('urls', {})
+                    digests = result.get('digests', {})
+                    # next line could overwrite result['urls'], result['digests']
+                    result.update(d)
+                    df = result.get('urls')
+                    if files and df:
+                        for k, v in files.items():
+                            if k in df:
+                                df[k] |= v
+                            else:
+                                df[k] = v
+                    dd = result.get('digests')
+                    if digests and dd:
+                        dd.update(digests)
+                else:
+                    # See issue #18. If any dists are found and we're looking
+                    # for specific constraints, we only return something if
+                    # a match is found. For example, if a DirectoryLocator
+                    # returns just foo (1.0) while we're looking for
+                    # foo (>= 2.0), we'll pretend there was nothing there so
+                    # that subsequent locators can be queried. Otherwise we
+                    # would just return foo (1.0) which would then lead to a
+                    # failure to find foo (>= 2.0), because other locators
+                    # weren't searched. Note that this only matters when
+                    # merge=False.
+                    if self.matcher is None:
+                        found = True
+                    else:
+                        found = False
+                        for k in d:
+                            if self.matcher.match(k):
+                                found = True
+                                break
+                    if found:
+                        result = d
+                        break
+        return result
+
+    def get_distribution_names(self):
+        """
+        Return all the distribution names known to this locator.
+        """
+        result = set()
+        for locator in self.locators:
+            try:
+                result |= locator.get_distribution_names()
+            except NotImplementedError:
+                pass
+        return result
+
+
+# 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.
+default_locator = AggregatingLocator(
+                    JSONLocator(),
+                    SimpleScrapingLocator('https://pypi.python.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):
+    """
+    Locate dependencies for distributions.
+    """
+
+    def __init__(self, locator=None):
+        """
+        Initialise an instance, using the specified locator
+        to locate distributions.
+        """
+        self.locator = locator or default_locator
+        self.scheme = get_scheme(self.locator.scheme)
+
+    def add_distribution(self, dist):
+        """
+        Add a distribution to the finder. This will update internal information
+        about who provides what.
+        :param dist: The distribution to add.
+        """
+        logger.debug('adding distribution %s', dist)
+        name = dist.key
+        self.dists_by_name[name] = dist
+        self.dists[(name, dist.version)] = dist
+        for p in dist.provides:
+            name, version = parse_name_and_version(p)
+            logger.debug('Add to provided: %s, %s, %s', name, version, dist)
+            self.provided.setdefault(name, set()).add((version, dist))
+
+    def remove_distribution(self, dist):
+        """
+        Remove a distribution from the finder. This will update internal
+        information about who provides what.
+        :param dist: The distribution to remove.
+        """
+        logger.debug('removing distribution %s', dist)
+        name = dist.key
+        del self.dists_by_name[name]
+        del self.dists[(name, dist.version)]
+        for p in dist.provides:
+            name, version = parse_name_and_version(p)
+            logger.debug('Remove from provided: %s, %s, %s', name, version, dist)
+            s = self.provided[name]
+            s.remove((version, dist))
+            if not s:
+                del self.provided[name]
+
+    def get_matcher(self, reqt):
+        """
+        Get a version matcher for a requirement.
+        :param reqt: The requirement
+        :type reqt: str
+        :return: A version matcher (an instance of
+                 :class:`distlib.version.Matcher`).
+        """
+        try:
+            matcher = self.scheme.matcher(reqt)
+        except UnsupportedVersionError:  # pragma: no cover
+            # XXX compat-mode if cannot read the version
+            name = reqt.split()[0]
+            matcher = self.scheme.matcher(name)
+        return matcher
+
+    def find_providers(self, reqt):
+        """
+        Find the distributions which can fulfill a requirement.
+
+        :param reqt: The requirement.
+         :type reqt: str
+        :return: A set of distribution which can fulfill the requirement.
+        """
+        matcher = self.get_matcher(reqt)
+        name = matcher.key   # case-insensitive
+        result = set()
+        provided = self.provided
+        if name in provided:
+            for version, provider in provided[name]:
+                try:
+                    match = matcher.match(version)
+                except UnsupportedVersionError:
+                    match = False
+
+                if match:
+                    result.add(provider)
+                    break
+        return result
+
+    def try_to_replace(self, provider, other, problems):
+        """
+        Attempt to replace one provider with another. This is typically used
+        when resolving dependencies from multiple sources, e.g. A requires
+        (B >= 1.0) while C requires (B >= 1.1).
+
+        For successful replacement, ``provider`` must meet all the requirements
+        which ``other`` fulfills.
+
+        :param provider: The provider we are trying to replace with.
+        :param other: The provider we're trying to replace.
+        :param problems: If False is returned, this will contain what
+                         problems prevented replacement. This is currently
+                         a tuple of the literal string 'cantreplace',
+                         ``provider``, ``other``  and the set of requirements
+                         that ``provider`` couldn't fulfill.
+        :return: True if we can replace ``other`` with ``provider``, else
+                 False.
+        """
+        rlist = self.reqts[other]
+        unmatched = set()
+        for s in rlist:
+            matcher = self.get_matcher(s)
+            if not matcher.match(provider.version):
+                unmatched.add(s)
+        if unmatched:
+            # can't replace other with provider
+            problems.add(('cantreplace', provider, other,
+                          frozenset(unmatched)))
+            result = False
+        else:
+            # can replace other with provider
+            self.remove_distribution(other)
+            del self.reqts[other]
+            for s in rlist:
+                self.reqts.setdefault(provider, set()).add(s)
+            self.add_distribution(provider)
+            result = True
+        return result
+
+    def find(self, requirement, meta_extras=None, prereleases=False):
+        """
+        Find a distribution and all distributions it depends on.
+
+        :param requirement: The requirement specifying the distribution to
+                            find, or a Distribution instance.
+        :param meta_extras: A list of meta extras such as :test:, :build: and
+                            so on.
+        :param prereleases: If ``True``, allow pre-release versions to be
+                            returned - otherwise, don't return prereleases
+                            unless they're all that's available.
+
+        Return a set of :class:`Distribution` instances and a set of
+        problems.
+
+        The distributions returned should be such that they have the
+        :attr:`required` attribute set to ``True`` if they were
+        from the ``requirement`` passed to ``find()``, and they have the
+        :attr:`build_time_dependency` attribute set to ``True`` unless they
+        are post-installation dependencies of the ``requirement``.
+
+        The problems should be a tuple consisting of the string
+        ``'unsatisfied'`` and the requirement which couldn't be satisfied
+        by any distribution known to the locator.
+        """
+
+        self.provided = {}
+        self.dists = {}
+        self.dists_by_name = {}
+        self.reqts = {}
+
+        meta_extras = set(meta_extras or [])
+        if ':*:' in meta_extras:
+            meta_extras.remove(':*:')
+            # :meta: and :run: are implicitly included
+            meta_extras |= set([':test:', ':build:', ':dev:'])
+
+        if isinstance(requirement, Distribution):
+            dist = odist = requirement
+            logger.debug('passed %s as requirement', odist)
+        else:
+            dist = odist = self.locator.locate(requirement,
+                                               prereleases=prereleases)
+            if dist is None:
+                raise DistlibException('Unable to locate %r' % requirement)
+            logger.debug('located %s', odist)
+        dist.requested = True
+        problems = set()
+        todo = set([dist])
+        install_dists = set([odist])
+        while todo:
+            dist = todo.pop()
+            name = dist.key     # case-insensitive
+            if name not in self.dists_by_name:
+                self.add_distribution(dist)
+            else:
+                #import pdb; pdb.set_trace()
+                other = self.dists_by_name[name]
+                if other != dist:
+                    self.try_to_replace(dist, other, problems)
+
+            ireqts = dist.run_requires | dist.meta_requires
+            sreqts = dist.build_requires
+            ereqts = set()
+            if meta_extras and dist in install_dists:
+                for key in ('test', 'build', 'dev'):
+                    e = ':%s:' % key
+                    if e in meta_extras:
+                        ereqts |= getattr(dist, '%s_requires' % key)
+            all_reqts = ireqts | sreqts | ereqts
+            for r in all_reqts:
+                providers = self.find_providers(r)
+                if not providers:
+                    logger.debug('No providers found for %r', r)
+                    provider = self.locator.locate(r, prereleases=prereleases)
+                    # If no provider is found and we didn't consider
+                    # prereleases, consider them now.
+                    if provider is None and not prereleases:
+                        provider = self.locator.locate(r, prereleases=True)
+                    if provider is None:
+                        logger.debug('Cannot satisfy %r', r)
+                        problems.add(('unsatisfied', r))
+                    else:
+                        n, v = provider.key, provider.version
+                        if (n, v) not in self.dists:
+                            todo.add(provider)
+                        providers.add(provider)
+                        if r in ireqts and dist in install_dists:
+                            install_dists.add(provider)
+                            logger.debug('Adding %s to install_dists',
+                                         provider.name_and_version)
+                for p in providers:
+                    name = p.key
+                    if name not in self.dists_by_name:
+                        self.reqts.setdefault(p, set()).add(r)
+                    else:
+                        other = self.dists_by_name[name]
+                        if other != p:
+                            # see if other can be replaced by p
+                            self.try_to_replace(p, other, problems)
+
+        dists = set(self.dists.values())
+        for dist in dists:
+            dist.build_time_dependency = dist not in install_dists
+            if dist.build_time_dependency:
+                logger.debug('%s is a build-time dependency only.',
+                             dist.name_and_version)
+        logger.debug('find done for %s', odist)
+        return dists, problems
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/locators.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/locators.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..acfa060471ae5a1d382ff30d4e87df6dac1e28de
GIT binary patch
literal 49817
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

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/manifest.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/manifest.py
new file mode 100644
index 0000000..ca0fe44
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/manifest.py
@@ -0,0 +1,393 @@
+# -*- coding: utf-8 -*-
+#
+# Copyright (C) 2012-2013 Python Software Foundation.
+# See LICENSE.txt and CONTRIBUTORS.txt.
+#
+"""
+Class representing the list of files in a distribution.
+
+Equivalent to distutils.filelist, but fixes some problems.
+"""
+import fnmatch
+import logging
+import os
+import re
+import sys
+
+from . import DistlibException
+from .compat import fsdecode
+from .util import convert_path
+
+
+__all__ = ['Manifest']
+
+logger = logging.getLogger(__name__)
+
+# a \ followed by some spaces + EOL
+_COLLAPSE_PATTERN = re.compile('\\\\w*\n', re.M)
+_COMMENTED_LINE = re.compile('#.*?(?=\n)|\n(?=$)', re.M | re.S)
+
+#
+# Due to the different results returned by fnmatch.translate, we need
+# to do slightly different processing for Python 2.7 and 3.2 ... this needed
+# to be brought in for Python 3.6 onwards.
+#
+_PYTHON_VERSION = sys.version_info[:2]
+
+class Manifest(object):
+    """A list of files built by on exploring the filesystem and filtered by
+    applying various patterns to what we find there.
+    """
+
+    def __init__(self, base=None):
+        """
+        Initialise an instance.
+
+        :param base: The base directory to explore under.
+        """
+        self.base = os.path.abspath(os.path.normpath(base or os.getcwd()))
+        self.prefix = self.base + os.sep
+        self.allfiles = None
+        self.files = set()
+
+    #
+    # Public API
+    #
+
+    def findall(self):
+        """Find all files under the base and set ``allfiles`` to the absolute
+        pathnames of files found.
+        """
+        from stat import S_ISREG, S_ISDIR, S_ISLNK
+
+        self.allfiles = allfiles = []
+        root = self.base
+        stack = [root]
+        pop = stack.pop
+        push = stack.append
+
+        while stack:
+            root = pop()
+            names = os.listdir(root)
+
+            for name in names:
+                fullname = os.path.join(root, name)
+
+                # Avoid excess stat calls -- just one will do, thank you!
+                stat = os.stat(fullname)
+                mode = stat.st_mode
+                if S_ISREG(mode):
+                    allfiles.append(fsdecode(fullname))
+                elif S_ISDIR(mode) and not S_ISLNK(mode):
+                    push(fullname)
+
+    def add(self, item):
+        """
+        Add a file to the manifest.
+
+        :param item: The pathname to add. This can be relative to the base.
+        """
+        if not item.startswith(self.prefix):
+            item = os.path.join(self.base, item)
+        self.files.add(os.path.normpath(item))
+
+    def add_many(self, items):
+        """
+        Add a list of files to the manifest.
+
+        :param items: The pathnames to add. These can be relative to the base.
+        """
+        for item in items:
+            self.add(item)
+
+    def sorted(self, wantdirs=False):
+        """
+        Return sorted files in directory order
+        """
+
+        def add_dir(dirs, d):
+            dirs.add(d)
+            logger.debug('add_dir added %s', d)
+            if d != self.base:
+                parent, _ = os.path.split(d)
+                assert parent not in ('', '/')
+                add_dir(dirs, parent)
+
+        result = set(self.files)    # make a copy!
+        if wantdirs:
+            dirs = set()
+            for f in result:
+                add_dir(dirs, os.path.dirname(f))
+            result |= dirs
+        return [os.path.join(*path_tuple) for path_tuple in
+                sorted(os.path.split(path) for path in result)]
+
+    def clear(self):
+        """Clear all collected files."""
+        self.files = set()
+        self.allfiles = []
+
+    def process_directive(self, directive):
+        """
+        Process a directive which either adds some files from ``allfiles`` to
+        ``files``, or removes some files from ``files``.
+
+        :param directive: The directive to process. This should be in a format
+                     compatible with distutils ``MANIFEST.in`` files:
+
+                     http://docs.python.org/distutils/sourcedist.html#commands
+        """
+        # Parse the line: split it up, make sure the right number of words
+        # is there, and return the relevant words.  'action' is always
+        # defined: it's the first word of the line.  Which of the other
+        # three are defined depends on the action; it'll be either
+        # patterns, (dir and patterns), or (dirpattern).
+        action, patterns, thedir, dirpattern = self._parse_directive(directive)
+
+        # OK, now we know that the action is valid and we have the
+        # right number of words on the line for that action -- so we
+        # can proceed with minimal error-checking.
+        if action == 'include':
+            for pattern in patterns:
+                if not self._include_pattern(pattern, anchor=True):
+                    logger.warning('no files found matching %r', pattern)
+
+        elif action == 'exclude':
+            for pattern in patterns:
+                found = self._exclude_pattern(pattern, anchor=True)
+                #if not found:
+                #    logger.warning('no previously-included files '
+                #                   'found matching %r', pattern)
+
+        elif action == 'global-include':
+            for pattern in patterns:
+                if not self._include_pattern(pattern, anchor=False):
+                    logger.warning('no files found matching %r '
+                                   'anywhere in distribution', pattern)
+
+        elif action == 'global-exclude':
+            for pattern in patterns:
+                found = self._exclude_pattern(pattern, anchor=False)
+                #if not found:
+                #    logger.warning('no previously-included files '
+                #                   'matching %r found anywhere in '
+                #                   'distribution', pattern)
+
+        elif action == 'recursive-include':
+            for pattern in patterns:
+                if not self._include_pattern(pattern, prefix=thedir):
+                    logger.warning('no files found matching %r '
+                                   'under directory %r', pattern, thedir)
+
+        elif action == 'recursive-exclude':
+            for pattern in patterns:
+                found = self._exclude_pattern(pattern, prefix=thedir)
+                #if not found:
+                #    logger.warning('no previously-included files '
+                #                   'matching %r found under directory %r',
+                #                   pattern, thedir)
+
+        elif action == 'graft':
+            if not self._include_pattern(None, prefix=dirpattern):
+                logger.warning('no directories found matching %r',
+                               dirpattern)
+
+        elif action == 'prune':
+            if not self._exclude_pattern(None, prefix=dirpattern):
+                logger.warning('no previously-included directories found '
+                               'matching %r', dirpattern)
+        else:   # pragma: no cover
+            # This should never happen, as it should be caught in
+            # _parse_template_line
+            raise DistlibException(
+                'invalid action %r' % action)
+
+    #
+    # Private API
+    #
+
+    def _parse_directive(self, directive):
+        """
+        Validate a directive.
+        :param directive: The directive to validate.
+        :return: A tuple of action, patterns, thedir, dir_patterns
+        """
+        words = directive.split()
+        if len(words) == 1 and words[0] not in ('include', 'exclude',
+                                                'global-include',
+                                                'global-exclude',
+                                                'recursive-include',
+                                                'recursive-exclude',
+                                                'graft', 'prune'):
+            # no action given, let's use the default 'include'
+            words.insert(0, 'include')
+
+        action = words[0]
+        patterns = thedir = dir_pattern = None
+
+        if action in ('include', 'exclude',
+                      'global-include', 'global-exclude'):
+            if len(words) < 2:
+                raise DistlibException(
+                    '%r expects <pattern1> <pattern2> ...' % action)
+
+            patterns = [convert_path(word) for word in words[1:]]
+
+        elif action in ('recursive-include', 'recursive-exclude'):
+            if len(words) < 3:
+                raise DistlibException(
+                    '%r expects <dir> <pattern1> <pattern2> ...' % action)
+
+            thedir = convert_path(words[1])
+            patterns = [convert_path(word) for word in words[2:]]
+
+        elif action in ('graft', 'prune'):
+            if len(words) != 2:
+                raise DistlibException(
+                    '%r expects a single <dir_pattern>' % action)
+
+            dir_pattern = convert_path(words[1])
+
+        else:
+            raise DistlibException('unknown action %r' % action)
+
+        return action, patterns, thedir, dir_pattern
+
+    def _include_pattern(self, pattern, anchor=True, prefix=None,
+                         is_regex=False):
+        """Select strings (presumably filenames) from 'self.files' that
+        match 'pattern', a Unix-style wildcard (glob) pattern.
+
+        Patterns are not quite the same as implemented by the 'fnmatch'
+        module: '*' and '?'  match non-special characters, where "special"
+        is platform-dependent: slash on Unix; colon, slash, and backslash on
+        DOS/Windows; and colon on Mac OS.
+
+        If 'anchor' is true (the default), then the pattern match is more
+        stringent: "*.py" will match "foo.py" but not "foo/bar.py".  If
+        'anchor' is false, both of these will match.
+
+        If 'prefix' is supplied, then only filenames starting with 'prefix'
+        (itself a pattern) and ending with 'pattern', with anything in between
+        them, will match.  'anchor' is ignored in this case.
+
+        If 'is_regex' is true, 'anchor' and 'prefix' are ignored, and
+        'pattern' is assumed to be either a string containing a regex or a
+        regex object -- no translation is done, the regex is just compiled
+        and used as-is.
+
+        Selected strings will be added to self.files.
+
+        Return True if files are found.
+        """
+        # XXX docstring lying about what the special chars are?
+        found = False
+        pattern_re = self._translate_pattern(pattern, anchor, prefix, is_regex)
+
+        # delayed loading of allfiles list
+        if self.allfiles is None:
+            self.findall()
+
+        for name in self.allfiles:
+            if pattern_re.search(name):
+                self.files.add(name)
+                found = True
+        return found
+
+    def _exclude_pattern(self, pattern, anchor=True, prefix=None,
+                         is_regex=False):
+        """Remove strings (presumably filenames) from 'files' that match
+        'pattern'.
+
+        Other parameters are the same as for 'include_pattern()', above.
+        The list 'self.files' is modified in place. Return True if files are
+        found.
+
+        This API is public to allow e.g. exclusion of SCM subdirs, e.g. when
+        packaging source distributions
+        """
+        found = False
+        pattern_re = self._translate_pattern(pattern, anchor, prefix, is_regex)
+        for f in list(self.files):
+            if pattern_re.search(f):
+                self.files.remove(f)
+                found = True
+        return found
+
+    def _translate_pattern(self, pattern, anchor=True, prefix=None,
+                           is_regex=False):
+        """Translate a shell-like wildcard pattern to a compiled regular
+        expression.
+
+        Return the compiled regex.  If 'is_regex' true,
+        then 'pattern' is directly compiled to a regex (if it's a string)
+        or just returned as-is (assumes it's a regex object).
+        """
+        if is_regex:
+            if isinstance(pattern, str):
+                return re.compile(pattern)
+            else:
+                return pattern
+
+        if _PYTHON_VERSION > (3, 2):
+            # ditch start and end characters
+            start, _, end = self._glob_to_re('_').partition('_')
+
+        if pattern:
+            pattern_re = self._glob_to_re(pattern)
+            if _PYTHON_VERSION > (3, 2):
+                assert pattern_re.startswith(start) and pattern_re.endswith(end)
+        else:
+            pattern_re = ''
+
+        base = re.escape(os.path.join(self.base, ''))
+        if prefix is not None:
+            # ditch end of pattern character
+            if _PYTHON_VERSION <= (3, 2):
+                empty_pattern = self._glob_to_re('')
+                prefix_re = self._glob_to_re(prefix)[:-len(empty_pattern)]
+            else:
+                prefix_re = self._glob_to_re(prefix)
+                assert prefix_re.startswith(start) and prefix_re.endswith(end)
+                prefix_re = prefix_re[len(start): len(prefix_re) - len(end)]
+            sep = os.sep
+            if os.sep == '\\':
+                sep = r'\\'
+            if _PYTHON_VERSION <= (3, 2):
+                pattern_re = '^' + base + sep.join((prefix_re,
+                                                    '.*' + pattern_re))
+            else:
+                pattern_re = pattern_re[len(start): len(pattern_re) - len(end)]
+                pattern_re = r'%s%s%s%s.*%s%s' % (start, base, prefix_re, sep,
+                                                  pattern_re, end)
+        else:  # no prefix -- respect anchor flag
+            if anchor:
+                if _PYTHON_VERSION <= (3, 2):
+                    pattern_re = '^' + base + pattern_re
+                else:
+                    pattern_re = r'%s%s%s' % (start, base, pattern_re[len(start):])
+
+        return re.compile(pattern_re)
+
+    def _glob_to_re(self, pattern):
+        """Translate a shell-like glob pattern to a regular expression.
+
+        Return a string containing the regex.  Differs from
+        'fnmatch.translate()' in that '*' does not match "special characters"
+        (which are platform-specific).
+        """
+        pattern_re = fnmatch.translate(pattern)
+
+        # '?' and '*' in the glob pattern become '.' and '.*' in the RE, which
+        # IMHO is wrong -- '?' and '*' aren't supposed to match slash in Unix,
+        # and by extension they shouldn't match such "special characters" under
+        # any OS.  So change all non-escaped dots in the RE to match any
+        # character except the special characters (currently: just os.sep).
+        sep = os.sep
+        if os.sep == '\\':
+            # we're using a regex to manipulate a regex, so we need
+            # to escape the backslash twice
+            sep = r'\\\\'
+        escaped = r'\1[^%s]' % sep
+        pattern_re = re.sub(r'((?<!\\)(\\\\)*)\.', escaped, pattern_re)
+        return pattern_re
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/manifest.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/manifest.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..e38d30c1c0d7aefaea91698c0c6ea8d7f96a95dc
GIT binary patch
literal 12954
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
UfKh-^fSHqtpIMYqhMkuQ00XWWy8r+H

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/markers.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/markers.py
new file mode 100644
index 0000000..ee1f3e2
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/markers.py
@@ -0,0 +1,131 @@
+# -*- coding: utf-8 -*-
+#
+# Copyright (C) 2012-2017 Vinay Sajip.
+# Licensed to the Python Software Foundation under a contributor agreement.
+# See LICENSE.txt and CONTRIBUTORS.txt.
+#
+"""
+Parser for the environment markers micro-language defined in PEP 508.
+"""
+
+# Note: In PEP 345, the micro-language was Python compatible, so the ast
+# module could be used to parse it. However, PEP 508 introduced operators such
+# as ~= and === which aren't in Python, necessitating a different approach.
+
+import os
+import sys
+import platform
+import re
+
+from .compat import python_implementation, urlparse, string_types
+from .util import in_venv, parse_marker
+
+__all__ = ['interpret']
+
+def _is_literal(o):
+    if not isinstance(o, string_types) or not o:
+        return False
+    return o[0] in '\'"'
+
+class Evaluator(object):
+    """
+    This class is used to evaluate marker expessions.
+    """
+
+    operations = {
+        '==': lambda x, y: x == y,
+        '===': lambda x, y: x == y,
+        '~=': lambda x, y: x == y or x > y,
+        '!=': lambda x, y: x != y,
+        '<':  lambda x, y: x < y,
+        '<=':  lambda x, y: x == y or x < y,
+        '>':  lambda x, y: x > y,
+        '>=':  lambda x, y: x == y or x > y,
+        'and': lambda x, y: x and y,
+        'or': lambda x, y: x or y,
+        'in': lambda x, y: x in y,
+        'not in': lambda x, y: x not in y,
+    }
+
+    def evaluate(self, expr, context):
+        """
+        Evaluate a marker expression returned by the :func:`parse_requirement`
+        function in the specified context.
+        """
+        if isinstance(expr, string_types):
+            if expr[0] in '\'"':
+                result = expr[1:-1]
+            else:
+                if expr not in context:
+                    raise SyntaxError('unknown variable: %s' % expr)
+                result = context[expr]
+        else:
+            assert isinstance(expr, dict)
+            op = expr['op']
+            if op not in self.operations:
+                raise NotImplementedError('op not implemented: %s' % op)
+            elhs = expr['lhs']
+            erhs = expr['rhs']
+            if _is_literal(expr['lhs']) and _is_literal(expr['rhs']):
+                raise SyntaxError('invalid comparison: %s %s %s' % (elhs, op, erhs))
+
+            lhs = self.evaluate(elhs, context)
+            rhs = self.evaluate(erhs, context)
+            result = self.operations[op](lhs, rhs)
+        return result
+
+def default_context():
+    def format_full_version(info):
+        version = '%s.%s.%s' % (info.major, info.minor, info.micro)
+        kind = info.releaselevel
+        if kind != 'final':
+            version += kind[0] + str(info.serial)
+        return version
+
+    if hasattr(sys, 'implementation'):
+        implementation_version = format_full_version(sys.implementation.version)
+        implementation_name = sys.implementation.name
+    else:
+        implementation_version = '0'
+        implementation_name = ''
+
+    result = {
+        'implementation_name': implementation_name,
+        'implementation_version': implementation_version,
+        'os_name': os.name,
+        'platform_machine': platform.machine(),
+        'platform_python_implementation': platform.python_implementation(),
+        'platform_release': platform.release(),
+        '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],
+        'sys_platform': sys.platform,
+    }
+    return result
+
+DEFAULT_CONTEXT = default_context()
+del default_context
+
+evaluator = Evaluator()
+
+def interpret(marker, execution_context=None):
+    """
+    Interpret a marker and return a result depending on environment.
+
+    :param marker: The marker to interpret.
+    :type marker: str
+    :param execution_context: The context used for name lookup.
+    :type execution_context: mapping
+    """
+    try:
+        expr, rest = parse_marker(marker)
+    except Exception as e:
+        raise SyntaxError('Unable to interpret marker syntax: %s: %s' % (marker, e))
+    if rest and rest[0] != '#':
+        raise SyntaxError('unexpected trailing data in marker: %s: %s' % (marker, rest))
+    context = dict(DEFAULT_CONTEXT)
+    if execution_context:
+        context.update(execution_context)
+    return evaluator.evaluate(expr, context)
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/markers.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/markers.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..14b306a9bd0e603a916df18a47d2fc4c7aaf4c58
GIT binary patch
literal 7112
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
BeH#D(

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/metadata.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/metadata.py
new file mode 100644
index 0000000..77eed7f
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/metadata.py
@@ -0,0 +1,1094 @@
+# -*- coding: utf-8 -*-
+#
+# Copyright (C) 2012 The Python Software Foundation.
+# See LICENSE.txt and CONTRIBUTORS.txt.
+#
+"""Implementation of the Metadata for Python packages PEPs.
+
+Supports all metadata formats (1.0, 1.1, 1.2, and 2.0 experimental).
+"""
+from __future__ import unicode_literals
+
+import codecs
+from email import message_from_file
+import json
+import logging
+import re
+
+
+from . import DistlibException, __version__
+from .compat import StringIO, string_types, text_type
+from .markers import interpret
+from .util import extract_by_key, get_extras
+from .version import get_scheme, PEP440_VERSION_RE
+
+logger = logging.getLogger(__name__)
+
+
+class MetadataMissingError(DistlibException):
+    """A required metadata is missing"""
+
+
+class MetadataConflictError(DistlibException):
+    """Attempt to read or write metadata fields that are conflictual."""
+
+
+class MetadataUnrecognizedVersionError(DistlibException):
+    """Unknown metadata version number."""
+
+
+class MetadataInvalidError(DistlibException):
+    """A metadata value is invalid"""
+
+# public API of this module
+__all__ = ['Metadata', 'PKG_INFO_ENCODING', 'PKG_INFO_PREFERRED_VERSION']
+
+# Encoding used for the PKG-INFO files
+PKG_INFO_ENCODING = 'utf-8'
+
+# preferred version. Hopefully will be changed
+# to 1.2 once PEP 345 is supported everywhere
+PKG_INFO_PREFERRED_VERSION = '1.1'
+
+_LINE_PREFIX_1_2 = re.compile('\n       \\|')
+_LINE_PREFIX_PRE_1_2 = re.compile('\n        ')
+_241_FIELDS = ('Metadata-Version', 'Name', 'Version', 'Platform',
+               'Summary', 'Description',
+               'Keywords', 'Home-page', 'Author', 'Author-email',
+               'License')
+
+_314_FIELDS = ('Metadata-Version', 'Name', 'Version', 'Platform',
+               'Supported-Platform', 'Summary', 'Description',
+               'Keywords', 'Home-page', 'Author', 'Author-email',
+               'License', 'Classifier', 'Download-URL', 'Obsoletes',
+               'Provides', 'Requires')
+
+_314_MARKERS = ('Obsoletes', 'Provides', 'Requires', 'Classifier',
+                'Download-URL')
+
+_345_FIELDS = ('Metadata-Version', 'Name', 'Version', 'Platform',
+               'Supported-Platform', 'Summary', 'Description',
+               'Keywords', 'Home-page', 'Author', 'Author-email',
+               'Maintainer', 'Maintainer-email', 'License',
+               'Classifier', 'Download-URL', 'Obsoletes-Dist',
+               'Project-URL', 'Provides-Dist', 'Requires-Dist',
+               'Requires-Python', 'Requires-External')
+
+_345_MARKERS = ('Provides-Dist', 'Requires-Dist', 'Requires-Python',
+                'Obsoletes-Dist', 'Requires-External', 'Maintainer',
+                'Maintainer-email', 'Project-URL')
+
+_426_FIELDS = ('Metadata-Version', 'Name', 'Version', 'Platform',
+               'Supported-Platform', 'Summary', 'Description',
+               'Keywords', 'Home-page', 'Author', 'Author-email',
+               'Maintainer', 'Maintainer-email', 'License',
+               'Classifier', 'Download-URL', 'Obsoletes-Dist',
+               'Project-URL', 'Provides-Dist', 'Requires-Dist',
+               'Requires-Python', 'Requires-External', 'Private-Version',
+               'Obsoleted-By', 'Setup-Requires-Dist', 'Extension',
+               'Provides-Extra')
+
+_426_MARKERS = ('Private-Version', 'Provides-Extra', 'Obsoleted-By',
+                'Setup-Requires-Dist', 'Extension')
+
+# See issue #106: Sometimes 'Requires' occurs wrongly in the metadata. Include
+# it in the tuple literal below to allow it (for now)
+_566_FIELDS = _426_FIELDS + ('Description-Content-Type', 'Requires')
+
+_566_MARKERS = ('Description-Content-Type',)
+
+_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)
+
+EXTRA_RE = re.compile(r'''extra\s*==\s*("([^"]+)"|'([^']+)')''')
+
+
+def _version2fieldlist(version):
+    if version == '1.0':
+        return _241_FIELDS
+    elif version == '1.1':
+        return _314_FIELDS
+    elif version == '1.2':
+        return _345_FIELDS
+    elif version in ('1.3', '2.1'):
+        return _345_FIELDS + _566_FIELDS
+    elif version == '2.0':
+        return _426_FIELDS
+    raise MetadataUnrecognizedVersionError(version)
+
+
+def _best_version(fields):
+    """Detect the best version depending on the fields used."""
+    def _has_marker(keys, markers):
+        for marker in markers:
+            if marker in keys:
+                return True
+        return False
+
+    keys = []
+    for key, value in fields.items():
+        if value in ([], 'UNKNOWN', None):
+            continue
+        keys.append(key)
+
+    possible_versions = ['1.0', '1.1', '1.2', '1.3', '2.0', '2.1']
+
+    # first let's try to see if a field is not part of one of the version
+    for key in keys:
+        if key not in _241_FIELDS and '1.0' in possible_versions:
+            possible_versions.remove('1.0')
+            logger.debug('Removed 1.0 due to %s', key)
+        if key not in _314_FIELDS and '1.1' in possible_versions:
+            possible_versions.remove('1.1')
+            logger.debug('Removed 1.1 due to %s', key)
+        if key not in _345_FIELDS and '1.2' in possible_versions:
+            possible_versions.remove('1.2')
+            logger.debug('Removed 1.2 due to %s', key)
+        if key not in _566_FIELDS and '1.3' in possible_versions:
+            possible_versions.remove('1.3')
+            logger.debug('Removed 1.3 due to %s', key)
+        if key not in _566_FIELDS and '2.1' in possible_versions:
+            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)
+
+    # possible_version contains qualified versions
+    if len(possible_versions) == 1:
+        return possible_versions[0]   # found !
+    elif len(possible_versions) == 0:
+        logger.debug('Out of options - unknown metadata set: %s', fields)
+        raise MetadataConflictError('Unknown metadata set')
+
+    # let's see if one unique marker is found
+    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')
+
+    # we have the choice, 1.0, or 1.2, or 2.0
+    #   - 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:
+        # we couldn't find any specific marker
+        if PKG_INFO_PREFERRED_VERSION in possible_versions:
+            return PKG_INFO_PREFERRED_VERSION
+    if is_1_1:
+        return '1.1'
+    if is_1_2:
+        return '1.2'
+    if is_2_1:
+        return '2.1'
+
+    return '2.0'
+
+_ATTR2FIELD = {
+    'metadata_version': 'Metadata-Version',
+    'name': 'Name',
+    'version': 'Version',
+    'platform': 'Platform',
+    'supported_platform': 'Supported-Platform',
+    'summary': 'Summary',
+    'description': 'Description',
+    'keywords': 'Keywords',
+    'home_page': 'Home-page',
+    'author': 'Author',
+    'author_email': 'Author-email',
+    'maintainer': 'Maintainer',
+    'maintainer_email': 'Maintainer-email',
+    'license': 'License',
+    'classifier': 'Classifier',
+    'download_url': 'Download-URL',
+    'obsoletes_dist': 'Obsoletes-Dist',
+    'provides_dist': 'Provides-Dist',
+    'requires_dist': 'Requires-Dist',
+    'setup_requires_dist': 'Setup-Requires-Dist',
+    'requires_python': 'Requires-Python',
+    'requires_external': 'Requires-External',
+    'requires': 'Requires',
+    'provides': 'Provides',
+    'obsoletes': 'Obsoletes',
+    'project_url': 'Project-URL',
+    'private_version': 'Private-Version',
+    'obsoleted_by': 'Obsoleted-By',
+    'extension': 'Extension',
+    'provides_extra': 'Provides-Extra',
+}
+
+_PREDICATE_FIELDS = ('Requires-Dist', 'Obsoletes-Dist', 'Provides-Dist')
+_VERSIONS_FIELDS = ('Requires-Python',)
+_VERSION_FIELDS = ('Version',)
+_LISTFIELDS = ('Platform', 'Classifier', 'Obsoletes',
+               'Requires', 'Provides', 'Obsoletes-Dist',
+               'Provides-Dist', 'Requires-Dist', 'Requires-External',
+               'Project-URL', 'Supported-Platform', 'Setup-Requires-Dist',
+               'Provides-Extra', 'Extension')
+_LISTTUPLEFIELDS = ('Project-URL',)
+
+_ELEMENTSFIELD = ('Keywords',)
+
+_UNICODEFIELDS = ('Author', 'Maintainer', 'Summary', 'Description')
+
+_MISSING = object()
+
+_FILESAFE = re.compile('[^A-Za-z0-9.]+')
+
+
+def _get_name_and_version(name, version, for_filename=False):
+    """Return the distribution name with version.
+
+    If for_filename is true, return a filename-escaped form."""
+    if for_filename:
+        # For both name and version any runs of non-alphanumeric or '.'
+        # characters are replaced with a single '-'.  Additionally any
+        # spaces in the version string become '.'
+        name = _FILESAFE.sub('-', name)
+        version = _FILESAFE.sub('-', version.replace(' ', '.'))
+    return '%s-%s' % (name, version)
+
+
+class LegacyMetadata(object):
+    """The legacy metadata of a release.
+
+    Supports versions 1.0, 1.1 and 1.2 (auto-detected). You can
+    instantiate the class with one of these arguments (or none):
+    - *path*, the path to a metadata file
+    - *fileobj* give a file-like object with metadata as content
+    - *mapping* is a dict-like object
+    - *scheme* is a version scheme name
+    """
+    # TODO document the mapping API and UNKNOWN default key
+
+    def __init__(self, path=None, fileobj=None, mapping=None,
+                 scheme='default'):
+        if [path, fileobj, mapping].count(None) < 2:
+            raise TypeError('path, fileobj and mapping are exclusive')
+        self._fields = {}
+        self.requires_files = []
+        self._dependencies = None
+        self.scheme = scheme
+        if path is not None:
+            self.read(path)
+        elif fileobj is not None:
+            self.read_file(fileobj)
+        elif mapping is not None:
+            self.update(mapping)
+            self.set_metadata_version()
+
+    def set_metadata_version(self):
+        self._fields['Metadata-Version'] = _best_version(self._fields)
+
+    def _write_field(self, fileobj, name, value):
+        fileobj.write('%s: %s\n' % (name, value))
+
+    def __getitem__(self, name):
+        return self.get(name)
+
+    def __setitem__(self, name, value):
+        return self.set(name, value)
+
+    def __delitem__(self, name):
+        field_name = self._convert_name(name)
+        try:
+            del self._fields[field_name]
+        except KeyError:
+            raise KeyError(name)
+
+    def __contains__(self, name):
+        return (name in self._fields or
+                self._convert_name(name) in self._fields)
+
+    def _convert_name(self, name):
+        if name in _ALL_FIELDS:
+            return name
+        name = name.replace('-', '_').lower()
+        return _ATTR2FIELD.get(name, name)
+
+    def _default_value(self, name):
+        if name in _LISTFIELDS or name in _ELEMENTSFIELD:
+            return []
+        return 'UNKNOWN'
+
+    def _remove_line_prefix(self, value):
+        if self.metadata_version in ('1.0', '1.1'):
+            return _LINE_PREFIX_PRE_1_2.sub('\n', value)
+        else:
+            return _LINE_PREFIX_1_2.sub('\n', value)
+
+    def __getattr__(self, name):
+        if name in _ATTR2FIELD:
+            return self[name]
+        raise AttributeError(name)
+
+    #
+    # Public API
+    #
+
+#    dependencies = property(_get_dependencies, _set_dependencies)
+
+    def get_fullname(self, filesafe=False):
+        """Return the distribution name with version.
+
+        If filesafe is true, return a filename-escaped form."""
+        return _get_name_and_version(self['Name'], self['Version'], filesafe)
+
+    def is_field(self, name):
+        """return True if name is a valid metadata key"""
+        name = self._convert_name(name)
+        return name in _ALL_FIELDS
+
+    def is_multi_field(self, name):
+        name = self._convert_name(name)
+        return name in _LISTFIELDS
+
+    def read(self, filepath):
+        """Read the metadata values from a file path."""
+        fp = codecs.open(filepath, 'r', encoding='utf-8')
+        try:
+            self.read_file(fp)
+        finally:
+            fp.close()
+
+    def read_file(self, fileob):
+        """Read the metadata values from a file object."""
+        msg = message_from_file(fileob)
+        self._fields['Metadata-Version'] = msg['metadata-version']
+
+        # When reading, get all the fields we can
+        for field in _ALL_FIELDS:
+            if field not in msg:
+                continue
+            if field in _LISTFIELDS:
+                # we can have multiple lines
+                values = msg.get_all(field)
+                if field in _LISTTUPLEFIELDS and values is not None:
+                    values = [tuple(value.split(',')) for value in values]
+                self.set(field, values)
+            else:
+                # single line
+                value = msg[field]
+                if value is not None and value != 'UNKNOWN':
+                    self.set(field, value)
+        # logger.debug('Attempting to set metadata for %s', self)
+        # self.set_metadata_version()
+
+    def write(self, filepath, skip_unknown=False):
+        """Write the metadata fields to filepath."""
+        fp = codecs.open(filepath, 'w', encoding='utf-8')
+        try:
+            self.write_file(fp, skip_unknown)
+        finally:
+            fp.close()
+
+    def write_file(self, fileobject, skip_unknown=False):
+        """Write the PKG-INFO format data to a file object."""
+        self.set_metadata_version()
+
+        for field in _version2fieldlist(self['Metadata-Version']):
+            values = self.get(field)
+            if skip_unknown and values in ('UNKNOWN', [], ['UNKNOWN']):
+                continue
+            if field in _ELEMENTSFIELD:
+                self._write_field(fileobject, field, ','.join(values))
+                continue
+            if field not in _LISTFIELDS:
+                if field == 'Description':
+                    if self.metadata_version in ('1.0', '1.1'):
+                        values = values.replace('\n', '\n        ')
+                    else:
+                        values = values.replace('\n', '\n       |')
+                values = [values]
+
+            if field in _LISTTUPLEFIELDS:
+                values = [','.join(value) for value in values]
+
+            for value in values:
+                self._write_field(fileobject, field, value)
+
+    def update(self, other=None, **kwargs):
+        """Set metadata values from the given iterable `other` and kwargs.
+
+        Behavior is like `dict.update`: If `other` has a ``keys`` method,
+        they are looped over and ``self[key]`` is assigned ``other[key]``.
+        Else, ``other`` is an iterable of ``(key, value)`` iterables.
+
+        Keys that don't match a metadata field or that have an empty value are
+        dropped.
+        """
+        def _set(key, value):
+            if key in _ATTR2FIELD and value:
+                self.set(self._convert_name(key), value)
+
+        if not other:
+            # other is None or empty container
+            pass
+        elif hasattr(other, 'keys'):
+            for k in other.keys():
+                _set(k, other[k])
+        else:
+            for k, v in other:
+                _set(k, v)
+
+        if kwargs:
+            for k, v in kwargs.items():
+                _set(k, v)
+
+    def set(self, name, value):
+        """Control then set a metadata field."""
+        name = self._convert_name(name)
+
+        if ((name in _ELEMENTSFIELD or name == 'Platform') and
+            not isinstance(value, (list, tuple))):
+            if isinstance(value, string_types):
+                value = [v.strip() for v in value.split(',')]
+            else:
+                value = []
+        elif (name in _LISTFIELDS and
+              not isinstance(value, (list, tuple))):
+            if isinstance(value, string_types):
+                value = [value]
+            else:
+                value = []
+
+        if logger.isEnabledFor(logging.WARNING):
+            project_name = self['Name']
+
+            scheme = get_scheme(self.scheme)
+            if name in _PREDICATE_FIELDS and value is not None:
+                for v in value:
+                    # check that the values are valid
+                    if not scheme.is_valid_matcher(v.split(';')[0]):
+                        logger.warning(
+                            "'%s': '%s' is not valid (field '%s')",
+                            project_name, v, name)
+            # FIXME this rejects UNKNOWN, is that right?
+            elif name in _VERSIONS_FIELDS and value is not None:
+                if not scheme.is_valid_constraint_list(value):
+                    logger.warning("'%s': '%s' is not a valid version (field '%s')",
+                                   project_name, value, name)
+            elif name in _VERSION_FIELDS and value is not None:
+                if not scheme.is_valid_version(value):
+                    logger.warning("'%s': '%s' is not a valid version (field '%s')",
+                                   project_name, value, name)
+
+        if name in _UNICODEFIELDS:
+            if name == 'Description':
+                value = self._remove_line_prefix(value)
+
+        self._fields[name] = value
+
+    def get(self, name, default=_MISSING):
+        """Get a metadata field."""
+        name = self._convert_name(name)
+        if name not in self._fields:
+            if default is _MISSING:
+                default = self._default_value(name)
+            return default
+        if name in _UNICODEFIELDS:
+            value = self._fields[name]
+            return value
+        elif name in _LISTFIELDS:
+            value = self._fields[name]
+            if value is None:
+                return []
+            res = []
+            for val in value:
+                if name not in _LISTTUPLEFIELDS:
+                    res.append(val)
+                else:
+                    # That's for Project-URL
+                    res.append((val[0], val[1]))
+            return res
+
+        elif name in _ELEMENTSFIELD:
+            value = self._fields[name]
+            if isinstance(value, string_types):
+                return value.split(',')
+        return self._fields[name]
+
+    def check(self, strict=False):
+        """Check if the metadata is compliant. If strict is True then raise if
+        no Name or Version are provided"""
+        self.set_metadata_version()
+
+        # XXX should check the versions (if the file was loaded)
+        missing, warnings = [], []
+
+        for attr in ('Name', 'Version'):  # required by PEP 345
+            if attr not in self:
+                missing.append(attr)
+
+        if strict and missing != []:
+            msg = 'missing required metadata: %s' % ', '.join(missing)
+            raise MetadataMissingError(msg)
+
+        for attr in ('Home-page', 'Author'):
+            if attr not in self:
+                missing.append(attr)
+
+        # checking metadata 1.2 (XXX needs to check 1.1, 1.0)
+        if self['Metadata-Version'] != '1.2':
+            return missing, warnings
+
+        scheme = get_scheme(self.scheme)
+
+        def are_valid_constraints(value):
+            for v in value:
+                if not scheme.is_valid_matcher(v.split(';')[0]):
+                    return False
+            return True
+
+        for fields, controller in ((_PREDICATE_FIELDS, are_valid_constraints),
+                                   (_VERSIONS_FIELDS,
+                                    scheme.is_valid_constraint_list),
+                                   (_VERSION_FIELDS,
+                                    scheme.is_valid_version)):
+            for field in fields:
+                value = self.get(field, None)
+                if value is not None and not controller(value):
+                    warnings.append("Wrong value for '%s': %s" % (field, value))
+
+        return missing, warnings
+
+    def todict(self, skip_missing=False):
+        """Return fields as a dict.
+
+        Field names will be converted to use the underscore-lowercase style
+        instead of hyphen-mixed case (i.e. home_page instead of Home-page).
+        """
+        self.set_metadata_version()
+
+        mapping_1_0 = (
+            ('metadata_version', 'Metadata-Version'),
+            ('name', 'Name'),
+            ('version', 'Version'),
+            ('summary', 'Summary'),
+            ('home_page', 'Home-page'),
+            ('author', 'Author'),
+            ('author_email', 'Author-email'),
+            ('license', 'License'),
+            ('description', 'Description'),
+            ('keywords', 'Keywords'),
+            ('platform', 'Platform'),
+            ('classifiers', 'Classifier'),
+            ('download_url', 'Download-URL'),
+        )
+
+        data = {}
+        for key, field_name in mapping_1_0:
+            if not skip_missing or field_name in self._fields:
+                data[key] = self[field_name]
+
+        if self['Metadata-Version'] == '1.2':
+            mapping_1_2 = (
+                ('requires_dist', 'Requires-Dist'),
+                ('requires_python', 'Requires-Python'),
+                ('requires_external', 'Requires-External'),
+                ('provides_dist', 'Provides-Dist'),
+                ('obsoletes_dist', 'Obsoletes-Dist'),
+                ('project_url', 'Project-URL'),
+                ('maintainer', 'Maintainer'),
+                ('maintainer_email', 'Maintainer-email'),
+            )
+            for key, field_name in mapping_1_2:
+                if not skip_missing or field_name in self._fields:
+                    if key != 'project_url':
+                        data[key] = self[field_name]
+                    else:
+                        data[key] = [','.join(u) for u in self[field_name]]
+
+        elif self['Metadata-Version'] == '1.1':
+            mapping_1_1 = (
+                ('provides', 'Provides'),
+                ('requires', 'Requires'),
+                ('obsoletes', 'Obsoletes'),
+            )
+            for key, field_name in mapping_1_1:
+                if not skip_missing or field_name in self._fields:
+                    data[key] = self[field_name]
+
+        return data
+
+    def add_requirements(self, requirements):
+        if self['Metadata-Version'] == '1.1':
+            # we can't have 1.1 metadata *and* Setuptools requires
+            for field in ('Obsoletes', 'Requires', 'Provides'):
+                if field in self:
+                    del self[field]
+        self['Requires-Dist'] += requirements
+
+    # Mapping API
+    # TODO could add iter* variants
+
+    def keys(self):
+        return list(_version2fieldlist(self['Metadata-Version']))
+
+    def __iter__(self):
+        for key in self.keys():
+            yield key
+
+    def values(self):
+        return [self[key] for key in self.keys()]
+
+    def items(self):
+        return [(key, self[key]) for key in self.keys()]
+
+    def __repr__(self):
+        return '<%s %s %s>' % (self.__class__.__name__, self.name,
+                               self.version)
+
+
+METADATA_FILENAME = 'pydist.json'
+WHEEL_METADATA_FILENAME = 'metadata.json'
+LEGACY_METADATA_FILENAME = 'METADATA'
+
+
+class Metadata(object):
+    """
+    The metadata of a release. This implementation uses 2.0 (JSON)
+    metadata where possible. If not possible, it wraps a LegacyMetadata
+    instance which handles the key-value metadata format.
+    """
+
+    METADATA_VERSION_MATCHER = re.compile(r'^\d+(\.\d+)*$')
+
+    NAME_MATCHER = re.compile('^[0-9A-Z]([0-9A-Z_.-]*[0-9A-Z])?$', re.I)
+
+    VERSION_MATCHER = PEP440_VERSION_RE
+
+    SUMMARY_MATCHER = re.compile('.{1,2047}')
+
+    METADATA_VERSION = '2.0'
+
+    GENERATOR = 'distlib (%s)' % __version__
+
+    MANDATORY_KEYS = {
+        'name': (),
+        'version': (),
+        'summary': ('legacy',),
+    }
+
+    INDEX_KEYS = ('name version license summary description author '
+                  'author_email keywords platform home_page classifiers '
+                  'download_url')
+
+    DEPENDENCY_KEYS = ('extras run_requires test_requires build_requires '
+                       'dev_requires provides meta_requires obsoleted_by '
+                       'supports_environments')
+
+    SYNTAX_VALIDATORS = {
+        'metadata_version': (METADATA_VERSION_MATCHER, ()),
+        'name': (NAME_MATCHER, ('legacy',)),
+        'version': (VERSION_MATCHER, ('legacy',)),
+        'summary': (SUMMARY_MATCHER, ('legacy',)),
+    }
+
+    __slots__ = ('_legacy', '_data', 'scheme')
+
+    def __init__(self, path=None, fileobj=None, mapping=None,
+                 scheme='default'):
+        if [path, fileobj, mapping].count(None) < 2:
+            raise TypeError('path, fileobj and mapping are exclusive')
+        self._legacy = None
+        self._data = None
+        self.scheme = scheme
+        #import pdb; pdb.set_trace()
+        if mapping is not None:
+            try:
+                self._validate_mapping(mapping, scheme)
+                self._data = mapping
+            except MetadataUnrecognizedVersionError:
+                self._legacy = LegacyMetadata(mapping=mapping, scheme=scheme)
+                self.validate()
+        else:
+            data = None
+            if path:
+                with open(path, 'rb') as f:
+                    data = f.read()
+            elif fileobj:
+                data = fileobj.read()
+            if data is None:
+                # Initialised with no args - to be added
+                self._data = {
+                    'metadata_version': self.METADATA_VERSION,
+                    'generator': self.GENERATOR,
+                }
+            else:
+                if not isinstance(data, text_type):
+                    data = data.decode('utf-8')
+                try:
+                    self._data = json.loads(data)
+                    self._validate_mapping(self._data, scheme)
+                except ValueError:
+                    # Note: MetadataUnrecognizedVersionError does not
+                    # inherit from ValueError (it's a DistlibException,
+                    # which should not inherit from ValueError).
+                    # The ValueError comes from the json.load - if that
+                    # succeeds and we get a validation error, we want
+                    # that to propagate
+                    self._legacy = LegacyMetadata(fileobj=StringIO(data),
+                                                  scheme=scheme)
+                    self.validate()
+
+    common_keys = set(('name', 'version', 'license', 'keywords', 'summary'))
+
+    none_list = (None, list)
+    none_dict = (None, dict)
+
+    mapped_keys = {
+        'run_requires': ('Requires-Dist', list),
+        'build_requires': ('Setup-Requires-Dist', list),
+        'dev_requires': none_list,
+        'test_requires': none_list,
+        'meta_requires': none_list,
+        'extras': ('Provides-Extra', list),
+        'modules': none_list,
+        'namespaces': none_list,
+        'exports': none_dict,
+        'commands': none_dict,
+        'classifiers': ('Classifier', list),
+        'source_url': ('Download-URL', None),
+        'metadata_version': ('Metadata-Version', None),
+    }
+
+    del none_list, none_dict
+
+    def __getattribute__(self, key):
+        common = object.__getattribute__(self, 'common_keys')
+        mapped = object.__getattribute__(self, 'mapped_keys')
+        if key in mapped:
+            lk, maker = mapped[key]
+            if self._legacy:
+                if lk is None:
+                    result = None if maker is None else maker()
+                else:
+                    result = self._legacy.get(lk)
+            else:
+                value = None if maker is None else maker()
+                if key not in ('commands', 'exports', 'modules', 'namespaces',
+                               'classifiers'):
+                    result = self._data.get(key, value)
+                else:
+                    # special cases for PEP 459
+                    sentinel = object()
+                    result = sentinel
+                    d = self._data.get('extensions')
+                    if d:
+                        if key == 'commands':
+                            result = d.get('python.commands', value)
+                        elif key == 'classifiers':
+                            d = d.get('python.details')
+                            if d:
+                                result = d.get(key, value)
+                        else:
+                            d = d.get('python.exports')
+                            if not d:
+                                d = self._data.get('python.exports')
+                            if d:
+                                result = d.get(key, value)
+                    if result is sentinel:
+                        result = value
+        elif key not in common:
+            result = object.__getattribute__(self, key)
+        elif self._legacy:
+            result = self._legacy.get(key)
+        else:
+            result = self._data.get(key)
+        return result
+
+    def _validate_value(self, key, value, scheme=None):
+        if key in self.SYNTAX_VALIDATORS:
+            pattern, exclusions = self.SYNTAX_VALIDATORS[key]
+            if (scheme or self.scheme) not in exclusions:
+                m = pattern.match(value)
+                if not m:
+                    raise MetadataInvalidError("'%s' is an invalid value for "
+                                               "the '%s' property" % (value,
+                                                                    key))
+
+    def __setattr__(self, key, value):
+        self._validate_value(key, value)
+        common = object.__getattribute__(self, 'common_keys')
+        mapped = object.__getattribute__(self, 'mapped_keys')
+        if key in mapped:
+            lk, _ = mapped[key]
+            if self._legacy:
+                if lk is None:
+                    raise NotImplementedError
+                self._legacy[lk] = value
+            elif key not in ('commands', 'exports', 'modules', 'namespaces',
+                             'classifiers'):
+                self._data[key] = value
+            else:
+                # special cases for PEP 459
+                d = self._data.setdefault('extensions', {})
+                if key == 'commands':
+                    d['python.commands'] = value
+                elif key == 'classifiers':
+                    d = d.setdefault('python.details', {})
+                    d[key] = value
+                else:
+                    d = d.setdefault('python.exports', {})
+                    d[key] = value
+        elif key not in common:
+            object.__setattr__(self, key, value)
+        else:
+            if key == 'keywords':
+                if isinstance(value, string_types):
+                    value = value.strip()
+                    if value:
+                        value = value.split()
+                    else:
+                        value = []
+            if self._legacy:
+                self._legacy[key] = value
+            else:
+                self._data[key] = value
+
+    @property
+    def name_and_version(self):
+        return _get_name_and_version(self.name, self.version, True)
+
+    @property
+    def provides(self):
+        if self._legacy:
+            result = self._legacy['Provides-Dist']
+        else:
+            result = self._data.setdefault('provides', [])
+        s = '%s (%s)' % (self.name, self.version)
+        if s not in result:
+            result.append(s)
+        return result
+
+    @provides.setter
+    def provides(self, value):
+        if self._legacy:
+            self._legacy['Provides-Dist'] = value
+        else:
+            self._data['provides'] = value
+
+    def get_requirements(self, reqts, extras=None, env=None):
+        """
+        Base method to get dependencies, given a set of extras
+        to satisfy and an optional environment context.
+        :param reqts: A list of sometimes-wanted dependencies,
+                      perhaps dependent on extras and environment.
+        :param extras: A list of optional components being requested.
+        :param env: An optional environment for marker evaluation.
+        """
+        if self._legacy:
+            result = reqts
+        else:
+            result = []
+            extras = get_extras(extras or [], self.extras)
+            for d in reqts:
+                if 'extra' not in d and 'environment' not in d:
+                    # unconditional
+                    include = True
+                else:
+                    if 'extra' not in d:
+                        # Not extra-dependent - only environment-dependent
+                        include = True
+                    else:
+                        include = d.get('extra') in extras
+                    if include:
+                        # Not excluded because of extras, check environment
+                        marker = d.get('environment')
+                        if marker:
+                            include = interpret(marker, env)
+                if include:
+                    result.extend(d['requires'])
+            for key in ('build', 'dev', 'test'):
+                e = ':%s:' % key
+                if e in extras:
+                    extras.remove(e)
+                    # A recursive call, but it should terminate since 'test'
+                    # has been removed from the extras
+                    reqts = self._data.get('%s_requires' % key, [])
+                    result.extend(self.get_requirements(reqts, extras=extras,
+                                                        env=env))
+        return result
+
+    @property
+    def dictionary(self):
+        if self._legacy:
+            return self._from_legacy()
+        return self._data
+
+    @property
+    def dependencies(self):
+        if self._legacy:
+            raise NotImplementedError
+        else:
+            return extract_by_key(self._data, self.DEPENDENCY_KEYS)
+
+    @dependencies.setter
+    def dependencies(self, value):
+        if self._legacy:
+            raise NotImplementedError
+        else:
+            self._data.update(value)
+
+    def _validate_mapping(self, mapping, scheme):
+        if mapping.get('metadata_version') != self.METADATA_VERSION:
+            raise MetadataUnrecognizedVersionError()
+        missing = []
+        for key, exclusions in self.MANDATORY_KEYS.items():
+            if key not in mapping:
+                if scheme not in exclusions:
+                    missing.append(key)
+        if missing:
+            msg = 'Missing metadata items: %s' % ', '.join(missing)
+            raise MetadataMissingError(msg)
+        for k, v in mapping.items():
+            self._validate_value(k, v, scheme)
+
+    def validate(self):
+        if self._legacy:
+            missing, warnings = self._legacy.check(True)
+            if missing or warnings:
+                logger.warning('Metadata: missing: %s, warnings: %s',
+                               missing, warnings)
+        else:
+            self._validate_mapping(self._data, self.scheme)
+
+    def todict(self):
+        if self._legacy:
+            return self._legacy.todict(True)
+        else:
+            result = extract_by_key(self._data, self.INDEX_KEYS)
+            return result
+
+    def _from_legacy(self):
+        assert self._legacy and not self._data
+        result = {
+            'metadata_version': self.METADATA_VERSION,
+            'generator': self.GENERATOR,
+        }
+        lmd = self._legacy.todict(True)     # skip missing ones
+        for k in ('name', 'version', 'license', 'summary', 'description',
+                  'classifier'):
+            if k in lmd:
+                if k == 'classifier':
+                    nk = 'classifiers'
+                else:
+                    nk = k
+                result[nk] = lmd[k]
+        kw = lmd.get('Keywords', [])
+        if kw == ['']:
+            kw = []
+        result['keywords'] = kw
+        keys = (('requires_dist', 'run_requires'),
+                ('setup_requires_dist', 'build_requires'))
+        for ok, nk in keys:
+            if ok in lmd and lmd[ok]:
+                result[nk] = [{'requires': lmd[ok]}]
+        result['provides'] = self.provides
+        author = {}
+        maintainer = {}
+        return result
+
+    LEGACY_MAPPING = {
+        'name': 'Name',
+        'version': 'Version',
+        'license': 'License',
+        'summary': 'Summary',
+        'description': 'Description',
+        'classifiers': 'Classifier',
+    }
+
+    def _to_legacy(self):
+        def process_entries(entries):
+            reqts = set()
+            for e in entries:
+                extra = e.get('extra')
+                env = e.get('environment')
+                rlist = e['requires']
+                for r in rlist:
+                    if not env and not extra:
+                        reqts.add(r)
+                    else:
+                        marker = ''
+                        if extra:
+                            marker = 'extra == "%s"' % extra
+                        if env:
+                            if marker:
+                                marker = '(%s) and %s' % (env, marker)
+                            else:
+                                marker = env
+                        reqts.add(';'.join((r, marker)))
+            return reqts
+
+        assert self._data and not self._legacy
+        result = LegacyMetadata()
+        nmd = self._data
+        for nk, ok in self.LEGACY_MAPPING.items():
+            if nk in nmd:
+                result[ok] = nmd[nk]
+        r1 = process_entries(self.run_requires + self.meta_requires)
+        r2 = process_entries(self.build_requires + self.dev_requires)
+        if self.extras:
+            result['Provides-Extra'] = sorted(self.extras)
+        result['Requires-Dist'] = sorted(r1)
+        result['Setup-Requires-Dist'] = sorted(r2)
+        # TODO: other fields such as contacts
+        return result
+
+    def write(self, path=None, fileobj=None, legacy=False, skip_unknown=True):
+        if [path, fileobj].count(None) != 1:
+            raise ValueError('Exactly one of path and fileobj is needed')
+        self.validate()
+        if legacy:
+            if self._legacy:
+                legacy_md = self._legacy
+            else:
+                legacy_md = self._to_legacy()
+            if path:
+                legacy_md.write(path, skip_unknown=skip_unknown)
+            else:
+                legacy_md.write_file(fileobj, skip_unknown=skip_unknown)
+        else:
+            if self._legacy:
+                d = self._from_legacy()
+            else:
+                d = self._data
+            if fileobj:
+                json.dump(d, fileobj, ensure_ascii=True, indent=2,
+                          sort_keys=True)
+            else:
+                with codecs.open(path, 'w', 'utf-8') as f:
+                    json.dump(d, f, ensure_ascii=True, indent=2,
+                              sort_keys=True)
+
+    def add_requirements(self, requirements):
+        if self._legacy:
+            self._legacy.add_requirements(requirements)
+        else:
+            run_requires = self._data.setdefault('run_requires', [])
+            always = None
+            for entry in run_requires:
+                if 'environment' not in entry and 'extra' not in entry:
+                    always = entry
+                    break
+            if always is None:
+                always = { 'requires': requirements }
+                run_requires.insert(0, always)
+            else:
+                rset = set(always['requires']) | set(requirements)
+                always['requires'] = sorted(rset)
+
+    def __repr__(self):
+        name = self.name or '(no name)'
+        version = self.version or 'no version'
+        return '<%s %s %s (%s)>' % (self.__class__.__name__,
+                                    self.metadata_version, name, version)
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/metadata.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/metadata.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..06628b518c7bcf8bb6af32b86e439a946d462f2c
GIT binary patch
literal 38836
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
SnfRG`c*XuRbbxxmY|H>#;GiJ@

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/resources.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/resources.py
new file mode 100644
index 0000000..1884016
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/resources.py
@@ -0,0 +1,355 @@
+# -*- coding: utf-8 -*-
+#
+# Copyright (C) 2013-2017 Vinay Sajip.
+# Licensed to the Python Software Foundation under a contributor agreement.
+# See LICENSE.txt and CONTRIBUTORS.txt.
+#
+from __future__ import unicode_literals
+
+import bisect
+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
+
+logger = logging.getLogger(__name__)
+
+
+cache = None    # created when needed
+
+
+class ResourceCache(Cache):
+    def __init__(self, base=None):
+        if base is None:
+            # Use native string to avoid issues on 2.x: see Python #20140.
+            base = os.path.join(get_cache_base(), str('resource-cache'))
+        super(ResourceCache, self).__init__(base)
+
+    def is_stale(self, resource, path):
+        """
+        Is the cache stale for the given resource?
+
+        :param resource: The :class:`Resource` being cached.
+        :param path: The path of the resource in the cache.
+        :return: True if the cache is stale.
+        """
+        # Cache invalidation is a hard problem :-)
+        return True
+
+    def get(self, resource):
+        """
+        Get a resource into the cache,
+
+        :param resource: A :class:`Resource` instance.
+        :return: The pathname of the resource in the cache.
+        """
+        prefix, path = resource.finder.get_cache_info(resource)
+        if prefix is None:
+            result = path
+        else:
+            result = os.path.join(self.base, self.prefix_to_dir(prefix), path)
+            dirname = os.path.dirname(result)
+            if not os.path.isdir(dirname):
+                os.makedirs(dirname)
+            if not os.path.exists(result):
+                stale = True
+            else:
+                stale = self.is_stale(resource, path)
+            if stale:
+                # write the bytes of the resource to the cache location
+                with open(result, 'wb') as f:
+                    f.write(resource.bytes)
+        return result
+
+
+class ResourceBase(object):
+    def __init__(self, finder, name):
+        self.finder = finder
+        self.name = name
+
+
+class Resource(ResourceBase):
+    """
+    A class representing an in-package resource, such as a data file. This is
+    not normally instantiated by user code, but rather by a
+    :class:`ResourceFinder` which manages the resource.
+    """
+    is_container = False        # Backwards compatibility
+
+    def as_stream(self):
+        """
+        Get the resource as a stream.
+
+        This is not a property to make it obvious that it returns a new stream
+        each time.
+        """
+        return self.finder.get_stream(self)
+
+    @cached_property
+    def file_path(self):
+        global cache
+        if cache is None:
+            cache = ResourceCache()
+        return cache.get(self)
+
+    @cached_property
+    def bytes(self):
+        return self.finder.get_bytes(self)
+
+    @cached_property
+    def size(self):
+        return self.finder.get_size(self)
+
+
+class ResourceContainer(ResourceBase):
+    is_container = True     # Backwards compatibility
+
+    @cached_property
+    def resources(self):
+        return self.finder.get_resources(self)
+
+
+class ResourceFinder(object):
+    """
+    Resource finder for file system resources.
+    """
+
+    if sys.platform.startswith('java'):
+        skipped_extensions = ('.pyc', '.pyo', '.class')
+    else:
+        skipped_extensions = ('.pyc', '.pyo')
+
+    def __init__(self, module):
+        self.module = module
+        self.loader = getattr(module, '__loader__', None)
+        self.base = os.path.dirname(getattr(module, '__file__', ''))
+
+    def _adjust_path(self, path):
+        return os.path.realpath(path)
+
+    def _make_path(self, resource_name):
+        # Issue #50: need to preserve type of path on Python 2.x
+        # like os.path._get_sep
+        if isinstance(resource_name, bytes):    # should only happen on 2.x
+            sep = b'/'
+        else:
+            sep = '/'
+        parts = resource_name.split(sep)
+        parts.insert(0, self.base)
+        result = os.path.join(*parts)
+        return self._adjust_path(result)
+
+    def _find(self, path):
+        return os.path.exists(path)
+
+    def get_cache_info(self, resource):
+        return None, resource.path
+
+    def find(self, resource_name):
+        path = self._make_path(resource_name)
+        if not self._find(path):
+            result = None
+        else:
+            if self._is_directory(path):
+                result = ResourceContainer(self, resource_name)
+            else:
+                result = Resource(self, resource_name)
+            result.path = path
+        return result
+
+    def get_stream(self, resource):
+        return open(resource.path, 'rb')
+
+    def get_bytes(self, resource):
+        with open(resource.path, 'rb') as f:
+            return f.read()
+
+    def get_size(self, resource):
+        return os.path.getsize(resource.path)
+
+    def get_resources(self, resource):
+        def allowed(f):
+            return (f != '__pycache__' and not
+                    f.endswith(self.skipped_extensions))
+        return set([f for f in os.listdir(resource.path) if allowed(f)])
+
+    def is_container(self, resource):
+        return self._is_directory(resource.path)
+
+    _is_directory = staticmethod(os.path.isdir)
+
+    def iterator(self, resource_name):
+        resource = self.find(resource_name)
+        if resource is not None:
+            todo = [resource]
+            while todo:
+                resource = todo.pop(0)
+                yield resource
+                if resource.is_container:
+                    rname = resource.name
+                    for name in resource.resources:
+                        if not rname:
+                            new_name = name
+                        else:
+                            new_name = '/'.join([rname, name])
+                        child = self.find(new_name)
+                        if child.is_container:
+                            todo.append(child)
+                        else:
+                            yield child
+
+
+class ZipResourceFinder(ResourceFinder):
+    """
+    Resource finder for resources in .zip files.
+    """
+    def __init__(self, module):
+        super(ZipResourceFinder, self).__init__(module)
+        archive = self.loader.archive
+        self.prefix_len = 1 + len(archive)
+        # PyPy doesn't have a _files attr on zipimporter, and you can't set one
+        if hasattr(self.loader, '_files'):
+            self._files = self.loader._files
+        else:
+            self._files = zipimport._zip_directory_cache[archive]
+        self.index = sorted(self._files)
+
+    def _adjust_path(self, path):
+        return path
+
+    def _find(self, path):
+        path = path[self.prefix_len:]
+        if path in self._files:
+            result = True
+        else:
+            if path and path[-1] != os.sep:
+                path = path + os.sep
+            i = bisect.bisect(self.index, path)
+            try:
+                result = self.index[i].startswith(path)
+            except IndexError:
+                result = False
+        if not result:
+            logger.debug('_find failed: %r %r', path, self.loader.prefix)
+        else:
+            logger.debug('_find worked: %r %r', path, self.loader.prefix)
+        return result
+
+    def get_cache_info(self, resource):
+        prefix = self.loader.archive
+        path = resource.path[1 + len(prefix):]
+        return prefix, path
+
+    def get_bytes(self, resource):
+        return self.loader.get_data(resource.path)
+
+    def get_stream(self, resource):
+        return io.BytesIO(self.get_bytes(resource))
+
+    def get_size(self, resource):
+        path = resource.path[self.prefix_len:]
+        return self._files[path][3]
+
+    def get_resources(self, resource):
+        path = resource.path[self.prefix_len:]
+        if path and path[-1] != os.sep:
+            path += os.sep
+        plen = len(path)
+        result = set()
+        i = bisect.bisect(self.index, path)
+        while i < len(self.index):
+            if not self.index[i].startswith(path):
+                break
+            s = self.index[i][plen:]
+            result.add(s.split(os.sep, 1)[0])   # only immediate children
+            i += 1
+        return result
+
+    def _is_directory(self, path):
+        path = path[self.prefix_len:]
+        if path and path[-1] != os.sep:
+            path += os.sep
+        i = bisect.bisect(self.index, path)
+        try:
+            result = self.index[i].startswith(path)
+        except IndexError:
+            result = False
+        return result
+
+_finder_registry = {
+    type(None): ResourceFinder,
+    zipimport.zipimporter: ZipResourceFinder
+}
+
+try:
+    # In Python 3.6, _frozen_importlib -> _frozen_importlib_external
+    try:
+        import _frozen_importlib_external as _fi
+    except ImportError:
+        import _frozen_importlib as _fi
+    _finder_registry[_fi.SourceFileLoader] = ResourceFinder
+    _finder_registry[_fi.FileFinder] = ResourceFinder
+    del _fi
+except (ImportError, AttributeError):
+    pass
+
+
+def register_finder(loader, finder_maker):
+    _finder_registry[type(loader)] = finder_maker
+
+_finder_cache = {}
+
+
+def finder(package):
+    """
+    Return a resource finder for a package.
+    :param package: The name of the package.
+    :return: A :class:`ResourceFinder` instance for the package.
+    """
+    if package in _finder_cache:
+        result = _finder_cache[package]
+    else:
+        if package not in sys.modules:
+            __import__(package)
+        module = sys.modules[package]
+        path = getattr(module, '__path__', None)
+        if path is None:
+            raise DistlibException('You cannot get a finder for a module, '
+                                   'only for a package')
+        loader = getattr(module, '__loader__', None)
+        finder_maker = _finder_registry.get(type(loader))
+        if finder_maker is None:
+            raise DistlibException('Unable to locate finder for %r' % package)
+        result = finder_maker(module)
+        _finder_cache[package] = result
+    return result
+
+
+_dummy_module = types.ModuleType(str('__dummy__'))
+
+
+def finder_for_path(path):
+    """
+    Return a resource finder for a path, which should represent a container.
+
+    :param path: The path.
+    :return: A :class:`ResourceFinder` instance for the path.
+    """
+    result = None
+    # calls any path hooks, gets importer into cache
+    pkgutil.get_importer(path)
+    loader = sys.path_importer_cache.get(path)
+    finder = _finder_registry.get(type(loader))
+    if finder:
+        module = _dummy_module
+        module.__file__ = os.path.join(path, '')
+        module.__loader__ = loader
+        result = finder(module)
+    return result
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/resources.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/resources.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..bf86df71bc8f59c92d5cd0bec21d7a0c836cdaa0
GIT binary patch
literal 15896
zcmZSn%**AGdLky70Sed{7#JKFm>7yVnHU&S7#LC*8FCmHav2$-7#SErd?tn*CWa^`
zupARZ4l_d(GmOo`5XAyxvob`n!q{vKQEV_aJ3|yZjLpFi#Q|e;GDLC0*jx-zTns79
z3@I!OIou4nJPc7h42&Q?D?<)1LoOdf6dyw_KSLBhL#_ZrlmJ7nAVZWO17j)+LzWOj
zsxU({BSVx3Lkbf^q8LL88$+rfLmDGP3Ohp!14A<dLu8aVLkb5&ssvb+6D}&rkix}~
zDhU?lhKouur0~E*dEuhc3@Lmt6ZqkxG7KpK45>0;69nO+vJ9C_AkkDgkdvAj8O%~;
z8B)0zvg8@eq7)b^0~sm>U_Mu5h*Dw*&y!_fNmXXZ=3*$C#>mJB3w9NdWF8|!M5+u!
zsscl*5<`|MgAIbC#$Xc-(k%|wovO}|#soIw9LNliz7!#lqoOnzG8q`6G#OHa!CWnd
zR8EF0ZH81Gh7=J{*nxsimmx(IEUO1{bg+gP0|P_m|NsC0YcMh}Fq8-|Fff$nWhUpR
zq{ioDmZTOX<`ny7f}{}gE}6w8IhjeW70IauC7Jno8Z024{0s~X$%)AssVVUVMfnA(
zMJ1Ibd<+Z>>8U00VDb2*#NyNvK?Vkfg2a-H_>z36a7t!T2`d8wgEL5T2`>W!Lr`jQ
zerZv1Dp&-bfSDK=7@R-}SdD>!A(a7?Zb3<hfuV&FoKzXX-eLiHtAzoSNP~jGE=vY!
z1YwXfok0e;GcYjJFoL2cn}eZ9m!X7_A&ZG2i<zN>1(c3TSV5VinUSHHiJ_K}A&-Hf
zgpHwuouP&SB$CAe(%THlG{G7mgZ)ZD9xZ~pS{LkF4Ng#?fUNY(&r2-<Da$V|0r5e;
z2Q#wrGxLI&LCQcxaS0?Cic1Spi-JJ8wS<F#fgwIVGcU6wJ|1ilSX*&wP8yg23QrAC
z?gkUZ1q=)f`UORqWr-!J`elhl`f2$&DXB%p`bjDJ<w;3-xu&_rMuth|=~d|#rWWNn
zSyg5RAdsG?AEIB7S)iMlS6q^qlcVca=HY1^01^V@__EZzl>8$76iBq|!~9vSS5O%Q
ziY{3O28LpggBcikm=qb4LB0WDP^tlkH^|o|3=F~GBvksCfq{Wb0SY{e6-qKv6~IBJ
z0J1(+AuYcMES8>GmYSykv(26huE(k%u_!SYE@Pz-l98%lm7J4UTx^v9OFIb)NvWB6
z=@64s^w2efA_1Zi#8Svl16v8ROd&H5%m+IQNpDeVNoi4@l|o2SX{tgdL=RYvLS`|<
z^$5ja&w}F#q*?<MAVHvH0*+OfMM0bl3=H7t0}}%hhhPU~7RQ4_Ul|mapv20+3C=g5
zBnXOHa6CST<eMx8hAc*CCWv8TsAXcPWoD>h0%bf%eyU++sAXZu+s07B%#g*xki`nh
zI$3OBk{zV7nUSG}nV}i14625Mp@s!iM%A*yba67&u!2O2Tfrh+P%a}VKSIpqhUzI^
zz)-@&P|L=UCj_>G7vwmQ1xz5p8a9Ta#|$NWAjK)*Ox-WeP|MCx!_JV!4^o*W0J4TL
zJcWrNFd~luq%Ig7U!_Zsld5}ai9#Yg)hT4=mE<E5i4LCR>4+t9g7aElaw;OdSiuul
zMydiRQRXG)rV^PjOF=PKp5&(iDqTxJ@s*aDmy%k9Rsd(_rR4{)g9=zsw1U%K5EqEc
z4=RLsK_zohYFcImsB8w6${?jFnMELnfJ^AiVvs0EZ*F3CYD#8NG1#uuip=7Y;vi7f
z5hMgM36$US3sUpIn#zkZOH#qCq{@=iVhxaXa7GA%JGKC9E7(0?1B+6NOLIzsKvff1
zBRFN2fQpkea5e!G1Cv)k**HD5L=TirWI$yvy96T-BPWvzqY$GIqX452BPWv(BO8+t
zqa>rB1}G-L*(*LC6o~QhC7|GrkI&6dDa}cZkB3ACDB!^X7o><%8VsB_!PO7Qd*EW7
zjgg0qle>fmlv1E|oKs?PD!gI_MGUxN21O{eVrBqW#!L)BkU}3`Cx8+vxGVuhZVe+S
zyT&tsii8>lhInw54AI~RuJ3|`VaW*;eBe9@Njf0$AXSvm8j$n=uKzqii2;=685lVk
zA&yi6g%zkQ1uFnYB!U<im#Q!@FnEAm3W@?YMsTu(RhICm1j&J;(hJeXVgPjtQklVB
z07x5)l_8Z4RN8}@-Hf1SKZwf=ig8d2lLIWv0^@Rm(g3J^S9%;)nmQ_gD{F<K)Pkba
z;?%qnP(_`Xr;wSaTacKXotT~qFJ^TVic6C-6cURS5*1PsOA-~*GILV(6hbmGixo19
z!L@o`eu+X}eo<~>PEMr)q+Bh@Oe{%FQAny(C@oGcQUJAPbrh0HOB9L{OEOZ6KoW^y
zz38n5H*m3;pirKXnVg}Jo0ylFo(gH9z-nwrft?IW^B@cgFmQSXm3}o04A8of0aT+v
zQgZ1en72Vq9#AC$YVg2}gZQktq$o8pR}WE#K>eox@>`+;tUawzlCJ<Nc@;8C6!MeG
zGV@D8Zc8iy@r%Gs6HqYarIsr|3<P@-WNT_-a)v@lW-d~7gOtBOWfG{B4$%Z|w}5lm
z0H@dzP6h^sL{Pf~6gXk9q|3mL8Tg=*pak5j1vNk<7)qEx?f66naNC^$)UpS)-5H@R
zP(N_D09><x8*h+O7*tk63SdyY4w?V}rT2JHb08iR03b&)F!M0-Fk%J*&J>7TmV&|*
z6xWctc(C|12vpakfjkJxPYg_CdJfdI0C}!BvnqA)Bx6v`0CG_l!haf|EEfc?BuYRH
zt@!wq{N(s}aI$nu%qdO<SGbwQ@yYplC5f4NsYOAc3>gFpp&%_#{Q?TKAYGJ75Tt@(
zVCol8uiOvhMNm6|jg^g&jfs<!pPiot+~tSWG|n*3U{*PxZX~4jkjez=(5HfjoS=0K
zE2tI$C08<&2B?h%N*b_ow|MZR4^WnbJF5s3f}kj7U;?)u5s3uSzBT|wJV-vsc(6pg
zAp-+LKFHaigbs>!aIXUv;gA{?9^0VyGq{1V7PEl?=_-P{Xp9U+>I^A@pwY!VHii@-
z5F>>Z)S`%D2Mzpz#&<ZN1Am~=MGmkO7efko&@YM`G~fqP!^4mQ9`K9e1r7FrMEDp|
zz=M5J{Gfq8kca?73V5I|N{}HHJjj?O!jL5js=uSeK*N3@HR7Pu2WoScn!qY^nEw<Y
zJuUF41*oi6D6T9nNkxoK6hj&erJ%scN-RqRGxQ27lVObfQc$6;2W}C8yWF7I1+|yJ
z%?f8ommAbNW&n*-frhQX&E#fgaN8L?W|hUtki`a*WdaSbHZy}f0MZ2>lZ6a~`IUl-
zo%r~i{KS;hqWJhyP<a_24{~*Ud?~0i1MZxGyI{HC9tyZ%N>43GEGa1h*OFj4i2fju
zZg8Is+))bx^&ugR3O-O8HAP9D15+e{GJPW`Wr9K&)HoMqgoiLFl))hksy0i&BN|yu
zpwWP4L^A=DSP|X?x0s7k6LUbdF_KR~`4?R7f{6j~DY&YLPfW=wEiM5!7TQ3*26>SI
z;$u*H0{I5)V^B+?1Uv#-0v--2k^qf&)-o}G@)~$Nrv^MATEhfNM4+)9W>6C<1)Sot
zSU`iIj3wYCm&Fbm$LV1J4flW=zpz0ZXnF&8+4W07#kPJXIDLV_3fu?IEQYkylT*QU
zKe*N_F38C&0jIFcyyDcN5^$12gg<1c!V;9OK;8kj(7?mRu)-7E$1VYRvpBT?Y+^xT
zQAu%-97qe;dJr)%5d_Y8ptd_WdOAVT1Ii{0%>0a;Ol*w&jKYjUkf;L18VG}<is-}{
zBnk2)NFO*{!1)rK9>K)G_!$&S@u1>yD#*Jaw?R`QhzY`AFM={@3OF@pF@h#GAiXAN
zn-$bBg7^ib9^y67C<EA6U}8YL79_&Jz%T>NSD+Fel=#5DN&%JI;O<}zBRCf^fr@L;
zuqilG6{~}0A8MHy@+`sP;PKODMus8}&>Tb!I5<GF56ldC{0t?mAT=O!U?Z(H%nb2t
zpsWWAEO0nEg34Vd5CP(XvqpSoaePW<QEGBYeo<u*sHP4AwbLL$3UV+cNbNwHKzVae
z<Q0&+K*?q{D1bpZfPs;p5tL8(8HJem895R81RmTVRgfYrixE_qH8U~5re;71rzi<h
zUQ5CJ3E_frAb1oKoRYxAz$7Pi1_p-ZAm4%<3(X`TzkzZPI5}y8#=*d;0`9+lLD0y1
z4HIbUs+oZyI6Q@cAuu8ZG|d7s#Sc6tT$BVEkAiy~JRwn(nwSC+hlfCr0;v1|m5&1$
z4B89~468uF07?N2jM!>xP$LYvw$1|QE?71Ig&Cs4fVEygov%R_;W`Wq4C_EX1w|D!
z!a<$}ML08PiqeIFfuWrNJmJj9(8d6Y>JkQqbZ{FG(oV?&H}PCzC7`n}p!p6)h9Xr^
zu@J|^P^bzjcA%L6rPCw~G9T30ssS$o$Yy59mjM+pSquyv;C4_mBLfdqV<|Uy3bLRQ
zJWv9gg#@+yQu9)Z%QH(dN<bt2#o3t!1*s|VsTC!udBvIedC=|^I8lMBe{eA~a48F%
z5)yNA^2<|GHi3d26xIxkJdBW$AW*U?PAvha9I(=y%;J)i%p&w+5>)d9fku0gatqvd
z15<JsF)%P}MEHoG8G8d4)Hs6`A4m;cCQx|@>S92A3g*I#1aNeLiGlGNsH?jj<Ta49
zpm_w8@<4Hy3`)btu+*{O<ty2o3`K`PlM3mKpv+M*8<Z!C_JPPOCUEt@2+B}3OblU+
zpaPT`)ZGLzSU?Tgid2x+ELH}W*l>ngR?u`{aS>?p5j4Rl3L5tYO=YrxMAE^Pc`X|>
z`_!<3@*H$(k(r@rJ=jL@Oe1K$Kw&Is&M}O!FqR>_P@SProgq9AJZK4-ZS(^-ks+;R
za7Qc%R0u%2U7!?NkY5l43KQ_W2e|tWZV`hU%!vgBsd*_7U3{QO1=r}H^a?KUOY&3l
z!3|>YTpri}aBn6rwH(rD29-O>8JRgL;P?g;0}|<AS7m~hos{Gk?EytTs0abo|2&MG
zjGT=8jI3Z<fRT-nlSvfRDqs{~0@r1*{xsH(HMsc4RG}dO3M=?HTo7nl57L3CECxHJ
zASbaTEx#xi+-E5+0d*%pg<cS7A_Y9P69npy1R+{ppoSqN-avJF5U55A0u}Z_po|KR
zK5$>HxFoS8GdVZ4BqKisT<m}|V30V-IpF*lgi;+3T!aLH20Y3^5djJ%HfGSwCMOdc
z6DKPtGbaxxGn8cEWaeb!WENrq5B5c67Qlu_(1w3Nr6qXy2h<0J4ECjf=a*6-GfT{%
z>;)QeVF8U|fEcWx#bO`^8v{urKtaLaLDo_;d;>PHo?|g+!G~T|W&wD52|8p0E=fTd
z4}`(3uzE-<tb`Gi-<!cLFHozTk%19ZzJk{z)Pl<wP>UU0G>C(SU|@@fvcSG;W@0Fc
z1R0RU%m7+T#J~{G!H_4wP{PTO#RV#PBtd#O7)rRoia0<;3P^+p)MJ2^6rgYfj~jtU
zZ;CZ|K?w&m@EQ~jVu88lAlHI=0*OV*8JT6N;Dnu%ng>qHkSX_g5ErB*Be57X#se-(
zAVz{`U#c<-GII;^i%LpB={mkDvjEYXfUMpE>nP4IDoITN7cijtvkGv21XuY%pkbh(
z2$aM;AO#CJvt9+IV^HzPz$nJZ!zj!o#3;lhfap$uLKPg*pem*YF%AT77K3Ubh@UtI
zfp<W~&I6ElK+b|zjv!Zq3UaU)u7N5?MsN~hV34l`uh#*kQbvYsHc%_E1U%4_R|FdJ
zD)Ix7DU1w~ki|IJ%nT4A2v;1s2#ytLB@cMusFs<bQVMJZxHBpV8V&-t$7`7w!t=x#
zSV}m+>lCLkFfuZhaDwVw&}zjRCWhjj3?*C)S=^xP4p{||#lw)r3tAGym?sI7V+J`3
z<Y>5D4X9rS@~0no&0?uAsCf$ND=MTVX6B@(SShF$DX119iI?XWWy8faK#?C51<E2Z
zAOh5FgcQH_pv(dqCQQmKPE9TeN&rcRf&{r37#KYBQc^2ii;D7#g7iURAcZ;k>FKGE
zC3`8UNu}vQp!^mDYFC3Bm58JQ?o)$@!ZN|-IG7liOaK}j04={O22C9?F!F-xPbNu5
z0Y*_qW=1JSUPdlPHbxmHNl2Ceg)<0)(-UZ(2^1CJ9zrd6q!iMYDuIn%h|7b93YkD{
zo-|N2fl?-P=_tq)Ncez?0!UpK3Ccxa32>x<+A84C1IvQL2uuu2K!J+8ub}J&ifK?s
zK^zh!AU}aHI7mQ=4<00tAycHbHK^7A`x)Gj0L?vt)-OPO2QmVZKtSFG`x8tIjAucO
zlwTmvf}8~{OF&GJ55OJ;t<`~ax<TFr$319uETVt}sRS=^&CCb)pPWD|y*&NF%^z^n
zYw&m$)GYgp=2?*QK^_KsRvuDtW-)*ZHbw?{P-15Qjk44*F-U?6Noe0V6Qm7N)p3GK
z3wW^t5ksVEkSsWQ!NkDCF{lm7z{tQ*49al~jL=FCRP}=dz#hMW&ErfAMV6pO3CQ0i
z;5E{q$^k3{;hKZy4H&?qmf#joEi-7mvKc%jP{Ib9mjb03$f{2!P<N^#57cuiVF3p(
zJE(P&&A?D}8Op6;Wsn55ioj+SPh|)It;b|w0M#t443ag>4Dz7f77IfbCqoSzsKEqr
zMG6yWRw9L&K@!x_s$m7yE9SMV425Y7;WaD_(D?{(odI6V4(@7cfCe|f84^+@fI62!
zpo$;}R5k^HmOuq1f?^g?8GxcZF(oC)22^-~LJyI!!3KeQTLn3(dEi1nC>2y$fLayB
z;HU=^0~7zC?gtAf{y`&wp!f%s`k+3QD5C_U7$Xa#Afo~!AEb~2r3iRCq8XAZK#>S<
zM--WXDrRt!08bQwk_1=?vXI^!+Fk(98i6#jfRuxVvzcJ+1r|`6k_0UbhO`%$q3s1W
zaC@N+++JV@_1(ek1!mY_E;s@qy<Bi^L&O+rJOw3zq7774qu0ft7y-u(I4;1%z(feB
zmnRI05YYG;s450U2%;L+-~stS2}FRG5rTTA;5ICz!wIU$!IKc+A~pzAs3CPTL1u%!
zh9CyUlc3JXMNnZ2s!!RN*%&#wIhi?yz@0~CP8Lpna32d)^n%hHxD*1ZtYKs*0grS-
zR&CjU2em=j2r?@K-lPJaSV}F5FG@|%EG{Xk1n0bx%7Ro#eFJKYfqUAZ#$jqvJZS2z
zXn=#G1T;ksac^o7)cppaBmfEk2FQvoP<sO&7Uw~Ej{y`Gpf<ZCh*879APLG|n?U6y
zB)es^GZdMEmdHaw3%ouaoGrm>nV>~;3L~ih3|ex}3~HgJurh#_%H@N$wtxyxMusNH
zP8V>_1nsL~1vSQNSwI_KvN%A!Q^@-KW=2pU4k}?GCTs<pzyflPSToF&8dgyL1}O#i
zJ3uot3=B5l9u>%grSlP;a?pkf<Yo1c_yRAdNK`0*tOkWFp@44tfQmsjZ-ABs!`8?{
zC7_BS>mjWaFc;rLh9nZ8OGT3r8%|IRfG&;z&GpB}ms&6|Fhu5;DkLZ7ftF;ZgSP^p
zI2E#BLPsG#FQ*dK_2{cEK-1Bod5K9msi5_oIr+(nC8@}(NK}jbz(W_12|S1;kj{2c
zFsMEORXY&diosp^_;^SkJw84NG}r+iFbo3amY^I^@c~*>9+V5JuRuW$Zk|Cs3N8mB
zJ#<hL1>9H-$^)qccX&a>z!V#xhP4?eV}OE+fsKcemx-T|mywrIh>?eppGk;O6x4fX
z<YDAuECsndK0c*1H@7lA9z4$hs=7e+G`KjaVqgHZ1!@^V%VR(jC*YO2jF65ksQv--
zYnec)IExjO*dePPKxr48QHshKN;p8n!jSQqEN)Or2dz<J0u2nu^MDe14GTj&FDO?*
zvIr=Df(P3nqcx>#h)(S#89LCV$Hf`>r8y~x719cc3h;G+&~?J_{7{ks$qb;hN=fQ3
z$$;nvF9q_0^p!!04U%TE(@RS-bHHUPs51jebE!p;G${<)I|AC(2NQ-SSa9M4CqqyQ
zgrsOlTtQMWr1K4mL&#V*s6vOWNP;GA$ZDhbcnwgzf*V<obPFos!TSTiDR?jx?a-{6
zmR|&3<N?Zq#h~hpft`&Bly*fK*%;XvCBVbj8lc7r)Q4%MC8b5F@$sNBUj|5vGaZ)E
zL8A<rdFhaFDglXta&d76C@vsD4+<7gy;mF*3z7!qT9D14VxNHltPE7WfcF^&fohf@
zum(_&r>B<qfCn)kiwr?)^dN-?Xto)=1q3|0m!Fgc8WB+e6(-=t1K?!@pmAZyU?VtY
zK}~7+Xkls*xacVXwKe0@it?*c^Ppu^PG%B#lCUT*F$X*z8K0I}0@CXV9%cj&v4Dq=
zF|>gz{b2C6P`AvSR3GpfHgEufxR5d(yztPmq@*Y_sk9^&Y*-LzWnvI$Ya}?WfHnAn
z*S3XJ7NiD&tPTPVZwG-23Pd6Tvj(K_1CJKiKyrs2DEAeE`XK^Lpf%qpm`Q+9iHV<?
vjaf`bj7>~Yj6*C+%$FHdOfoYwF*6D<@`5ohBRiuoBMUPpGaECfq$o20FhAo*

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/scripts.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/scripts.py
new file mode 100644
index 0000000..8e22cb9
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/scripts.py
@@ -0,0 +1,417 @@
+# -*- coding: utf-8 -*-
+#
+# Copyright (C) 2013-2015 Vinay Sajip.
+# Licensed to the Python Software Foundation under a contributor agreement.
+# See LICENSE.txt and CONTRIBUTORS.txt.
+#
+from io import BytesIO
+import logging
+import os
+import re
+import struct
+import sys
+
+from .compat import sysconfig, detect_encoding, ZipFile
+from .resources import finder
+from .util import (FileOperator, get_export_entry, convert_path,
+                   get_executable, in_venv)
+
+logger = logging.getLogger(__name__)
+
+_DEFAULT_MANIFEST = '''
+<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
+<assembly xmlns="urn:schemas-microsoft-com:asm.v1" manifestVersion="1.0">
+ <assemblyIdentity version="1.0.0.0"
+ processorArchitecture="X86"
+ name="%s"
+ type="win32"/>
+
+ <!-- Identify the application security requirements. -->
+ <trustInfo xmlns="urn:schemas-microsoft-com:asm.v3">
+ <security>
+ <requestedPrivileges>
+ <requestedExecutionLevel level="asInvoker" uiAccess="false"/>
+ </requestedPrivileges>
+ </security>
+ </trustInfo>
+</assembly>'''.strip()
+
+# check if Python is called on the first line with this expression
+FIRST_LINE_RE = re.compile(b'^#!.*pythonw?[0-9.]*([ \t].*)?$')
+SCRIPT_TEMPLATE = r'''# -*- coding: utf-8 -*-
+if __name__ == '__main__':
+    import sys, re
+
+    def _resolve(module, func):
+        __import__(module)
+        mod = sys.modules[module]
+        parts = func.split('.')
+        result = getattr(mod, parts.pop(0))
+        for p in parts:
+            result = getattr(result, p)
+        return result
+
+    try:
+        sys.argv[0] = re.sub(r'(-script\.pyw?|\.exe)?$', '', sys.argv[0])
+
+        func = _resolve('%(module)s', '%(func)s')
+        rc = func() # None interpreted as 0
+    except Exception as e:  # only supporting Python >= 2.6
+        sys.stderr.write('%%s\n' %% e)
+        rc = 1
+    sys.exit(rc)
+'''
+
+
+def _enquote_executable(executable):
+    if ' ' in executable:
+        # make sure we quote only the executable in case of env
+        # for example /usr/bin/env "/dir with spaces/bin/jython"
+        # instead of "/usr/bin/env /dir with spaces/bin/jython"
+        # otherwise whole
+        if executable.startswith('/usr/bin/env '):
+            env, _executable = executable.split(' ', 1)
+            if ' ' in _executable and not _executable.startswith('"'):
+                executable = '%s "%s"' % (env, _executable)
+        else:
+            if not executable.startswith('"'):
+                executable = '"%s"' % executable
+    return executable
+
+
+class ScriptMaker(object):
+    """
+    A class to copy or create scripts from source scripts or callable
+    specifications.
+    """
+    script_template = SCRIPT_TEMPLATE
+
+    executable = None  # for shebangs
+
+    def __init__(self, source_dir, target_dir, add_launchers=True,
+                 dry_run=False, fileop=None):
+        self.source_dir = source_dir
+        self.target_dir = target_dir
+        self.add_launchers = add_launchers
+        self.force = False
+        self.clobber = False
+        # It only makes sense to set mode bits on POSIX.
+        self.set_mode = (os.name == 'posix') or (os.name == 'java' and
+                                                 os._name == 'posix')
+        self.variants = set(('', 'X.Y'))
+        self._fileop = fileop or FileOperator(dry_run)
+
+        self._is_nt = os.name == 'nt' or (
+            os.name == 'java' and os._name == 'nt')
+
+    def _get_alternate_executable(self, executable, options):
+        if options.get('gui', False) and self._is_nt:  # pragma: no cover
+            dn, fn = os.path.split(executable)
+            fn = fn.replace('python', 'pythonw')
+            executable = os.path.join(dn, fn)
+        return executable
+
+    if sys.platform.startswith('java'):  # pragma: no cover
+        def _is_shell(self, executable):
+            """
+            Determine if the specified executable is a script
+            (contains a #! line)
+            """
+            try:
+                with open(executable) as fp:
+                    return fp.read(2) == '#!'
+            except (OSError, IOError):
+                logger.warning('Failed to open %s', executable)
+                return False
+
+        def _fix_jython_executable(self, executable):
+            if self._is_shell(executable):
+                # Workaround for Jython is not needed on Linux systems.
+                import java
+
+                if java.lang.System.getProperty('os.name') == 'Linux':
+                    return executable
+            elif executable.lower().endswith('jython.exe'):
+                # Use wrapper exe for Jython on Windows
+                return executable
+            return '/usr/bin/env %s' % executable
+
+    def _build_shebang(self, executable, post_interp):
+        """
+        Build a shebang line. In the simple case (on Windows, or a shebang line
+        which is not too long or contains spaces) use a simple formulation for
+        the shebang. Otherwise, use /bin/sh as the executable, with a contrived
+        shebang which allows the script to run either under Python or sh, using
+        suitable quoting. Thanks to Harald Nordgren for his input.
+
+        See also: http://www.in-ulm.de/~mascheck/various/shebang/#length
+                  https://hg.mozilla.org/mozilla-central/file/tip/mach
+        """
+        if os.name != 'posix':
+            simple_shebang = True
+        else:
+            # Add 3 for '#!' prefix and newline suffix.
+            shebang_length = len(executable) + len(post_interp) + 3
+            if sys.platform == 'darwin':
+                max_shebang_length = 512
+            else:
+                max_shebang_length = 127
+            simple_shebang = ((b' ' not in executable) and
+                              (shebang_length <= max_shebang_length))
+
+        if simple_shebang:
+            result = b'#!' + executable + post_interp + b'\n'
+        else:
+            result = b'#!/bin/sh\n'
+            result += b"'''exec' " + executable + post_interp + b' "$0" "$@"\n'
+            result += b"' '''"
+        return result
+
+    def _get_shebang(self, encoding, post_interp=b'', options=None):
+        enquote = True
+        if self.executable:
+            executable = self.executable
+            enquote = False     # assume this will be taken care of
+        elif not sysconfig.is_python_build():
+            executable = get_executable()
+        elif in_venv():  # pragma: no cover
+            executable = os.path.join(sysconfig.get_path('scripts'),
+                            'python%s' % sysconfig.get_config_var('EXE'))
+        else:  # pragma: no cover
+            executable = os.path.join(
+                sysconfig.get_config_var('BINDIR'),
+               'python%s%s' % (sysconfig.get_config_var('VERSION'),
+                               sysconfig.get_config_var('EXE')))
+        if options:
+            executable = self._get_alternate_executable(executable, options)
+
+        if sys.platform.startswith('java'):  # pragma: no cover
+            executable = self._fix_jython_executable(executable)
+        # Normalise case for Windows
+        executable = os.path.normcase(executable)
+        # If the user didn't specify an executable, it may be necessary to
+        # cater for executable paths with spaces (not uncommon on Windows)
+        if enquote:
+            executable = _enquote_executable(executable)
+        # Issue #51: don't use fsencode, since we later try to
+        # check that the shebang is decodable using utf-8.
+        executable = executable.encode('utf-8')
+        # in case of IronPython, play safe and enable frames support
+        if (sys.platform == 'cli' and '-X:Frames' not in post_interp
+            and '-X:FullFrames' not in post_interp):  # pragma: no cover
+            post_interp += b' -X:Frames'
+        shebang = self._build_shebang(executable, post_interp)
+        # Python parser starts to read a script using UTF-8 until
+        # it gets a #coding:xxx cookie. The shebang has to be the
+        # first line of a file, the #coding:xxx cookie cannot be
+        # written before. So the shebang has to be decodable from
+        # UTF-8.
+        try:
+            shebang.decode('utf-8')
+        except UnicodeDecodeError:  # pragma: no cover
+            raise ValueError(
+                'The shebang (%r) is not decodable from utf-8' % shebang)
+        # If the script is encoded to a custom encoding (use a
+        # #coding:xxx cookie), the shebang has to be decodable from
+        # the script encoding too.
+        if encoding != 'utf-8':
+            try:
+                shebang.decode(encoding)
+            except UnicodeDecodeError:  # pragma: no cover
+                raise ValueError(
+                    'The shebang (%r) is not decodable '
+                    'from the script encoding (%r)' % (shebang, encoding))
+        return shebang
+
+    def _get_script_text(self, entry):
+        return self.script_template % dict(module=entry.prefix,
+                                           func=entry.suffix)
+
+    manifest = _DEFAULT_MANIFEST
+
+    def get_manifest(self, exename):
+        base = os.path.basename(exename)
+        return self.manifest % base
+
+    def _write_script(self, names, shebang, script_bytes, filenames, ext):
+        use_launcher = self.add_launchers and self._is_nt
+        linesep = os.linesep.encode('utf-8')
+        if not shebang.endswith(linesep):
+            shebang += linesep
+        if not use_launcher:
+            script_bytes = shebang + script_bytes
+        else:  # pragma: no cover
+            if ext == 'py':
+                launcher = self._get_launcher('t')
+            else:
+                launcher = self._get_launcher('w')
+            stream = BytesIO()
+            with ZipFile(stream, 'w') as zf:
+                zf.writestr('__main__.py', script_bytes)
+            zip_data = stream.getvalue()
+            script_bytes = launcher + shebang + zip_data
+        for name in names:
+            outname = os.path.join(self.target_dir, name)
+            if use_launcher:  # pragma: no cover
+                n, e = os.path.splitext(outname)
+                if e.startswith('.py'):
+                    outname = n
+                outname = '%s.exe' % outname
+                try:
+                    self._fileop.write_binary_file(outname, script_bytes)
+                except Exception:
+                    # Failed writing an executable - it might be in use.
+                    logger.warning('Failed to write executable - trying to '
+                                   'use .deleteme logic')
+                    dfname = '%s.deleteme' % outname
+                    if os.path.exists(dfname):
+                        os.remove(dfname)       # Not allowed to fail here
+                    os.rename(outname, dfname)  # nor here
+                    self._fileop.write_binary_file(outname, script_bytes)
+                    logger.debug('Able to replace executable using '
+                                 '.deleteme logic')
+                    try:
+                        os.remove(dfname)
+                    except Exception:
+                        pass    # still in use - ignore error
+            else:
+                if self._is_nt and not outname.endswith('.' + ext):  # pragma: no cover
+                    outname = '%s.%s' % (outname, ext)
+                if os.path.exists(outname) and not self.clobber:
+                    logger.warning('Skipping existing file %s', outname)
+                    continue
+                self._fileop.write_binary_file(outname, script_bytes)
+                if self.set_mode:
+                    self._fileop.set_executable_mode([outname])
+            filenames.append(outname)
+
+    def _make_script(self, entry, filenames, options=None):
+        post_interp = b''
+        if options:
+            args = options.get('interpreter_args', [])
+            if args:
+                args = ' %s' % ' '.join(args)
+                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, sys.version[0]))
+        if 'X.Y' in self.variants:
+            scriptnames.add('%s-%s' % (name, sys.version[:3]))
+        if options and options.get('gui', False):
+            ext = 'pyw'
+        else:
+            ext = 'py'
+        self._write_script(scriptnames, shebang, script, filenames, ext)
+
+    def _copy_script(self, script, filenames):
+        adjust = False
+        script = os.path.join(self.source_dir, convert_path(script))
+        outname = os.path.join(self.target_dir, os.path.basename(script))
+        if not self.force and not self._fileop.newer(script, outname):
+            logger.debug('not copying %s (up-to-date)', script)
+            return
+
+        # Always open the file, but ignore failures in dry-run mode --
+        # that way, we'll get accurate feedback if we can read the
+        # script.
+        try:
+            f = open(script, 'rb')
+        except IOError:  # pragma: no cover
+            if not self.dry_run:
+                raise
+            f = None
+        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)
+                return
+
+            match = FIRST_LINE_RE.match(first_line.replace(b'\r\n', b'\n'))
+            if match:
+                adjust = True
+                post_interp = match.group(1) or b''
+
+        if not adjust:
+            if f:
+                f.close()
+            self._fileop.copy_file(script, outname)
+            if self.set_mode:
+                self._fileop.set_executable_mode([outname])
+            filenames.append(outname)
+        else:
+            logger.info('copying and adjusting %s -> %s', script,
+                        self.target_dir)
+            if not self._fileop.dry_run:
+                encoding, lines = detect_encoding(f.readline)
+                f.seek(0)
+                shebang = self._get_shebang(encoding, post_interp)
+                if b'pythonw' in first_line:  # pragma: no cover
+                    ext = 'pyw'
+                else:
+                    ext = 'py'
+                n = os.path.basename(outname)
+                self._write_script([n], shebang, f.read(), filenames, ext)
+            if f:
+                f.close()
+
+    @property
+    def dry_run(self):
+        return self._fileop.dry_run
+
+    @dry_run.setter
+    def dry_run(self, value):
+        self._fileop.dry_run = value
+
+    if os.name == 'nt' or (os.name == 'java' and os._name == 'nt'):  # pragma: no cover
+        # Executable launcher support.
+        # Launchers are from https://bitbucket.org/vinay.sajip/simple_launcher/
+
+        def _get_launcher(self, kind):
+            if struct.calcsize('P') == 8:   # 64-bit
+                bits = '64'
+            else:
+                bits = '32'
+            name = '%s%s.exe' % (kind, bits)
+            # Issue 31: don't hardcode an absolute package name, but
+            # determine it relative to the current package
+            distlib_package = __name__.rsplit('.', 1)[0]
+            result = finder(distlib_package).find(name).bytes
+            return result
+
+    # Public API follows
+
+    def make(self, specification, options=None):
+        """
+        Make a script.
+
+        :param specification: The specification, which is either a valid export
+                              entry specification (to make a script from a
+                              callable) or a filename (to make a script by
+                              copying from a source location).
+        :param options: A dictionary of options controlling script generation.
+        :return: A list of all absolute pathnames written to.
+        """
+        filenames = []
+        entry = get_export_entry(specification)
+        if entry is None:
+            self._copy_script(specification, filenames)
+        else:
+            self._make_script(entry, filenames, options=options)
+        return filenames
+
+    def make_multiple(self, specifications, options=None):
+        """
+        Take a list of specifications and make scripts from them,
+        :param specifications: A list of specifications.
+        :return: A list of all absolute pathnames written to,
+        """
+        filenames = []
+        for specification in specifications:
+            filenames.extend(self.make(specification, options))
+        return filenames
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/scripts.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/scripts.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..e893d6714f9a71921f5a88f948c6133fb289f6ac
GIT binary patch
literal 14496
zcmZSn%**AGdLky70ScHI7#JKF7#NB_GcYiuFfgPrGUPBY<T5fuF)}cM_)H8rObk&>
zU^ym+9A<_nW*D1=A&LdYW@U(Cg|XQfqSzQxm>E)77;@Mdayb~HI2dv{8KO8Da=93y
zxEL5ga;ywF+zh!q3{gA~J{v<0FGDULLlhrFE<ZyQKSQnnLzDnRt{_8{AVaPYLzEB$
zV=5CvmM}xA2tzX?LzE~(3OhrV7(+7yLzFl}DhorF1Vai3SW1#1g_9vliXnxIp@o4V
zN}3^sn;}((A&rqCg$E?k%)k&CCCiY)#1O2(%fP^p`Tzg_{~C-83=Adg3=9lTl_jag
zp8kHBAQ25v2$gVxf~c}MIX^EgGrfc#6jrGvsmUersd>ryDVcfcV2x3k1#X!+sSuOc
z7#JARGV@YWi!@k4Ci5^bFo0zJ3sQ>`OY)0K1Q-|?(o;*~Q!5Jci$Ero6jhdhR3+!<
zm8BMy#1|x%WR&p1Ri!4EmLw+Sq=K!=%!@Be%_}SZ$jHFJWn*8Fo1;*cT2!2wpJ%IN
zsAr(00CSkFQfP>qu7#39aY<rcN@7laUaGB9WoogKy&acLVsUY5Zc<LALPc&)Ua_rG
zX;Ge4adJj#Zep=+Zf0^(esO+UiEeU!u2o`ju3nj;l0t4`US?WqaY-1mWp-Q&aHBj^
zQu9hOODa*Eqi3LJpv0w6P?VpXT3no8<XDuPkqHXF(xOybr3ec%B`$@$#N1R{CDmdj
zE`^fHf>c|j^2|JABPD%1E-nQdMO|G5h{<V{3MCn-3W)^;Iho0cC7Jno3dO0(r9~hs
zi&6_qGmBDlQ}arS^%Qh<LGCIkDlIPY%uCBB(vQYUAYCvcL2Qtzsl_F!DFH>9Wtlmt
z>8Zsi!mbsdn90n~^GPjB%~8k!k+w>S#h!U(`Pr#ON(!Z!j>#Z@+bX3c<`k!byrf{G
zkHc7fWUKYzuD9c|(TByBU9lVk14Ep$qMlYkWl2VUUb%g=fv%-qtd>T!0%xqAmZrT*
zaSam#gR+9ImaYOMfm$h)mZa%gfJC@5(-h+4LE#-AuV8DdpdKHeo0ypwAFpo3rJ$go
zkeLfgkP5|>#X1T_sa#;Ol+-kZ_@dO}{G75>jokc{(wtNsg|yPVWKD=3kiPhMh|c(U
zs0vN6R*+O~eu{!E$V5Ge-r{Ho9Sc`ckXTewtY8Z^Q?IxnC$mIDT~8fhLQ!gQX-<iP
ztwMTgNn%M!5y%Q11+Xr?g8Tvv15Je5wEQB40)@;xh%~~1AeUg60};?sC_v~hN-ZfZ
z%2R;IK>S})REaRBxUyI;u_(PP+8|cJR-q_WuedZxqexvtw>Y^dv!EnKub{Hrz9vR5
zwIWs1UPWC;L0w%3?0KjrO^BHw=YWDx!4?s;>Z%}*mFA>s7K8MuYJe1I79$5lGBlJl
zG!>K;{POcs6*BWmQi}?TQcF@(6cURS48Vb!T9KSuP@>=pra;*wu~;G1N<l$cAwMst
zQlYrC02IradFcuP;6$WgXRBbOX9m^_av8{z#U&}JMMZk$MVTe38tSU5#W8v63aY9K
zsYqc3a*iQb7f45HMP`XcQL-jiGN|wbm7O5$3@Sc5K&2)lLk$B%HXB1x3y6`$04ju=
z85xRF!CXdA{gcAX(9FaT!^BX_$WY4!5~*PVYiVStVPXJjVF8u$JVlKRDXa`Nj3Ci8
zCI+!u28O~$hC;Z(U{%E}3@L0Nv%%6W40#M7POt{3ocAjMxly4QR0Zgl78mI!W#;Lp
z=9MXc3x2SqQZY!OYOw;SU@B%|U|;|-G?+jIIv2=OC7@(mo>`Jn0xIMo=@#VU5|C^v
zxMTpA*&wmhys{E*1_p+Bgt!K%8U_=^c?=8;`UORqWr-!J`elhl`f2$&DXB%p`bjDJ
z<w;3-xu&_rMuth|=~d|#rWWNnSyg5RAdsG?AEIB7S)iMlS6q^qlcVca=HY1^01^UY
zP(6{7U!<RsSzMBnnWPU%qs4j!l_kPp$K(~3=9i=*Im!v-F;MNqz{tbO&nUqt!zjkY
z&nUnMc6~57jr%5Mrxw9m5uktp>ylw)U`S;EH6BtJK&^&UW^fxp1k@r(WoJm`U`P=G
z#b^sNs5y|r1gedrxENBo8M1g7vUowQ22g5<0<|4LRW~0fia`v1P|T&Ufz=CuYJQM8
z91JZ?pyojeCs<sFAyt?mN(5Hzi-M|skX|vcr92ERjG&f63NKi(1VgGMLkb^=4QfqD
zF{DZ{WJxom@FR)HFl5OxqzEu%Gcgo@1GOMPTxJlrh>0;(h9OH1DqF<Fm?8+$7$pyO
zrwBue5ZF2eu+_p~wjx7Nu!bloY~vXi7{EEkQ6V`evA9^FBwrypzo1efzepjuC^fMp
zRRJ1H3TZ|8xeCSkrA5gIF_5anoE%WP0-I7?keZyC2CWT?^}u4upyme%gAyJ%`)y@l
z0B05khIj^0mZ@Q2h-YM|VFu-gcqWDt2!jR2U}Y#_W5{9$MOHQwLqRx<%LMX%K7`8w
zl?55a$xy-t%4*Hv93IcjP{YblP|Z-n!%zdxh#)n*Fhf{Dh7_!ZaUo_xxE!Du&t?L<
ziVxJHgymIG{wl~X&a5Z_rM9fZvcwWl<|zhwFhVb~1e7Q9O2An&2pq~#2@Ozd4V)bz
z!5E*CSp?>mBo=|1Umz~11V~ItiO)$a%}dTmEh+}*W;al64Q8d~7bQd5UCBB5NlB?i
zVB7MG!A=2Hq+nIxDz$_I6vL?{@wxdasU;vc6sMMe1<MkPG86Mkii1Et0XO2}(=u~X
z^9xEq@f4p~9G_RB0b+tpEl$lz3le8wU<i@`5t5)12UHfN6jjC-mF9u<K(vF44=^zh
zWeCW-@$s2?nI-Y@(IBsjfntS;lMxD;<QRn*`58r-_!*Nyp#kzdhz6(0L{OT9l<ABN
zC5)hQzbF<I^;t{|MX{iyn8m`71uo>98NpQoGea#4C`Dzlfocv&RZ$C0v>=u2;PlJ_
zGN+ailoM+h8G<!H>BSEm73rm!;DCcPo4|1ZVU}xv`~gvuS`s7$3UU<?Aqxt3kO82^
zcn~O^fOQq67UU!*r-EZDD?c+2+{6!31?k`e=>Wx4egUX;S`1DqDS2QjEe{+|U}7L5
z3zUlDL5V&wrzEu~FA=5K&j!UF7bx}^r5Pm{g%~9mgG3k@7?MFb3lwFbv<Z$jP&`-a
zFqD7`lx9YTeko8z4XT{M6?iivC~mTu7=pu7m>B{i!t*p3SW3V}Od1nIHWx!t7y~0C
zV+lBFQ&>QyQZo|+V+k8Wa6}3-Lohfni*sOwB&ab0!Y-*LsYSV&p!QB0xDNm=_fk_7
z5EZIIX0bvdwDbfQgdm+DtdX3bSCW{S2a;A+RLIH9Lu$l;6l8+DSqvhS75$0@LA|xa
z%$(E|P~n_kkea8US`2PAfa4q_0A>`WCZ>Q>gnzJWQBi&onC<BgVS@rJCqF$s6(U@o
zSd^EUmkv%{;BF;Sf&tl^Rsc>IU}7Lr2PddGkXamGoRON7Qw&NCpx!70D>EZMqb#E^
zqW~j3DS(^{P6~0L9LxY}mDMnUT4hDHpgJLifguOncmt&gCWb6#hAb9PngFE?Nc|ZG
ziuK?;Nf4FA3hKmzax}Q6D1yjA+IC{W;3Clv+(idB#`25x;3ck4W?pGUF(}Puf!na4
z7I!hIyhmxyK_f268k9XjDH<GeIf;4c;KCrdvbZEQ7u>c<Pb~>3$}dPQDyamQ=sEf2
zsYT$zJ2fw*7}U%|i#Kov0Y?~^7>HN{mACO}nHBMnAV6xz)q|oCR2(rd@-y);Ni(uD
ziZZc4ieXRz1<KRlNL&jlvKSb$z_~Y@nW0F6p@fN{mYE?h08|D;ViwduU;;(4cnTAP
zIH=5p<X=d9dVyMOwX6(zY@qtPmKD?#s9|KtW@pGx1(nw|tPI(VAR}v-8H$=g4Y(Rc
z2Jspu2JsXQ2Ju=phCDUUpiM0sLk%0K0SA}mW)L@rit;c(S&&hiVi_iAGYXV_ok}xv
zQb1WhBQ+^8FCCo0^%OkwASFd+Zb43}LULkps)9y-o<ewLUP^v>u@0!gm8ejRqy=7P
zlxJinXMjqRy!;Y{lKgyyocz3Wka~DIQe2RjoLa1@P+FV{vKL}ST7FS(X%1vuA}zlN
zZX9UL0&0(*f`3UyYEgM+ajFhjGq~SToB`^(fs`Q%GaUs`l2b@j0NGiTS(cgtHxFu-
z0>qh#IXU^|#SpK8o9CcHtEe<jAvF_Zl|m_K7z)<U%P&$W&H&k*nU{_*uQU@pxTFB;
z3}oh|>nVg}B<5v<o2DL#MTt2n3V!)TDd|P2c?zKJbw*~fLS|k;X^9@9FB_bis*spd
zoNuL&QBqQ1rLSLJUaps!r(2qntCy0hUzeK*8e2-v2K8<-^Gl2Mp`OrJ&PmNnFUf#A
z1{9wV3^J(LN?$)CT`xDkDl;c1Q7^wJT_4KUO-{`#DN4-I2Q`HBOEL@ea}$#h#sq=-
zH<_SR4$kK(iACj^d6^7M3=El|tPun%H=qT6F{mfV1ujXH6`}FLRSYT+)z#HO5u&b8
z%+0{SprE8;proLr;-JJ;3~I@!E2yihgG;C&P)i{QG%y1$T|$aVA+5ih)I4yrqPVgc
zT#yvxB$j{@3AipnssKQy7vvY0#6vps;BmiVaGC;@$Dkw)5rU-Ecu0tq2r)1)<R(_Y
zl)!{R6;Ba(zyw?@fr)`An?Qw6d=e;U!d%!5DwAYDjSOynMowlaMt(+4CN@SMMjj?M
zMo}g<MlnV%MsWK*8Pw_m6;mM3fQzXYj0~VQ2dDuEF06_a!A(U*hFVr|dBwtz*9j`G
zvRFX%NwFnE3Akbbl}d%6u0}HhLs0=}h&PLaA&V2Nk_%K@fodgi>m-XC+5r`7W&#<S
zXN9Vo8&t@FRI`FLbAt-GW=0sB8B{oe1|lGuK?U7WumgEOeW4ogs0PR_3=Ac_3|V{(
zS^S`45Y*j$305WmQq~OiO&)k88stntgkTK|Ly-Vui4Z~rG?>8(8WM+$dxL@jY;p=G
zsDD)y%$ULj>gi>(Gl1CK2zCt<Xe8XcmI>TOW?;w?0U27u1a3I9F;ohIO5rR~=y*C~
zc%C8yONkh`={A!Q)N~VPNZ|#k5o=~-Xkui@V`PY^VFW1$)gDh6;RZme4#x1pCyX!y
z9>5IX0~t`m$N&y9urY;C7$ZP_Vq*vf_uBlxttn_%xERzzhqTsJi@{mSHNq8~v7J2q
zTs(uonHMInS`5}2<{A|2>F)=wrNQ|XJO&EZoSc&h&fmHbR&GU!xv9nAVIUB%G$#it
z0xBRBKtd1&It&a9AsMOg`a(msNE22=q@*V2r+|9okRChOo??6AHGm3!h)3Zg_X;5M
zHNd?;7f{Oul$pS7#~@H)1)hY+ERKix7?R0?KtU7)DzzY`kuFG^KB#gBNr2k@pk55P
z90744vl;PaiA6!iAeC+)!W~3_+I>Nw0UdCWm6u<X3#vMUK#gK>h=V5=QiFU!MuV~^
z*!QX6(kL`9GdVvc)ddtDsgPzcC>X;Mb4npxM8O9(9BdS*RqO$>*Z^cADAT7xMx}y4
zo(4xHw5|XbWnf|;$}>>7fcsBS*Q^4SW<H?OjFAo6;pJiEVdP{KWt3#%WaMGwXB1-u
zm1{zbLQF!;Y>fQO{7lk}JdC`ILTt>8f{eV3%#4C8JRlOxW@Z$JG_pYrY*5I83qA#S
zBfA9LM5|$B$YKJur$G#6hGqsPv0!k+)DIjxx!~b>a5V%PJqGuG!N~=Zz~W0%b3wHb
zr1zSVnOp+aRZx_gmRSL27MG@_WmZ6jQb2uLa9bEu)mDN-9!v~G@Po!AA;AxB<iwYx
zR+KyfMFFU)U|<x51Rbct2L&HE=s>k{3Anb%VgmIwK;<hFxVU8o6^CNM;K@2aa2O#n
z4LD^cB^IZGdm5n31Dp2(2Q#?Z2B*r@3WySr13>D*K?5cRB78u}6O^%Gj(vd$8zDyU
zh#)8jgR&PmY^E}S2g9=%81nhSLBhyT%Lb}Rq5U;*hpv_#6i%Qq7<N$oR_p-c*03|c
zDi1b>;$W~4GlMv&$4~*PNm9TgdPRj`Q^9k=pm674$b;C!2CYYHIY9MmGXp~{CqoGb
zLk%ZboQa`doS~MBp@s`oOM|+B;Hr}`JcWTFFrtQ&A&U!Czt?gz)Np`o7O&w3TU~LO
zv4)YsC3ZJsEf3fi;6ddY2GF>24G*|#1J_waZx~CM7_zuQb#M(Y$Wx%X20n&beuf%;
zaIMS+5-d_<tl?v*<poudDeMe2ybNNsybP7%U_S{kWC?<VAhkMUcwqw*ONkJ;f_wq4
z--JPRDx_LwOyLA66{{71xk{9wMgVNZ1h7lQpj<{!wa>(mB@R*!Qo+Q)2y#A}WhKJk
zsctTi380!5<QcdT;e{_5VJ>+Ba!KJ!#)!fOrii>LV23j@6v;5v@PY=_Qov)h;?0Z<
zJVi20DLi0XS;5sY#MdB$xf!xVK@y;5iXRimHIfWGMSe^mM~E<h8UehZkYy~q1PUjR
zJeq4kLQ)Jx4Pd<jpdt1eUWRmV(gOLnhJ_(Z25JGw5KtrsYk*39Kcos9l${GI!80-?
zV6q(C8i&nW>J?Oihk-#fsL)g`1`h;Sp^V{xC$W%6igXo9iYhbn(m{PCP#;b&B{e6t
zBsDixAtygQGZ}1yYB5~27*sboCgr4p)I-Prkc}%X2AKs{4lxAmSUs>$REzagi;F=c
zaKYJ`1qC3*sTG;UB_IZ<{{k9c0+m)lASFSF!ADSb1&vk}rxpZ-gX%~}P#p;xi3Asg
zup#RpP%RV$D*M2N7udJOC6K|3^wg3vQ2iSOZxDb7mB9+ZQ&y=JB|)IVBS;x!HmHyQ
z>yJ;$%u6h)1P@b#mq5TL6N4;3F0llu1_e0SBgNplqbM~uzbqBX1Q(y6eo{(mQfYb+
zsNEj~s?5MMPsQN151_eoP`e2-UJf!Wv7jI|FGU073P?c<G5};!aZoJCLXbnDHCYm9
zr3Tn#pb!MB0XObaD@sa0%1Vn<;bZzi1t86!vK$s<U`H006s0ESf=6eo(!e27m01v<
zl30=m>CAzGKfkmDWHvZ5^S~s;gDGhsVQ_H|CI+I+2PXtbY(WC$4XDtM0Hp>-A@I;U
zFC!ZxFB1==5EDNmC!-Lf7$XlOA0scL1S1=x1gQVT$i)b1cknXtGI22qF$ypWFbXsB
zGC|rW+)SXMKN&^=Mm9!aMovaCMsUXr)LjKd7Puk_WCSl90(H!o8H#*BgYckfS|)~c
z22kNp%L=L!ihMwws}vT{FjEaHsPGblNPwC$V16wNL!l3>7-0sDBh|2gx>(>smJu`v
z!~hycg!Cy8y4XSWdKN1Ks5W5(*9@GXULC05VF%9}uLadCSsbA1qM4BaRO*1ra|Y1t
z7HB5=E>t=NtfB;5zoc+7NJ9H1VD((!!V_W~FC(Z9;sDJq)^IRD)$=eYAgKrS{qz`X
zm_g&BDZC6N+@N46(ql~F166FGF*1G-1LQ;=knJ^W3^m|-wuXzLnH9Y7Dp&*5+VKN-
zg~3aOAmaj{N&cev#G>?KaEYg&S_~P+0Ob*Iry~edOo7vA1bDt$wOF+{6O<aj>Lc_b
zp@osIYB6|dBuEpKEkNZ)L1lRmXwV(JBq|8h*$D#m9Uz4cXq-1F4V39YLmWYhAeItL
zXJSf95UBG2ZW2M4Awha7T?`Bi8lbcS&dEWkAZ_5W7mzE1KuvydGZo|?NahBmDM&ho
zWIvEz2p^Qyih~+J27<gZU>OcnuEggiW~atO+@-+Cz)%c!4I>*P8>0|7pNKL_FiL=X
z1fY3yenv$`5S9Rsb%3YAKs6l5ui*USzyulCU<S>BWr4@bK}mxJG=Kp~?VuqA@C+G3
zmJOyDoc^1^lV_kD$iR@r!N5~g15UBv#0**@0iF{BiI#v{MJbG+Oaq#ANnv0Jt`r6h
zNq{==kP!e@hVVQ!29^>&aD!$$XtD<69)5=6bqq}mpd6aQ03IL7XNag_1vQ00Z8-4I
zZSiwZYR?h^<#muAVNiwy`GFads!K$`4GK1fEHO}HFNGD9GeC_)c2Eu|Qe!L;2agi7
zgWEXZhFF0DV+uPccY}rom>G&28EaS>itIsTmL$k{P!0vz#mSH*1@abX!Wr6hl4d9>
z1h=6$!OaX7<dz2$Xm%f@7E~te20L30G=u>PE(V4yHil+qNc)Qu)F>?0WGaydm19|g
zpt1|pWaI?rVOEAL1<=qnsAvJXLJ^#yIY9oZ<pvLBvw=&YH;gIV47EJq5po_7qXgWG
z%VGx&kAp&h7aU_spvF)-BSQ_ib(W<J@?Z@U1E>MZ3NE`qp0{BF1v}jHpg08QTEAjx
z1_lPuh;?#)0l00WTCAW^TA*8!ubYxslBx-==ZcbwL0MO|*h)dQ7&L&9n5U4MTToJ|
z0IEe5G>W0^6HV~oC@&Xea1^{K23#D0m!H8bNX$!7NKDBpg*0STixqV36rd$ekTxj0
z_ksv;xdLv}fTvc$?Hoj71U$_Rs%XK@lAv^u4v<G6%@I)1mX}(dS_ElyRDonoK!iDn
zPy-c0pzarFB^0>+22II<8cadp<_V}21@(!N^K)|(^HLyl^q@-9%`+%CB;Lo<&ow^C
z72LzkO)N>y2+{+Y3L0<$i=`Lkmll9o$vOGOso=H-$m`%X5x6ZAR1MNl19L`ZURr(-
zsJ#j<*osqAvxC58C#WP0G6j`hpsWum4kv<if{H_MO9T>%L2V$DKqEY9;8hA~nMK7V
z@nHYV0x1WTnL(flSg@l&;*e$$xMU1!2U#%i#UnU`AjP9OsCWc7P8r!4<rq~M6&M8=
zSy-7tO$<g(Mm9z+CLZwMi2x%DlQg&pm0$uDq`c7Ph5!=}BNrnNqbO+51T?t91S(`z
z8QB=YOUyta1;XHhlnXvkk_DRh2Z{SZhA}`5+aOR{0r&U8!4EF8!NdTx+rVzg289hM
ztuQcwXI4Q>5C;1NlyIR%5d&zY4mguz^$|!5*hk<b0dDDoy#*!)%5V7yzXgG&D8U{C
z)p($$2H1n3)&yi|CI#Fbgbo_WfvOJB$TWDA0JH!Qy#Awx3DPrV26v*FLG8j6c2FUk
z!oeU3nT>>$<)EPo@KAgf8>o(|VPy!`01b&kR{I5Hf_ebpV$jS4Oc@)2N0veDBv7w0
zC?B*S92CyrRug!%5}ZAYONvU9AuD;36LXS_Gpka;#SLsFEm%<zxH}aDDv!YVAG81*
z94p|S3S^=PJfa3tk)4^B0#=ojSyBvX?ttd5p$qlm3lfvF6Vp?JK;w(xs00%O5ub$&
z3=HL<_yiSQpm8?Pl#Kwh7^4JaG8t4tgD^N+y+I4s89<dde0>P0SpuH_&*oq#G6Yw1
z;K4X>!=8aLPYf)?45|ogn89s#P&<SX)PRPJYZhMyEpvxV2`VUn)*gapT)~5YNb`?Y
z1&Kw8xeCx_A&|x4Rtn$|d*l^zI?zee%wpK|Xre+{Voqj?0%RpVmT5?s%^(^)4vK1t
zf<{Tc0;ov{cNJt7Ad!Gk$<S4NnxJ{*L~!j3YUN@vE~%1`QPBDxyk0O7wqh_R9})_h
zkVSzY=R*Stx;V*7!BGJ;0-Tu->gX%vrzt=sAXCoyIXR%=2}nt<ke-?c+PaXLpNC`|
zWUVyFoSe+!5|9arIXMc6NyYg&r6s8fpa}<%pNbVgebkcFJcW{cgl=$W1v>Z&DjR~P
zfvUJAAYwA8CIclZNXZ7Ou~8xxtThN!d4hWt;Jg7Q1|WlgGchRsTS1uw)Inh22G40S
z3Nwje$s(ZEOFB4<RH%a*tS+(g;AL&#{vxOi$q3F0piBU2Ycdw{GKANF7Dj=JrQ$=#
z3!_33vq7s5U}29EM8yiA#u><6&;?P&kYrhsk(#RmPfySUfvOWZK2c>5k!M9l)FZ3~
zSIgisGqs{5H7_M-Giro`iW*d#kz#xkNbP_&b3o}46teNTr8y;;1v#lRKv55>TNv2b
z7<n0G8T~XsjqIS+pynK?T@nu(;VR8ZjgJR+ljGx4@{{A^!Sgb~&Ox35A@L!uz5zat
zA+AB7Ws#7q01Aa5P-7I*odzXvtaEkXrA?p-JMf$wq{RuYUqPd2@h+}zj-fsw@xG3J
zo^GzeAwe0S90pqN7X)sWg7R7rDA$22v;yb~C~y-697CWLtf@ti=@B`QR(TKssujSo
z7PJi|IzWzO7=T<DBm{C5X!HxzglA)6V`O7uV`66H=jUV>V&vrE;o+3$x8P)9W8!4t
zG~p5FG~s6vV$o&c;o}k30C@}C9LUTEH&(%M1X{ZXnwkW4SHO}*sX;42mVgI4Km}HE
zer`cx33x&l+~|i4z=E0^puIAnRolgg#z1LFW)67qZxBdp5V*qwN-^LWTX4@JJ+;IK
zyj~ETY{2~;aO<JCq$sl>Xcs6cfpmdv&CE#+nhA2tP7nc#W^h#HCuOB3mw<x;91jR$
r0Ad83oNRKz(~)){hZloJfCWISJs_9~G_I(@%rC^l%rDNy%qai>gwOTf

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/t32.exe b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/t32.exe
new file mode 100644
index 0000000000000000000000000000000000000000..a09d926872d84ae22a617dfe9ebb560d420b37de
GIT binary patch
literal 92672
zcmeZ`n!v!!z`(%5z`*eTKLf)K1_*F~P<Y873=9l>^1JvLws4+R+`;H`Rxu<avsj^^
zC_lX@F;^iuF)uH_L?J0vp{O)ZAu~_G#XndfH$Np+kC&HA1#0q)pZ<DxW+>Leu>ZB4
zwRdMI)*ff=s{IS5_t#zq)7`bJXDHTQeXyzaCRn{fZ97=JAF6&gl->iTgEEsdKxRU%
z!Jq<M85n#RSs8X^Ux|WAK44&C<YwezU^v0Rz%UOYI!l*<fkA+Qf#Cs&?*L&lF)*+)
zFoFc&G{XT#a3Gp~WMp7waA*W81nC252Gd{>upSUmz|6>C17ZX)GAs!IG0^Y^Mg|8?
z28Ia_85m^Hq>#Bg{xLA1#MJ|kzmQd+vh_+*D@qs`7_5##{RQ$XDDsh%DKIc3=oO_T
zmLxJTaA`yRuEW5<a0W>c1K3^%J%}=fBW57;7$KenB@85`4h#$j^ooj$k{K8vehpw`
zU<hJhVBmm+Axx<Q1A~KJQEE<pG6TaZJ_ZJc4N&u<Fw{B0^o-J!g+OTco5nXREDQ__
zTZ9}LjE{D@{%Nk|U?_F%brlHsU&_<l`serm{~7<885lA^g+#!MtF8<T%|}Ea5&;=H
zzZ@7|6!J1KG#_vXc%dT#lH|!^{4dJzz=5IL_mA<}7Yv*X3?~nVcE9QN<p?+a-|O}#
zfPWwB0Xav8fWQ~8`M^3_50psn1POI>T62^#b^qw~VC;6~&_3AfV({nn`R?QKu^<zg
z-{^#A`22EU=ym;L{68Z>+mRulv-VGC?S~iXoD2-cC#{e3PdS(o^2>oC@P)$v|Npa?
z!vB~4c@ZYTzyPA-#Tgi8cDlY`{qyht|K=kqouO|!U4K{~uVwD6{Sh1%{=f7GNSQiB
z`EC|Q28Q4)#{Z=pFHD6&CUA6rcwzh>q*cNCc!_NHhb-2}-r6glmv+~3Xdh>G{V}uq
zLucrlmyHYz4Eq=u1X#je9OPzT=yd(k?fQb1f#JjNNQ8Yb+jfeBjQ$e_vgpf;GeRKV
zm+lWQPW}7;zx#vn0qgJlQx9Ym{BmIEEPWI3!V@Iy`bOLJOBO4$>yOC)rC(-3+yJur
z#aRvphVEL9<|8`VrBAd=A83EBWHSDi#SjMam><Nd;4H@Q7s)~l3}EArNgw!rBV)=h
z2Zn$bZ~lTjr_$?U_dhQBHD6k{z|IZ792nB91xwgHtdAGJd(GVG`T=BAoFoH7x9f+<
zcyQD<zu^hX()(Y^Vf?ML^v4TD4hDwE$kqcTvSAq+x{i>v6ZXH9BkaE@#{&n3)&nIa
zZm$c&Gq!-^@=HLk>z{xZ$HA`q(hZISCw@@E5V8JO>e=i1BVhlLUk(hQxO}aEWMlxc
zk)<Lah2dc@*o8q_d906>UU|)I{LKyI+->X(43Y8O$Kt@w4eS2!UsU9Q14FYKLl#pO
zV-`ag$f$t-qAs9h`=Rw)DbIgV8<2t@Y^98D-N)h}=?|1QgcfF)I)c2wnZ*$BUsUFS
z1B3Aa2Z;QWAB}JBFu=0Yk<J#C8w{Xu;s_24H~t?U-sz$u^Iy~iWXX+Q7Zrhktb$$_
zm5P8Y&fx!|I*^dzX|7QbC@5t$KH%`0$@oCV8F0)5{rUgDu}7r?l-~_Np$pbo0@2Cy
zz=0v-4OpGlpa1`}T;jrdT~tiM176(r1BHc1XNihNx2eSg2ZpR~|E~q~x~QbQ`10@n
z|KltwJikE^|M~a-|B;bdUm=niFRnu*HNcYBAd+7ok~uGSK_p$kk~<-ij2Sw@4h+X#
zRALwy85sVHIy`V-=yg$%0NJGz5FQ?$#TXv`zeL3({J*Hc0|$oxB`P8r31Ab-fB*mA
z?V_U7e1zwJiHgKxQ1Ax-7gd0$lKC&{0dn{M|0STXlYp2j5CGw-fPCHoHpT$#kpCqr
z0+7<@OlbF;z~Hd(Zd;d!4h*~3{B~dn{$I-R|9ba_)^8<ty>1+xu7CKqGo-a1D3Nde
zp;RK3#S!qLQ~(sXtp`eZg8!HPfhaD$-1@DAw>y@j`4~s{@0VvmQ5wsU#gnlEWabM8
zc2LpNdVqh*!QhM=zd>csl3)M-_f|{rZ)a~lA_1~M7-Y62)a(*i+y-aJ`~ii2=`T>W
z<7qz5#J`;#q?`|={1rdcDbLfI?HRhimq_w&X9G!Ggh_BTA7e_hWGj6RmDmB5DB&<Z
zkk-l8e2gjlMckkN|AW8Z$O!r4z##oUiy@-%IVel=PdyOu;_pw8y#i^?)=H&n#s|`x
z?UaJ~ryR)W0K4k`&;S1+<{aT^KE~91n5p?V6HL|A0~r^<s&@YT|DS(5Tk{bfki*qL
z?lXirLjtV*HP|;YFhTC-V@&+p+0t4Mls@lv<>@r&J{}(z4bGR1Z&a9JnFmxCfr?~N
zmIn?DY0VZ&B`jGAuUWH{nh&r<1_r#?%M1-2p5v_#{`~)c;+F%%Yn9#trq_ZXH>~A@
zNS7d6*SQs>5>l@31Jxd3Sq%S0HNY0wg7``$9GzQV{Q3X?HSh6O5S^s$$k6<Pse3Aj
zV|+5LlgFvI^~0b4{{xOes<0QSKmY&l{$YHe^*{gA1IJlZ6#jx@bn%b>|08?bK{bf+
zx5)1E)<23xy9674@s{v3{NgHMceFlH^!_zd_ebLct=~Z9y9HQV4oF*MaBu6EzaT5v
z7_`5Kg=cYOy!;EwQwE@N<Ad=5<J;DsL3&cadMtiGqN$}6q$x78cPofavz!Z};Av(q
zFEl(LX-2N}IXEVjGba3XVBnu}AmGJ^@8BYUDIOAEIWP@e%-=!LWqr8x1z3w>#sQd?
zy<ja6^)^`4_qM(P1yxw*ToC;t`_KRXovly)fZS_27er@#0T~5KibdZcq9BDC3jZ7!
zzzH<w`~UylU>(gzBzirV(z*qhkEdB*F8!u`@Zyi|58Yr3FeEx#@B9I21VtK#WcP_~
zaDwR#U`p$jU_PGKdb{+S_MwYEm`^bGg7k&=mKbt`z1YjhzyOcfjF^9*Xg%}o|NsBs
zMD!n=O#W{Lx%dB8uwN$pb6^My3x6?>161Z3gui(8^Z)-dFIE2j|8LC;YG0KyeLnnB
zSA>BfizlPtzXQVyTWJOc<NuwtPmB+A$8uQT=bw7O`gp0xi|bMh496M77#J8{R7o)~
z7$10DZG51+ln2}tus&XL&-g%^r5#vx$)y*w#6e9A4(sEkyf5a0bxJTWFuXq5S^Fo=
z(z;aPMF&_AWL(z2Ue^x+86d~J*dPOPCeQ1I0sl({!h&DS0yo|SI$fU}cLlYN{=eV^
z6?CpoUfh;qU^onF1zlocV2C{2{Xew(O;~p+N9(sz;TPIc3=COfah(P)&V!l+$6l*s
zG=O@Or2_v;d0q&CTT48hY^?`MSd0(6W`FS;q>3Rf7Gg}dD@R&)D9>w-H0x6(Ld^%5
z__uSUwVo{fkY*`R!eo2^stnX9Ez$j7%8|wJ-&8`$k>S5+2)MQ^l?Z#W5@g~BNPQjf
zB2topA+nPVW<g+c>K}$MQ2XM4DG$gGnzEpFPxBF;)^DW}maczFgkNMxGJxuHt{3qj
zlYIYla)28OV1IVIa)fn%Jm$v3(0ZUW`Gu7x14E}9N4G~#CttTmMyDT3H=i|chO{F?
ziBLDMf}|rut4Bd8`-_)q3=ExY-EJ(_tQr!I3?*XSZX5`Cju#&CAahu{-8jBE6fl*F
zG<y^<9dqMhe9hI((aG2Cz|!f)0%~;}VqpL~qxp@1@qyrQOIHE@7EnK|JC>vMcB#~h
zwG!}@5+K3Au;c&#|Mf3dgW|20r}cly{jmR~BE7yJUKsrU|G(SyLvw`)L#d<oeg5q%
z*3Ca0i+G!VM3r+iA5h@m{^2!K_Xkjg^~14<8zjsI7Cz8?oaw)>K#5CQ>$ej7H0uu~
zhhJNO5)uD)=71OPwHO%qw|{`}*#lnO*J5C3J|Y0AD*pQl@NYj*!UfXF3etIkfBOmk
z?Z>naHq`!Mh$~_5_WjYESnxMK`XnSVG~0S8IWjPWl~x)b0Q(fwj)tT&@fU~1;XX|h
zhx+t&a<?x}>&cQw+8_D1v+$w$=)!BJ?hE|e89~A*J~{~Y5m#F4r4rUO>kB1^!R|Vw
zeekt#7Q=sV!Ud(2=6~SY5tfpIK@EW456bhy!kcYDX^^2*;)S0+14EYFiy68M3>p7H
z`E`XBxSYLR!qR>CHM8*nhX6#9jR2M3KU)8ns%7!SS+cItaAYXq4So@%&%hAbdZ2XW
zYxWm+#TXbm4PIOWQ=p3RwMg&_Ly&?Ohr~buz{3D4529la?_dycWH`L=fSV&jSe8g!
z>w!}C9Slqi46oU&kJYkwA6pEP$zln3vD6UcqQy(hK#kT?xh$5jPE(NFiyjmS)-0)r
zxWmSmc7n`(&AJezzLSTk`Jh7cA(qCU4ML6#HLtS%#Tj4PDInm;5Z-<0;1AYrmevMS
zM~3cS&ClfzK4<G@VQ>ENzl6j3SP4t(fl{VU!{&nuPK`ec1RNP^&cz!ah&%j3!-RpM
z!L|ex(Iu=ez8Eqv{5J*J^+Nd1|NlsZ3)p|wABvP3|0M`HGL%bopVK~Z@F#2YL4m**
zX{HPejea}~4GavCueq9!DTMtOjd|dJT&y(z5UCYwJ|GbA!qODf1m|h=fT)i>-0jNK
zd_W-pq6J#Qbh~nZeQtfQNZuA~p+sW>&;R=W|FsVu{J{z~NZf>hAu{$bL~p_a2L_m4
zUk;FwKSgSVp?biMd|`~K+(m^axb;9uP<Mz5hw<&M7!{uHhd={xC1PD%&4(C`PL~ul
zzhEpef{2#BYJR~|BoyBL``}{^=KCN@fcgGw>G<XYEG2v}9S+Se7)w7z9|oy?+RbHr
zdjJ1_|LT~3Hh=tYd>#~e4;dI48%rK^d;KvwU7~FCx<vBeO97+PB|Jv2OPF4ti0^g!
zAAPvj>0dmE{0k=k#79H&WVb6v>wyxX<`*1|7I*J5FqE<fyvY3Z|9>RZ?}34cp@ZPC
z?vKW|!>vD;io6g3Rde8KVTUjS!%H1dr=XN0?1j4-C^cHUaul&c8i!ZAU3t10x*bHU
z50`3oA4{{8E0N~k&e8l6R1E!$DrajxsF2pl(R_d@%~GQDsqulAj~Eyjf`haEhwTS-
zHNpd4905h}iRL2`oxVS;PnU|nm@W*;Dq5iY*dxrq(9Q629RmY{r7uUZAlT9uWx@;$
zSxPTs|NsAQeY(y$>w)p5i0>bpe=rr9_quR$*n-A7%7tI-1sQzA`f!QNafUNz7#Lm)
z2E6zH>SkCUF5x`R01A)h103DHKe}(U-Y(^RArH2f2UPpEfxQ(7a%TAd0+AOArl68h
zqV+(DAgC7-_F|0*NPwsN!)u-w&xIHmva}*QIl4avzi9pU|9@onvEI}-@o~|RArw$M
z3sy$H5%^y!04maBK@Cq|4p7+(s%i87{r?XtS0f|g1uIkws7wP_eY+u*F*N3ST_r$e
zQ>h4|#0xeDxk&=5p!tnJw=YL<cPvj>cz3Npr|*x>*gviROQf1>MHos%T2GdWzt9x|
zg*2#X@#2CYsAK{+<-1EITECU>G@tlyeChjlOIMLH#pd7tOL&5_7y@5-IDjnSY5i7m
z5TT%aEC2dhk?(FiJd6wsowXmj@0W0NyGeAqetFG)-1Q4+7`633f6FZf1_r325|?f_
zmevC$w)`ERK=s{k>l;N(-9M~r|M0i(W?*0l|8EBBz?J@Zkz~)npjpSlXvbLlL;HU7
z5dqEGKi#z-UbZqYFj&WaDT-;X{lZWpzY|n<8eg)$S;pCY@O$Z(?t`z{yAOjHhqVvA
z<_1@-);G$Tx({2s{wa?R_+R=X?8O5+28PIh7msZremYQ64JrUr7+rs8-_UgZ^I9eB
z#XC@n2Z;tX*ZyHBQR?>n@!$1F2V=LJg!g~nKb@{$T5t2Ws(~wLk(YZwl};_s{}NF1
z2^4c2FU0M^hQBx{019g*1_p+g{UB9-JPO^%wGSI#`d%vVvIQa{@cK;_PsRjL<MM$3
z0|RI{=80vgK#9I(sYr>IWvN7|ZZpVq{{N*spaGc|yX+u_r+^IyM<hE)<AE1X1;DL7
z2}pMDEdBGpRN_B!YPk*`ED}L#FtUOo!u84P!~aVqUMvNb5|Ba!t}W|7sA7!*r$dq0
z!&y8T8$eDq1=)DJGZxeiuH~@)4QkmQE|qw3o*(36u%n7V<3T6>zdQ=A|14v9z-mhF
zbk=f&zc~K$|NqF&*gxOgc^pdf!(VvWGB8Aff?T@!$G;M>?h6Nhv38$mekgzNAsaK#
zR8W=mnssM|v?IeeN0s_gO^{MakW!Iua24}F{@?>PW|m%v!X03R4k`^LA}?$aE_whO
zy7YbW-!k?|sdD&>*S4T`C1~6<_<t!+_=|gXpjP>l@UR!T;2@SkZ&kPQgTt5OMGeUH
zkbnx@0h)zLvvlPsWidW*^6(B&2?yd93-E7u<>=;pBkRb(zn#VLwJfMfo5k4c$`Jq>
zZcTx-hM5&XLmD9L%cFb{n*Rg4T?JYXl#0A);DZOJG9M_jo;)1ZT?)#HyxqPWttU%m
zyFsM*i*SU(U%ViNFZ&ok4L!kdP@74Qf4g0GDNkDK{}Q3@<7w81ko(vl(wglUO1PU3
zGVyO0Ol!SVdNr-tlA+W0Pl-*pD-Zv6i|$acPEr2th9J$yO1PU3G4XF_N^3n(`XQ~^
zilG#w8KkN7%4_gA24nL<rfye(PL6KZKiUVs-;h3_?D{7@4(hw+H$1`N-L)LXx2=Dd
zO1zlE3-_ZvXjuBh|CgzZ3=Co6FHEgL5fs^3`ol7wrIxufo+XPhIPAq{PjCk4bp2y}
zn7`*YC<TY}d_M%5oG9hcc4v913hD>4cl&d6-_X9<8T;kiA?6aB?rWeVB?3-L&Clcy
zK4bglV#Lx=BG!G;`a-cl_lE{6u2M#4C+llPUpr&JfO3ARbob$xpy9xlOBL^5eBpt)
z^JO~&1H(6W9!CC_EnwSOS}&DyD29G{xfH~W{n1_eL;E1}p@Y9!o1e+|%FG3&%1&2~
zZf3Bp1}qIFm03)nqT<JkXC7eBSiAlyRp@r-==SAcKJl8f!Gf!l`M)cNgZ06p&)?m7
z7!(*7UORwv{P|z{<HbgZrq%<Mtj#C>zqSB3BQ0Gy$_2XpdA=RwDB<{i5L6+SFn7C4
zfGz&!V!*;u0y47Ol|$3@Pq*tAX4gM)poV-FPsRmMmQLaUr5j6E4*sbJS`U<pzF>xX
z_{B1A1_qE#8lb{}``iEjk)Tc*h@%Cn`;ZD0SPwLk2bxy`K&l~m1=IuWcH>#mTq*!I
z5z=7>nVa7H;C*wg0Ar^cPbpv6i>rVC|7UdNX-*Yjhzxrnr@_F`?Zy+?a-fo<`N5w~
zH=fsGD;P_JR&bQ?tps_ql>NAy1gIqqsTadu{ILL+@m=nqVZP=gJk3A;^G`k4>-awo
zT!MW7dAFDw&ATGpu=stkoeSb!`|eVK)^8<T&HornSeySbmEHn*nfoi$|6$M$syw)K
z<iQdO!Q9YL@B-<9ghI1zgP9`(Ls++IijpG(sML5}9^U$`RL{~hM#+((B>lxdF9wFi
zFXS8<UPyR>`ni>yFFHIyj8boirq*vIj^GZqHOM`Io(v3;-9KJy1iWwqF|Ci6Np-WO
zHQQ9!mI{XdFXae$Q36XaCH&3DSi0F-50qXqJ`f)ld$^me*QJ8#^_MK33;_m5h8Hnh
z3=CQ9FSctkFhqjtqCdt5x@$SC|A7kcW2GW5-f_YP4<>OkFm#qad0o<J-tEd`eXNA3
z)4=$EWvKvIY01_9r2;Rw|ASgaH>~fKTn&D)(u0Aaw}3H=DeQ&t2T(_ir<2|IzxDA_
z@fR~VL17PShP~+J1U3IUU7x&`4h{==VXh6yAID1-LAD$R+0t1HAMg+cWjNO-FJ5sn
zFdPmCffp+{z&?=CKpFW6Z$AIO^;@aP3tg~P;2P=z2Ll85@z*Zj+<2NxEW%!FRRu-M
zj~8a%3=Cl}wwp091iVP|0@*JB&T8lXzZU9tlW9Fr!X5BJ?EU}$&1o_Wk<Dp544{4=
zIB6Mx!cc;ffuY&=$$!uY5JxL$un?S|HgkYH3AQ;5G~jgN|7+fFZafYpykH|-pS(~3
z`6BGas!y;4_QD1ffJg}oRA0Zo(hX{te+Q|8C8;-ZjtopCtS<@_K$B4%FLuhoy0<5#
zLCyEr!&xF30U*a!bATEdmZl5L92rWv!@{x{!~TorJaAyx;Ty%kkY>pWnkOz{1;wn{
zLK_ALhQ=Kr5zzd5>8qXGj36}~5)2LurFWWllrT6j@ReOQK54n(1p{aV@L;F!lNV9k
z;Ka(2CG!H*UXOh7Ujiy1@WKb=p%>}?ptSSng`omSqLL#^`o&>c28PK0q8Sey7#7bl
zb7Xk2#*cwv@e@!kc<u{T#qnY;NY#r3Z>Rw0iyn|b7UPR#kT<Q5m9PiAs00Zu1m&g0
z2}+I(0sl=yK;uuQ0ZNVxFXZ1qQl9Gr%hD&MYymGAWf>S=Xvi`!yw>Y>ebdd+&DrUD
zCm`^}CQw$2Jlvi7qTBUOr|W~}+9wPk_0MG(7+$c;GB7|}2i>j@UgWSdFdTky&yRuO
z<y6pQA85F(@r?#E1H<AU@{SChyk9`1=m!uf`vydsz5tQ7PvjjL(t1P%6hIU&3z(99
z02XAu1Ey4OfGOQ8@{SC1`dK*?92vS@85aMM2hl8x85A5DdR;jd^MJ&`gQUk<J>(r3
z7#SED7J?)f|B-WKIL`V(&XIwWh2g+))-Q4(S?HL3XX}kW|Nk%S5OQSbYz2*^{uiwQ
zMSz36BSRMBi{*X{43VG#_lgG&3>j-4IxzefEdkB3*@6@>lyYP-zGw!i$pD!RnV<{!
zFIw=xf#D=HWxf$uD534hV0<Y!th<z_)Adhh=$FpWADy8eUNeK{LYnOqN<gF4%|8-L
z44Quwl_)p=C@&Fz(Z&kTESjvKlKN#L69dC;MrH<v*SyBJn|=Q<zUJJ`$q346f0!T>
z6vihV!_%w}@wZ%KWMJs6tltG%Y0-L;zeR=-)D}9>{3DpZe=-9DLrHz}3kCj`Zww3!
z%`do1f;>u`n_ozj=r+ILDp72H!NT9VkdcAG()9;_D`@EMxa$wlf`;bP0xu6UFfef6
zf4K+L066Tx-?|oL#Ayfc0N!!e4<KbPXM!b}_**A{3#UKLkN-74_|trviTik`>z|jP
zvDW6=9}J}>aB~%2=QY0wDT!)+!B^tyQDOjclxXt{HvU#gMh1rOhZznqFqFD--+Jv1
z>iCpeH>UpizyJUL<E~#o7QQwFi>h*l{(*_eL-hzYo(7G$yyo8l?vLFlVKF}Wnu+@c
zB)rmE5Ae6%0d+%aKQQpOEMQ<@$Wn-h#EYd}$&W1Nu#7Da9T;952muv>JRs$u>CEP1
zYzReZ&33k>rJ$$;YhlgU^U#4I?8V*J;C$A4pp?7$7+2$I&|;g{j#(TTC&1GCkfjAc
z(o77mm9p3~?trD|!=<I0kMV(|85tl}g42uf|1?Xx5}_A~%<x3Q0!kP%84ci33xQr&
z&}1M-z>8<WAeW0k$Fdc=T}A%0K9F++Ep+Jg;OX||>8xPswCJqh=&X?G^bi2|g|h@Q
z3P2@gATtAl@on&Ee-`75rAnYt>exS^O7Vd;cs!23_Y`R67&I2v%d){zq9htLECOoZ
zc&r2kd#Piu+u!CN0_8%zZUO->7Ak^A4f$K9z;yjL*%0>P?;Fr84tVsgn`Of{2cG5<
zo`A3yA#Xv#Zm%bH|LClJ@;W)o;)MsOVC&`u+1JUk(fV+SU&aD{1_qc`$S79>xL*Ml
zD;554vf)MUi~s*4!Te5{4X>rUSvEivf=1uK!re9-I%}VF#`9SJE)i=?2amaR#<O(B
zb9Bmg#>+JO3;c(cbuYL<Df;+}8YTvY!`-z{vKU`%Re)Es-L4#qMU)&Fpo0;R0uX7e
zsXLY<95krF9{j@33)J0P3Yyzv$nxn0&lhDe1iZMX&%n?NF2*1wQ*WyQxXa1|DV;i7
zAN>9Qzq9uah@5%@M9#eeBDY=uk$cbl{r^9$XX+0y)%yla%{>98T91IKr3b*&+C6{&
z|DV&}`r+^Y|J|-Ey}m4+y`agr<6!$hg=c5$3y_@WpU&PVAcikbXD`UP-M#{yy`agX
zPVht)q`b^x=>G9v6jVs|f(z6DNHN)Zpj4pse<=^t(~+PWrQ7#Uyz$xS7jvHe{|_o7
z!?GCniL)>q2+Lx6aTJslkMM+{6r^#Gg7m*BC}{tSc7UU|ggN&A1N7eg`v3p`pD{iV
z00J+LgWIGc5Y64L9L6WDS<X%na%3nGc5MEsTlBHl<8AX#!E(MV-iX-4-7IIP2!Udb
z)djQ$hcD9lg!BRBgUtsxVh_Kl=LglcrEEKX2s<(yZa%<q_(cv(=nq7Q2Vzgyi$|bA
z5nqnLPL3B%pqjq>!;3xt|Nrkah>JaZ1_Uw`OdS|f{+ohUMRdEU2z2JC2=wNt2xvbD
z4hsh-7DLxR#zzA>Q(ycq{n73E2b%OcU4Qhten?pi(s#Jq_d`l2FNhf#4;pfN8XE{P
z{mdEY+=~Qw5UjhH!`Kuwbr#;ucFgrZ1GISTtrh?c9q@Mhu`r)E=COFe|K$JwZa<!G
zHx3B@|6@?H;P~dik_IV)yL|<ELtk_T|LKnA>2!V3>HDVn_rH?(UQdQzmgsJuHj!SJ
zHi1sp58Vu%u0L8&mWXs;e*r3+kGcM5Y&}rnQ19OD`lI_s^N)X}=NfANGnA-wv!Obn
z2V|umPj?vD305y^Kz!FP5Z@gJ4XA;}C{K3#ax_{d7w0}G)oiw%0qRGTC}e=>7oYt>
zB^_vdjlVmTBa1QUzbHt&`3Oh1FHd(U$BQYTUa>2WWdu)&5O_W@y!&$Zi5Jr#!ri_<
zKm{V2tG+#g1Psho&p>?F58WOd-Pd1eF)}cK7MA?C4Cdi)@&Et-Kh)UMFB};e7+y+(
z(j#a&M~I3*w~LBMw~vZMXiz|4V1|P^JPm-O-1tbRiwZ|drz$8)yIoWax+6HceN=Re
zCA$lFn*aSPvF;90F=_twuY|?=Q<+|`Nm*~qW`S<*P7j{uY8HmlGZ~B^UpRBTI26FZ
zuoF}%b~|&txDvp?@Onc^Kd8~n(0oK9J}&xjw~q?TcSjaB1_p*5Aay0i-7YE|-5wmq
zCth$o`u{()J451s0nh&e0niw*9XJ>9#Ddj?s0eg2?EsDa9}eyIQQ_#;{9h>Zzfj_T
zp~eeQsKP@m454A+!QHPwbN<GcjK3NG|9>$W+|hc~{jvLC7UK)~08n$r__py$<4eZ>
z|33@ueiIxPp2ZN9@yr~w62)&G14DdVbnM~K?i>}4pg_>Nn-^OlMMLZ%4u&j-3{Yhb
zYL-m^tz<gcdVqiG!Ns8Yt?q-6d<Y&JDv^c`l3Tm-6!X6@{qz6-aRyKq3p7W|zuuQ8
ztovi@w^Bwo;{(nA9+V4*WpTh}YC+Rptp`etnr%TdUJNBNVK3rEz?E0&CGgNx2^-9)
z*Sy`n0<9-Y*p4%T%#Mpath<DnfuTgH`2|afc=HS15+08dX5#~gcYqcx9^N6u!oYBN
z2MY&?6a=xm|A&Qle*i}yXsMx0c)*JrnxGKk-+rR|U}qgmXB|gp9nZms0^A3C>jYM>
zUcHk+#F3%-2v4t@jP|+xpqTFxVeAla@Gt$|+a}8hTFA%9z|bYa(IMdASNc63T7ovd
zkzs{4d%?>lgTs4UU;O(2Kj42E%YV@+4;&c4vlFcc_*?#fhb%i<SV6Pu4%WwuzI3&|
z`}P0-u~v|PLd$^?gWkFCfBpZ@zwHG7HfHM+<zm_g9Rhl%@Pg#C6oOueYJzejPnR=e
z^I@iz1Etrp82*=m7H9tY|Nnm(OF(!p*r))|O12lyfuM#)@c%NF-qt^V|Njq%ONak2
z;|YH84V<-IpbGvVE64y3dw>*O1S?W8KES`d$Mw&z|Np-oWGvxp@L`h`=;~nw8T(rB
z+d-xhQIL=VNa)Z1{~bMSpa6T#-Z2Nv0Qq(Q>mW!l9&df}>;M1x|Ns9tKB)<2cTWY0
z^tSMUG%;W3jZ$d-Em_Xh;KL^?&>N`mnz#9vWH}FrtI!+xphMs_^DzbnN9*%N$6(do
z(tDt44>aHnYGJ+q`TzfmnV=5;kA>iwc=v)5+2;Bjh7$4a@{HDRr5srbFIIt;A$1>n
z!T#(2|HE0lFJwT=1wg}3-Q^jbrBAF)!PE6-t=~$d!v2fS0oRYE{Eh!WsicHG>_zT<
zQ2Pg@sM9^88?3ss^hwx%(HRdMV4XP7Qcs50ech!`vUp!S5{EZwn%@Wn8{ZBFP2McH
z|Nnodtc;Q)L-W6XrE<qvK}=8y@?Uhx0|y3+*gqw%(CP8lHqHP3mI@&&S@6Jt;q~q2
ze}77ax?MkXJFp-mUmpSKW$$+V(VS55xBD1;ZvBk{q;LeUs{+mGbeD33zeoYqus@8y
zb%I7^O8L4Ezt{y{p7RpaW$7$^Vtl}Ihk=A61Aogz(4r34C(Q>8Y(FqCFcdv+{Qu%F
z0|S3c2_pkT<A2Z!CH|HSaM$Q~z<<#d;E>~Q2?KSWTwer)Lox*@KbSKzFo1Jtud_^8
zzzYjC1_t9xPR&PnI;&Yai+L<VU+}kq@=QbRI|lxi%M1(*y`}HF_*zc#w}6(d^KWze
z&%f>D%asf$#(Y#|VCeRJ(tLy``=mi<>4V;l4ib(Gpn(VNE;q)O10|aL+wAza9e6F&
z?fRgrK}W)ofy2dGmVcWYqr3HwvR9x*v&Wbk>=;TfbeBH)@A{zm7)NvM1D4LxCq*y2
zk9StH9Cro{3NyUO{Qdub7F(w?Pp`8;Z>NcbBSTbLw_#eRLGwYT<^xP#r60RLzqtPU
z|Noa;Kyz|F%(5&F)(6YJH6LSYsQb^r-wIlc(d#U?^B)5PLjwnggJ<c_ZfBMkg1`U&
z?{wzr4CZ*v+*!;4%6lie4?>EnYEV)2dby=3D4p=PhJXt26aPW^AP(IAyA93=A{iS%
z8R6Nt|NonPAN+sO!v<Qy)LDDy1*l`*9iP!%%JHHQ)VOu!uy$tQZwUuQg#r@;!wV}x
z(6HZ)*4z9oZj1~JJ3&3O?(&T8-=CK@D}xtKzS!~?)Q9MFeE{mYfg-58^v?gX40tXP
z>~_nrh2)cf7p`|eQ!;TG!QHl?obmtqH@5;N{?=EZ-YhF9cQW#~-eq85$l`r5Qxw#E
zPyNHt?aZ=RN6C?)+nHmr0hs1lY@+1IV0@s{^-1#&)>?tIZXaiXv`!vZ1tmuYhu1H_
zGPa;XyOy`hM?$8fLqQBA@e(2dnmwr%=<1OGl`tJ08sZ?iXaB*u7Vd1}g`nIFcX-cj
zki%s`V!{8fABQf5Vgj|746=A%2!m>_!>?7FfBY|1X#5TFZt#mRkggZ<UqQ7ZXiV-k
zOLOW22GD5Eys!WNA8xko0ky75g|hy>2m_6AA7=##fHJ)C0Z1(y9M)|L3aRk!T8{Al
z*Sgy`Fn}7$CCmXJ4rpUe>j5YSG)(~K96%`RjSo2P$^mMOG*<smk#uAz;p}FHDr~O)
z!%)K2?F?$tfsAZEEb!l#qx4#L`xOQT23C-f0spUoTMFPtFUT378P{geWP4b*DX1hI
zFlWU@gLeRc9R?ct;plDyjhTSf8XPXkx8;y?WGKn#ZUcpw_2H5@ONr8`?lw@6SsyMD
zx0EOq4tTNk=Kufyw}EuMZ~~1nMRvD={ESdA1)*SvFKCeS|2B|$FKQ6tg*QPNpt}te
z<kp8vTr4F@9lG0&FfcIag0gbJi-4Q||97{626^^_#$~jR2fVNa3teDfU;y#-!G?kK
zzfide8qyHxZUcqCtp+Hzq%CKF+yrv&K2HXQ|Jy)PFMi(u+1gtNkK1}k+zNKHTOTgr
zwv+%Z$+!kmWEuabM5x=H1tGj2B;0%)9M#9eUTgqyQR0}V^?!*qWQ~VOShs=o_Y#fp
zPKy^=pse2dtwcKP#XC@!*^VI+R0&Rya%2Eig2kXD+<iO_v_3r^JW_oDRPN+``v3oh
z1QTeQ4N?KS6_hA7*X1yj$h=?#2^Zu*Yhe`*P-%1QMdK$>EzI*`8mROE)x!TxL2K!n
zkL85Dhy?ZcB9TU`!Fh0B7SD@*0g&#}Cx=0;)|Lkj42S=Vu6f|V0A4H?_TRKX8ni%g
z18B7sXeqz+e^VRKkS(~k+x-EqU<*jWvADwvbEF*^KvTeC0sl>1;41%LXyygU{9gz%
z4<yeQ@LzNXXuy&eB=Y~|27U&HERKv1Aio!V{Qp10<|$}Qa}UVeQjX(pF$;b;Ff^xe
zFc|-L@2nH)tSdOy2HJ4te5}ozk%7VaxLXFO{K(>cF%9G+u>V2jDX18L6+CvJGLi?f
zEWNY#4`{)(TTbhNQjUe7fa-M1`CpdvVmD|_3QUJ6XxWR#$N&Ei8~=CjF6GGLeGvz0
z^c>FOc@YX`fEvmF!P^`Dn}U4U{o}=vfB*mgzW`bpU+R}3!o&a?ug&2G#bjh;>$eiC
zFo??krVdEq(|VvpB8wsH#Sc(&i2N^l1Qa%YEdM*%UUP=MaK85cf28rZ@c*I*9yl<7
z_Ff$B{vY<D9@OFhMGHrkzzZ2RP)r_+JDkOlA;IX#@Iw2;|Nr0>fBY?=ZDieUDy;`V
zqwwFZf~J1lbRfJJ5S|HycMHO^f$+{icn%QWJ_yeR!rK7hc|drJAiNk`P&9!onFtcd
z;(fsZ3MEi%bk}8o*1Lqm>k9tH|DYHvVGn<i0#XbM^KeKkod+#CKkoVmRIYc|<+T1U
zQ4W8x7PJn++7=XDB_fUg!Fh<M*`A@4J^Y0ha>U6ofF_D~K<2*4c>n)DC^>_pZ$4;g
z^<hv{^1PS~VgC<DPHdnxg`6);{(_cJ#~%*sHa!6vVXt@!+A?!3BL_q;wg5%kwTuKX
z2b>?SWki5E;3&P;YztDs&}|CJ7K=gIphT?M7Nn4&gtyriq==yew5m^KAt+}p2FWZ0
z<%Z*|AdM%S92h#msROJRk|7s^@(F0VwB;bE^$5;}0spUo8iC-lbt!0k)fA+?+Z2?K
z|6hY-Rj6YjsSRusNCxDl#UOY5zXrDB#WV2CP)TyPEodAoqtnHK;Xl~4|JVOtSPV+p
zpj_($OV4vaTcbXJ)3X6;dcOYu0%!*sC@t%NRw1IKW#a=5ui3%vIpYIy@sP?IyiB9{
zjR<II27e1^0zViuecS8%=EbqgpcMS3+fT&!w)N>!(Qa3cUXT50%|9i}S<)a&YF~SU
z*L7qug0vUQfo5I*-TnVRvh@IHkw;{SPIn)u4&mR%!uVRDH}p?X7GrNHM^HfEi(8;I
zCr2b83QJh{x4Ztai2VUt@bv|>k`}a$0$fRENIZj;M6Cx(L^C*^Ie_*mfs#e*ff82G
zHkb?0fmM+0CqP9lND#bj?@SiQ3sxRbuO*A)g)%pY0m``jzd-xZ!d^^a0VUIjSO5Qq
zy}0EMVjl&QyL>_H#lE1fssyx`44R`iKJc0!G<Mm|*Lt#q>Ho#%V=UICJVkFn)5V~v
zt!CQ^ptezoWCn<SQ3+bR(|VwU3+x_{P~?j}0SpWoIS(BeGD1KT2n#{Z1+AD32@B5%
zuW?{_(GtMGu*2t}1H-<6hYq0WYwKgh{N3!W2TGX!UuZtgV*Rh^W3%lPkUjBnCDIun
z)(d{9O*~nkO<)ZFMM0vV;fySW3<pqQH1GBQ|5+R_esV$Er^W{yELm%mK)oT*I*!E^
zN{$R&t^$idi&>j%c^LRxL6aW;O*_mS8M;kDY4ZQI?i-!47g}$ZWc)X6F>_@2e+@JM
zf2A|_PG{|n=Jza}wO6cv7kR%h`uYFAC40$R>)%Co|II<#UdaFa|G$&{|7D1IAR(9$
zma%tASuI^}l<<MfiM`P2dIM}~ckG4NtB<=rDR}6>&{+GV=Ai>av0%6BlWx%Jc2GdL
zK4E$N?6~WL2C#w$El>py5DFfE6@bPa{=ZNF%|_J<FqCQ@2m2aSs%3G!5aa|+t(J1U
z*b8bI)Cw?^aAa}3_zkMj55L&(>i>U87Rh1&EimDDvHl;Zox=l7ZCMPUZH^o-X2L{4
zLl#*KFFGOo!&!_VffrR!E;up2cnK;dN;zH_F)%PhLY7&BN2kHE#s|86Ijnh(Zg}Uw
zP{QTV{6nnh9VimJS&nXb=YW_#02RteJz!AE3=ew&TJ+cb!}xY&=U$e7|NmS6=5NVi
zWMIf*ejynMiuE6i{4MMd0S=Hr>w!|<W?Rr=Xh!~)cMJ>+jsHMBA^sLKP*3X3dk2OL
z5oQL4{S8Wv4B;<MfL4AS0nc=STB8}D?LhlBDLFEP1*a|Er2=ZDfHoiP{>=nx>X*uA
z?0N6N5FGYm0!&{C4{QWp;RPtaZBb`naENUFVN<3R_F}m@14A#1E2tpuKB0Xsi}~Wu
zj4kgS7_@H&2fXM758#Nj9w^<LvF5!4!#<F+!opuLfW>)Q50ozbzZK-=u<#dez?%d?
zViPk26c`yY65cy7guloHXJww(als()vJy0w|K-0ZXcuAk2kXxzZq5JxmpB?9=;Cqj
z=wapf_y2#IrHp$Chl4F>u)63)aBnNff`HyukX%4V?C%#f9-yT(P=T=jqGv!&CEq{s
z;7;uIGvH1v^NV@@kf1LS&0>Br5yWXdP$~}%_END7P>8=!{Ri5Z3~K90gPR|aR0o<h
zTA=}&djKbn|E3@ge4c|JRHj@2ZA=C2z>7T$PAA|p=#5WUuj`h8|DrcQdkr136ym~O
z<S>D{0mdh-50-K?pZNchpNWB?cLD<k1H)qQ5-igaQ%45tL&avz2Uwdue*aH9?(m<1
ztJ8xy?YM(H1J^MJMXpW{;|>q~Zc~u@<^vAB0lyoMfef&|R&+KvJk8Sg8Gj2OXt3G!
zh4n%H7G@ArqWJ(zr|Tc)!}~xgLHmX8)i8D6vy=r{SDU@R#nh1@%OOkQ#TiDB`&ti_
z1U9pR<P>^4z&hBi4;C9j-PD}G%+Qb^-_V?3%m8s;+HnU3F0Nw^`V8It%?BKq&-DiU
zw!T<&srfhy#EP0lui3i6mKpzVy<JxXnri?zk7Gb{4B_3rf4Vq9qk+EP4sw)o2mBYk
z0v_rqvF-le{7k<4_`x5n2cNMqn?QC3xc=w{ZG>_C)5Xx?#sZ#U>~-S__%8~XS>$g4
zb;<s_aWuRBU~&KN`p5crO`q}Y?$012z`+KZ+W23>4YHf9!H=ckb>T5Lmd4iGrL0-s
zB3^U#I{yc)2y8y^H2|74e>DI9U*gpIzr-#a?lxmp(B_OzyXGHEr65xrUUN48U@m28
z@MGb?a8rrSe>aZTTn&CK4#(L*?PBNV-^~0y8UO$P{|}Dy|DqQ_L*)nJqvK8<Za(q<
z^*3;03kx^?2C7ZZo&Ep6`$uH!|59~J)(skt3}y0R|3x2wHm<h4U}j*jh6pk@pZMSX
z0W^+q3bNn_ZV0I0<N=vf`vPPVXs;5{W*tT|3%aPR%Lg<P6bW*aj-@M436U;4h+!IN
zSu)6J&%g#koTg*xDnP7>dm$!f31lRIs#xnM|Nk3<R{mx&zL*Hw(b*aMCyP10v-W|t
z?EyDOhT4$s@8D@=OPLKNuCN(x{(u+vZh=-c{rC@Bh4`fTzetS+SQ&gi`pyFf$W%6H
z(t5{9(4Z}Nrdwu%`|E|rp`$vm<%Pc<gSw%NFU&wW9#W7%h8f&=x=%DbWH!Ft@RO<3
zVI^q%uf($3jU&9<PWwme|2m!UfUp;LK%KXM7xv)A0X){nOZmIqcv=or@;5*D3tC>t
z-t5Pt(0uxTe774%a~canCtF<i;b>@u2&#u#zm;-^y#P&OM!wb$dr<>w-hi5Eprj@L
z-Hivd@T5c}>_xEvXbsuwU<QWB?>8c)4}iMgpf!jh84aMYeE;bGfAIQ(&e}U!j4zx(
zp6RSbU1HD-TPy%tVqj4c*UbQ4A`li3_Tumv&^UwfC8y5NKd`Xu_Tc$;u(?FvGL)lK
zFyMt3$Yr25wcLN#C$A+fYdK0qK(he+0Wb8SQl-qCu6H_X|GeN}U|?{2-D3Q|yYvCr
zIPmg>Ghj;&!y-Tk+{EBu>~?)p!rbk8=S9IINKC8&RrQBK^IITuK^@0%<8S+SXgD%7
z+kD+4?a07bD%;EQb%(SgL#G8e2md!{J}v<(R!Vr>n*XWPTsA)75FdBASp}>Rw2$&*
z_y6E-Sy18#+XvDd-fh?VzeKpXj)k#=H~jzQ@E1MD|Nn1RV~A`%#?koihKwUa%^k4H
zc+fh>5>AlHQs#jFml5*MKofzWTBO^R<G;yKkg@+oA=`tpcrsRiq9)`aC~Dk6J3Vh(
z%7P}>N+n(h{rvwwOYQ||k1M26lk)`>1Kp(@y(VA>TgsKNbRU16n<epLHmIZ6{lofq
zDgTR|4?v@gp!qT51Fr+JxL!nn0;@CjkEL9xHaIN8Vc}3J9{ytYvH$-gU$nqAb;dq<
z&E0ADnmzo*0+19eE?}AA?E_F0aJ|rkhCJxx4p)w_UWm_{?HEAgQ_3Jo&@e=n;EQn3
zn%w_pknL3PR{a}=;Be#HS?tCKB719}bjCjTyxKBWq*UU?ulpe9g9b@o%)S5rKd5E}
zFKwz72<t8dts0TE{#+{h;xa;68ARFZZ15h8PS+>aKgyXqYoGitmFabT@V`{zxa%9x
zkud*DMLJ7g1ay`@_#evAd_<trRmA#piK+GB8m0ffPb%2ET_1EvycX<reGm}*f)|uM
zz?%eEyIn<I^BW(qjD6A(WA~qb?t$hPOyI@L;1apHR)nEc^o29RJ<sleogI5PxH}f)
zXpZpK+n}Yrr2>|vJf%X$2VSlM4a$BiVeba*!Ymbd!3Nh1UhVzj+r9t)|Ch=@)?8Ts
zF4O9^a1IX3n77P<;l*BX+gAcKyYK$uEXXPgrP9b3hwuIW-)ZqWpj#pws&EQK;V~Dx
z{|q42lFhXO|4YSR%!KMuebEonBk@|M^+2WcF*dLwffrTxK;aMCM)E=yr1Hdn#E9Vk
zQVCGygR~{+C&Ut@(ki?a?lI99y7&J7hwT2nc=!MR?qlG&Y4COf*0fHx*Y~@xX<q<s
z=>_d1JiwIJda{Jszw{kww|wc9v`)4cZ}0y9pQQxe`Sf}ZIJmoAMOqKkaf3D`zmNhY
z>_|vJfdn9x*?-X|h`o2l2P|EA%7nUoIY3(mN;n;w4>DQ1@)UgpuMi3B^-<x_KGFP;
zpZTElN$!J@FJDD7Fu+CGVWL-}86f*?13_sp>;)(I)E1s@H=f89O{L;5-0p(H43tB_
zW%-H!FZCH27*;rx@V?LnOM!y(_2XdU+bbAL#5&_xRtP|b1-kt>njie@<m+?;8P@#Z
zee(&XPB)&;IF`=XKPy3-ol13H7#{oozxjZI^@kFk7ph>kgY}0}UeK;Cxmd_VIeXZP
zQ!$`&-;D=U35D~wfCiXBn~LpvJs3Ory8R@ye|UEKu~`4ElMM$Q-Sc9-52z;&S|s_}
zxA}xZryFQL*6Ye{U!LZl|4XEsfBq{G>ps~0K)(Cp!C$Q44KLvB46j+C8(vrxN<^}l
zf`bEJq((C^C?5iC?EUe-M77(Eqsy10gX6WB@qhR5URMsVbq;XrENlOia6-fBHAlBA
z2e|PCZY+UgxEW{BaQ`+an88Iu(`|4b1Fwzjh8GPo)}KoyUhF_9i-sx#ErNrV0-dEV
zI!hlkf?8|#Wt_)dpMdsty=LoWvF~(66dC_ZMFNmZi7@NKHBO*Xf(u+q{C9l-D=0t<
zwj#j=1(s6eIB1|8ED0_}1i+<8TBl3hKODu#pIdM*&c6lrBA#Ldv}+NO+XP<hhiiV>
z4eI%<zlF6J$=>O}@M0n)<AMqX&lhbVt1OgCV_($V0v978;9>-<FykL+N*;7hNvBWU
zKahG@K@tGfrT)SVq)XzpT<d{KS<opMd>~~4FZ99g0j2#Hmq61Q$VCaXVI%s23#<qn
zscUck|NrtAXw@HR-v)ondj?P@;%|KpqM1s#A;}cHNv8P(X!`~vhj50yI2#Gt>C4*f
z#?i_4zf9tP8AsTQ6wsMI0WZ?oAnDwV1vIV*3K#H*V-skm(T%66G%)Oi6-Xth-C_{-
zLJz|JSE3Rg_Ck@Jf#Ki}*05e1aBt;>AUgv?^8@)vP;Ow4jE820E(aEsCYz>GcF>k%
z1qO!3I`ICGQc=+M6Vz=Z0t^h@eE<De__r}ScJjRz0ryQF2s9rM;B?~wHU64U{6|!g
zGTouz`XlRKM5pVU&d?{;A4;WPyt(oJf3pI^i;FivNd;W!ocRB;mX(1a7<BSS4Tm+j
z7g8ku;?Rx%|2rjKtbi+g;SJJz;{QuORtARdV+Vh*hJ*GDL44QEe()JvmyZF<w}XtO
zA}?AYnzP}WUuQIe)|1qi`*p^CvA)dT!p6$L@a-TIf9qcs1_sMmo)Xh87XuZh0~daD
zxc=kccfccyC9*`)qm-}v(Dw_Vg0K0}zs^vB?pU7A*blF(Afly`FQg$hF@kLZCxj)}
z|Nnn&)_v&Wi%wqw>w`tiovxs5tuMBG`v1TCMr3E~ht}Jraxczb2ZaErrSsxCm<eiB
zf*K5YET9<**btLr7z0B$f2Rwd2B^{x;nV5nXFm7Mk;S9?a7k5{Cu_q`u9Bi=&`4Fz
ze_w%y+J6ik+}-@W&Wz9%e8*h)Sh-39y7{|&_*6lPUBQa&J2<-e9UwYDN<s5a$6WYS
zxk^>RO4UG0rNBx>U`mg>egQ4%I_AQs#+Aj;>-!?`f2lw~H~W7Rw*R6pz#V1&mI`Lj
zQiT_-C;2;aLH$8r0si(BkQh6o@0VT|HkNM;4g4)n7#SEEYX33uw}^m-hfbDoHCS_%
zvNmwAyk>4t_}v}*q1*Kf^Wn}|flk*i);IW@FM=|buRs^0jTC>&dIkmt8{QJ04rXV^
zPG5nSpyeCgu3tQ?PZUe^Ix>Q`gn{<ib@~b%W9E8Y+UY9rI`_Y;Ko&!<>x%%;zQX^g
zt}f+*%ow#ED0OYFeZf#--_8Ebg^k6dM5LkiKUc}lW6ZqW>|MV9JABw!U#nWjekf%F
zODxD@%=!=6_c;^1@LK>Z%yNvG*SXvE3+SAOCb$3p|GyUPW{3FQ0pv-h*Q{NP9n8+%
zhqYZlG}QiM>~#IY-wK*X1?6(kESh&0cgx8NHs_aZ;Pq7w{M$~x=5PMNQZH;B`=N->
zn|~X(L&MGoGL8%kB`>;!`L~_o-`5G^ww^5IeNl21l(axw#9voATAwIoVZQO&p_~7k
ziy@0giK=r)h#_n952hN<F5zzeju1XoXV7>7jHl+TedD#z_Zu^_7=u6uhrQSj?)wRJ
zyFSs5{c!OGs6q_>U-}`70qNu(&_>?_r6!PI40s_4n&)ZueFHj{!`hVxH2);H8#Kw~
z`lk8EKmOKk&{&Y`mzT{Dx?9}%r1fF`sRx-4bh>`&^bs?7eXR9l33pmE{zL&<8`145
z0NznA#ouxh)ZzNcTOyd&$qhQC;{a2qtH8^x;FR;F`QSh6gT->a9!zP?mRzO0;DIQC
zEH3cwPf#Li0qJ%XV1lL+CeVRvC}|rhl|+M6NhmCpXrwjQ{@^Ovl*Jp7*2xS?DL+6d
z1;qH-;lrld&3?><O^xfd7AWPgLln1ylg>ZTa6?=WsE`+ch;u>=X+F#ZOF&Yf1SHwb
z-&?}R@{J9YfcThRbEb7Oq;)bkA7;{y{m>cv<>e&MU=DcRGmACO`dF#>i@eLAQ~)Ys
zUzA<`|G(4VWfrK~{E^Gw8U<pczF~M71F9b(V?9{{87Dy9xmM5|Pb^3C?|-GzFKjPE
zifbjfS)dYX8>k0xyMn_SJd#!<^+F7)?Dr+OmGdtB|Nr_@_u+#-SfLeA_h-mv(r$MC
zeJ%zp%?}t$j)6Np)~*852OLU8U!1=Lv26?37*JvQdVBDT^C_SaQ_vC`cF^8T#u8`?
zKKR8X@DX32-Gr~jU(|y&fxX)fF$c7<4Aubzm9yQhPhPya1RBGS<p_Quo(h@#fph`E
z+s<sjMu6;nasMK;{nG6qfao8Hw0;BcLQDj0DJ&I!!F>tVLs)+i)I)gf0WLAcEK7Nc
z1jE34EID3$(E~*<&+Fs=OL;&Y5RMn1Mg?fEC8*TiZCT1w%=hBpMMPg=Q<hi+s2&Yb
z;Q_6|ZM{^IX?&o|MTMi~K&e>cFHqySh_Bf;#}t(NSzq#{F))O8|7`xnQe^o3X7fYl
z5+3b~9qi4=8Jk}+mVWC#aqs~L^Fa_Lz<jX#RP!U|gD;s%*gmgry;Q;lQTGa@&P9bI
z{&2U83JYYA2-L<2djZ<>67Zq~G(7+sTCRDKxC`2z2L}ZIi$E|R)TU1`KHvb^G6Frt
zpwuroyw|3cL(7q&*`8rHXen-~Lhy?<uR)8D*jo>j3irB+WHEJu+C34SZW5htEU$UH
z?Ln(p?K<NmI^$Rx{dkxlCoecezh*K%016e*U<4@mOVmN#8PEul00TpbWY`PExBve)
zrt$oL_y2!$ngr<hL(uYs$hg?U-yC@yO4yn!IT%V*{(G`iaCZxKF#Tr)Etuos-*+G|
z;KiL!pwS7?cqKC@+u{FgkRWJ$)4+tX4z@d%2NW#E2g18+L8-8}cL`|08FWtts4?By
z3R+3l*$Ub&(b)>xPyyK<(b)>xanacd+D*|3-eK{ga@+s^FHW8Z9UC^~?|;yiOYIlC
z&Vw=#I0eR@|Np;X?}oqs|AW>xwXOk8NF@~f1?4|;ZUzR>cF5AWuou>#M*1$$E`CrO
z5PBv6=s1Ax4+sCTg3kol3L2q*&D4Dgd?3JVkUH3b0L>5N5B`Mok9wi14t;Y_Y2a@y
z1TSW_zRBN`{{R2~F5yndR+3)uR+8QwfB*mQnEL+j|NkwQ_*?q87#N(5zje+9Z5grL
z3fgnR-&4uOz|iaTz$T)cpMT#W{(TJ+9~>B(AMk_Xk$+#yL5mL#3|Z_4f3QS$w)TLI
z5j)7=uE52>@L#1>wZMU)xfisn<bUVZ4sZyA!)+@#Jhy^Faw|B5w}SSnynM;Yz`(!n
zQ1c6g60hbL%q3>cFE~n6Jv>T8n_n>Vx1Qo;U})|IspojP56)(Jxe3l@e7TI1fuRws
z29&*CPKQe|z3k>>U}*TIRjSi`oTYOwD3ZJD|8(vJxyAY)e{T+4Da-e{Ai<YWpk=z?
zxX(Vo#lP=VuM5WoNLqMl584U5738y*CQxJ5P>lu2fs7Re8w=w7f5{0p5X43{5X67^
zjsxU4&yvuFUl}DX4Zm_qBpQB|^S55(fcXbBZSwLsNSSp`shBgwlc2l^iLRGxKpSkq
zJ{Neo0M1r;Ifa9Pp^MqZtW>U{n$e_GqWLfrRBr<V15|GT2LpqRF<6BWM8#52FoRAO
zf~xQXsYu~(aRbqr{4I7MI-kGA3`Cdmx9EZB3jP)~5FNqaBFDkN(76?q9u&cG+uI7t
zVFCQx4h6gr3}67ACDqjmN_UYZO5MGny-dB}^!7sH&;S2j%+3&NTMqEIYyh2-hpgfo
zXw~XIc1TkBk;31<4YZ)QC4z~80leLD7ihbqPxA}M5&;j75)}`R5)Ka!{?^s33=9p2
z6ppuo5+Z1t7?SQ^hA}ZPd<W-q0}ciT{#MYb+Ry;v0G(n2I?V+xUCM=!>ISFm=AZvd
zSwS<j_07jwAm#{w{EkRqpbcF7E&o^;7+U|AaxZ)$>&O7v)zuB&+jSgVihvyS@(c@T
zcV+~CixM*fgNH{+z4k%=7Le~i?tjg~z|ajg6^lhB2K?LI{{&=!*2Y5*X6$VRW$}O)
z*AhY1mH_Ag(c|D^3uM)6;V$<-9pDojkAu~L1R)wBZhKh+vW^{|rdtn`Sa*A{w4N+6
zfp`*>9QpS%boPS0S0XYKbT}cBSIk)$7$7nKQU`Q&^8>iA171jLGcZKH6a{(qM*)Ao
zEfWI+e~T(O`cnCOn8D)d{C(R&4Y?ngB{j`I@=ElYf8_JGK4)fN_y&%Q21rmq91rSo
zmE=HU26VhwLUSu9f3tLhsqTV5FT#C5v)BABNuX^4U=tKdc+$FCL1i3h5Re1H>|{fP
z(Mvl}{}dA9;C$r(v5gDV5Csc-KgiGka{B{N^OwCloTd3V$4eg2B0^+cz2HMG!3S1!
z&IN^5XX}E$|NmQpi;r5K<KS&~parq7vq}XUex;WtLxez4@;clSEM3P2seT&wf=Ua}
zmasb8Zm<E3$6`T8hrEz`^8bGqxFnD4Yy}nTtp`d3AaU8b6=Yxcjn`ZdgF)K6*&&NR
znvZjIwl;va`?>$=Y;F1b|35UR{s$M>{QD052U`OvFa!RBjp_yK2oCsf+93y8F7p3E
z_g+wW(R@Uv@j0m6Es<>oJCvbR1ZrIHf72;YwULnxdqFury;PzVbn+jhWC;FmIsu`;
zTDMdX8lRv=h>&m#etGck|Njs_fTFy!7gR^T)@puH%-@pt=l_2X5B`=2P?H!`TkHl!
z3OF8)gX?m2&{zvN<{KdK2s-kfzs2a^|NmWJ1uTKbT0vVY4LVvur*Rwy*Yu$N^h>^f
z|NnnK2r6s&TSY+TA7}Y?P@zNu5-8seI+U>S?|1+6ngx^zXTBEhcK-tsWS;q&$@mgN
zkyPuYda)Xo)&s=?-){(C`+f`ILuj6wz`)S`tNTVNlQCNI0H+11W^k$e9h{U<(?$1T
z?&GCwir^}>xAb#2IMMtE7f`JS>e)cjCA!_<oIW!sAUycRbI>6V2Ms#sLXt-JujZeY
zb!^Pw5bfaed%d^U^|SUdH>kUq7#KRinmf0G5^zZpXmMiqxduyvlJNiF5}+GQ9%D3c
zcx~^QW@%8u-h6<m^<?R1ZEzuX@yBZoaOsCA2Oy>2Yj)2D3x*O_ht`v&Um<ECHZ|`B
zH5C~6TS0r)y205E6sD%%4}uoVmvBPjO82!CXqq3&(|*kZn&}gS$SFW#5EOLX;96W8
z>;-Lbyh8Hew}U*Ts@*?c%OY1n8x;IsO#1r&fAd~Y;qbqNrS*UP{r}*g?cNJ&;dRdi
z*H_@g63`1SLS9TZhm}kmk&z{OkV1;3RJD6AD1cu}LTb0}(;E!@Uznm9{<wKBsQJSH
ziJy|v)&q5g-Qa-kY@P8Jd~)&sUJxT7i>=r7OF(by1klO5&BvHt{EUVc?xkjyV9^r2
z|64(_C@ux-0eR-d8#4xm=Di@Z7$PG}m%UbQ1~&))zm|e%2>1`S7wV~fpi{vjA>qJK
zV+8e7i6+!j7@-#P1ufK?_kv0yh7#fbTS1H$S62Q1-@FvWWQgnrw=%n!JHX9=mIEci
z-Mygp0;FK?y702-E7pcHq@afHDsfv0T97kgf4T$1zElT>cc~5xK4}gNGtwLw7N<Ed
zyi9Xokj!v^Oq_t){9!Ndg@XE_KR}1I2p<78(?NYr&@{Gh`2SJ?P|psu^y3X^)emTy
zMkxnmGz8S%Z9P!J6Yzrh2xwaW#Q)dQ;L%Iy`I3-Maj%O3OM}8+_yU3#psx6@!~g$-
z59S1Q#Wx*>bdIMVMzZ@QXl|etxhvicRaO93_CokDF<tTC7inM*V(Vys0~KCJpdD>7
zgvoLc%dmB{n-9Y}+Ur2ZLON8SO=8`#0<E`8*^LjpWCI;Z0XlVF>cyc$AWwn&J*kKO
z{|65XynF^)GYme%t5oX60)z@@xC+o26XE+ob0F6D%S2z)Ak@eo`v3oBKWJet<cwIJ
zm7smfAG#etr-gZShjM6N<KNC=)Qoyg?1|S*-6uc?e*XX+(D);&9Cl9ZF(z-&S+6HS
zXR4kkIm*BN0{`}d+J|172Zw=9Jj`GOuU<G10m@Yptp`eFUVJzRIkFIPa#IO>)7tUZ
z0?h~hfeteSt!#yy5er}13Ogj0zZEp33F_sRO1)Ti5FR$32Vr3Y8m;OEpAUO~AISff
zr2=IlFRBqr<qm=eB;vbEIcRc#tPVIy2*7&e;Iodw2U&s(WLJ)hKRlr0CV_#V?LVMH
zW{hul#{TJM3%5R863}f6I`JEH)MY?$@c-+erC^6k9J81LUR(riH;M$GSyp23zw}2y
z*8l%zAT_NAO0;@i{{#oT$d6zE-@#BJ3O=LB`f%ws&>2n9&=pITv42Xwfo?{av+V!>
z$k(sC|A%#(zL0Zd2sZ|Gv!y_N=(!9G3~9|jY)cs3!(Lc|X8e0g++b(7KMT%caSwmt
zej7YuAK59JqU6W`T9yUM?x_&7UYmx!VEq68Kj>7C$leOZ5~VDr@E0Nw$AfkzIfjJ?
zyjb)Qyh60~K&fZ*VU}K#I?xevrAPmRo%7<)(*OUPRY5LeXjW!8&I&s23RLeHABc>O
zk30MyeD2kYYhYC%CxA~DdjeZF`EuX?|7W`Yhy54*0xEPq7@xHM2pW}%JDg_8S0VsD
zRg|Oj2bBI0tbMFEf+;-sh4wAb$}7-vDc-REq8~tdkH<&H9S#l)f8h>2IQtoRHWO6v
zg@?U(0_u2yh7AH1f(8ki|1p+wero_FLB>*U&|zOP-yB>ROT@C6UhE72O<r{Wc(DPb
zC(`;jXh$^Y7NE!g$Xy4m2Vmo<-9KJ48UGJ^!4LqQ&Os><BagWlurRd#FX0J)acUp5
z;A8^Da_r$Ofea2NM}`--_92yzllDQ%$MSuk>;f&DUxFNoQa)xwl?A|+z4*MBxbo2r
z<R$Rd3Fts1Pw<PY|3HITu1{X`zxcNoZn5tZ_&Ff3fyd%~u<~#o$QVd@2nt`&JX>>#
z+zO5ossCjhFJ3MNk79lQ4chMz*~tbP9dlzr%4XdRjTYcz4YZmo1ei-zx*bGp6<8-r
zmWbLaf+#*)B@o4K%iu7Rv6S`2RyoiX@z_Hw3>oLk92g*nZ@@O@g}neRS^{m2;cqbl
zHGKVIx<fg-4~AO`l<+nm;OX57TE1d^yy$)7K``rJF^eVm@N#fVE`X!;61XV;3hHzH
zVlCxqPT&CD81nK7Sb&kg1+<vF+m|P}J1(KqFQMCmrTHfZe=BGNIZGw7yDp|V#gc=e
z`5;f@PmuXFZ@U?~>r!m{7#I$eavpa}X=Y$xcwJ{Z0mcWNn*BP@b|Q=qir?39wv%Ce
z(7C6t{cL+-e9%nkYdhP17#}pB@><V!5{%ykGGESiD-+bdUJ#$pb_<Ble%vjk4^)Me
zrDSpZzZBV7m-3n&<iS7?CoUnn88jyx3*P|A`r_lU|Dd7<bQBk)sF45_HK4NG22#*O
z$S^QO_Li_QcCob_D18MkWgcDwXUE7+TTmI<`oH9Kw<*Yk;Mc}sFVtli7#i$sBYPu2
z1q@^Gi_M^&N0FVN<^T3!!2vJkh=b}J(E4Wg=Ho2PpFx{^Py7cP@M7*lQ1JpXi=kN^
zTk!(2@I^UT6^MyiymajX7cZcjM!J0kf{hP^b+UJV>JH^O4w`piuyo}p;RLl#Tsc@e
zg*#pUG}tMXg4PJQ{@JX=Kjna1r|X~BHvidMFO_g~v2`#xb%yeE$?<PH9N_k%3DhKL
zJy0V2pB=QfpoFX2m#2&Ezbj7%qg!_<Pq(i?%k2^)@WGNR8-6R4ur~bWES=wasf6X2
z(|-m~7HqI%;BR@!z`)SOW}{HTV#8U==Jxut-|NR<3D8s;sP-)3>~`g7202jRKcn$&
zXV8&OZjKFhF(p4iu2lm~7R!UIDdFjLV{EWcDrM>Z@R}ENB88>vAO0x^I$i%<eA#-k
zM933tIa7?&fA-dsr5{0lVQV>15(?5>%3-5W;%&oO;@*0@#Fl^Gfq>RaCCV@6hJc5w
zN_e~2x_x;dp8L;^@ab#b7gbOt%x?eL|Fd_8^0>VW`~Uxc>!lL*V@wR75Cdrtc*zIa
zSLVtQ7Y*9*+N{9vpAmE*PH6WV&;g;wx5L6MWqUw})Um$EKl1-SWGTLY7HBDchpdP;
zXes^=(2~(PW{wP<ra4NE4AzHB*gIYSSV)vIcb5L?4*dg~?FtU=t^M+X>mR74^rQI*
zkL~~e|Lu#tx_!Si|NLL<)cxb&bEaMve(QrpW&tmrfu@N*L|T6?(S&Me{udqwGT<a=
zRKOKvfX8CcL2{koL*<MQyap`_1|J&*u3JD(hgDrSjK5jm165tG%hN24p;eawwCXY_
z{Se-5`{x1Z0*Wy0!(kVHI0OWTg>|}qfixSAl~@G42)_(2hyPd~E71xI1GO6dmwpKj
z3;TZ^blnZ8EihpoNJZ(NU}%-+`sXz#lnts?z-I}B?MV3Vz_1TQgm?eIvd;#5LPpq*
z43H`ifkzcMb_Bq?GMZC=fD>(S_<p}<4!d`Q?jy85Uc%dYxP<fjg~gyV<zA<Tfui8Q
zD9=L&hVIfo#-%_0i*h`4U@-mw*?S10S-|{W*AD^zMHxWqT)!B*elY%E{k@cZpZ_z5
z-LC~&KbP`!ALA8tXJ9z^K!E#0C-_jG@7Fp_LAHPw{xz!>fM$*$HBj>#lVIc9-&_S6
z!n!|n#@^|O{nr`$<GAY?P`%X|d!dB0Gxo|c*Z%^qxsJPD0kus!V*mHL-U)c&4oSQG
zt@qd%7<PaLv|3#SN`=0=3NSdZGnBGgy51>aY4H8u(CsSF{D4{e@J<E>h6A8M)`k*i
zj}i@!5``D{wt?1oH1qv`ac~=KCM|UvsNwqZ9s>hIr|*~7(%)PKI7&D{#xk%ol)izS
z@8j^Axij=jx2s5&K&1A;5_9c?C0g1COJubVmIySza421B8TtjBec!y6JMQ`hv~1zE
z=yBIKpkbNUJjY$%fPC_rxij`nx2wP|26oUAu$>Gn3=HAmlTEA-)*F{-SRXD?u|8fR
zZVMV6EeWv&-6mP8d))N}*p!gtt}j5h3%>R~?)n03fs-u*D+5D`i7f*g14D_5^`R2Y
z7k{?Ge0YB=%!kceK|TcMgyZ0=(-=VKfWH7asoPcHxa$YdP+05n60vSxA0<bI?-!MQ
zC0b5autQJHTj5Y5)aVO3r-G%?_X`69BSW+A8<v%zVWtvh&e{(v6iPTD@*J<ZR|u4_
zLpTC2d_YH=p8ns-W_`F+@kP?s|DcsPopLW+w}KijpnFwbSb?0z@G=2X-gMgvJahnW
zb^36e0pz^@r7wD2&jkE0ee=Kc3uwXO^-k9Z)`v?Ax_!TZHUS+_K4E>LRQsE&0Aq=2
zW9k=B&ji#l{?O}s=6@+@=>VEW^KLU-ec^wQ?sLG4Gh0Awd>3r_|Gyh_X4K0x76yj@
zr4L~HA4**an$i6s>_r>M6tFhXja#kXO4q*d-2(DA=y0sp3!1^3Cw%|IH&6Kf=K!fT
zd-1@9fuWnN`vPdH>=$b{<XB|TBC5zP-~SCK89RKKSTN)dK49y0VNz*OXz1|$+mQO#
zqr>-qY5li@4g4)Dm>3woxe73q6l5_4|2KOv>piIYZ$83f{kv51#hK0j|2JBIT0JEJ
z|IJ>Mefj_Y<$q9DEA<8gXywWckmxMX+BMMDt5T`7=Gq%lrNZ6EX9j^}93i`%tPhtQ
z0xuvkdtnVaeDw&A_2H5Y-(3GU@V96%F)-{0Wzn6WrT4A10;T-ju6LA=m$GvD3cP0K
zbQS1!6;M8IeXzvE7L>S3G;J9i7#T{GY#A7s7{ELx2#<xK1k}o8VJMY5=K7EEwM4hC
zzz)!{li*aqb<Fi2(`%MvuKyUInU}w14I}7Ipl`1K9Xe~D@VCwdwK!eBfC~oYgSHF|
z3=aG)pv|)&W<yD#^+EpDO0b$2*2nqV@<8JSKbXq+nt!mAX*d61<!_A!P2ucw{b&5&
zgTF<Nk%7U3ztx=)bmHif|Nj^mvY1{9fi}1?g@^w)d-2Tx)Kn7SK2&lh94zqE0F>{W
zj|f;F=5Oiy_y2zubFb?YP&itER{ViNjlZP~6#74yO0t@NF!Q&9*6ugfK6$@;KSOB*
z$k*Tneci5L2ZAn7YyQE+-<AnF<LU<se|tD+Um3*q3YhKuEugIi5Empv1eFh2ALefb
zwKZR|gR9>ss{j8pFxdY4&%jVB_229T==6ce7jrg3i;&LJA1~t>85nFqo-CCP&tm#-
z_9E~txT^{B%b~yj|AT|y4(v~Jh|KF*$6diL&ti`5KCFE_px4C~?At^|P{8njmln4F
z{r{i&hxPsXyUnNnce8=djPK?FPY#1}04QBEs&sJ}`TlEoSZ~0AOGUS@K$pP5mjVYK
zvNt@c=Q`C;`<J1Eqf`-GnoEOpflT|!3N;#>Ul>^$I22Gyk~(lnQUS_{kc;vd{+EKv
zk}PIW8Px6iMHN)SfL0{^7X=kn)`v^sYmlaH_z!kJR(llw{Wp8j?#RFp`EnuXhCZ|I
za|hv$fsDv?vha1g{&*Ss>;Hey7Qx^bRqOx%Ka(Yrp#kc8#%};^dI0TtIM7`x0lmAb
zRQScu_0TAKF?T(vlz$!B%=h2;fMqS{tZ>lnR+hCgCH&p4BC7TO{)2aSIh360to`#J
z>GA<k8tgvyBIXAuK1DiRAHWu|fKET?c70%dyo4E4XDVy}pM%g{Dq&gsq(sBA_CX0a
zWI-3nfKT~{25zqlBTEC=$I4C&43UtEAG}rdKhmuSFBCzE_6Yof4AACS7VsuQP=lP~
zzpp@vDF1fGwAKS9ylK`<r5vCWfetafe#XC@k$*dv_CfHXbkM<tP}~h#snPAr0X;35
z5p+jZ?BQ-l8|H(J7T`mY-y2_o9+T`L!9V3t_aPJ`Ao^W7x;<=|Pw;Pd6bTOF-(JXO
zd?~!wg+l^#fJb*NPqzn;_0J;C?g$R%o7TUJxSW~~Xjoq>dI4_Ip%@1_?=b6Mh6j@)
z1LSPQg$xV~3<1q=KsQ)|8)}BGKa7tCz)w%?Onq_O6|^CfAp>-<^9wC-2!T$S3F&s_
z&;^MFKx6{IGN9XJthyak4!)58exdmRBQ)NS&tQy;?tU737<_!P@uf!45z+_1J_nti
z3{?)=^ouyO5uyPUq>$6^LP6zv#)~!w2GG(mAAbghSm?=zptV9M=k*zZj}r9wV|?O8
z#3b-}eFEJ98bRFwDnTzqK>hP092m#-fes;bQ4t6Y$oiM@p$+})LC}SlERd5WyIoW?
zKxYpY@PKy8S~b_G==?8Xvo2B5DbwvWDeLCh-07pj13GrFW-|*zsW|vhtZtXh94|aU
z^PnI`JgBd|9pr525tYz`2aOM;bc1SThQ>-3kQ+(`x&wK-gLo_hIZ9bU(>e@?g9CSe
zkac8u%?)LAgY5F==yYc3%;pIV42Xz~jf_6T!tnnBB(*ocfwaVpk9NBL=?;|$26dXO
zFW1R;yNYz5^0bgB;c&1%UHYy0<p1tN+6O(X57ja{bh=7(#{RI3RVn4}cI5yaSj*Ds
zs?u!=8n`q*U>U0s9Q?mjf`94(&}<~jQBVUZ;D4zKWE=bk>)+s!ksw9}2G}J$-=UZA
z*mJ-x;juXP|9>~yB|O<v{{N3exr7IFQw(!w>=(<}FC}Zj!A&pFZ6%;AtO7Z40(6CU
zw<&1rNN_Mj0eCOtHSn-1Klp?SaPzj+SD-|*+f@NnNr0*{(8109pn2VZ|D`g>8o|pV
zyK8?~|E_a_9F7Qfyjib{J%{zda<Lb6ppBq^tbdne9A^hzAJlxD<F!=4i*=LH9S<4i
zv;JLT|G)G{`2W%mVE03u*Lt8tDLB|NR-u$7IQTW&|563;ewZKO!Ju#y1@-wlU4MkX
z@SFDkKj<>x7p~L5ozuwP)F+@+559xBrXMtu11>F^K^F*dfX<+knF!iFpwSDu&{qX!
zE-28zi}H8^UOWY@r#hm7G7t~#RHIz`1WG92R3L+#3S<zeKmn8rM8K&)pckGBWI(CF
z`Zu^wTVH3>`2WNI|Mlf2px}eWz0DcSxX+)25qvjVZ<p-qWw8&)VhDcm;yS2K-~ojX
zX#E)|1;~I>K#Ac0Qi%Z2<t+b2LD!{py8Z}$Au$yeScuz}{QIy3*86@?V5xuu3%YL$
z7EG@}t)C+@*n$Z(c-i`mza^QOf#H7{%L{#wDP<fl)WI~*3wbat@Io9+i@e|m(-JS(
zLA2Qm1`t)I@Zv`w=$uED7azd1#)}tVTIa<BFm3SS2ADQ^aRE%ryf^`-EnXY|(>5=5
z^nrrJ;eVOKi?v`OmlsRHw8x9NVA|)!R4^Uzq8Chuyl4f}5ie@Nbj*uVFrDxs7fh$T
zNCndwFJi%T&WlhmUGTyeOqaZH1=AHTY{7KR3sa~Qwt+fsFVsPz+du=8FJ!<>&~bAw
z1i{Q6(9RY%FcUP~`Qmpk=;SWYB;Jb;VCD>vf~R2S91!ysm<c+1<HdO}a|uZF2$;D7
z#M}vHf;O7JSO;c;58zr1W`a)ddNBjc1T89m(F<mRj$e7v)C&o<ZJ?pD7bRc`P!H}!
zCYT8twS5r>W`eGKei002f=Zbe9$+SDeD{SdnE3+a3?ne}4Tz}@W`d9Rk^wV8UDX$Y
zVCEN)0yZ!cbOh3i-#sAzgR0mUAHYmdH}l0)FcWm3#EV;CCTLsOi}O8DCxdpDy*LP#
z5MX3rc(D!46ag_;gP9T_<^nKN2E?2SW-5S~U0|jPh*=M2YJiv}U?%7uw-=dUrU6Ja
z4$L$GF@wQO3lP%-%(MY9ZNW?j5Yq_EbOABd!AuVjQwHW_9}tfZED-==GJ}~RAm)#5
zP!L3bm~X+%7!dOjn3(`#Uhf9^TLLx(0LgYGk=<<8tl-1p*aKc{>Hhye5_};i59qi!
z_J9|QAR-*rtO8Jx2@nwjYgP-WNF7+D%*5K%1}qZxA_pXbY7u`6=vc#UHy&$N5wNO&
z7j7U`-EIQbtP)TW6Nre2HLDC%L<u4yVa=)l6%l}l$XK(gKt=v_fnBX&&8h(vc>@tq
zv1ZkQirj*TSXi?<Kt)bKL~N{CU7#Y{AR-RdtR7I2B@hu8YgQkq$Rvn}hc#;eRHOkc
zQs!fA8Uhvxdyxkcft|j626V-C7<8&FARwSSl&9B|p^J&@KnZ8_Ax8eyEGn-*c9(KA
zpZwqJ$<Ta|v5O5Xb&QdJF^fv^yY7R{M-*W9ICY0|goT4fbs>9Zg<o7+4C^M8Ee3ZJ
zjKPNmm$Gy)y?)gFN&7<=M+Xm^LkoCI>F3t}rGm$p7+%Z)>4I)3JqBvwqBL;3LsVEm
zhb=>|SG4J7vSKXN<2q2HW|hcTs>=1GME2kd0V_wQQc11@C4yFo%%uX&2U(gAv2Z;p
zz102R_`u-_(g!X+Xg<Jr`1>JHYo<h^i>dh#qZMQ6^X7w$Tn9?-d_M#l`zl$I*3Hy>
z2xR^_t^*~<K;|FidQ!5t`5@El4p3VaghRXEgoBo7cl!!-*K%|p?7ql+%=%v$hxHHs
zrUjsLReyqt%OV-rN_OG!u;%Cd&CmF)|HZ|Zvc42{U|{%u95k|4Dsu28Q}ZL{=ARrz
znxB{cSDE@@k^@8c@m(Ov=9er*Jk1Z7nNR#zX=Rz@!0=zCmtnF4!-W4Ty)Ba*7$%5J
za$s<n<iL<J$$>%nVi#KndzTwyhdX1J8`Hs;Odak_&BvIVkAn?A12??a6QLHYiV<{6
z_;DtX6PCeMO@Nr!e2fv~z~hV{*$%jDuP4LvNe&EGCOI&indHE5WRe5Jo=FZ2TP8U$
zteND%umt1>m%b;RF8xosUHV>hy7a&3cIkW5>C*qE+okVAr%V5bZkN6<oi6=fx?TEy
zbh`Ba=yvJ*)9KRxr<VmZQN_Ugf%yk4H2#A;%`w@5L1eN6gT`bBhHh7mxcHNYCxCp6
z%!c?LDgsK=$RX0<&IFa2&|6~or?<xP4>S%`KwgBz0q@_>OaJ^=nc6c2v_R(j&HpOB
zHd7oJdOhKB@)Hs#+Mqa@Fc};tAjK0FOm<*6GTDLQ&146LE;nZ7iyiLF&F{dW_Z}R2
zn~;nKxeclY5m)b+n%{$Cp#w?f1ejS}ZlDP5as!#z;m+9nj=A|gC}#PaK=Ud{I(j`B
z9Huxhcua9%2$<r)5HZDpAz_LGL&g*bhJq;$49y^)x%A0&y7bF*yYxwPy7WtQyYz{4
zy7Y^5yYvZky7UWlyY%sNy7cpOyYz8%y7Y5&yY#Viy7aT4#tq2Z-T&uIabQ?7#ereV
z6bFVAAhTg{<Hp?K&I}E4h<`iWnIXP_ih}$G7ek3VP$omdppMk{gP<%?qSD3Ke2}r_
zK#3njp!7ZXVE5i7Dxe-Ol<H>O1-?u5Li30J#)p~@vaDnPU8VY>+wo7!ffA#ZCnYK?
z85sUEln8@PBmQ5)^!jYC<A0DX+6NE!I{t&R{=!**pe(SfKo@BfE<d~fg9}ccW@y3r
zvDfWCq~y%v$jAT<wS1ZP|No15>;C`mcBp7QP$CAJ{`-I7HM{Wv2c%x}i{~~B3@>=+
z|NnnD<G@tVJU8gjy~Qfpjtr14An5cY4Q)q;#X2Cu07RH*!w*veb?|s?emXFOSq89_
z@OOXA{>H;x%F%p)$NE^&o9vT3%)T6P)(4AOLDJy6yZ@Vl%zzxfbT~^PqXXntk9p8x
zq0ZVHpt;fC-1XiiqTPqHm_XAMO4<iYIJ6IzL~0)_b$$`F7BukNS$hMtniVup3~CPS
z137Uah<F|PzdWY<GUQ&U-U5zpw%38(hnrvUml!p_U@KAdC=q(mJ@@~A$O5AmdUOB(
zf4y@b$W04D#A~sAAdfBt5wE%SfxNm9L>zYo?Y(3OfH=I<^?~t$=Gq60{4Li&x5&Ca
zC}q!LexbYh|9?x@Cnf9wFK+AsopcGB2yOn&QNq>yo4bUy`8P|cbhm#(r|*?c_k`x(
z9Hn;M{wbZl7mmB9fLgd95uI*cgP#rzoxXRvc};#gFffC;mcDmtCA)p^WS`{e4v*<{
z5#;#qdgt}s7yPUL|L<gj4uHG>jdOv_kpEwv68t~(LF8-6?pTiQ+8dyorAj!m7+z$8
zb`u^3%b_|;u-g^pCbn+Z3!UyM#s^+}p95NZ0UnNW<ydTk66=c{5M1y=CD74!;jnY*
z{(}#;1D$jC=l?a(!C?GNpcM$+|FnPiy0bL@U@0mMezCxcfuZ|GuRBYm^^IbW9iSEN
z);Efox(_oSwmw|M9{`$t^w<vCVAOh`RIJxo!1{2J9az)|Dq5m{@IO;PugQ-8qTp29
z0Xj{ul%v}g#QT4}ldbs}OW6PGi$SOCb-QwamK1`gkGlVdWwB%_yqLEQWIE{hSA>4B
z;?{4atXUEfafh4L7(h2vgU)OLrPBqo|NnpSaozv_;LKFY@d9)z9`bp#p!GAL{c?L|
z|NnpZ#f5dS00a#>ZT}A$x%_@361>JMEZq42|Lp~!RoGzbJKI6*=Ho2Q|22x9fu~Ht
zlc6f$F*e8$j4MZQr|W}mSDvu&PS+<d_*a6Q@`j<=)<xS9bhqe>(%OtAKS9}81T@hJ
zKD!&#*zdLlo%5J6<EH~dFlcU<zXiPI9(=-P!2fF*9UzItAVdCN2k}e5d=JnZIG7&+
z=KH|-i$k<QH;0!9WH^8%z<L%3Xge}21QFf7FCeSktq+#CTk?X`me>b?j_U+5yMKVr
zEo}W?qSJc2L<8iQ63JfQJAqj|y}lm;vls*ZUv526!uHMe2V*H`qptu1g95{A<Aor%
zSi8O`(F7kBTB7v-LZ|DS)&nJy3qh^|$?!vDI6%{EAj$uxVE<eLt;`4a%b$P-#7p1&
zzW_=I@D;5kb?~k|sE>ehlu6P|SbLLgCaAp$KFS1i8wF^L3bc>mZud3N{iG#q&4-x$
zOTV=KFL|zg5j5P}$->oq5Ojel;&78gpu<fBKqf-lqN~7zFWsS_`;<k(AP2@=DiyE{
z1s@m_54xcPx$%2-2Fx*)GeC}ceHXGIG_8~A^#$-984y=7y}r_YsQLH*Qi<+Qpf!w)
zX`L*5P{*kIm%e+g)csNW6aRJ|Hs~GNpvyJ<OPIY&UxU`_fzEQ^X#LOM3Od}+_yEWt
zfo@-(tbnvm7q5R2FG1G>q;)dAa0599;**zIpovd#K>@lmwnDD?CsQ3y^H1hdk%gdp
z17i<^sZL%9=LPo+c=@|-I&8xzNIPipNhvqzkdwI$|NlqELhqsloqNLZf~^i*q`vkI
ze{BH1Rs?ieaTddWQ_$H-|3xK02_AInZJZ_R8VyH=5{IxC+#A40sFuh!|9en&I_$;o
z^`JS?p6MX#K{NG`&cKW6>7ZjwVH2m?(?Kg9*j_(+k&GfP3=!`>{`wRo;(U36LFc)a
zA+A9YDCU2mhh+L|NB;G`0%76ZA1z}!O1MF#z$#PF@y0hmZhyf63br4h6WB^btnU>I
zXnzjNVqm@>{KDcWsPD=HTGk9Z6l}*6DF%iY_M*reD?#M|=*kA;|DCNSPyhe#+-m_Q
z4W9o0Z&@n<N)9jAu`w`MA1{@Ev2q&dl#dtv(?FgFFBvwP1`hj|-E0hygCV;A1^3E;
zPrc}7ZhkI*@HtzTkA(`;$qPR_=c+vY|G%Tx{^|e!4L_MmSQ~yama2FA3Vgo^S_~xn
z!W(3k0>cXfgz=ZB{{R0{mW_eon~MdDLJ2?ULR!#qy30gB(`Eu;FG9t@D}DG|W`g$c
zFn@DlXKCPX=>c6m@N6ll-I8N`($Yhuw^iZk|Ns0`4hD2H|2JXp{`g;10kopyB<Og=
z1SSRs>yITo7GS6Gw*)XTF#H#l0i}hx;2;5OHa^hVssjoXR{{PuWmeGk3Wulv|97>5
z{L^xPzcn3np9^>QR*)}^4>bJb0<D5*m3a!93u8XsTw%dbBH9&T(h>Tl!}n`*f(1hs
z6KHF|Yj6I22LoO_mjHXD#Hza&WT*CNW?up00}j?F_}f6o8D}x|wz@q1|35h3MYaUU
z?~p0ONh}Nu&i`9M4tXt|#TX1x6!5|wNe$>w3s7S)i?!GHOJEjbZ!gH8z<~c-L16;b
z{U1Ey3t5e53pxdZp%?7ifH067yIVn?>Sp+F!VWoH6LeSt7ihZ~*y`?HP-<a5*x3q7
zJC<8P!NlM5jTy9Y0px!M{ua>uY!=K+&}{mb0GOf2T)*(57`zdz5o8D>f6oTc5N9jM
z{QqFnUxFs+Z5T^fY?w+F`L`PzpKSie#XsdB=+ptQW0*R(g8bLn3$huiFz7#6?8RCm
z28PHqYj8;Nw|au?0UOHHyceXJp+qx_HzJ@DEdQbbMX?On9U%Yx2fL=*RlpK#AAi%&
zzyJTg<NzJC!Pg}Wab-sczezV=rwhNu%lAy6`+d8aK`FR_zhxm414F}JP?}-r1V;pa
zD`+sW8=TTCeFga2{(@5SY2$C&;DpfI>hbjde`{ZXVzn+|XUERDph#=@#Z}4;amO(R
zUI(`h0SC9nfB%IU7>cfTe}HJw{s0PZji>+r2ZTXH;319@+Rh;BT0!a<!C_&2jK9Yk
zBz9OETp(Dx3h+1O{Qv*|C1}4N#OX}@t)K`+a<m6%FW^#8I%McR4RJXr$%5P-2XeeK
z|8`;Kd(7t`?r;9ZRVu}}6%?ykywPc$65U{LF&|^x3NivhrgaK1A8XtT68H!5*$z^D
zmI+$FfabGAkQlPh+(AAA9h=_`_ANAzgW{nSq_h{544WYyL-N+o|Np_>vhJP=Qoz4m
zh!LFXna_c|#s~2fPVcN>V_+ycVEipCEF+YcfuXne!|VV51ABWte*XWjeGt4aGobrm
zKp6Ct571mp_YLcN{4LWN7#QHO+I?92SU_)!DM&N6s4d}P-U^CV>wER5U-Lj}CP>n@
zzE>a94bI+>D2C))a72UdLVj%@*xL)z83=0fYy}lZ|4l4l8NWod8yu$1OF`L;0iqYx
z{AO?+!cdyiycevdL^q2y&JvsjOGRD;P5{*&pjPgS$O)jsF<#q4vuErC(4GN9Sit})
z%pFSjAraGHAqAe%QF$Q<)-MAZ&X$}2UPuMn8o<*HPQBXT%oz=8nHisrdvUu2)Gz~`
zuK{X$t4=^#w0^fAtoOyCewcGW9YN510Lr5EZBS*i;mTgv_5Ua0e2w526G2yLf?D~Y
z!%7TTkWSCY1FtXO>2!VaTKt70!emc~W!N_Ltm_B$13;%|+yog5T8RGw<fp)XxSxby
zeCtE@3uulV$uB}LuEV8YRQ3J;|N2%pt}{Z|z-NS<3x07{0krc9x-p53g|Wmi_(cFn
zEa1PW%0mZ+)&r&7(4^)11av#i69#ZkQ4&1E)9w4DljB7K+*)iNyV?iy7z5a2;C4~q
zH)kG)u<j4tprx`Uyv@}d45jSdt~`uvukD)E89*zS>kPVGIl37B`|@<3eld0L|NsA8
zIhyVMm-02+YnAeMpWa~qqJHoH{~)FHS3&n8uy(ut>12nE3lnj`1nAs{&aI%0gOClO
zovkZC2O_k70F$8e1|U0pVFyfrw#!2gn2;#>|NlisFX(`YIj{pJB6~rR18z0_=>hGN
z18=G;;pzr&Wd&WU1xkR4NC!;Z+V%f`B&`mZ_y#Iapa)EV_wjdby#eyr);(Ynv<DKh
z-M-}#f6FE=1_tN`f7l@tov4RQY-?EX6Mo1<cQ440>;s(q+gdmd{B&T*;yCz%B@S{1
zhxIZ3miM3)U+j_Ah=V6KZE|2RJ^(v<0(>k*CwQAN<oE_y7(>DywD<DmbHvdT9-yNq
zOtg=Ij}8z4pFDArlYxN~d{PCK51wfK&)-S%!4u6(L7TuCUK-;*c>-jv2-3+D9Gnac
zkWIlDCr`ZPz<%<?Rn(Iwj)9a}V?B9dH3#fm4uO~R;cSJMlQ{^VJdqDNF9Pq$6TTo7
zDf}(2AUc!3#TG>8^S79S=u-X`T@YQt-=YelBlufnK`vMdN-_-1OF?nV&<j3v1#<Sp
zRM6EVtp~cmn@-Wso|v-}?d*xE=x0w<?fn1$<!+?2C$@tYF1Cb%8Z1A8`TIf3qDwH(
zo>&1pdjhn<m63sg0g@SB2Gi&4iQg=Q&z?95I(Fej1b+*tZ3;VkVl!wZrU!p3Xn{0j
zUoL59PejRsdKb{MCqN|{$nS*Do~Q(M22jqPuz{RCVfr0hUV=vE@SHti0`dwZ>R)Q0
zA3iY;bT{-%&^?^Zpu;CXr)l%ID1qZImA~gds1^Ssoxg80XkFEh%#sSw;S*Zm!zUi2
zA3gyo;|Lr)agP&n@PrrPgC}4CMEt=McNrNNnE!RV|L6|?^O6(P&ITWN068Sb0eS`l
zmh&e-8^Eb{^2CybNGDH#N_x=v7VP8+kWIv&JOQdC1O9`Ljln#50%R0vCr^Nl!*}uo
zOabAOCqM;BC*&lIUQosT8glAH3G~#7XwdQ+(5VyqK<#{RBpe4<@HkGLFa@7F0Wt{p
zsS|?#5T{OvgUl!I)CuX<OZDR5Qzrz!-)O$XfdAMDXqtf~4sd=YeC`DJNCl$KodA{h
z&7gB9K(X0<1AguVC@2V@JCO|Dtq4AMA_C*w2?x)#W(x+`!4sb#he?og@B}Cy((vF3
zkk4@*JR!Lm?Fa?f!4sgCAGU)hq`v<D4>_0t{oo0ZJ+Dy?p4hVq)o^?VPk;`Q;NQ;n
zzZb-SA3Om%J1GEk@I-?ov}6YzJOL5~9XtV|yZ0iw6mjrGG5BZ*kXe`qPk=O_9z5X+
zK4c!-!4qIlVH`a1cq6LE?l*&v-CzJ6JOL_^UPNbr4xRupu^c?X52@OWzja-BnF2nW
z1KfHj;f0(*!p`5?`vq$g8|^5H-D#lyVXr5H)hY)D^A!#ZnJXL^j;?TE5M1fNAiL6m
zA$g?(!_-v{4B%;1H~~88n??JC^nvdeluvXYQDyk>|G)K#BChU(kyE-EI$2Z>>w@+K
zwKBYZ3F*!RLWfy9U4L}D3WSGsy8d~=Da^poeExr=_3=`{7dDNc&H<=X+<m<J`fD%H
zx>nymf#BVAqM(B<K+8#wmkLArTCE34I0IhjHG;a!=W*@g`3t&XCG<~x+{wdPA{iXa
zjtnnU8vp-qKK;Kl_D*N)1JM4=AOA{aUR-W~^n`abz};}T`|?Y0_whglhc);Xm?Ehc
ztD)*9z}3AlZutNI^+oVbg<c!*PKE9dkTv|>{QUcT3|X2VGL{?*c+n<=)Qtpng=LUe
z-M_dFDl0(;>)+`NeehcHg&x8NGl-=SC&OkbLF4Y-u6MdaAH0~>@c;i|(4hDskQI>m
z=Krh@<QyRvkiXbD3$)V7m!s1Wv_zb@*^`IkxT6Fpc3ulMd-AaKI*N2Uf`mY;Yq}jd
zniE+VIvJtoCqRRU|Ha&TSkQo$<+mb2Md(EnT<V2t{r~^3?{%L*-}k`3&xMht`GEt}
zRFoCbpbJ5GzPa%@g!8w8E_(`l@np^a|B<_4#|r9&y|@e#09{n06!zlyn*aZiPnO=k
z=Kud@_{q|*nYs^mIjE@A+c5FBfEEXay_g2k{J%sm>_r!Z{jWqR>_r`#L3ua~V&rd`
z4>}Cwg)c-i*dRv;8*Gp%nn9`<27Pm2X();PU&_(z`X!4Mw8lT+#b?L>KB#g4UwZdC
z*7(0=?T0#p|9&hLLfvd#KDJ*vIJ)_u2VV2>?{l&J5*F}c-2%{bE9gLk6YkcvA8Ib7
zfhJ`Yn%!9bRq%H6fzHC{WNc<*dd&;E^DZpl#UIeN??}*i5co2vQ%Rr<51tKeKEY^w
z(vmeo+mV5P%0bwz^q_N6Kuf1UM`D+VTE+^L2w2F0?!)G=K3u{Ip4c)z06H}UoI^jn
z&`SZW^!;ENAyO*W?Fv%F#=ng(t&;=!zHH+I4zEx5x_$`Y-^Ld30<<<X5_F_zE$Ei*
z4$xxo=AVpps+PV2H44U;EMqzNrydIWU&;{}mc{wMfaSj^XxV$~fo|6ir2^f)0@h$H
zMG6*ij3v_D4Iup%v48km(m+!|zCS=W_Pvby|NsAs=QW^I3p$J#*)gC|2J8QzGY-Hu
z9SHbe%F*rmA&U{!HvU#C(CN3kzy%m+Cn0#<cqs??+=b>Nu%lVQ>%KwLt}j%Q|NrOT
z=E~9S`=PrNwCI(8JBy<#Lj&lz=|2qcBUhj+y+I~&fbU6*j6_*W2P$O4K-(v{50q+j
z`=|(XyQuIOU;6&B`$o5m3di@4-5<ISe@{^n=swYX3`8?ueC^(SqB}-Kpc`~-tBVT9
z#g`XvUwn1(2KUL*FW*0RfB2rFBGP@L+eJm-`!nW?MSRvFDm>*JMf}z-Dja2;e%dZ7
z0@5KWBF4A1T~s)vLsWRa-}-)|`4&U>sqV|&H$nEq9TI??NA%4Be4c3q2SbSzDBxab
zfiHI43EDH3W__@fwVCgK?BV}x(5#MU9LpItj%C{I%E7-KG>{e0efY&R&~_GA4yI<i
z|B<Eqps_50Ec@=mFX}+&q<{yrE?^tXssMGGT7(=Kz;pb;-LWE|iD=^kp!1QsYk7Km
zw}5T|-+Bc^&V2$RTi1ZeA7JtZnEV1J?|{h-VDiH6|NmcjC;tEcVs;gHFzYw;wA7v|
zP|^YqX6aXfYT5(8p{J$p`ThStY%uFB7XyRwH|u{T=lQpbcW!+FGIQ%2FnI(_t^ko!
zAN>CRKh63Yf6Eds(8j??=AWH=7yJgFxA*)1fBv2d$WT*S^N)yfe*W!;_)!O&wt~!p
z3^o}c4>o~>L4!^HpdkIh&fm@pIpdW3C}gM!<lX<BtusJwXodI}5)P0MfP@Sv1YSM>
z4K-~CpK^*AYSKPf0vT%B1|DhxDSx>gJb(jYvb<akXEVN>4?g1*Bo115`EmkCM=yx`
zvXv8b7|t)PQtfW$=EE$V(8vKfr1b!QXBylPmhW>xf-ghB<3b=NXk2JJ^oUas|D`2J
z@luet7+&ha%vD7(7bFQXmk*@07sUJjk_l`gh>dI_i2w3A=zPuXhnjzQmIOBc$S84W
z{*hB6(fp&Fzx51wunFV`P~ZOLUJj5y>~l&5nSVBdy#}gdUoHa;?SQ!gFK5Bo3NQP>
z2D3N+Fe{ZzYp!Q9DHUoy&H~lgz`*b_7o_-yF+|n~BD)l18|Z}7m;PW`=;5Z#KcHhw
zpgw<#30SI>zeO9&sNio=0y84`TO>h@rJ!WN(A^5k3PHW#G<m!g6w9EF(+hD>c7FK*
zG+YGob_##LA^5Dz{ovt-VE%p?Mh1qGdhk)D+6PObAj``5TOYDAFf@aXDg~t`kV&23
zRNV~@;%0CFIP~uQ^ZWmQ@KJ!Bdq03v9Vjofp5*WBV`5-9-U<qG(5aFy?|}!IK)!_>
zaC#Cnv;j6m;pJZN>83EbQg(>p3f+4_x|{$1FJ%Rv%GG?B<y$LAl>#J5bw~f{oC~s)
zzvU-rZ0U9>_reF@6FxzL%}YTpVd&lp;<Wzf?-OKYU;rJI!r#Kq3Ywt;6(9WDK<72H
z{rdkOTzfIPx&3biX|vo5B5N+ZyaO7=0S!pqXJTLg9fUd+<n9;j{4HPpfo8V&TX(TA
zFz{~&C3NF&ZZP+41%*Dum7T3ieuJ*r>u5dk8+5KE$l8GJRuFZp^(3f>`M&{F-}Qp!
z1A1FQAsX<)2|S-7(0ZVfzjG@nC%<M->jcX|RCKn2{M89AdS04=hN?hLfLPgjpu`F?
zRAu}f9AKd23?8Zi=_wJKseK5MK3;wVjW#U>Ihf%k=x9@<FbsI{_3HoskuNWRlz;}R
zo`MG&&w{s3r}Fpg1B<8g_dN&gfBKPGk_Q^7QUN8})<xifDo}JabZ!L|hb2kSyZ|~I
zH4I)bbVvVrVgLRAf6)AU1$cN0qz7^?DyVc#>tue-(cKDSb}}Ca7iyry`0_g_X21!^
z;dm>^e9(!gQ161zL!Aj4mb%yN{G&Vg&&#Wf3=E}0Y0baVOT!_l5@g70Z|f6v9G&1)
z+I^z&Cur|loq6v@$YG}7c_?t2kL+v(73+{8B~Tbb!oB;)Yc7akAdTJ3kmX&?hdDZ1
zCxG?=JOAlyoq~w;|64&h2|T0(O4yLN3iuC>!d|eB@BpO4Oy`2a0d$z@V^9GLI?NQL
z3w)R<DDeb@BOhj(*1Q)K2B6bSZ-b6Ig{eRqQ?l0uon{I$6tpeI9g<(eUrPS_|G#r9
z$mrwX`jZ{Bk5UDEnrZbPa1w8s^Y8zE@C?K`&}MkBD#(Zu$gl=T=tIsitpQDf7(}FX
zww?h609a}BfxxuR)^ni3p%+vQy$lBpDM8Yu0O+h^5Fe4ZOJpFK$N>^QphHca!H1eU
z|C#w(94goC{HFwZuqn89feM#k8)gDI669lO+CVzpv>9B$Fx2uuA`zS-q?*A+GVFL$
zP`H4Oy#>*r^Gi$F6k9=_=-v7obTAD#<@^Vih{z|Lf}#R)!YS*w|Np@wO+BFSK#Vkj
zS}Kr{rdE(a+Mq*D!472tt-=8nKAqr#t0WH8pXff;U|~=a{J$5J_PW72A5u;oV=#Da
z(+Vp1AO|`l<PjPCHK#v#NQ#a5VC#R-QK%qA7k_ku3%cgLpt6O5zjXy@$PgSUD;!F+
zSAqhpge6P&HQx%x5|%9O*K8}8N<^|0BGWp1K~Z}g915Ti>)s2hsI|cbruJS?*mQ!E
z;tHNpmDh5RN-0YLQY-nt=mL*yfHL#{Nbs4a_x^7M>FM4(2NXbaK~-2UIPnDZg7f@~
zcJR;=C~QDOOZt$QW+_$c2HWylD$4+3cK2cb7dq&sKWg3!F4#)5yXS%ewe@ygVmG*=
z>IIj;(1I9N0)tBG@Br@@M?ZlUnhA8af?}=pK%L6}tsp6gXCT(SIPm5Ff9Aa)1(B_{
z>o>gCYwiVm>$NH*M?-w{9~_I_P=A3Gyx0aERswMtYK);CD$#;^2qVbC!Gl&H)vzFI
z-U}*?z~f3F#tY^!(6|za$q?BMZf16aa|Qo)cH?iI;KDJ@`dA5j_l1{*UqNk9P<sJ1
zumqyn`CA#mXPja*cOiu?yq}pA0_tb>dNM59<G`?JmjlC<T@DQTyB!#+cRMh&?{;7~
zyW4@`$R5xp4#+JSVd1R@Dk33cEyaQ05f$)I3T#+~|KKyWW*ff$rKZpei-Wskc}nG)
zUoeyifR0Nq6%Nk&@|q(!>+5Ug;H+=|MKwU{*VsE{*o+TEzZQFOI}g-g2MsX2c$^0w
z?|~kn2JYW=`*J|`WuLBzw&n%h`db{_eemE9*6xpJ7d=7l0WoW~G5B9%0Ch^KtoG>=
z0nZW+PaLjj=3)D9eBia{i%^6sV)MYq^MKBAgRM`54!20WaD=$<g&JIW^NIhlhmpoz
zq+ZBE)iA-;yjYt1|NrZ&kg!8OH{+WN2Mc4#*=`n&*uz;o85*FWFv-0C|3Q1BK=%rR
zZx{yM3~T~kxCmXRZ+zP_j-%8xi|d7dFK9Jq>>m(c5_}UT@?FEF%$>1M{=0F&2B!=_
ztNCM}l*oebEQYLsgr2Y1>tX>qs5S<4?xX9I7q@c%|37SeyStVni|d78&;S3>10p~>
zA}|J#dR-VndZ8D9N@RF|d=Z@c|37F^1?Ya(J6YT>9)ouJf$q-)b@D-LowB%JOavL+
zS^EccGyH!C{$6WP;bpS7!PJofw1*gU1Wae?gKieE2rH=dWBq}@c^c^KZ8sLi(&*+o
z4u(>TEUp)z?U#|px1Bp<|A57$F@u7&GxpAFX3)LMsec$=Xn>l3wRadw#e3s;f*}`q
zesg1CERha|++^B(%;9x&ckPYt(g#^wFZe-@Kimw`@a&iy3u80ie{G065B_88K7Q~4
zEAxlW(kIQJ8#*i9U+RDkcmZ8lE!_@kk#@R1XgyGp*vkX<M<*ln^6GBE#zSB~9V!+-
z=D@<x%<=!211nc^0tZ9$0f$c42e0oQe9qcg`ve?Y-RGMh${&2l292*{poA0t0<_d4
zvh_eI3n-{z(G1E;pk?}^IiPz@xnBf=wlE$}<9~l3Fc@_IA%E+E()#X0&5!C2zF;pg
zhwl7I<F98-<F9uV01*lx!T>}#fQSGPkpLnJdOJbQ7?08mt(Qv7yAK_F!BWEinz`4L
z0i?gzQ^2G2Tk|9S5}EEp#<vf?Vk+V2l<f6n@hbh%{D8THtwYk$qx4sF#NqB6-)}b`
z7SO(Id?2X%a`PjQ9HXOG>92#YL3$W_Jz2a<e?+|u1qCJ7e^H%>4h)NPOdT0uhg2d)
z!@|331*|`p3R?dz<AscKF?C89A9!62;V?II{0HBSSYIamB0uXt^!85SEbuDxu>YkJ
zprZj817U+@{H>r(*lFFaB0E7>Xs1~pEHktIT*7btyNo+LIP68$3{a)Q^Fk#HRBVBU
zuwF=l%wm9yWI;x`z#B2FKbNRk|1MW}@iP;2k562u!Hc<>|Nn#3wRXGy01ZXF1T91F
zV1u}n?Kr5q2ARX(Vgnj6gQ_w3|NnolFHc}_cvu!=udhg8aAzzJc=Qdl{?7VviHKz^
z4}U9onYu5B_34tmos6${LdN5pe^l|ef(|0F{><M}{Qv)d>)-rs+5i9l2YF>ZXnFb(
zo|n-e%RnpCK|^1lBLx1J@_+`eCxaS{M?|0_Mq%BhBCX%*ctKYfy(k3bh{)~_-L5jw
z%S$C*#Dc|Izm-UVc4P(oFO>i(g_!kU)Zn25!)vkbbJ{0LS+kfTUUM5CXg$e4^FXf)
z10!O0G5B!X*D9b3Jvm<dT?P*7)&r#i-E92ZSt>wB^U8q^n~?+`@!NW!^jh~ZZC21J
zxCehQeZK)R2f=^+0bGLwhIjukKG1!>^?!+vC3^{H^FbDeW=n?B?_myEECDadn?cLt
zBO^OY|FnK9<;dcEQ2|<t-wirUQ&jt3z>5<c3=H7SHr*`dpuG0BS&gCF^$%zpCD{Dt
zHv-+R9AU=aI!nJ;A1jr3!Ic3@8Q>A9wds&W=%73k+$|B_8T-fjUP)?}ZSaeCzM!36
zk&)K_N<yvgmjoIgNV6<w0<Fw;{jm__BWu<SB}ax*t`}zi|NmbM7CBa0u@H17r)4Qm
ziLv#u68#rKEB^mq3_2_Lh0bzN=c_XO1?YU^)&nJeFPhR}?f_M&psU+0OMmdU9$;i(
zus&8QoyGFPtm*&%$i*NNt&f%5>NKzf2Y;z>7Rw81uoT4BlKq_q-QeSnt?!j=)&?C+
z^ylLL&e{(z+&~9Y{fM;w$KUf8RJj=Qw}4K4?KRo`-|U64FK8$?5_Fsh_=v1--#?vv
z-M$>1jK<$UJ}A#(iVg<tgF3(T|Nltl!vQZ|H^Rdt>VN4UklbddT=<Ke4rprNZ+!|n
zEyneO@yT8m_q0xqZr>lwhri#HKKcEk@`=Fk|Dq<4^?&@$zF+>os7?a~11O`0zgXb&
z|9_-q>5mdVklB-bK$)H+veTg3^~=j!AiwyrxOejPn(Ve@EBy>EHSGDD{Xk_9OE~o4
z<%gh|D$qG={4J)ih<T~~|Nno>(jTRf*8ggmzTfY4XR<!d-_!c<|9|j#nf%RF|Nj3E
z$YOz-F&AP6Xb3P7WNYZ3UY;GDf}Mpdpx`kCNA}B`|Nj3E1A!N!si31c{=9hP4Rf#Y
zftT7Kji5{m9_I$1Z(`#E9_Qxi_WjZoD$)|dC|fEAzI#jvW#n7gRRFX{2y|?y@c{>H
zr+8$sfJy?;p1N6}5lW;Xb&23G&?VQ5pz}>QI>EQhz1aNt|Nl<c7vTGHJ44@qra&UI
zn7}GtOn?0UfA<OHQ=qGKfBr9V>@MZ$t`*S!ApMKK;}`=2Lp_J}XZ|+ONfqF$z=E?l
z{)+}YZ~$#ZjCkO{(CPZ8^+2iki|r|(I0Q|uy;uX9)?fe^uo<8sd{99p%E-VF8QJOj
zqxF9cS3QgM=OUKw!>^gTkAXJSffP(X3r;&Ar<u(J*<Qg`f4TKr>G^KZ(KA0lN-jdL
zUjCEC0Cz&j0|y4<+u-{aU%03I|KDuETFU)G3+x!sVMNX6{&$vsdA-;AcYR?Ei}mN?
z>|oHsWJu{b=h6TF;4lFnq2>a*p0||a#oDj`|3?P=7qxik!0`Qs^nvd;JZ5&feo#Kt
z8Ttiu)tKgs)5##ef{cH0IT=(oK}zyYw(imo%B5eL|NZB00iC@c4B84-`U2#3Llmn(
z3CH*VIQ@VNC{TMGH0BPTj_nlzw<No{Ad{iY=eitKm=1*VZ>wbC-**6V<I2S!jlV(X
z0G0$a{sskciBscm@Tq@lAexDxL=Hr=FqGOhc(OEfbM^Wds&ol9JZfw>#n>VES{+ri
zso@mU>lY1)EcLH>5i$*m4XvPixJ%i=$Arcn1_g#H!vO{cR*==uI;Y!}1AGbJ_9Rf4
zfQ!_qBv2I|5qr3sH%8l$p_2nN?-|~GtoZ?d>jD1OgP@|}V)MiLgRj_2QeU(6&Iavn
zPUFvKOXJV?6G-FF4^v3v&yNE&ZrIcK>-|CPop4ZlC*B~9KR?YOjXysxAdNr2EFq0Q
zzpfySzdjw*2FeGufyzN`p!$Md@R=^X`$46;SLx!`lO>+r7Z1K-X}we;j%;5&dvBRQ
zZ@qw5>HFq~{3R;g2SJzY@pg-KiuabW^wzU@mVWL&0lJ)z6SN=S&E2!~dqiA(?BQLY
zVHoWT+NT1$55W|Ob%=u%9DKo4f@Fk8>F3CoptbQY8V-XhfD(=@u@_B;|NoEt#=1bx
zk%6g1FpDuml!3t^i}}UkcyKnzVt$cO4m-ygyem!gMQ9>CgnuM}E3H`2<TYXknh*F2
z@+_tok>&92Kwz`&202HDf2FK1Qb3pDfjFQ<%nqJ8J$V>(A?zQ}#vWgez<~dvHsE5p
z<Pm6Q^dw|L9D4nDS0AVd0o@oLxuU65^2PB4kZV8<*=9c;1+Zx^ZDALXuL4Vg?n`|A
za0O$DIOvvP(Dmb>(+|+DA5UX}oUxn5)coLmH22|7Hy+3h%Q`RCdP46kEa7>v5X=VM
zR|vj?eAWZ-#=27WuorG1=6CoV<e)7+&^ySPpm&gKpYHTyY5fnogk0+aIEX>#T>C+9
zcLr4fBwa!-8l1(D#Sr-7{yjtqQlbm8H<lx<Q{uHOXn)op&<Tg#zq>&~v437{IuElK
zbQ?K0JlI~dcOM3y8;Q7%JlOcQWh@7H&w^uEIH>&aoA>{JZvkT#Q`n0guAnNo`3R5o
z?-Kd{r5s`5FFu17I)G}tQkL%HuX!K`A2!B;DtGWUPSCt441>@22=4Y3;67R6+g-}h
zUCXoGadXr*g<emFE;X(vUF;?5Tn9>&n~yOzA7`|BUc_egxSWaUnbq+kHmk$sOiahD
z9+Yx}?x?(IeA4Pc2`A__wEsm+-*0vwj0QEi!289R1G1PiKqrG{$oz6(fE@F<7?k)9
zF9eaGVx9-IEP*`$a=*Y~nDfqnCTc-bx7;T{r^A(Ug08mw{_v0hL-6;9&}rNh6%l60
zgziJ;%h87f82+pFJa7P&BBOZ7hrkaOMg}%kMg|F1Mg}!jMg|8~Mus3(Mus$2Mur+z
zMur)zj0{^?85vHoGBP}1Wn}on%E%zZ#>k+?#>imC#>n8t#>f!I#>h~>#>nuFi;>|D
z7bC+GHb#aGY>W(h*cchEurV^cVPj<Y$HvGYz|P2^#?HuK#m>kO#?Hu4!p_Lh!OqCA
zft``z06QbY1$IV;JM4@Muh<zGzOgeh@NqCQsBthd7;rE$*l;j1_;D~YL~$@OWN<Jt
zlyNXJG;lC7OyOW;Si-@`u#1C{;S2{O!wn8bhF2Vn3_my+8MrtZ8I(8~8MHVV8LT)N
z8QeG-86r3t8HzX=8G1Mw85VIeGVI`FWVpo1$nc1hk>Lj?BZCkZBZC4LBZC1KBZD0m
zBZD6oBSQigBSQ%nBSQ-pBf|nNMutsXj0|VE7#V(Xfd+~h7<xc=^q{4LgR%|`8TJkg
zk7qbAY&q$`AXtvbF%PafFcirl_-I-gc4c3Q0*QgvIr)MZpnmsj28IuEjtn01jtt2R
z$qdB|3=E+RAq;K|x(pUbY(oY!1|J4jkS>N$20sQ*24@C;1{bi12ZINL6+<pVE`t?A
zG1vqKh7>5&VNhW3g+c|e7)Yd&0RkDoGWuX~eXtnFf&d1v>lhrNv<pKjLo!1uLoP!S
zLn=cNNC|@<Lq0<pnwURBGD8VNK3r8WLn=c7LkWs1M}|^{bcRxfVulj1IbIB<3^@#y
zaCRO;DwyraP{2^ckjaq40CHm@LlHwV=p0f8H-=P(B!(h}QU;J1OkW~H9+C*ey$nz{
zGB7~g#lQe@4+8_l4GatryCHNQ)E<zD5W8XaGC=JFsRP*qGAEItgrSt7h#`d`5$bj~
zuxk<g5QYq}iee-+;S8w^DGVSVB1A(NN*Pia5PV;Te1<$EJ;4m6Xnc^}AUA<Rhk*fN
z4+8_lY!Dx09?0z=b3kqd=?7hmX_cF6RSZgA3@IroDLM+izP`Q+AVy_nWhH~JuYO93
zekI8J3<16j4354G3@)k3skuq1;0X82FN3rFlS}eJ!ojHpB``t9()7~e5(WmZ(j2fE
zUZr{9h;%F{$^^$@Vo@@vCUZ+oDk@DZf~ZN%12bJxlNtQ-%NYEVOBjMv3m6<r(?RAi
zc$MZc_$F2|I2IH!_$C%HxTPjBcqQgB1Sgi17NsPD&2THq1hYaiN{foYECz<~)Reqb
zC?}*8!t%|}1Iq@NLg~a32DhS2hLDU>ka~uY(o_cD{5*!>(mV!l23Lk420sQ@1|J4v
z1|tSN1{Ve&1|M*`bjvArD@sjeaLXwUPAv&b%qa!4-I3UiIXU^sV8sj!42(?7EUawo
z9GqO-JiL7T0)j%qBBEmA5|UEVGO}{=3W`d~DynMg8k$<#I=XuL28Kq)CZ=ZQ7M51l
zHnw*54vtRFF0O9w9-dy_KE8hb0f9lmA)#U65s^{RF|l#+35iL`DXD4c8JStxIk|cH
z1%*Y$C8cHM6_r)hHMMp149@vQt`(Uj0Y&-Asi4@;WhiDyX2@qKVn}63Wzb_tVaNgJ
zF;I@mV<=(BWXNSmWl#X;^CGZ11+Z6m89?*Zp!DU#;Li}u5R9S*A{)%$$>7J}jzxxn
z!G*z}!I!}itOD6|h)xEEAO<rA0|sLTV+N3jE`tJtBSQ(a>;RP^3gD7O0bFu`+~>;x
zvdxD<0qmO;u$$8uKrYT@0IAJj$YdyHP+&*|mxz$E3sla4%0N)g&1A@9NM}%B$YTKI
zr%Z5JhHMr{J`)@si3~XmnG97>b)a0u1<rL4^FiuT7%~}>!SbM-46;*!Aqia0DKLQK
z6&NZR^1-D6NUngP0Bj;eM<zJG>oF)WcruhQfYgIroy(99E+G}bDzh0<!DS@GUm)Lu
zVy_rna)R{aGo*pT0pwDUTOmFJl~tg!9}-Tw;Bd-iC;*qKpmIooL4!e`A(<hEp@>0~
zL4hF+T+)C_aEO~gBCzmG#2Qk0U^jwN4oDX$O({TA3?e36!0F4EArTxBdf?avB`8>Y
z8-YbY@twzz4-SD;1`rEWOJp!8FcdQsFeHL&ACP+>cH}VRgTp%q9P6MEP6OMU3yuSb
z>p`gq*&ai<J=oI~$Q0E028DA8Lk8FmXNDk#5C#PXP`rS`9ugCf5C)|PQ0=J4K#O#N
z?hgaFKVWVGg%&6kVDmu=ST!OXj2JAyBB1aF)eDIXNeqxs1l8N1)R)JA8492<NMtAg
z>jaqv!jSkgVlW4bg3N=tgShxBX8^?$HX9-N5frL0za!gcMuvT$wgxDV=7aMWx)1T&
zX9~Bk0GxwCsiKS_lc5OQ0s!SWP`U(#B`6Po{FH~37ZE;yg_jB3JmSME9$ZGGGE{)$
zMjxEYVLVVugvBDlHduLT$Y2S#59CIeN{}v4Xyh{#Fo5C<Qu2ZFb3QaZfJ#)5KS3!Q
zo4Kgz2;>@&NuV%*lr69{gRQJb#HS%r`T@BQ)0|vrDF;fG8Q@wgks*ZvR4#(bfNZRF
z4YK*<q!&=G2jy~zO`tYi2}2?{91-D)$cLaX1(i!B3>x5aGy`1cfNB6x4U3!_Kp_JQ
zOGtV!K#CvY(*r2RKyd>qo%6u;HK^u>m<%%)5kJJ63u;k=+UB4Z0La8*sGkwxX~2Le
zuhSSn<uD}o<bmtb0)~8WDGw@*K(!O7rh|kGsGfzC?hrko)P*RUK<0z`L;>#{K=Z^5
zKi)bpfQG~tymbJ#IwIaWfL5|HFuZkO5M*FrSn$SyL5P8YA>xe#gD^<*8wUo^1wIpA
zJ1|IsMoV5hFi0^lFkE=$z#z@Qz>x6DfdO<_g}^HZ204)UO9uvd1_lO>mktb|*3E(!
z4xob%7&bg}V5neVV3_dC0o<xDdFH@S1+wRv0|V%k=747o44^KX!7~R2UvQldih*JV
zQ2h(?a~QbI0qU9LFeorMGiWntGbk_wf$LR7%gTo#6WoIVg*Lbe%fJQpB?E&V7&0)}
zfcrlA4CxF-42cY&_6(?%0*Vz-`zMbf8(c${GvqPYfqai)gDXQ3xFuA?pa?cQ0L+7#
zW(D@M2DrxrYWrz|&Ctjz&B@VZ0A1e12AZ7}U|?orU}F+sadmZN1p!k7&{dTT3>pd+
z0TJvR4CV#~;Q{On3<?UMTg4eT5;77J5)v2~DhetpDk?bGIT#q&88|pN7#KJhI2b@&
zustK4P+&lZ8VoRqE`yEl!61MawlH8qR2_{B2*}7l97Hyui2(tb7>I)~{h-`7ngY<{
zHG|$MfUyw{8Hoh27zEKxj0niYNE`&|17UQ(lg=lU13<QjFo+=K5@faj1CbtvDnnOK
zoNp1T1Q-x(2n&3FC__VIQ*%peTYE=mS9ecuU;l)OlO|7@I&J!lnX_iknLBU(f`y9~
zFIl>5`HGdRR<BvRZvBRhn>KIRx^4T8ox67L*}HH5frEz*A31vL_=%IJPM<k@?)-&|
zmo8tqdhPm+o40P?xqI*agNKhEKY9A>`HPpYUcY(!?)`_4pFV&2`tAFVpTB<p`TOrb
z#RC(#2OfwTm>6jP548Ohhd-f#A>8udfuVu+KPv;n0d8njAj`mT0Cbroh&v654Z6n|
z+_+$1U;y2T3}b`tGlsE2cO%2tpnH*FY|tIYFgECZWEdNCw=s+jy7w5y2Av!ZYIB0t
z#DSJyxTnI#%)&GCQu51#OA<>m^Ya+oQ%gdNQ;YnQvQm>vJoD1>i*msd;S3BQIiJMh
z6366{%(B#g{DRT~uo#37F^0i6wYWGjJ=H0{BAg+VAs9T;h(5*$3J11^hPH;r1_lNJ
z=C+2mrUnsKR##Wo*49>51_lFzhJc0+1`Y-db&G)T1_pLeV=N#5bkmB0MngvfXu3Wj
zBOxOrgM)*;qM)F>pa7*E2AVnWWAF#hGl0%ScS|fu%uz@!D#|ZX$jnp7Ni5Av&PXk?
zQcx`h5Be1`B!Qg7;Fg$~lbWJXlCO|okea8ET9KMuT9TNQ0~+WJ%>yw&a%q`)DGG^s
z3W)^;sd*`>DGH#G-^{X9JqCoDqSV9`g|wplT!pkuuyzJzMFxfd21kYv1`h^Th6sib
z1_lOeu&oRXUinE1nTViPC@f7as?5wwS4aap2t&R&wWI_|nxVKPB{NSUrL-U?GZ`FN
zFpUfhAi4a~66})2B`K*zMcCyKen~D$O)N=OD1eNxDwGz3tX5aeDF*F1K?<|<)Dnf%
zip&y)<ouLWh5R&_4p6%v)b9m_A_Idyc!aZvL7yQB+?Ub^_s`3qA;G}lT2YXiTmp#&
zNJuLr=jY}o=A|g4=B0qF&dgI#*GsKPRR_goaYkxVVqUsJPG(-Jm4a#xc>Ev3jPi`k
zlGNgY#N<?k#I%ysA_aB*(&8fhq|7}1)Vwlvm_~%3!8Rk}A7oQ%URh>QeqL^BUI|P+
z$k7P9Qj2mk^Af=klagPWl#{AkSejpws*sjngp`y(MqzVw2$FV)zVghH3{cb+mn0T}
zO@#;(XB<+zfc*ls5=;1&KrM#k4X8SBc%sBbN-8*7k>#ODAvDBI*8)W?*hY0_b%n$d
z1+eQusR3Ch0~U9vE2=A`<>%z&mxCf1q&qWD0aX(stn(GXcA&-(iee14iACw9pvWs$
z&`2#y%~QxsQ%KD%D5=y$j}cV2C8a9BGJYax-UE~sU<neG=oE5ObMuQT8I%}Q8FCnk
z8I%|lpezL}Vhju(phQC^25r6$`0u~~D$9d{U4ogE3*;Xhe(1VNbqn_lwvP)z8#|q?
zVnF40aZFfdUSefTKv6!ZATN$7&de>yNsWh<eK9GS#U(K%#zuMtDd56S!IXi)!JL8N
zLmPI-{reBvf6l;g1xmyC+ES4DU>F}=K0*b*e4{FU`L!DO<u_~MmsiuqFVCujDt`va
ze=)ia3<bKV@)wZgK_S&;ges5j|5$5Od1UiJ`t|Km<<a$Tc0!fEfoA_bX9osY*uO<$
zqpMrsicq%(iG2XgJV!57`_TQ%6NoC0?w@Hv5P6W_l7bL+qWeoS1fmY+c658BlJLtn
z7vh(nT!t!-?#^c|sPf3+HM`A$VO<+;`3F-S7@kZ;l}8W9v(r)K(f#i=6ICAF{}D^^
z%Ns63l}Gnq!4_0`bo+IVqspH^O9vlMK;%L3sC&YJVGT26%?OBJ2U<7sfPvuy=n^-O
z00RTV3^qmvmxoXe8a29Bhk9#uBpH#XyW1JvQ%js7?IWMeywq?8S(e~bP=hoeu_Pm$
zp^zmw6}c7fm7fG@*)yzQa0a*QpcCie3=9XrW|bBdrRKr91`I!0!V@z~-13WpGxO4O
zQlWa&8QoL!Qi~ExQl0bjit}?)olA;xT+34PN*EZ#7#xd>Gt={+=7!`WtYo+kvH|3L
z=lqmZr~(EC5hnN465srk(wtPc%$!ue#N5<y28N}~fuL3}QV#@SP&%`3X--L|Q)NkN
zNPc)`N~&{4ViChssE^?492po=KxPM*q<AFerGVPuOdvj}5912z3@|Y0g2D&M6A*Pp
z3@;d5psndth!8^%gL6)PF^uQ!8sz8dV{D|Cl9R*0;K~?WQWRWL<QdMu5bWU-?ik<+
zmN?Jkk(yWlUQWSq8q9_)op{IKnpcuq<Xn_ll9`;C6P%h1?s_p;GW(<^mZf5dXM$WE
zTvC*ommX4C01BNpP)H)hyCcJ8u=%L5&A@Pg1=g-ag!g5Z(7X(Ac%-;iB&QaD>~_n{
zDFLm6Sqcgd+|taR#V)ByrRnLZMFB;r#h?g(%;cGuS(2HUlUarCaL2rq;DXFN=ls&V
z5{6d{u6dvqWI%o<$nOlNK&x*+$pFfiU<oS83C%0d%u8W73-${neKIf<f&Cf)N(l__
znLI(dbMlk3Q&T+il8aJ7O*#gK*T~{7sc`WOkX}dU00stgP#F5V`hwV8%$~(zi8+}m
z;B=Unp2~2PB_yX95;+XVL2USXmlGf!d?m~=5Dy%o5+L&+sTPt#!WkHfL7|6~x{iWu
zcZTGskPJ|t&@+XB!4;$vl=>Z0Qi{N9R#aKTi!w{Vsh=SqWCp}UNWd|C2AKlN8KAgl
zNCxQ+26YKa3qU~<&Tx^zB{e6t1U>W_Hn9Zfq^1@y=ra2_`z97Z(hn$~GY6$6rhp7&
zU`PYm24cdZg&~m<<ULnJX9uFMIGo`Y$Q{@u7=%G?f`kRgEKm-1WMB|vg=Ni<e0Y9k
zSPse80jWjcp@qEURIoQwix?(@ObN+M&ISuGFdPKg2Ms+?aHSR(d!{f{f>Z@p7MG;v
zhGgcZIu?U$1hE+Uq4^&q5YAxF?316E;**(Flvq?5&cJX9oTh?OA(1=_Y<51R@CsmH
zScAm(%}+^XU<hY)%PB3+02$^~nwFMYRLsE84hk)#(u9TCvl!~K{35qh(5kIeSiVSM
zaL&&yNGwW)gkLxVLpVq`Quu`>7G;9E7U2xR5SbMJG>~-+3|=5VLJbC$APfvwz^)I@
ztV(5IP=TZtXsHDnmqDv;M+EnPnIqVrAR02_4CXRGCQ_knC<U5(MYLX^f=Cod9)yvE
zMwz1_fHwp{>B;Yz!|sie`&~c^L444*CQv#8VNf3(M1#hCL38)43=9mQtze)&I%pgg
zbgT<#92PV_3!*_{AR06v36cYi9mC{6=7RKsXnqC;29UX+jYS|a(0T#TS^*FSi7P_w
zF@>rF<r0uOXDB~_fdRb6APA~17)pc65s>+j3=9k)yFqJOLHcqTKsTE)FcdH_fY%rl
zF))DFE`a<2QV$x71-Th?aUO_ng35z7*ns3gH)Vs&naIGv0Gf%P2el7$^e4!@pc}72
z_AQ5sZ-=_?9Mrwnq3)4jXJ7z@4+w+81r+AA!vZ(~#7+gA03tusN!*iP5TD_me1XUh
z2NGuz0A)Q;t{CQN01AeBQV?-uU}R$9Si;P}kkC}w1S%gvK3jGlL^3ceTneEZ=RW`~
zfnso|YXH+Lm>C!jF21!G*NTqDe-M2RP<kto>K&o#w=pv?oL}^0krczzMK2abLkvSA
z;pW#Z1nUT7Wnc)r6?aR4A^uj@Eh8kA5N6}$8}}akWMD9?gXjc}tAWaVi>D3@CQlt0
z44yhL=sa~`(0J;=pz_p#LE)(bgTzw@27#vz3>;4#82&tQVEFLFf#Jmy2ZlRO92jmq
zabURe#DU?$69<MfPaGIdJaJ$+^2CARz!L|CJx?4Mc06%l*z&}IVZ###hBZ$d7?wP7
zV3_g5fnmZE2Zj!)`i3VC3>8lt7z&;^Fr++jV2F9*z!31nfx+d81B1g82L_ub4h#lQ
z92jJtI4}r2abVzN0c}o(_=n?(0|Ubo2ZkSy9T+}5c3^n%*n#1}V+V#Cj~y6JJa%B%
z@z{Z3#bXDCDUTf(8Xh|^6g+ldh<WV55c1f8!RN69gUe$F2AjtY3?`2q7<3*xFsM9s
zV32w2z##J2fr00-0|U!r2Zle792nj_a$vae$bsR^BL{{9k09!|JaS-I@yLN;#v=!Y
zmPZZ@C662!5*|4)_&jo8aCzjwVDrd<LF17F0|Q9^L&!K8sQ!nzoVuinB&Y^Qm`N!g
z<W3Mqn8?7uA&0PI#zzMRg>McF3%)xrXh=FTOptP90PT1O;W?ij!0ZN4MUQL%iENnt
zFdC*E#)r|k#Bs@!svc$zjE3nSr6~^q=<*_*6cZX?h60$)1|J+46h1gGfYRfv&khU<
ztdl`YUt!V=dJLd>Wd;TYIY$N=ZNj)73RvVE85Fc}V^CfIr3aAtAR1<&!(|5sVlYfS
zsBH^lgJ@8B45H!Kn-$cAhI2<5<b?pJf5pJS44xC!U|?wAV*vM68bE!n4hGPn7Z7tH
z>exX`e;F1qFf@STX9ojA12bs7Gy_8eNd5%_Lj$Ov#=ywX0E!$5MurAZU(A3J-5f^n
zE=~_D;-EB>fJGeSiVBb<h{3?X0J0BO+jZa&pMgUhbT%Z^7!-4M;81@8hxiQ~;xDj>
zgX-oVj0_AML5vJ9m>3wIKs><kA%u}ZgAu`(2xDYe!GYi(h+|~PU`6mXQWzOls3Q0m
zIvE*O2q5?svltmNSP=XN^BBSVVqx}q%x7eXLb4BZ034`|2C9V_p`if_8+2MvPmjUf
z-JKykJe(mjGn1jTv=kDt4Gjzp4Gj!4X3St%zI-{u&Ye3M4jeeZaQ*sqhJXM5f$BVv
zQ4L_l|NsC00OIj5^q*<qVc<VrUVfed)Hgl<|NWl^o<HT~H8mgw@Bg3qbN>IC@8#v^
zkAGlb;P`X?|9jBY>gDC-<sklx^JmVS`TzfWc{!+RWdL2W{Qm!+wC^DK@|q7EZ_fWe
z^Zyu>Uw)qB2S|Tf+8?ldc|Az|ne%CB=Z}L0>LKQ*rGc(d{Zn3E&++2?nLp>#z~KCG
zi2C>c!Q8Z*@8ux%XU?2I1`+rUHvc}zez3sznhzZR|977UO)CEXla}`XKgj(*@Bjb*
z{~JgF*!@j^y3YJL^9^JMi2pAr#`FIF|9^7Q(sDj9FtF}9DWW;&%=!Pv($YZT!*OG6
zqcA7{{{R2~1GG2cZ>y1@&zbXQ&j0TL1sBJkm9q>jAPT_zA7{@mQCf2btQMsH|NsAQ
z9Buyp`2YV0cnsjr`7`Ghhn)HG=X}Efko=GH|Ns9D-T&hcSQ-?bXU?2?Ip@cJur$d1
zpm2Wk0wT@8@dFh8XU^P!NQ2aa<RONG%<F&xkl_pr41eSg)IVTuuy0^skVnGI4Gav7
zpfM0U7$gr;hpZ1|4mMohz`*dofr0UV0|WE_1_t*34GjGM8yMvOgVH&u;|WUZgwnZ*
zi3x+RuP;Mza4<tvRTVhdGC<S#gb5QER;^mauw}~@a2mgM?Ha?=r%&POyZ|)(vw?x3
zV8eEHP)e^ZsQ$k#Z9hZ({`dRSvhx}0-~a!gw*UYC`u(rt)6&wi>)(Bi-<Fn^RzL4)
z^#A|A(`rvX4Gj(5pXOt-Iy5viKHIC%|NsB3@&D^O)%Qn-#xvCaU%Y>7D9F5>eIWDe
z|Nnpc{rd(6a4N25V5pOq|1ZEU|DS;wiW%hpGvLB7H6ZmM%nu1CP#8hV1N<XJs;a6C
z+S=L-1_lNUwzjqmj*gBDo}QlIunP<fWC#ljV~C85WQdK8WvEMWV@OX=XUNLRV#v+S
zWhg2t0+%1PwY3ZjOYIp}SJ^UbuCr!nPIqPK$#!O#lJCecyU2lIccT@<+6GUCS&c~y
z+h-Io9P9UHxUe{zL1W*42AxCy84Qp8XRtr=pTYFhe+HX#{~2P={%3H$@}I%`)_;b;
z`~Mk=@Be2Aee|Cp`uTr`<Oly5lHUAhXl!g`=<Mudm^g7F!}RIX8D`F$$uMWm9EJr8
z7BDPbx)dD08#ZiU*t&HqxGdYVXAi^W!y6cyKK^Ie`r$vr(W6HhPM$o;aQ5t3hKm<3
zGF-WGh2hq%TMT#a-eq|I^ajJ_PyZPnK70sH7cXDFWcc#_6~p77{~11f_`vY}`*(0!
z0TqEv`V0&#0SpXm1q=)v6Brn{HZU-7pJ!m;`@q1U@L!0*_P-%R^#4GH%KwE7GyYFx
z*!q7X!<GLRVdW`<h&}^@QUC*kK>-7U?F0q}pA8HQk>?p0(myaTRQwlY==yKSFz0_D
z!@B>43<v&CWVrNyBf}FU{c8FQ3=RPd3{eFP3?&m782UCaFswY!z;NgT1H;Atf($qQ
z8#3JcAIR|de<8!m{}UPB|KG^)4N1Sg8UsUsBLhQ0Gy}tg5(b71eGCleS28esILyHC
z|B@iX{~Lx3|L+De{C`r&@c-3BhW{TnGW`FBaKF9?14Dok14DrU1H%M628Ip33=HR^
z85llfGBEtF6lD0{WytV<ZXm<|^@R-o4^CwGe`zDb|EEa$nHd-YSQr=z*ccc<_cd(b
zVqiGW!@%%?kAdO8f)K-hJ41&5F@X&Ks|p$ZPoK!}f7?ce|5uRoGw?A4Fo-i0Feoxi
zV9;jRz+lF3p230P1A`~Sf59k*|Aqw&{{!0?{uj<+_&;$I!~cyZ82(?p4-bER1_g!y
z1~Y~N1|NnA3`q<d7%CXfGxRZhU|7QNUvM+Sf5UwY{{xRR{4c!7@PFbRhW{I%GW@^z
z0j^(%L7%~!A%G#1p@5;CVFJTah7Aly7|t_1Wca}FLGVArC&T{?UjqL#d@KCV@O|Qc
zhMyb%GyJ~zAFf}TL7zdFA%MZ2p@1QXVFE)k!v=;jhVu*^3?CR~3jSwUX850BOW=Qo
zLxukt&QJW$aA)IxhSx~?IT-Z8At1_7z#z>qfkBaB1A`jFc?KPZ4-9sK{~00-|1%T@
z{%7bZ{Lip#;(vzy8~-!hLedXP!w4J?0SEyG24`m{M<++{_&$S=mWHZ|l9HM`T!EvL
zm#3$Ti<h&#y`xLKu7<k0s*1b2ay(Rli>H?-2zk1Adbzm7YioiOxVtMr<-L5JUA^ob
zog7`A9qpYQ<8?p^R8^G}q4J)-4vt=q&MwZLE}kHl>FH=|+kqG$%)r3l<?96lZqgFs
z@p^g?6I7HG6_ni>7(7AddwF@<d&SENOG?D+ffQ(HsH=h$sKqmQ`Pw^z3~=^}mlhV5
zgvf*4sG_8x5YONVH$PrfL|E9{7Hohv$P+4x3LyQ?E+GAmUh$$LBEquXAa}*b$NOl3
zY=~#@jJJ36_4D#_^@^7Q86YVkE-uEy!z1GZaso&mbU=r%ua{T66pDg)4Ruvjki4_2
zucw!nudA;-ih_6zb#*O}yuFjJi<hgfi?5rUlql2+F&>_HO$}Wi1_sY~UteEmupLmB
z#mC!7h>P)ncnlzUXIEcCYhOoa7hhK|U$7^@ZiIz@yuD+*i=hL^30}Uw@ltMX!otE5
z;^J`mcr&(m2YpvxUtd38-*`DUHxXfBNeLOayfZ&5zXhLxtCx$fm$R3fJlL1AZqVdm
zZ{_G{#LUlXU?1-r@9XL63vyR{Jmh2=ko%lXoSgMp7`gnQ6288^UY;)Sks8l<OML-O
zHbzE44=*oYUoVify}c8Xyra3PfiWjDhmfb2udlO{vy-EVi8E+S5bOd_qH=Qdx8`GK
zHH(jrca8^{?&*TCKi(On#NV2iiQNGt?`-d7@8|{A3nD=A8}H)f<>|mJ$mbvL>}zlB
zX^)U*0BMG}+(SUn($~?`%gYl<n!z*P*##``<>hH^>}>6cDh)|LE?!<Pp1xk5uBKLK
z(n#jV`}%r1TA>&Y${(P_iNL<db~7+A{QrNT{s(`9{R0LD`2&bH9jKiKYOjIYOgP$f
zAbF5F^!6O6?S_uAw&fZa?9tkD_}eM4_FPa<5V$>3m+B60dn~W8W9Z0qWtdUq%&?`&
zm0`oIItKF-{~7Er{%7#G{+}W25v0vf@#sIpv}w~AX3w6@Fn8`;hJ_0kGAvoL1l(5G
zym>RYJ-BPvE(TCr;p&0q46~pAXV~!JKf{qDM;OkXI|ptXJb84V;nAZ<3{RdsVR-%e
zHN%@XZx}v(d=G9LeEs^B;qTwS3=_ZqXW01jKf}e}h;p7mAGG<woPnXhhk;>2G6Tbg
zN(P4W{R|8rmN5wa-@;({e;-5O{}T*_|1UF4{C|gG<Nv1&7yl#b83uhm28I9$28IG9
z28Ibb3=A907#PkwFfe@ZVi5cv&0zSykRkAYJ450BxeOEkZ(`W^|0Ki3|A=~Sw4E~A
zP8q806wp3@P;o0IB?X?kk_3-}N=c~d>+6G#LY7jHl9G^8)RGtA<CD{8V31VOP*qh|
z)fW`t*W}e_V31N&R#(^8*B2C!*Voq9W{^?R($JUX(iapI;OFDzm6K6a)zIhW(vX7+
zC@5%X>2q-KXz1(fYYOr4N=b-o>2q^%aB;G-@@Vq&OR=y?X~}YPaDfE$1>{B98QGQe
zK|q$16=c4c1e377zCO1y7bmAS1A~I1sx-5VzCK8ctTqG4er*{Mb!BaReQnSNA{j+h
zEp2TTZEZzuu>WLaWMn`StBQ(XE<-&(1A`4{5Dqj@2f|2WQ=o8xV~{vV9)v;aK?^11
z85ltQX3%vB381s8z$XL1b&$gV4I6?+zCgo+Fbo<p1ldZCd8FzA`I1yUAoqfnScuBY
z%Yy<HghAWl)Hpdg)fgBUKnJjbj*9>tB_RS`h5-seYWfLe7HAm=Xy}F*_k+R~G~5A7
z{tENw&kuj}=+W-?@83Ur_wL>E*RNkcdi(b6)7P(G-~aOE%li)>K0LW|=g!9C$B%b2
zGBRr0*x2YZFo2K101X3!%mFR00fhr8;RlLqP{k~yrlzLMz`y_sE70&VG47X$j*hlB
zGcz+|U|^8Ge*Jp?%a<?z@87@w|MTb1|DQW|?*FxG*Z!Y5bLRj3`}hA}xpL({NdC^9
zJOA(Ay?gh?ix)57zkmPm(xprD4jw#M@8slU42>tyF(2a4B{CqlfZ`Q28wbK5HYkii
zOM*a4Z)6!57{qgPbB%xe`0<N@fkB6XfdQn4823v)di3bLqN1V+$P9CHb2X6rUc7h#
zcK@kUr~dEUx%2;}OPBud*s<e3$lXt$KK=jf*|Yx_E?oG3@#00WI*^_>Z{C2!pPV{%
zYW~KJ8*8_3-(DLZAMe`S-0WXaP~g(n*B2lxEDUlRXnByfxVX4+XJ==Wk&zK7>?B-V
zTr@!DlIs4?pFjWKvuDplWo2d4g9i`xy?XWP|A7Ms;Ng7!{Q3VkZ{7sE^ZNDcAUA^9
z4<0=DfBW`rFdyV67=H5P$$t?0_3PJPK7Rc8<I9&XzhAw2_2SpBU;jUS`t<qg)vG%n
zKYo1w;K74GLF%?|-#%GhUfy)io;`gay`;MT>({UUU%!40#~}B^FeqGM7!)Tk3`$#|
zumaH_3}VAD$W1T|at{nYe*E}93_p7G=syg@#9%Zz?mv9^aF3CZk<x_=7g|7mIdtgI
ze~=$Q>EqU|TmM0E@bKY7aC!l`6O<>8A3qMx8<#I%{tv>Sya9?25DiLapu7XpbNck@
z{~$kr;_$<V5C1{&@b4dJmJK|N3nu>k`}h0TuU~&a@@i^ophXizr~hx?zWrBFPynZY
z3kwT1P&x)-ko(V`J^O$6?%n^dUcLH%*REaQJPe8hP@J4RdGbF9gWP`N#EJi)ymI5l
zjsGAv$Pb`00F>T9`2-Y4Ah&IM_y2$Dt^fb+&;9>za`OLw{iC3J-v0mBJMjO1(5e6b
zS3Ujz|LeDJm;3tqK>44j{0nmbzJ2>9s;H=#9yxNP@9o>S{|_HN{2$~8P?-aY15mhv
z`~!*$klR6QQ2gJ!cke$4gV>-j2ZcAty`Z!J@(ak_pzsH!(M50m|983e|G&ef|NpJe
z|Nn1(=Kp`=6aW9~ANl`Z>)`+YYJ30xSK9Uef8U+||Ns2?Glv+*GcYhng53Y^-MjxV
z401mVgZzMuL1_zyL4JT?ke^@}6hANwaz7|9fYM9&z5oB+Z~Xu7eD(i-dypT_{r_)v
z`u~5U6aW9`UH||8+n@jc(=Pu1Z?F%Xq(D;>#CSpS`}gnvj~_qYV{B}!bouh-7LY%V
z9618^56mAR8srvGIs&;9<_8cB^8+Z{L17MxBT%{lrGHSlyLt0wu!H>X{r~TM8{!A2
zEC2u7UHt#w>fHbTrl<b@FSr45f9B=?|5f&Ym4l9VBFg<ge*E|kEB`_1|NZ;-|3Mh!
z4;TiyAC}HRVGD{AP`U!84Uiu|7?j6B=?s+aLHPnkgYpH)MZpjM|M$E1|G(F*|Nq^t
z|Njs2gYAX?|1Hl#{9thO|9_oB|Nm=%t{jE#Q6s_wk|6gVJa}-Ts;a8#@#Dw)K=}+*
zwt)Nq!Z1I8Xi!=Q`2~hS{(xan_=Ds@^#VvAsGI@08-~N4{Qn;W^26Q#|2=R0|L=PJ
z|NjkdVX}DXkN^MwpM}FOl0Sd`{QvReM-&Y50}O-Q0>dCbz%a}YAR6We5dHi2@BbHf
z&i%i%#_RvALi_*I@*TjAi+c9|f9T`?{{tWV|L+U(!%b*@zWo2c4J<!{%A_NZGD&S8
zBtPr!f#m6b|No!C;s>z%Po6y4V`5^WbnV);7LZ>+Wgv)#`2j?O(mg0$gZu*X1B?dw
z0hHE3>FEBME&rF7+x%Z#YWsg)u^reCAP>a8{Qo}^>W6^)|Nr~k`TyVJCQ^O|`2m`r
z^+09Pf&c$i_x}H{xa<Fa`5ln5_5c6>pykWR-T=E_Nl6J_{(t)P2~^Kx#0Mz<g6ad1
z`#~6#A3%JVA3*N^^XJe11JhIfudcNDzpUK$|Dsac|8tA&K+gZ4_~!rrn3w<mM?C%i
zKjhK>{~$lW@-wJRg5_sWnPhnU|9{=X|Nm=({IKW$e}$d@|NDbBZvOudS}u*@{=<h4
zgVX=1Q>Xes?IBQ}gZTqQ!{P!|AAsTlhC%*-VUYVl<>b~z$N%f9t^cp8wE4fZ-1h&%
z5{UbY-~a!g@cRG%m>2*5hd=%QAC#X#Ws=uzM1BVO0hXUZet_j?P?@B$8ypPZksS{z
z|3Uc-RKI-r^5s7agZu!)Aos&C$R98a^8<_q`2%Fb_Ik_zn`*57udA~Dzp}#S|I#ws
z|6f16`hWe`|NkIA#J~RkKl=Iq|KUja8B`{L^0VXR|NlW{lEqm_{R}IU)c61YuMBZN
zdbuhIa{rk#XL?LcO_grmyx9Ws1E^dC(V#Q~@&~BR1EN9x0EvO>T2Pw?gh6tk`WDn?
z0J(oxgXRBib(a4()>!>tTV?%!MTO1(Ju~zFe|i5BBux;%{Pq8T?(P5oEkN}%C_h8n
z80wIE4a5DQ@&cCrt*ornKyd-Xp!^DQH^^-uw}aRq_kzlPP<apP*MQ1RP+bM8+dz)n
z*JSa3XM^Sct#wxaH`G}FUsGj`k)NmLJN%!R>-fJX+v$Htrt|;ibm#x|DK7uJOQZhZ
zyMEz6$PdVE3~+uv2r?aVHUUx^k_5T``0?Z5^nd2enLd!)LGA+4AUA>B4ayH7cf;ZY
zRK|na1)%T;VNe|m@*^nyAMUXGzqiTa|BeRB|66LU{%@$Z2Ipr`nFPwupfYJ@q5Xf5
zA0~kOkmdBhJ;V8bbDGQlx)fKiA3!bzwJ|{TGblfU+8CxsL8AXL(m$xo0M%ijb_58o
zSh3>&>eZ|NgW5$f4Dt&MgZu!)p!k4ckU#(a{rmsIyu|+po6Z04X|(viqu%oW=31-&
z>!JA>R3<GfwfjG}$nO7)0{j0{@*Mv6=Q#fF&T{(Smf`%rDb3}7ZHg<{p`iL1l%GL<
z0JSmVE`x<J${&#X&!0aJPXBlA+-U*%rLC>)|C%*x{)7Aj^8<*6`2j@3`~agt{s8HH
zadGqiLoMe24>X(q-`!~OADo|St-xgxEI%(OvHL%#$o~KI0*C*T^Bn&7<v9ND%5wVO
zn(q9+F%^7q6S$4xcm<N5L1ohB*I@T!l>Z?2!_vRCwY3_^4IuY*bacS|fbI``e);?N
z&;N%9XZ=6g<NSYrv&H}2(EJQ4lVJIINtx|`kRN74{V*xl@qb^o<NwY~h#x>M1-CJ-
z{r~TC?f?I|&;S4b_y7NCq;wBsN`m72<jIp00|NuS^78Udf!qqpkDxqIS62u21ISMx
zaTo@<ABI7Gg<()!fY_is1<DH`ci_X<kE{dN&!9F2C_nc?^D~+ryzL*5`$2K<;o<RL
zNlEGd%9Sg@eLPTGrn9s2e_2@>+z<Ht0rC&X?Jx}T3k-wY11giYfXXC7`8nGOq#V7R
zgoQUcEeQ&z2@@t9w6e1Ludc5CKR!PG|I(#P|AX3f#l^+{OG--q_w@Aq2j%O#ckhD7
z7C>zwY<>Z`9aJ}f$|_J>2-F@0^#?!>0_ErP%S!+M`Stz(@x^7}`Wcj;L1hxCjWH9N
zpC{xvf|TQR|DHX2_$@3fKu1%7-LI>wYnGOlmY0%}@>*3@6&w$X7A^Yk@9+OVI5_x!
zZ*TAaY15|tpE702e~^1X{d-V&gZu!h3qbV*ENy}MFd#pG%2QA}1l5J0Fgnuh^8eCu
zko&*=KeeO`oS(sMj50_Y1C*aZWzwt)Uy%C=_P=awY&v~?eH%gP=ggTi6V=qzOt)^`
zy2jet`oE2h&HsvuivNLuf&W2#Z*TAapmxI1qesDQ43OJF?ghmW$PX|K5(D`Ul=eXV
z98lX16c?cU0Ls(g{M={(uAgD~8B``A=jSuq=Y#sc;7iQV6AL=u($aFu%$YO6;~*fr
zL4E=Cof;Y%Ko<%AS5{X3uc@i|-^9cO+@A!w1JvF?#vnhyFw7qy8e|>_gVGd;2AK^i
zThGo-`oE{u;r~`>8v|57uda3ezkPE0|J$dx{r~p$>*e0wUZTezX3UuJzon(+^Tdf0
z|2H)?eT|BW`k#}N0}gjZMMZF00{H=yFF@lyAh&`10m8`s0F6O_>S0j22epwvc?C2c
z0qRGB#6WE%P<{sa1(ZP0@Xwz=f8GPd7pdbvAaks&tQHg$6x^?_uKovdXLxw{e-H-c
zX_z0hw6y-0mzRU%0aRyz(mbf`1M>&Sy&(64(mcqYpuPc!2IU7(9s%VCklSGxlm<a{
zHmvRe^}Rv;XHv)CKzR$4{w*yn7dAFFUIFD(FE6kEH8nNhcmVkURIWNXIsK1_hyaU&
z;sE3a7zX(P)FuM8p+S8yP#YVR?m=z^(V#R0@*7AW2!q5yZ7PuZJ$v>{Qc+Pc+p=X#
zKd28uj{8Ar6NEu&2{hge@)O8ypfTst($fE+{Oj!O{NKUB;lG}q9ylIA@*q7R8iqms
zfMMjc1<D^Fcf)8<Is%mkpmYUl2ZG`b)Sm<OTNxM_K+|o+&R>Ab&r6ps^_ZENDLr`b
zpaqnl_wL>MALIv6_<+U@TUuJcen?DA{O{xA15R5@mMr-Xaz7}nL17MJgWL|v2cYr?
zBo1nug3=GDtqsZtpgaJ|6CiUzW$@FdPya1hvZO^qLc(F%v}ucu969oWfq?-u=L4G8
zK`(Bw@xko}SQ-Sie?VagatjE9`img<Y}vBqe_mc5XjL(2tmwaripqaWOUwVDGytlj
zKw%A155gcmNDrtS1%)Z7{NJ=`)Bknr)`9E5_3PJz^?|~A@7}#HOiWB-OG-*=jvP61
z=){Q=?Vx!G@Dv_4*J6rEg4_#g|A5N>3l}c*f%u^O2BJZ30mVD0T-dW`54bIno0|(R
zTdS+9!Sx%ctO2EOP<(;h56TCid<lvZP&xs{0jNv{$%D!Y5C*Y9=7Qn~6d$1a{MM~o
zpdE&wauYO9i0M-7B4GD}!ViW)X#j>net=<++d%#Tr6EvWXm4--Ur<o+A5>3++yuiQ
zx4|$-52&00l|>+VQ2GJ&i9i_Sc96g3&!7K)^XAP9n3$MIbvwvMVE4n?|M%|QYXSKK
zRxV=m2PnKjWs|S3?|)D~AuTQKKd7z+xf$d}7zXh{?gzyUC=G%5pm`lox(B5tP?&@A
z&<xOGe#n+}Qo<eNb`S=;A36Pl$_S7jkTJ|3AQ}`OAR08r9upJufBN+4|3T>+<UVu^
zQU^*)ptKH>1JwZ_w}bouDo@v}Su+>9-JTq`gWV6Z1J?gNckWytC|!c;Ado*mc@Pv%
zpz;G$)`99Hka`dX`2!TT+qP}{KWo;k{~&#!@P=WK|3PU7ly^YwCJ-N#W<chF+<y1&
z-Q~>8%;cmQkh@_R+<ynvCol|h2MmM!0K*{rkuk^*$aukm1>pWB$X_5mAisg!3rbs{
zvJ>PNnA`8%xwDMS^bT`3j0TVYoIQIM-2c6O`*sV+AE59D(J+62Xpoy=7!;<U@&%L^
zKo}G^ATdxpfXYr#J_W@Ys4N1_C4lCjKz;#*`|aDe$th=G?nS4;?uVs+(D)B1oIn`l
zei#P1ABI7G0JZNy?H`aBXkHG4L1_y_A3JsoJf{Q-15kbirFW3~LHXd;ty`dDASg{U
z$bJBi-@?W}PoF*wAO8XQ0aSN_+ApB;50nl-^%1D<1cfoE&j|{9P&|Oz0w6Xh9zc9h
znGY&!LFL%ity{tK#CPu8p|;yW{s5<cP?*9navDcwBd2v38<f^TY>+xoT!7L%D4aol
z1f})Ik01Yg`t<3G>({S?>Q&Gh3v$aDkXx}~&~YT7H3+oCAUi<o9zg3fu(^RGvHuPK
z|Nq}#UjB!H{r^Av^701^4E7%&Gy?;*X=bqb3=E7=nt@6*%siO+NbYU`g@%23Ie0r0
zlK2CtI7xIp)V=>9G$WK|hSKa%njcEbLuq>`T@R)ILuf`24O*v#*tY{>fgDB>2CeS_
zwQoTfl%8>}^#RTI{Qv*|BxpMutX%=6zy1IJA2g$aJ|2k6At1XX6crT>Vq#*vQd3g{
z&CJYPOifKe%dkPq&OmK$Q3eL^1vubz3bOm|kN^M69{vCCaSbxZ1{w<n%_$fi{{KJb
z-2eaAK7n0>&kZ2I%CNGsnm0B!7QTG>@&~9qd-(9-*K60Vy}W(<_M1C*?%dk4Wy_+n
zva&2SH8s#421C#qqJRJXy-$AvnI{9yw>n(@|KA!qUwq~B|NrMd{{L@(1Z@91T%KlN
zV30j<;K1T%&z}7Nm7kz864YM;xdDVh<s=A$+S!jDJ^J_P(WB2dZrr$h;lhPoAd^9J
zrl9#o@7s|1QqY(<Xe{>Xm;e7Sd?ISDR~}SOH#IdSPMI<#4CDq-+X>X~0M(D6avf9`
zfy!!7TNcz#0m*^bAp4_VK;}F_b8VnG9?<#)(3m!8eg`xr51L~Gsl(%cc~Bpqw6rv@
zy1F_GRR4nNHBdhnWG|>44GI&e|H1t^ka;i+nlFob4w>%*&6REW0F%K<gEmGYrw6e8
zp#C7JZUSMD8$cLTzJo9*OhEP5+o!kwFK-S5&r5*D!$CGAz5V|`{uN~2H24u@-WRk6
z0yMS{n)8LFN9}|E|Euo#|KH}||NmD})1*A8PHAarNt`}?dKkzZAPjN`DE>ihV31ot
z_0R5^x!^Hv(3~@9Ode)G$PIC?AoHG}`E$^`t=o<N|3PzYpgA7U+yZDF3}~(sG*1|L
z8l?08322<igX;0}^76de+S)8o-3-DoH-Oq4Ah&?p*6Zq=!E=3}`5DkSBFGew-5?B_
zdj-uOgXa8@(<5jt3ut}=v=#?6#{^n?puHEQ^Zz%P{h&4wD11S6DhPwxX&?-82MB}Q
z0@4ARCjyNHE-r)2`F?r->VM<M|NlYugD}Vqp!68_7&7+@OON&!A!{H&YiU5~5pAAM
z9%O%8TU+AHnKQ$X-2t*2l+Hmk$bQg#8))7ZG+ziB6W%txfZ&|rt6%^B7v2B=-}WM8
zJr5{PfaYvL=E3|AYFAWNR_4{$*Jpv+pdbu$2WZ>`6c!-$pz(FkToY)H12k6#nr8yd
zZ-C~>Kyyr>xed@98EAf~CfW5r2v2Lu{10*iI6Yo~tj7V(8-vV4wjWdmfH0_S1HvFT
zfH24%APkECgYEX<`L0d1R^T~D(AYR=js=t+LGxUo`4!MyBY2JrYJY8t8^|i~x*%A3
zv<2^lM#Mj;UDnyznK)<8oG?&X0P639+UFpDgWLiN0}y>_aVB`)5Hw!}n!5$90RYWC
z&o8$751KCo<q6RI2xzXbA=L%!e^3~J901M}*Z=<qmC>NNTTtBu^FJtWRaI5xH8wV8
zf$}1#+yV6qKz%z<n1IS2P*{9<ar6JF$pPSbKhXR!C_RG4*Fj^`usi{pX9CUjf#%8T
zp>6=#4=x{X|NkFz`~Uwt-$5eqbrSNR_9Z9{g7P7#%@3kM?f_v>cz`g-9iVUm#RFJ3
z4&w5m_5VS0rl7gHmUL(Ed?}hzjPeg;e|L9x;=FnD!a#FFp!PV(9iT7=^{YXBYS6eT
z$Q_`t0F_4|Igq)a`CHIB09c;DmL5Uspka-Tk_WZ1Yierp+S}W6LE+Hf-w$422P$_#
zbswnw2c-p2c!1I($Zn8ZK<0w-#JfjV{=a>6?f>#}$ebTMJ?1!q=e|MeuvrWhlLz(3
zLE{{tF<np?gZfwX_4VL615n-sxe0_p@dCmicYrV`E{;wN`2XR_mH+P_Ujxr!gVSRP
zB0bKoiv(GZwf?_$?HUtkZ8gaLu&}U)_V%DwT{(DeIx{o#e^*x*c%3cCO`viSln+4e
z0EGc4en4UK`NggO=N4xF-`VU4UJC$AkBchZ{%@LE@c;FbJ0Sa!>pQ5o85r#B?2H{8
z94bNnsH>~XPfAKUZeU>WKRY`cJPzE~*Y_VZb^*#Cpl|?%Ifw>@Kd65PN(-Ry0J$Gz
z2{Hzm`RUWAOTT~r#%edr5xTm%p>yWU`48#`g6ewEybNe=Nli`de{^&-c%2+5eS+Ko
z!=Ug0xdVhj;Q_)RcYxdnsw+Tc2dH1lz`y`n_Y7*^!K}kZ%Y*DLEiHWono9)DNqBmC
zg2!J$ZYV4)1g#_g4=N8p^&rS>kX@ko2iXNG7eH(fe*5<ApPZbW^qQKQ;!~$ifzBE;
zfgZhx&0d(8JSeP^l9DE5WMmuz&GCT7=tDz8|AXQJG{06`TMJ$*1!@m~!X0Ek2!q;W
zpf(zeK6&!wFI`>T>ZGKk`Df0YdCLIVvH`OP7Y$DTpgagN3)Hp)h4-F4d;WvcAZRQd
zG_L{5A0T&v;u?fOaR4e8K>9##0fhyq+y<4IAb0NHzrUZzHS*y6-_z5RxNzaZFp%9K
zGeL0;azlE0`hRV0?f-s$e&8`}kQ+c4qz04+K<Ys02GmXhl^39OiJLZU0v(A7>MP*#
zGqO0i`~{Ui&CShOAoD<D@}N2&ROW!@7Gh&#!E?-@d;xMFD4m1C0Aw#H{z2_!(3}dW
z-M(<)LeRQgV(kXG18hGiErT#9TtOJ*4iE;}2da;Xii*H<GN84pAisms8z{a&VGZ&(
zs7$_m`SLOb1_n~>2HOv^r>m<AT>gXH0Ky<QfG|i7)&}0VapV8FbLajCjTM91g`hDf
zP<o`mZm|6zdtmi1C@q2f3o;XgL1i8&&w=tb$e*Az2Abywt-aX3eLJ{(Ak*I<yFpkU
z<VTPjKp4bE#-Q+rVNf{(D*Hh3ykWzJ|JScye|!4$=}ra)@D;Nlv&g}qy(XZ2HRNE>
z8hk?K8%{U<k#Denz=(1N3uqrMXiqM_J-aYDkUEfhFb36Q3=9m&=di%`?-IFh7xy^D
z>eZ`3d#bSdWA5C!&hzKb-?C`YqHjx<EP1zd>C#EdmMsH?3tau0HEZ6lUcEYh)v8rs
z@uf?bvMgS_*mJ>x1^d>nT?<|>0?N;zd<}~0j~_o?gKK7BU;xdh9XxmtG{5$H)v8qw
zR;*a@1(Xj#ePd91UH9?-|KQt@bx`)F|No!;2xQWK(DA!qV?b&_X&Tgq1J&7}_6#gf
zfy%P@myk8XpfQ9?U;h6$IS$qj>mM<I>R^yvpu7eump~YlRzZ3}Dih!S{}1W|Z-?|N
zK|(P6_5c6>+dyR#C?A2`3Tium()WcuOa4#Hhpa<Oe)}K1b{4d57PM{|)K>uQJuo=@
z|NqPf|Nn#LT0wnsklR7&A7t;!I!|z$`}6x(|7U;s{~u%qs4oucdx6FxK>a?`Q~&>4
z9Q_Y&!+_dUAa{exEs*0teHc(5YV*{>{~$9!Vle#rH)Ko)G>!o3vw^}76i=W!2-FS&
zsoUM=3T|(K`X8Xa2dM7@S{n%JZ>*Wq`5$Bks2}ce>HmLF{6$7a{s+x-gUT>aI6OGA
z@c*_3Tk!f-P}?2UZU^-nKz*m$RCkaS|AX)U|G(nR|NpaR&;Ac;4}#W+facXeaS2K<
zpl|>ygc27HZUC>3t4)T4>;M1%LE*m@6n+aAE(Fibg68Bv>jyx3L1uuoZmhHW|LVbI
zaCn0HP_3C@`@et_4+8@ODD8pDdQiCoip!v&AaIz1%4tws-aEAD|E4B)@OtjK72f|(
z?OF~pb}LN(zJ2?^^97*t3zTj^<u<6z1&R+)d5Y{75F1pN!}Nk^ka}4BgTfAEFUTxV
zJqfZOR3Cx*2_UmU<?{ah`|CmaU>H<RgWL@=2NV{dxgwCCKy@}~JPD*1)XxUh-A9fb
zLD35`qmF%zqX7FFM+RmnW?19MfD6OafYgI9KS(Vj13QC)f&c^Pv?tJsYm5v60uUbP
zyfr2U1qIOgaU9^&)|eRt1Ry-nS!*l|1_mIW0{EmgR;Wq^@HuO2P?ZYcQ`XoSY!Zu$
zQ*)DYDitbnbMlI9l}d~9tcsH}QgaiFb#pV5i}H)}(@J!c^K-2di*xnL43!je6Z10D
zQj1H%Qj3Z+^Yd(#4D}3@?0C5p6l_Y0N{hkw%@AptF+`t&f=zL1a%oX!NhR1E&<0?e
zqSV6D)Z&uVlz^hlvdo;+^weUwq=EuM+7*0FV`hGyPik3ejzSKIv{gzh_RK5G&rU5;
zQYg)IOioTMF1A%lOUx-wRkE|uhntP68E!t33JlwA^ikYuqYwAA9WR%SJ}f-#0vrPz
zU0gi<+#@2O3@A0qhXw?cA}c%?1Q-}Va~50%js{T%RR+BVTMYIYTr*f@$YrE#lx$RN
z)L^vAXq(Y7qd!K1#<Ip{#?Ho(#%0F6#!HNk8=o<LXUuG(U}9_HV-jUjW>Rl5)ntyz
zGLuav2ThKd+%S1&^4i4SG|05k^tI_XQ*kp}vuS2a%ubvAF=I97F;_IVH4irLGGAxD
z&z#x9%%ag^x`mdduVt2HmF0KKtya6O&RV%!`&*}2=UY#(v9!&w&9kkw-D7*m_Kxjq
z+aI<pb|QAtc3O63cFuO`c9nMRc602O*`2ZbZ^vgZZf|X$We+-DoPl8q=$=G_>&8tc
z-%S3R$eXH}ZZth<>S(^zJk-L)@`&Xb%e$5@Eg7w%t>#;c+t}E6+JxC8+2q-j*tFU7
z+03+gVDr@Gy^W@=o~@~^we1GmZD2Q?usvsc)%K3<W7}7@A8miw{<mef<F^yHQ?}Ew
zGqf|ebF}la3$;tMOS3DptF~*jYqy(gx5RF<9RmY{0RsbQ{;0rUk-<TO2L{fDX@(t!
zlMPQA-ZW%35;0OV(lD|x@-p%_ns2nxXrl3K;}yowjNcmnGG;KbHHkE-G3hrsXmZcQ
z$dt!S#7xJ`-E5xOQL~F?cg%S$BrW1CQZ4c=SS%eaBP>r?-Lw+6R<PExwy<`z_O`CK
z?y{a@z1DiW^(pIj)~Ys9Hn}!;ZGPD}+itSGXzOMdWS44JZa2wpmfa$|opzV(-r0S(
z`)kK$&uuSd?`WT8Uv1xSf7_nHfq}t;k%2+Wpvd5uL8sw%LwzGpqbQ@vMu&|~8C^5F
zWAwu4ozZurzea4vLdFut3dU;2M#dJ#uEzexp~msXjmFcA_Za^%W-`$+F*30*@iR#?
z=`mq5)igCW%{DDI-D7&l^oHqO)2F7dO+T6bF#T`JYQ}3OVkT*(Xr^UmW@c^XVCH7#
zWfou-Y8GvlV3u#zYSwKw*=&Z{0<)!NYt1&9?KC@KcGm2&*&VY#W=!T%<~Pmno4+uB
zZ!T!jX3=M{&|;0nMvKE1XDu#SytDXW!DlIHX>4g{>1G*b8Dp7ixy*8d<u%K@mftP^
zS!!CHwz_Ba!OGm)-#XH|#Ja}1$$EnI5$lWA&#c95Ol%r#*4bROd1Uj#M#$E}*3LG=
zcCGCe+mp5ec2ah(cCmKVcJuAd+dZ`7w>Pr4uurnjwlB9|XTRP4u>Bu<h5!bJ5(Wka
zRs%r;KZ9_CWP=)mxdzJ&&Kle@xNq>*;Dq68!*7O?Mj1xyjkXybFuG*)5*(@u#_Gln
z#v#U0#>vKI#<PrX8S9z&ne?0PFx_q@U?FaC&GNq`x3!Y>4(pfJdA2HcdUlWOKH6p2
zmxA&`0t15u=vW_v5Q8rUMusVdJ%$gA%8WaVJx$)2aG4sIPB5Ksy36#u#Zk*h>p9jZ
ztY2E6wS^o83!0!;HPAHBH83<VHLx_WHE=X2GiWwgY_Qkhy@9ylR--=S1;+d)J|@v7
z^GsHnY&JP!a^B>%iMna1=_J!Rrdv$!n(~{On+cgqm}gs5S!}Y{WAWF5!&1mn*;3E)
zoz;IUc57a1A!`Zi7V9qSW!C4crEJt}Ol_=eqHPjv+H6+ZY_mCJbIRtD%{?1-TYg(9
z+aq=^_Ur8r**~=Z4Dwq81Ne+nHUkNR2!jd(U*mk^6~^a{-y8ol7BDe2i7;U`l`xYv
z(>L=qOEgP2yJO~P?rVM&oHhh3A}u~y9I~{rinsb<_1NyK9lO1xy|#UzeX@P2eY^ck
z`_=Y)?axDOn!v!o!3c^saRW_*RfcyAzZm{DWH#b3;xQ61vNVb}sx@jc>M-gtnqV}=
zXok@oqXkB<j6N8BG5TTj$0*4-*SN#D-*}4g4C6V*dyStPOPVN{sF-M&=$IIon3!0Y
z*qF4L^q5RAnPM`-<gn>4QwB3uGhs83%azQGz%I`>+h(@g?5o)?Ge&bZb6#^Ha|QE8
z^DgrV<`Nd_7UmXq7H$^XEOuKQvAAsU&EmHOgQd7-zGbOpwdG{XZI%Zuk6T{1ykq&+
z@~h=<OI9mxD^V+HD^)8!D@!XoD|f3vs~D^4RvWEOTlw3B*~Hjvve{vC#OAk+u<asS
zM!O|;N9?xP-vx#D0tN=qgs7Rp62m$pKjV7ism9lgzZy?6Ib!n0B+Yb!=?2qhrXNgK
znfaP$n@=?VYR+q6Y~gL~WOLb8%+AR!8B`W-U|{fJU|?`F*krWLXqVAGqeDi=j7}My
zGx9f%F)lTpY<%AMyK$q*QxgtTB~xe9RMT~)-%S^qtuYHQ-)CNKnPgREHP33f?Q4)(
z2N)PSKnF}1WExC0*lw`Eh})FkRM=G9RN7SDRM}MB)Y{a~G~Tqubie5((^sZkX0c|i
zX7kK;nLRfXF_$;@HIFt=F<)Z7&HR(OxP^*^k42qDo5c}}9hQ47&sn{(s<K{aebxG@
z^>UlFHal$&*<7^|u~o3ux3#u?W@~E~WY=i7%x;POYI}wY;3A$u-9XQv(_otci{V+r
zw?-z$R>pzGamKaApgQt`={3{arVmX&nVOk_Dqs%=28Ia37{dg^6vGU|62l6^HHI4u
zx7h8mJ7Ran?uy+VyC-&U?7rCjv1764u@|wIu~)Izu{W`|v3Ifeu@AA20ma7$1_sc<
zBVX)(*mc;ius>n{!XDIq1%)q%frf#HL5e|!L5IN#gA)cX3^)u$3=Irz3?mFH3}+ZF
zF+5=Sz>vX6!N|cV#wfw4#;Cz)fzbh@2SyCW3dRn`3C20b3<8V{BB0d(1{?+&78;g1
zmIjt4mKK&amJXIKmL8TqmI0O_mJyaQmI;<AmKl~gmIan2mKByYmJOCImK~NomJ=+e
zSkADVW4XX`iRB8*HI^GJw^;75++%sb@`&XL%QKc2EFV}tv3z0q#`1&Z7t0@(e=HfS
zSgbg#c&r4hM64vNWULgdRID_tbgT@lOsp)dY^)rtT&z5-e5?YjLaZXJVyqIZQmitp
za;yrhN~|iZYOETpTC6&(UReFG;;@#m*0A=mj<AlgPOwg~&af`Aeqj5=_J!>mTMj!O
zI{`ZpI|(}(I|VxxI}JM>I}1A-I|n-#I}bY_y8ycoy9m1iyArz!yBfO&yB50+yB@m<
dc2hv94%AH<#iJoG8UmvsFd71*Auyyu008rizHtBm

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/t64.exe b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/t64.exe
new file mode 100644
index 0000000000000000000000000000000000000000..9da9b40de922fb203df6b9a1d0ad4139af536850
GIT binary patch
literal 102400
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
a;)=x$i#rxiSUh7fC}2kMXb23h5C8y3xyt<j

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/util.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/util.py
new file mode 100644
index 0000000..9d4bfd3
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/util.py
@@ -0,0 +1,1756 @@
+#
+# Copyright (C) 2012-2017 The Python Software Foundation.
+# See LICENSE.txt and CONTRIBUTORS.txt.
+#
+import codecs
+from collections import deque
+import contextlib
+import csv
+from glob import iglob as std_iglob
+import io
+import json
+import logging
+import os
+import py_compile
+import re
+import socket
+try:
+    import ssl
+except ImportError:  # pragma: no cover
+    ssl = None
+import subprocess
+import sys
+import tarfile
+import tempfile
+import textwrap
+
+try:
+    import threading
+except ImportError:  # pragma: no cover
+    import dummy_threading as threading
+import time
+
+from . import DistlibException
+from .compat import (string_types, text_type, shutil, raw_input, StringIO,
+                     cache_from_source, urlopen, urljoin, httplib, xmlrpclib,
+                     splittype, HTTPHandler, BaseConfigurator, valid_ident,
+                     Container, configparser, URLError, ZipFile, fsdecode,
+                     unquote, urlparse)
+
+logger = logging.getLogger(__name__)
+
+#
+# Requirement parsing code as per PEP 508
+#
+
+IDENTIFIER = re.compile(r'^([\w\.-]+)\s*')
+VERSION_IDENTIFIER = re.compile(r'^([\w\.*+-]+)\s*')
+COMPARE_OP = re.compile(r'^(<=?|>=?|={2,3}|[~!]=)\s*')
+MARKER_OP = re.compile(r'^((<=?)|(>=?)|={2,3}|[~!]=|in|not\s+in)\s*')
+OR = re.compile(r'^or\b\s*')
+AND = re.compile(r'^and\b\s*')
+NON_SPACE = re.compile(r'(\S+)\s*')
+STRING_CHUNK = re.compile(r'([\s\w\.{}()*+#:;,/?!~`@$%^&=|<>\[\]-]+)')
+
+
+def parse_marker(marker_string):
+    """
+    Parse a marker string and return a dictionary containing a marker expression.
+
+    The dictionary will contain keys "op", "lhs" and "rhs" for non-terminals in
+    the expression grammar, or strings. A string contained in quotes is to be
+    interpreted as a literal string, and a string not contained in quotes is a
+    variable (such as os_name).
+    """
+    def marker_var(remaining):
+        # either identifier, or literal string
+        m = IDENTIFIER.match(remaining)
+        if m:
+            result = m.groups()[0]
+            remaining = remaining[m.end():]
+        elif not remaining:
+            raise SyntaxError('unexpected end of input')
+        else:
+            q = remaining[0]
+            if q not in '\'"':
+                raise SyntaxError('invalid expression: %s' % remaining)
+            oq = '\'"'.replace(q, '')
+            remaining = remaining[1:]
+            parts = [q]
+            while remaining:
+                # either a string chunk, or oq, or q to terminate
+                if remaining[0] == q:
+                    break
+                elif remaining[0] == oq:
+                    parts.append(oq)
+                    remaining = remaining[1:]
+                else:
+                    m = STRING_CHUNK.match(remaining)
+                    if not m:
+                        raise SyntaxError('error in string literal: %s' % remaining)
+                    parts.append(m.groups()[0])
+                    remaining = remaining[m.end():]
+            else:
+                s = ''.join(parts)
+                raise SyntaxError('unterminated string: %s' % s)
+            parts.append(q)
+            result = ''.join(parts)
+            remaining = remaining[1:].lstrip() # skip past closing quote
+        return result, remaining
+
+    def marker_expr(remaining):
+        if remaining and remaining[0] == '(':
+            result, remaining = marker(remaining[1:].lstrip())
+            if remaining[0] != ')':
+                raise SyntaxError('unterminated parenthesis: %s' % remaining)
+            remaining = remaining[1:].lstrip()
+        else:
+            lhs, remaining = marker_var(remaining)
+            while remaining:
+                m = MARKER_OP.match(remaining)
+                if not m:
+                    break
+                op = m.groups()[0]
+                remaining = remaining[m.end():]
+                rhs, remaining = marker_var(remaining)
+                lhs = {'op': op, 'lhs': lhs, 'rhs': rhs}
+            result = lhs
+        return result, remaining
+
+    def marker_and(remaining):
+        lhs, remaining = marker_expr(remaining)
+        while remaining:
+            m = AND.match(remaining)
+            if not m:
+                break
+            remaining = remaining[m.end():]
+            rhs, remaining = marker_expr(remaining)
+            lhs = {'op': 'and', 'lhs': lhs, 'rhs': rhs}
+        return lhs, remaining
+
+    def marker(remaining):
+        lhs, remaining = marker_and(remaining)
+        while remaining:
+            m = OR.match(remaining)
+            if not m:
+                break
+            remaining = remaining[m.end():]
+            rhs, remaining = marker_and(remaining)
+            lhs = {'op': 'or', 'lhs': lhs, 'rhs': rhs}
+        return lhs, remaining
+
+    return marker(marker_string)
+
+
+def parse_requirement(req):
+    """
+    Parse a requirement passed in as a string. Return a Container
+    whose attributes contain the various parts of the requirement.
+    """
+    remaining = req.strip()
+    if not remaining or remaining.startswith('#'):
+        return None
+    m = IDENTIFIER.match(remaining)
+    if not m:
+        raise SyntaxError('name expected: %s' % remaining)
+    distname = m.groups()[0]
+    remaining = remaining[m.end():]
+    extras = mark_expr = versions = uri = None
+    if remaining and remaining[0] == '[':
+        i = remaining.find(']', 1)
+        if i < 0:
+            raise SyntaxError('unterminated extra: %s' % remaining)
+        s = remaining[1:i]
+        remaining = remaining[i + 1:].lstrip()
+        extras = []
+        while s:
+            m = IDENTIFIER.match(s)
+            if not m:
+                raise SyntaxError('malformed extra: %s' % s)
+            extras.append(m.groups()[0])
+            s = s[m.end():]
+            if not s:
+                break
+            if s[0] != ',':
+                raise SyntaxError('comma expected in extras: %s' % s)
+            s = s[1:].lstrip()
+        if not extras:
+            extras = None
+    if remaining:
+        if remaining[0] == '@':
+            # it's a URI
+            remaining = remaining[1:].lstrip()
+            m = NON_SPACE.match(remaining)
+            if not m:
+                raise SyntaxError('invalid URI: %s' % remaining)
+            uri = m.groups()[0]
+            t = urlparse(uri)
+            # there are issues with Python and URL parsing, so this test
+            # is a bit crude. See bpo-20271, bpo-23505. Python doesn't
+            # always parse invalid URLs correctly - it should raise
+            # exceptions for malformed URLs
+            if not (t.scheme and t.netloc):
+                raise SyntaxError('Invalid URL: %s' % uri)
+            remaining = remaining[m.end():].lstrip()
+        else:
+
+            def get_versions(ver_remaining):
+                """
+                Return a list of operator, version tuples if any are
+                specified, else None.
+                """
+                m = COMPARE_OP.match(ver_remaining)
+                versions = None
+                if m:
+                    versions = []
+                    while True:
+                        op = m.groups()[0]
+                        ver_remaining = ver_remaining[m.end():]
+                        m = VERSION_IDENTIFIER.match(ver_remaining)
+                        if not m:
+                            raise SyntaxError('invalid version: %s' % ver_remaining)
+                        v = m.groups()[0]
+                        versions.append((op, v))
+                        ver_remaining = ver_remaining[m.end():]
+                        if not ver_remaining or ver_remaining[0] != ',':
+                            break
+                        ver_remaining = ver_remaining[1:].lstrip()
+                        m = COMPARE_OP.match(ver_remaining)
+                        if not m:
+                            raise SyntaxError('invalid constraint: %s' % ver_remaining)
+                    if not versions:
+                        versions = None
+                return versions, ver_remaining
+
+            if remaining[0] != '(':
+                versions, remaining = get_versions(remaining)
+            else:
+                i = remaining.find(')', 1)
+                if i < 0:
+                    raise SyntaxError('unterminated parenthesis: %s' % remaining)
+                s = remaining[1:i]
+                remaining = remaining[i + 1:].lstrip()
+                # As a special diversion from PEP 508, allow a version number
+                # a.b.c in parentheses as a synonym for ~= a.b.c (because this
+                # is allowed in earlier PEPs)
+                if COMPARE_OP.match(s):
+                    versions, _ = get_versions(s)
+                else:
+                    m = VERSION_IDENTIFIER.match(s)
+                    if not m:
+                        raise SyntaxError('invalid constraint: %s' % s)
+                    v = m.groups()[0]
+                    s = s[m.end():].lstrip()
+                    if s:
+                        raise SyntaxError('invalid constraint: %s' % s)
+                    versions = [('~=', v)]
+
+    if remaining:
+        if remaining[0] != ';':
+            raise SyntaxError('invalid requirement: %s' % remaining)
+        remaining = remaining[1:].lstrip()
+
+        mark_expr, remaining = parse_marker(remaining)
+
+    if remaining and remaining[0] != '#':
+        raise SyntaxError('unexpected trailing data: %s' % remaining)
+
+    if not versions:
+        rs = distname
+    else:
+        rs = '%s %s' % (distname, ', '.join(['%s %s' % con for con in versions]))
+    return Container(name=distname, extras=extras, constraints=versions,
+                     marker=mark_expr, url=uri, requirement=rs)
+
+
+def get_resources_dests(resources_root, rules):
+    """Find destinations for resources files"""
+
+    def get_rel_path(root, path):
+        # normalizes and returns a lstripped-/-separated path
+        root = root.replace(os.path.sep, '/')
+        path = path.replace(os.path.sep, '/')
+        assert path.startswith(root)
+        return path[len(root):].lstrip('/')
+
+    destinations = {}
+    for base, suffix, dest in rules:
+        prefix = os.path.join(resources_root, base)
+        for abs_base in iglob(prefix):
+            abs_glob = os.path.join(abs_base, suffix)
+            for abs_path in iglob(abs_glob):
+                resource_file = get_rel_path(resources_root, abs_path)
+                if dest is None:  # remove the entry if it was here
+                    destinations.pop(resource_file, None)
+                else:
+                    rel_path = get_rel_path(abs_base, abs_path)
+                    rel_dest = dest.replace(os.path.sep, '/').rstrip('/')
+                    destinations[resource_file] = rel_dest + '/' + rel_path
+    return destinations
+
+
+def in_venv():
+    if hasattr(sys, 'real_prefix'):
+        # virtualenv venvs
+        result = True
+    else:
+        # PEP 405 venvs
+        result = sys.prefix != getattr(sys, 'base_prefix', sys.prefix)
+    return result
+
+
+def get_executable():
+# The __PYVENV_LAUNCHER__ dance is apparently no longer needed, as
+# changes to the stub launcher mean that sys.executable always points
+# to the stub on OS X
+#    if sys.platform == 'darwin' and ('__PYVENV_LAUNCHER__'
+#                                     in os.environ):
+#        result =  os.environ['__PYVENV_LAUNCHER__']
+#    else:
+#        result = sys.executable
+#    return result
+    result = os.path.normcase(sys.executable)
+    if not isinstance(result, text_type):
+        result = fsdecode(result)
+    return result
+
+
+def proceed(prompt, allowed_chars, error_prompt=None, default=None):
+    p = prompt
+    while True:
+        s = raw_input(p)
+        p = prompt
+        if not s and default:
+            s = default
+        if s:
+            c = s[0].lower()
+            if c in allowed_chars:
+                break
+            if error_prompt:
+                p = '%c: %s\n%s' % (c, error_prompt, prompt)
+    return c
+
+
+def extract_by_key(d, keys):
+    if isinstance(keys, string_types):
+        keys = keys.split()
+    result = {}
+    for key in keys:
+        if key in d:
+            result[key] = d[key]
+    return result
+
+def read_exports(stream):
+    if sys.version_info[0] >= 3:
+        # needs to be a text stream
+        stream = codecs.getreader('utf-8')(stream)
+    # Try to load as JSON, falling back on legacy format
+    data = stream.read()
+    stream = StringIO(data)
+    try:
+        jdata = json.load(stream)
+        result = jdata['extensions']['python.exports']['exports']
+        for group, entries in result.items():
+            for k, v in entries.items():
+                s = '%s = %s' % (k, v)
+                entry = get_export_entry(s)
+                assert entry is not None
+                entries[k] = entry
+        return result
+    except Exception:
+        stream.seek(0, 0)
+
+    def read_stream(cp, stream):
+        if hasattr(cp, 'read_file'):
+            cp.read_file(stream)
+        else:
+            cp.readfp(stream)
+
+    cp = configparser.ConfigParser()
+    try:
+        read_stream(cp, stream)
+    except configparser.MissingSectionHeaderError:
+        stream.close()
+        data = textwrap.dedent(data)
+        stream = StringIO(data)
+        read_stream(cp, stream)
+
+    result = {}
+    for key in cp.sections():
+        result[key] = entries = {}
+        for name, value in cp.items(key):
+            s = '%s = %s' % (name, value)
+            entry = get_export_entry(s)
+            assert entry is not None
+            #entry.dist = self
+            entries[name] = entry
+    return result
+
+
+def write_exports(exports, stream):
+    if sys.version_info[0] >= 3:
+        # needs to be a text stream
+        stream = codecs.getwriter('utf-8')(stream)
+    cp = configparser.ConfigParser()
+    for k, v in exports.items():
+        # TODO check k, v for valid values
+        cp.add_section(k)
+        for entry in v.values():
+            if entry.suffix is None:
+                s = entry.prefix
+            else:
+                s = '%s:%s' % (entry.prefix, entry.suffix)
+            if entry.flags:
+                s = '%s [%s]' % (s, ', '.join(entry.flags))
+            cp.set(k, entry.name, s)
+    cp.write(stream)
+
+
+@contextlib.contextmanager
+def tempdir():
+    td = tempfile.mkdtemp()
+    try:
+        yield td
+    finally:
+        shutil.rmtree(td)
+
+@contextlib.contextmanager
+def chdir(d):
+    cwd = os.getcwd()
+    try:
+        os.chdir(d)
+        yield
+    finally:
+        os.chdir(cwd)
+
+
+@contextlib.contextmanager
+def socket_timeout(seconds=15):
+    cto = socket.getdefaulttimeout()
+    try:
+        socket.setdefaulttimeout(seconds)
+        yield
+    finally:
+        socket.setdefaulttimeout(cto)
+
+
+class cached_property(object):
+    def __init__(self, func):
+        self.func = func
+        #for attr in ('__name__', '__module__', '__doc__'):
+        #    setattr(self, attr, getattr(func, attr, None))
+
+    def __get__(self, obj, cls=None):
+        if obj is None:
+            return self
+        value = self.func(obj)
+        object.__setattr__(obj, self.func.__name__, value)
+        #obj.__dict__[self.func.__name__] = value = self.func(obj)
+        return value
+
+def convert_path(pathname):
+    """Return 'pathname' as a name that will work on the native filesystem.
+
+    The path is split on '/' and put back together again using the current
+    directory separator.  Needed because filenames in the setup script are
+    always supplied in Unix style, and have to be converted to the local
+    convention before we can actually use them in the filesystem.  Raises
+    ValueError on non-Unix-ish systems if 'pathname' either starts or
+    ends with a slash.
+    """
+    if os.sep == '/':
+        return pathname
+    if not pathname:
+        return pathname
+    if pathname[0] == '/':
+        raise ValueError("path '%s' cannot be absolute" % pathname)
+    if pathname[-1] == '/':
+        raise ValueError("path '%s' cannot end with '/'" % pathname)
+
+    paths = pathname.split('/')
+    while os.curdir in paths:
+        paths.remove(os.curdir)
+    if not paths:
+        return os.curdir
+    return os.path.join(*paths)
+
+
+class FileOperator(object):
+    def __init__(self, dry_run=False):
+        self.dry_run = dry_run
+        self.ensured = set()
+        self._init_record()
+
+    def _init_record(self):
+        self.record = False
+        self.files_written = set()
+        self.dirs_created = set()
+
+    def record_as_written(self, path):
+        if self.record:
+            self.files_written.add(path)
+
+    def newer(self, source, target):
+        """Tell if the target is newer than the source.
+
+        Returns true if 'source' exists and is more recently modified than
+        'target', or if 'source' exists and 'target' doesn't.
+
+        Returns false if both exist and 'target' is the same age or younger
+        than 'source'. Raise PackagingFileError if 'source' does not exist.
+
+        Note that this test is not very accurate: files created in the same
+        second will have the same "age".
+        """
+        if not os.path.exists(source):
+            raise DistlibException("file '%r' does not exist" %
+                                   os.path.abspath(source))
+        if not os.path.exists(target):
+            return True
+
+        return os.stat(source).st_mtime > os.stat(target).st_mtime
+
+    def copy_file(self, infile, outfile, check=True):
+        """Copy a file respecting dry-run and force flags.
+        """
+        self.ensure_dir(os.path.dirname(outfile))
+        logger.info('Copying %s to %s', infile, outfile)
+        if not self.dry_run:
+            msg = None
+            if check:
+                if os.path.islink(outfile):
+                    msg = '%s is a symlink' % outfile
+                elif os.path.exists(outfile) and not os.path.isfile(outfile):
+                    msg = '%s is a non-regular file' % outfile
+            if msg:
+                raise ValueError(msg + ' which would be overwritten')
+            shutil.copyfile(infile, outfile)
+        self.record_as_written(outfile)
+
+    def copy_stream(self, instream, outfile, encoding=None):
+        assert not os.path.isdir(outfile)
+        self.ensure_dir(os.path.dirname(outfile))
+        logger.info('Copying stream %s to %s', instream, outfile)
+        if not self.dry_run:
+            if encoding is None:
+                outstream = open(outfile, 'wb')
+            else:
+                outstream = codecs.open(outfile, 'w', encoding=encoding)
+            try:
+                shutil.copyfileobj(instream, outstream)
+            finally:
+                outstream.close()
+        self.record_as_written(outfile)
+
+    def write_binary_file(self, path, data):
+        self.ensure_dir(os.path.dirname(path))
+        if not self.dry_run:
+            if os.path.exists(path):
+                os.remove(path)
+            with open(path, 'wb') as f:
+                f.write(data)
+        self.record_as_written(path)
+
+    def write_text_file(self, path, data, encoding):
+        self.write_binary_file(path, data.encode(encoding))
+
+    def set_mode(self, bits, mask, files):
+        if os.name == 'posix' or (os.name == 'java' and os._name == 'posix'):
+            # Set the executable bits (owner, group, and world) on
+            # all the files specified.
+            for f in files:
+                if self.dry_run:
+                    logger.info("changing mode of %s", f)
+                else:
+                    mode = (os.stat(f).st_mode | bits) & mask
+                    logger.info("changing mode of %s to %o", f, mode)
+                    os.chmod(f, mode)
+
+    set_executable_mode = lambda s, f: s.set_mode(0o555, 0o7777, f)
+
+    def ensure_dir(self, path):
+        path = os.path.abspath(path)
+        if path not in self.ensured and not os.path.exists(path):
+            self.ensured.add(path)
+            d, f = os.path.split(path)
+            self.ensure_dir(d)
+            logger.info('Creating %s' % path)
+            if not self.dry_run:
+                os.mkdir(path)
+            if self.record:
+                self.dirs_created.add(path)
+
+    def byte_compile(self, path, optimize=False, force=False, prefix=None, hashed_invalidation=False):
+        dpath = cache_from_source(path, not optimize)
+        logger.info('Byte-compiling %s to %s', path, dpath)
+        if not self.dry_run:
+            if force or self.newer(path, dpath):
+                if not prefix:
+                    diagpath = None
+                else:
+                    assert path.startswith(prefix)
+                    diagpath = path[len(prefix):]
+            compile_kwargs = {}
+            if hashed_invalidation and hasattr(py_compile, 'PycInvalidationMode'):
+                compile_kwargs['invalidation_mode'] = py_compile.PycInvalidationMode.CHECKED_HASH
+            py_compile.compile(path, dpath, diagpath, True, **compile_kwargs)     # raise error
+        self.record_as_written(dpath)
+        return dpath
+
+    def ensure_removed(self, path):
+        if os.path.exists(path):
+            if os.path.isdir(path) and not os.path.islink(path):
+                logger.debug('Removing directory tree at %s', path)
+                if not self.dry_run:
+                    shutil.rmtree(path)
+                if self.record:
+                    if path in self.dirs_created:
+                        self.dirs_created.remove(path)
+            else:
+                if os.path.islink(path):
+                    s = 'link'
+                else:
+                    s = 'file'
+                logger.debug('Removing %s %s', s, path)
+                if not self.dry_run:
+                    os.remove(path)
+                if self.record:
+                    if path in self.files_written:
+                        self.files_written.remove(path)
+
+    def is_writable(self, path):
+        result = False
+        while not result:
+            if os.path.exists(path):
+                result = os.access(path, os.W_OK)
+                break
+            parent = os.path.dirname(path)
+            if parent == path:
+                break
+            path = parent
+        return result
+
+    def commit(self):
+        """
+        Commit recorded changes, turn off recording, return
+        changes.
+        """
+        assert self.record
+        result = self.files_written, self.dirs_created
+        self._init_record()
+        return result
+
+    def rollback(self):
+        if not self.dry_run:
+            for f in list(self.files_written):
+                if os.path.exists(f):
+                    os.remove(f)
+            # dirs should all be empty now, except perhaps for
+            # __pycache__ subdirs
+            # reverse so that subdirs appear before their parents
+            dirs = sorted(self.dirs_created, reverse=True)
+            for d in dirs:
+                flist = os.listdir(d)
+                if flist:
+                    assert flist == ['__pycache__']
+                    sd = os.path.join(d, flist[0])
+                    os.rmdir(sd)
+                os.rmdir(d)     # should fail if non-empty
+        self._init_record()
+
+def resolve(module_name, dotted_path):
+    if module_name in sys.modules:
+        mod = sys.modules[module_name]
+    else:
+        mod = __import__(module_name)
+    if dotted_path is None:
+        result = mod
+    else:
+        parts = dotted_path.split('.')
+        result = getattr(mod, parts.pop(0))
+        for p in parts:
+            result = getattr(result, p)
+    return result
+
+
+class ExportEntry(object):
+    def __init__(self, name, prefix, suffix, flags):
+        self.name = name
+        self.prefix = prefix
+        self.suffix = suffix
+        self.flags = flags
+
+    @cached_property
+    def value(self):
+        return resolve(self.prefix, self.suffix)
+
+    def __repr__(self):  # pragma: no cover
+        return '<ExportEntry %s = %s:%s %s>' % (self.name, self.prefix,
+                                                self.suffix, self.flags)
+
+    def __eq__(self, other):
+        if not isinstance(other, ExportEntry):
+            result = False
+        else:
+            result = (self.name == other.name and
+                      self.prefix == other.prefix and
+                      self.suffix == other.suffix and
+                      self.flags == other.flags)
+        return result
+
+    __hash__ = object.__hash__
+
+
+ENTRY_RE = re.compile(r'''(?P<name>(\w|[-.+])+)
+                      \s*=\s*(?P<callable>(\w+)([:\.]\w+)*)
+                      \s*(\[\s*(?P<flags>\w+(=\w+)?(,\s*\w+(=\w+)?)*)\s*\])?
+                      ''', re.VERBOSE)
+
+def get_export_entry(specification):
+    m = ENTRY_RE.search(specification)
+    if not m:
+        result = None
+        if '[' in specification or ']' in specification:
+            raise DistlibException("Invalid specification "
+                                   "'%s'" % specification)
+    else:
+        d = m.groupdict()
+        name = d['name']
+        path = d['callable']
+        colons = path.count(':')
+        if colons == 0:
+            prefix, suffix = path, None
+        else:
+            if colons != 1:
+                raise DistlibException("Invalid specification "
+                                       "'%s'" % specification)
+            prefix, suffix = path.split(':')
+        flags = d['flags']
+        if flags is None:
+            if '[' in specification or ']' in specification:
+                raise DistlibException("Invalid specification "
+                                       "'%s'" % specification)
+            flags = []
+        else:
+            flags = [f.strip() for f in flags.split(',')]
+        result = ExportEntry(name, prefix, suffix, flags)
+    return result
+
+
+def get_cache_base(suffix=None):
+    """
+    Return the default base location for distlib caches. If the directory does
+    not exist, it is created. Use the suffix provided for the base directory,
+    and default to '.distlib' if it isn't provided.
+
+    On Windows, if LOCALAPPDATA is defined in the environment, then it is
+    assumed to be a directory, and will be the parent directory of the result.
+    On POSIX, and on Windows if LOCALAPPDATA is not defined, the user's home
+    directory - using os.expanduser('~') - will be the parent directory of
+    the result.
+
+    The result is just the directory '.distlib' in the parent directory as
+    determined above, or with the name specified with ``suffix``.
+    """
+    if suffix is None:
+        suffix = '.distlib'
+    if os.name == 'nt' and 'LOCALAPPDATA' in os.environ:
+        result = os.path.expandvars('$localappdata')
+    else:
+        # Assume posix, or old Windows
+        result = os.path.expanduser('~')
+    # we use 'isdir' instead of 'exists', because we want to
+    # fail if there's a file with that name
+    if os.path.isdir(result):
+        usable = os.access(result, os.W_OK)
+        if not usable:
+            logger.warning('Directory exists but is not writable: %s', result)
+    else:
+        try:
+            os.makedirs(result)
+            usable = True
+        except OSError:
+            logger.warning('Unable to create %s', result, exc_info=True)
+            usable = False
+    if not usable:
+        result = tempfile.mkdtemp()
+        logger.warning('Default location unusable, using %s', result)
+    return os.path.join(result, suffix)
+
+
+def path_to_cache_dir(path):
+    """
+    Convert an absolute path to a directory name for use in a cache.
+
+    The algorithm used is:
+
+    #. On Windows, any ``':'`` in the drive is replaced with ``'---'``.
+    #. Any occurrence of ``os.sep`` is replaced with ``'--'``.
+    #. ``'.cache'`` is appended.
+    """
+    d, p = os.path.splitdrive(os.path.abspath(path))
+    if d:
+        d = d.replace(':', '---')
+    p = p.replace(os.sep, '--')
+    return d + p + '.cache'
+
+
+def ensure_slash(s):
+    if not s.endswith('/'):
+        return s + '/'
+    return s
+
+
+def parse_credentials(netloc):
+    username = password = None
+    if '@' in netloc:
+        prefix, netloc = netloc.split('@', 1)
+        if ':' not in prefix:
+            username = prefix
+        else:
+            username, password = prefix.split(':', 1)
+    return username, password, netloc
+
+
+def get_process_umask():
+    result = os.umask(0o22)
+    os.umask(result)
+    return result
+
+def is_string_sequence(seq):
+    result = True
+    i = None
+    for i, s in enumerate(seq):
+        if not isinstance(s, string_types):
+            result = False
+            break
+    assert i is not None
+    return result
+
+PROJECT_NAME_AND_VERSION = re.compile('([a-z0-9_]+([.-][a-z_][a-z0-9_]*)*)-'
+                                      '([a-z0-9_.+-]+)', re.I)
+PYTHON_VERSION = re.compile(r'-py(\d\.?\d?)')
+
+
+def split_filename(filename, project_name=None):
+    """
+    Extract name, version, python version from a filename (no extension)
+
+    Return name, version, pyver or None
+    """
+    result = None
+    pyver = None
+    filename = unquote(filename).replace(' ', '-')
+    m = PYTHON_VERSION.search(filename)
+    if m:
+        pyver = m.group(1)
+        filename = filename[:m.start()]
+    if project_name and len(filename) > len(project_name) + 1:
+        m = re.match(re.escape(project_name) + r'\b', filename)
+        if m:
+            n = m.end()
+            result = filename[:n], filename[n + 1:], pyver
+    if result is None:
+        m = PROJECT_NAME_AND_VERSION.match(filename)
+        if m:
+            result = m.group(1), m.group(3), pyver
+    return result
+
+# Allow spaces in name because of legacy dists like "Twisted Core"
+NAME_VERSION_RE = re.compile(r'(?P<name>[\w .-]+)\s*'
+                             r'\(\s*(?P<ver>[^\s)]+)\)$')
+
+def parse_name_and_version(p):
+    """
+    A utility method used to get name and version from a string.
+
+    From e.g. a Provides-Dist value.
+
+    :param p: A value in a form 'foo (1.0)'
+    :return: The name and version as a tuple.
+    """
+    m = NAME_VERSION_RE.match(p)
+    if not m:
+        raise DistlibException('Ill-formed name/version string: \'%s\'' % p)
+    d = m.groupdict()
+    return d['name'].strip().lower(), d['ver']
+
+def get_extras(requested, available):
+    result = set()
+    requested = set(requested or [])
+    available = set(available or [])
+    if '*' in requested:
+        requested.remove('*')
+        result |= available
+    for r in requested:
+        if r == '-':
+            result.add(r)
+        elif r.startswith('-'):
+            unwanted = r[1:]
+            if unwanted not in available:
+                logger.warning('undeclared extra: %s' % unwanted)
+            if unwanted in result:
+                result.remove(unwanted)
+        else:
+            if r not in available:
+                logger.warning('undeclared extra: %s' % r)
+            result.add(r)
+    return result
+#
+# Extended metadata functionality
+#
+
+def _get_external_data(url):
+    result = {}
+    try:
+        # urlopen might fail if it runs into redirections,
+        # because of Python issue #13696. Fixed in locators
+        # using a custom redirect handler.
+        resp = urlopen(url)
+        headers = resp.info()
+        ct = headers.get('Content-Type')
+        if not ct.startswith('application/json'):
+            logger.debug('Unexpected response for JSON request: %s', ct)
+        else:
+            reader = codecs.getreader('utf-8')(resp)
+            #data = reader.read().decode('utf-8')
+            #result = json.loads(data)
+            result = json.load(reader)
+    except Exception as e:
+        logger.exception('Failed to get external data for %s: %s', url, e)
+    return result
+
+_external_data_base_url = 'https://www.red-dove.com/pypi/projects/'
+
+def get_project_data(name):
+    url = '%s/%s/project.json' % (name[0].upper(), name)
+    url = urljoin(_external_data_base_url, url)
+    result = _get_external_data(url)
+    return result
+
+def get_package_data(name, version):
+    url = '%s/%s/package-%s.json' % (name[0].upper(), name, version)
+    url = urljoin(_external_data_base_url, url)
+    return _get_external_data(url)
+
+
+class Cache(object):
+    """
+    A class implementing a cache for resources that need to live in the file system
+    e.g. shared libraries. This class was moved from resources to here because it
+    could be used by other modules, e.g. the wheel module.
+    """
+
+    def __init__(self, base):
+        """
+        Initialise an instance.
+
+        :param base: The base directory where the cache should be located.
+        """
+        # we use 'isdir' instead of 'exists', because we want to
+        # fail if there's a file with that name
+        if not os.path.isdir(base):  # pragma: no cover
+            os.makedirs(base)
+        if (os.stat(base).st_mode & 0o77) != 0:
+            logger.warning('Directory \'%s\' is not private', base)
+        self.base = os.path.abspath(os.path.normpath(base))
+
+    def prefix_to_dir(self, prefix):
+        """
+        Converts a resource prefix to a directory name in the cache.
+        """
+        return path_to_cache_dir(prefix)
+
+    def clear(self):
+        """
+        Clear the cache.
+        """
+        not_removed = []
+        for fn in os.listdir(self.base):
+            fn = os.path.join(self.base, fn)
+            try:
+                if os.path.islink(fn) or os.path.isfile(fn):
+                    os.remove(fn)
+                elif os.path.isdir(fn):
+                    shutil.rmtree(fn)
+            except Exception:
+                not_removed.append(fn)
+        return not_removed
+
+
+class EventMixin(object):
+    """
+    A very simple publish/subscribe system.
+    """
+    def __init__(self):
+        self._subscribers = {}
+
+    def add(self, event, subscriber, append=True):
+        """
+        Add a subscriber for an event.
+
+        :param event: The name of an event.
+        :param subscriber: The subscriber to be added (and called when the
+                           event is published).
+        :param append: Whether to append or prepend the subscriber to an
+                       existing subscriber list for the event.
+        """
+        subs = self._subscribers
+        if event not in subs:
+            subs[event] = deque([subscriber])
+        else:
+            sq = subs[event]
+            if append:
+                sq.append(subscriber)
+            else:
+                sq.appendleft(subscriber)
+
+    def remove(self, event, subscriber):
+        """
+        Remove a subscriber for an event.
+
+        :param event: The name of an event.
+        :param subscriber: The subscriber to be removed.
+        """
+        subs = self._subscribers
+        if event not in subs:
+            raise ValueError('No subscribers: %r' % event)
+        subs[event].remove(subscriber)
+
+    def get_subscribers(self, event):
+        """
+        Return an iterator for the subscribers for an event.
+        :param event: The event to return subscribers for.
+        """
+        return iter(self._subscribers.get(event, ()))
+
+    def publish(self, event, *args, **kwargs):
+        """
+        Publish a event and return a list of values returned by its
+        subscribers.
+
+        :param event: The event to publish.
+        :param args: The positional arguments to pass to the event's
+                     subscribers.
+        :param kwargs: The keyword arguments to pass to the event's
+                       subscribers.
+        """
+        result = []
+        for subscriber in self.get_subscribers(event):
+            try:
+                value = subscriber(event, *args, **kwargs)
+            except Exception:
+                logger.exception('Exception during event publication')
+                value = None
+            result.append(value)
+        logger.debug('publish %s: args = %s, kwargs = %s, result = %s',
+                     event, args, kwargs, result)
+        return result
+
+#
+# Simple sequencing
+#
+class Sequencer(object):
+    def __init__(self):
+        self._preds = {}
+        self._succs = {}
+        self._nodes = set()     # nodes with no preds/succs
+
+    def add_node(self, node):
+        self._nodes.add(node)
+
+    def remove_node(self, node, edges=False):
+        if node in self._nodes:
+            self._nodes.remove(node)
+        if edges:
+            for p in set(self._preds.get(node, ())):
+                self.remove(p, node)
+            for s in set(self._succs.get(node, ())):
+                self.remove(node, s)
+            # Remove empties
+            for k, v in list(self._preds.items()):
+                if not v:
+                    del self._preds[k]
+            for k, v in list(self._succs.items()):
+                if not v:
+                    del self._succs[k]
+
+    def add(self, pred, succ):
+        assert pred != succ
+        self._preds.setdefault(succ, set()).add(pred)
+        self._succs.setdefault(pred, set()).add(succ)
+
+    def remove(self, pred, succ):
+        assert pred != succ
+        try:
+            preds = self._preds[succ]
+            succs = self._succs[pred]
+        except KeyError:  # pragma: no cover
+            raise ValueError('%r not a successor of anything' % succ)
+        try:
+            preds.remove(pred)
+            succs.remove(succ)
+        except KeyError:  # pragma: no cover
+            raise ValueError('%r not a successor of %r' % (succ, pred))
+
+    def is_step(self, step):
+        return (step in self._preds or step in self._succs or
+                step in self._nodes)
+
+    def get_steps(self, final):
+        if not self.is_step(final):
+            raise ValueError('Unknown: %r' % final)
+        result = []
+        todo = []
+        seen = set()
+        todo.append(final)
+        while todo:
+            step = todo.pop(0)
+            if step in seen:
+                # if a step was already seen,
+                # move it to the end (so it will appear earlier
+                # when reversed on return) ... but not for the
+                # final step, as that would be confusing for
+                # users
+                if step != final:
+                    result.remove(step)
+                    result.append(step)
+            else:
+                seen.add(step)
+                result.append(step)
+                preds = self._preds.get(step, ())
+                todo.extend(preds)
+        return reversed(result)
+
+    @property
+    def strong_connections(self):
+        #http://en.wikipedia.org/wiki/Tarjan%27s_strongly_connected_components_algorithm
+        index_counter = [0]
+        stack = []
+        lowlinks = {}
+        index = {}
+        result = []
+
+        graph = self._succs
+
+        def strongconnect(node):
+            # set the depth index for this node to the smallest unused index
+            index[node] = index_counter[0]
+            lowlinks[node] = index_counter[0]
+            index_counter[0] += 1
+            stack.append(node)
+
+            # Consider successors
+            try:
+                successors = graph[node]
+            except Exception:
+                successors = []
+            for successor in successors:
+                if successor not in lowlinks:
+                    # Successor has not yet been visited
+                    strongconnect(successor)
+                    lowlinks[node] = min(lowlinks[node],lowlinks[successor])
+                elif successor in stack:
+                    # the successor is in the stack and hence in the current
+                    # strongly connected component (SCC)
+                    lowlinks[node] = min(lowlinks[node],index[successor])
+
+            # If `node` is a root node, pop the stack and generate an SCC
+            if lowlinks[node] == index[node]:
+                connected_component = []
+
+                while True:
+                    successor = stack.pop()
+                    connected_component.append(successor)
+                    if successor == node: break
+                component = tuple(connected_component)
+                # storing the result
+                result.append(component)
+
+        for node in graph:
+            if node not in lowlinks:
+                strongconnect(node)
+
+        return result
+
+    @property
+    def dot(self):
+        result = ['digraph G {']
+        for succ in self._preds:
+            preds = self._preds[succ]
+            for pred in preds:
+                result.append('  %s -> %s;' % (pred, succ))
+        for node in self._nodes:
+            result.append('  %s;' % node)
+        result.append('}')
+        return '\n'.join(result)
+
+#
+# Unarchiving functionality for zip, tar, tgz, tbz, whl
+#
+
+ARCHIVE_EXTENSIONS = ('.tar.gz', '.tar.bz2', '.tar', '.zip',
+                      '.tgz', '.tbz', '.whl')
+
+def unarchive(archive_filename, dest_dir, format=None, check=True):
+
+    def check_path(path):
+        if not isinstance(path, text_type):
+            path = path.decode('utf-8')
+        p = os.path.abspath(os.path.join(dest_dir, path))
+        if not p.startswith(dest_dir) or p[plen] != os.sep:
+            raise ValueError('path outside destination: %r' % p)
+
+    dest_dir = os.path.abspath(dest_dir)
+    plen = len(dest_dir)
+    archive = None
+    if format is None:
+        if archive_filename.endswith(('.zip', '.whl')):
+            format = 'zip'
+        elif archive_filename.endswith(('.tar.gz', '.tgz')):
+            format = 'tgz'
+            mode = 'r:gz'
+        elif archive_filename.endswith(('.tar.bz2', '.tbz')):
+            format = 'tbz'
+            mode = 'r:bz2'
+        elif archive_filename.endswith('.tar'):
+            format = 'tar'
+            mode = 'r'
+        else:  # pragma: no cover
+            raise ValueError('Unknown format for %r' % archive_filename)
+    try:
+        if format == 'zip':
+            archive = ZipFile(archive_filename, 'r')
+            if check:
+                names = archive.namelist()
+                for name in names:
+                    check_path(name)
+        else:
+            archive = tarfile.open(archive_filename, mode)
+            if check:
+                names = archive.getnames()
+                for name in names:
+                    check_path(name)
+        if format != 'zip' and sys.version_info[0] < 3:
+            # See Python issue 17153. If the dest path contains Unicode,
+            # tarfile extraction fails on Python 2.x if a member path name
+            # contains non-ASCII characters - it leads to an implicit
+            # bytes -> unicode conversion using ASCII to decode.
+            for tarinfo in archive.getmembers():
+                if not isinstance(tarinfo.name, text_type):
+                    tarinfo.name = tarinfo.name.decode('utf-8')
+        archive.extractall(dest_dir)
+
+    finally:
+        if archive:
+            archive.close()
+
+
+def zip_dir(directory):
+    """zip a directory tree into a BytesIO object"""
+    result = io.BytesIO()
+    dlen = len(directory)
+    with ZipFile(result, "w") as zf:
+        for root, dirs, files in os.walk(directory):
+            for name in files:
+                full = os.path.join(root, name)
+                rel = root[dlen:]
+                dest = os.path.join(rel, name)
+                zf.write(full, dest)
+    return result
+
+#
+# Simple progress bar
+#
+
+UNITS = ('', 'K', 'M', 'G','T','P')
+
+
+class Progress(object):
+    unknown = 'UNKNOWN'
+
+    def __init__(self, minval=0, maxval=100):
+        assert maxval is None or maxval >= minval
+        self.min = self.cur = minval
+        self.max = maxval
+        self.started = None
+        self.elapsed = 0
+        self.done = False
+
+    def update(self, curval):
+        assert self.min <= curval
+        assert self.max is None or curval <= self.max
+        self.cur = curval
+        now = time.time()
+        if self.started is None:
+            self.started = now
+        else:
+            self.elapsed = now - self.started
+
+    def increment(self, incr):
+        assert incr >= 0
+        self.update(self.cur + incr)
+
+    def start(self):
+        self.update(self.min)
+        return self
+
+    def stop(self):
+        if self.max is not None:
+            self.update(self.max)
+        self.done = True
+
+    @property
+    def maximum(self):
+        return self.unknown if self.max is None else self.max
+
+    @property
+    def percentage(self):
+        if self.done:
+            result = '100 %'
+        elif self.max is None:
+            result = ' ?? %'
+        else:
+            v = 100.0 * (self.cur - self.min) / (self.max - self.min)
+            result = '%3d %%' % v
+        return result
+
+    def format_duration(self, duration):
+        if (duration <= 0) and self.max is None or self.cur == self.min:
+            result = '??:??:??'
+        #elif duration < 1:
+        #    result = '--:--:--'
+        else:
+            result = time.strftime('%H:%M:%S', time.gmtime(duration))
+        return result
+
+    @property
+    def ETA(self):
+        if self.done:
+            prefix = 'Done'
+            t = self.elapsed
+            #import pdb; pdb.set_trace()
+        else:
+            prefix = 'ETA '
+            if self.max is None:
+                t = -1
+            elif self.elapsed == 0 or (self.cur == self.min):
+                t = 0
+            else:
+                #import pdb; pdb.set_trace()
+                t = float(self.max - self.min)
+                t /= self.cur - self.min
+                t = (t - 1) * self.elapsed
+        return '%s: %s' % (prefix, self.format_duration(t))
+
+    @property
+    def speed(self):
+        if self.elapsed == 0:
+            result = 0.0
+        else:
+            result = (self.cur - self.min) / self.elapsed
+        for unit in UNITS:
+            if result < 1000:
+                break
+            result /= 1000.0
+        return '%d %sB/s' % (result, unit)
+
+#
+# Glob functionality
+#
+
+RICH_GLOB = re.compile(r'\{([^}]*)\}')
+_CHECK_RECURSIVE_GLOB = re.compile(r'[^/\\,{]\*\*|\*\*[^/\\,}]')
+_CHECK_MISMATCH_SET = re.compile(r'^[^{]*\}|\{[^}]*$')
+
+
+def iglob(path_glob):
+    """Extended globbing function that supports ** and {opt1,opt2,opt3}."""
+    if _CHECK_RECURSIVE_GLOB.search(path_glob):
+        msg = """invalid glob %r: recursive glob "**" must be used alone"""
+        raise ValueError(msg % path_glob)
+    if _CHECK_MISMATCH_SET.search(path_glob):
+        msg = """invalid glob %r: mismatching set marker '{' or '}'"""
+        raise ValueError(msg % path_glob)
+    return _iglob(path_glob)
+
+
+def _iglob(path_glob):
+    rich_path_glob = RICH_GLOB.split(path_glob, 1)
+    if len(rich_path_glob) > 1:
+        assert len(rich_path_glob) == 3, rich_path_glob
+        prefix, set, suffix = rich_path_glob
+        for item in set.split(','):
+            for path in _iglob(''.join((prefix, item, suffix))):
+                yield path
+    else:
+        if '**' not in path_glob:
+            for item in std_iglob(path_glob):
+                yield item
+        else:
+            prefix, radical = path_glob.split('**', 1)
+            if prefix == '':
+                prefix = '.'
+            if radical == '':
+                radical = '*'
+            else:
+                # we support both
+                radical = radical.lstrip('/')
+                radical = radical.lstrip('\\')
+            for path, dir, files in os.walk(prefix):
+                path = os.path.normpath(path)
+                for fn in _iglob(os.path.join(path, radical)):
+                    yield fn
+
+if ssl:
+    from .compat import (HTTPSHandler as BaseHTTPSHandler, match_hostname,
+                         CertificateError)
+
+
+#
+# HTTPSConnection which verifies certificates/matches domains
+#
+
+    class HTTPSConnection(httplib.HTTPSConnection):
+        ca_certs = None # set this to the path to the certs file (.pem)
+        check_domain = True # only used if ca_certs is not None
+
+        # noinspection PyPropertyAccess
+        def connect(self):
+            sock = socket.create_connection((self.host, self.port), self.timeout)
+            if getattr(self, '_tunnel_host', False):
+                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)
+                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)
+                    logger.debug('Host verified: %s', self.host)
+                except CertificateError:  # pragma: no cover
+                    self.sock.shutdown(socket.SHUT_RDWR)
+                    self.sock.close()
+                    raise
+
+    class HTTPSHandler(BaseHTTPSHandler):
+        def __init__(self, ca_certs, check_domain=True):
+            BaseHTTPSHandler.__init__(self)
+            self.ca_certs = ca_certs
+            self.check_domain = check_domain
+
+        def _conn_maker(self, *args, **kwargs):
+            """
+            This is called to create a connection instance. Normally you'd
+            pass a connection class to do_open, but it doesn't actually check for
+            a class, and just expects a callable. As long as we behave just as a
+            constructor would have, we should be OK. If it ever changes so that
+            we *must* pass a class, we'll create an UnsafeHTTPSConnection class
+            which just sets check_domain to False in the class definition, and
+            choose which one to pass to do_open.
+            """
+            result = HTTPSConnection(*args, **kwargs)
+            if self.ca_certs:
+                result.ca_certs = self.ca_certs
+                result.check_domain = self.check_domain
+            return result
+
+        def https_open(self, req):
+            try:
+                return self.do_open(self._conn_maker, req)
+            except URLError as e:
+                if 'certificate verify failed' in str(e.reason):
+                    raise CertificateError('Unable to verify server certificate '
+                                           'for %s' % req.host)
+                else:
+                    raise
+
+    #
+    # To prevent against mixing HTTP traffic with HTTPS (examples: A Man-In-The-
+    # Middle proxy using HTTP listens on port 443, or an index mistakenly serves
+    # HTML containing a http://xyz link when it should be https://xyz),
+    # you can use the following handler class, which does not allow HTTP traffic.
+    #
+    # It works by inheriting from HTTPHandler - so build_opener won't add a
+    # handler for HTTP itself.
+    #
+    class HTTPSOnlyHandler(HTTPSHandler, HTTPHandler):
+        def http_open(self, req):
+            raise URLError('Unexpected HTTP request on what should be a secure '
+                           'connection: %s' % req)
+
+#
+# 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
+        xmlrpclib.Transport.__init__(self, use_datetime)
+
+    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 ssl:
+    class SafeTransport(xmlrpclib.SafeTransport):
+        def __init__(self, timeout, use_datetime=0):
+            self.timeout = timeout
+            xmlrpclib.SafeTransport.__init__(self, use_datetime)
+
+        def make_connection(self, host):
+            h, eh, kwargs = self.get_host_info(host)
+            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
+
+
+class ServerProxy(xmlrpclib.ServerProxy):
+    def __init__(self, uri, **kwargs):
+        self.timeout = timeout = kwargs.pop('timeout', None)
+        # The above classes only come into play if a timeout
+        # is specified
+        if timeout is not None:
+            scheme, _ = splittype(uri)
+            use_datetime = kwargs.get('use_datetime', 0)
+            if scheme == 'https':
+                tcls = SafeTransport
+            else:
+                tcls = Transport
+            kwargs['transport'] = t = tcls(timeout, use_datetime=use_datetime)
+            self.transport = t
+        xmlrpclib.ServerProxy.__init__(self, uri, **kwargs)
+
+#
+# CSV functionality. This is provided because on 2.x, the csv module can't
+# handle Unicode. However, we need to deal with Unicode in e.g. RECORD files.
+#
+
+def _csv_open(fn, mode, **kwargs):
+    if sys.version_info[0] < 3:
+        mode += 'b'
+    else:
+        kwargs['newline'] = ''
+        # Python 3 determines encoding from locale. Force 'utf-8'
+        # file encoding to match other forced utf-8 encoding
+        kwargs['encoding'] = 'utf-8'
+    return open(fn, mode, **kwargs)
+
+
+class CSVBase(object):
+    defaults = {
+        'delimiter': str(','),      # The strs are used because we need native
+        'quotechar': str('"'),      # str in the csv API (2.x won't take
+        'lineterminator': str('\n') # Unicode)
+    }
+
+    def __enter__(self):
+        return self
+
+    def __exit__(self, *exc_info):
+        self.stream.close()
+
+
+class CSVReader(CSVBase):
+    def __init__(self, **kwargs):
+        if 'stream' in kwargs:
+            stream = kwargs['stream']
+            if sys.version_info[0] >= 3:
+                # needs to be a text stream
+                stream = codecs.getreader('utf-8')(stream)
+            self.stream = stream
+        else:
+            self.stream = _csv_open(kwargs['path'], 'r')
+        self.reader = csv.reader(self.stream, **self.defaults)
+
+    def __iter__(self):
+        return self
+
+    def next(self):
+        result = next(self.reader)
+        if sys.version_info[0] < 3:
+            for i, item in enumerate(result):
+                if not isinstance(item, text_type):
+                    result[i] = item.decode('utf-8')
+        return result
+
+    __next__ = next
+
+class CSVWriter(CSVBase):
+    def __init__(self, fn, **kwargs):
+        self.stream = _csv_open(fn, 'w')
+        self.writer = csv.writer(self.stream, **self.defaults)
+
+    def writerow(self, row):
+        if sys.version_info[0] < 3:
+            r = []
+            for item in row:
+                if isinstance(item, text_type):
+                    item = item.encode('utf-8')
+                r.append(item)
+            row = r
+        self.writer.writerow(row)
+
+#
+#   Configurator functionality
+#
+
+class Configurator(BaseConfigurator):
+
+    value_converters = dict(BaseConfigurator.value_converters)
+    value_converters['inc'] = 'inc_convert'
+
+    def __init__(self, config, base=None):
+        super(Configurator, self).__init__(config)
+        self.base = base or os.getcwd()
+
+    def configure_custom(self, config):
+        def convert(o):
+            if isinstance(o, (list, tuple)):
+                result = type(o)([convert(i) for i in o])
+            elif isinstance(o, dict):
+                if '()' in o:
+                    result = self.configure_custom(o)
+                else:
+                    result = {}
+                    for k in o:
+                        result[k] = convert(o[k])
+            else:
+                result = self.convert(o)
+            return result
+
+        c = config.pop('()')
+        if not callable(c):
+            c = self.resolve(c)
+        props = config.pop('.', None)
+        # Check for valid identifiers
+        args = config.pop('[]', ())
+        if args:
+            args = tuple([convert(o) for o in args])
+        items = [(k, convert(config[k])) for k in config if valid_ident(k)]
+        kwargs = dict(items)
+        result = c(*args, **kwargs)
+        if props:
+            for n, v in props.items():
+                setattr(result, n, convert(v))
+        return result
+
+    def __getitem__(self, key):
+        result = self.config[key]
+        if isinstance(result, dict) and '()' in result:
+            self.config[key] = result = self.configure_custom(result)
+        return result
+
+    def inc_convert(self, value):
+        """Default converter for the inc:// protocol."""
+        if not os.path.isabs(value):
+            value = os.path.join(self.base, value)
+        with codecs.open(value, 'r', encoding='utf-8') as f:
+            result = json.load(f)
+        return result
+
+
+class SubprocessMixin(object):
+    """
+    Mixin for running subprocesses and capturing their output
+    """
+    def __init__(self, verbose=False, progress=None):
+        self.verbose = verbose
+        self.progress = progress
+
+    def reader(self, stream, context):
+        """
+        Read lines from a subprocess' output stream and either pass to a progress
+        callable (if specified) or write progress information to sys.stderr.
+        """
+        progress = self.progress
+        verbose = self.verbose
+        while True:
+            s = stream.readline()
+            if not s:
+                break
+            if progress is not None:
+                progress(s, context)
+            else:
+                if not verbose:
+                    sys.stderr.write('.')
+                else:
+                    sys.stderr.write(s.decode('utf-8'))
+                sys.stderr.flush()
+        stream.close()
+
+    def run_command(self, cmd, **kwargs):
+        p = subprocess.Popen(cmd, stdout=subprocess.PIPE,
+                             stderr=subprocess.PIPE, **kwargs)
+        t1 = threading.Thread(target=self.reader, args=(p.stdout, 'stdout'))
+        t1.start()
+        t2 = threading.Thread(target=self.reader, args=(p.stderr, 'stderr'))
+        t2.start()
+        p.wait()
+        t1.join()
+        t2.join()
+        if self.progress is not None:
+            self.progress('done.', 'main')
+        elif self.verbose:
+            sys.stderr.write('done.\n')
+        return p
+
+
+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()
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/util.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/util.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..386de79e43bab804dd231fb9a579981bdc1928ce
GIT binary patch
literal 67805
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
TqLQMV++uuUl48PQ=3;sPjVId0

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/version.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/version.py
new file mode 100644
index 0000000..3eebe18
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/version.py
@@ -0,0 +1,736 @@
+# -*- coding: utf-8 -*-
+#
+# Copyright (C) 2012-2017 The Python Software Foundation.
+# See LICENSE.txt and CONTRIBUTORS.txt.
+#
+"""
+Implementation of a flexible versioning scheme providing support for PEP-440,
+setuptools-compatible and semantic versioning.
+"""
+
+import logging
+import re
+
+from .compat import string_types
+from .util import parse_requirement
+
+__all__ = ['NormalizedVersion', 'NormalizedMatcher',
+           'LegacyVersion', 'LegacyMatcher',
+           'SemanticVersion', 'SemanticMatcher',
+           'UnsupportedVersionError', 'get_scheme']
+
+logger = logging.getLogger(__name__)
+
+
+class UnsupportedVersionError(ValueError):
+    """This is an unsupported version."""
+    pass
+
+
+class Version(object):
+    def __init__(self, s):
+        self._string = s = s.strip()
+        self._parts = parts = self.parse(s)
+        assert isinstance(parts, tuple)
+        assert len(parts) > 0
+
+    def parse(self, s):
+        raise NotImplementedError('please implement in a subclass')
+
+    def _check_compatible(self, other):
+        if type(self) != type(other):
+            raise TypeError('cannot compare %r and %r' % (self, other))
+
+    def __eq__(self, other):
+        self._check_compatible(other)
+        return self._parts == other._parts
+
+    def __ne__(self, other):
+        return not self.__eq__(other)
+
+    def __lt__(self, other):
+        self._check_compatible(other)
+        return self._parts < other._parts
+
+    def __gt__(self, other):
+        return not (self.__lt__(other) or self.__eq__(other))
+
+    def __le__(self, other):
+        return self.__lt__(other) or self.__eq__(other)
+
+    def __ge__(self, other):
+        return self.__gt__(other) or self.__eq__(other)
+
+    # See http://docs.python.org/reference/datamodel#object.__hash__
+    def __hash__(self):
+        return hash(self._parts)
+
+    def __repr__(self):
+        return "%s('%s')" % (self.__class__.__name__, self._string)
+
+    def __str__(self):
+        return self._string
+
+    @property
+    def is_prerelease(self):
+        raise NotImplementedError('Please implement in subclasses.')
+
+
+class Matcher(object):
+    version_class = None
+
+    # value is either a callable or the name of a method
+    _operators = {
+        '<': lambda v, c, p: v < c,
+        '>': lambda v, c, p: v > c,
+        '<=': lambda v, c, p: v == c or v < c,
+        '>=': lambda v, c, p: v == c or v > c,
+        '==': lambda v, c, p: v == c,
+        '===': lambda v, c, p: v == c,
+        # by default, compatible => >=.
+        '~=': lambda v, c, p: v == c or v > c,
+        '!=': lambda v, c, p: v != c,
+    }
+
+    # this is a method only to support alternative implementations
+    # via overriding
+    def parse_requirement(self, s):
+        return parse_requirement(s)
+
+    def __init__(self, s):
+        if self.version_class is None:
+            raise ValueError('Please specify a version class')
+        self._string = s = s.strip()
+        r = self.parse_requirement(s)
+        if not r:
+            raise ValueError('Not valid: %r' % s)
+        self.name = r.name
+        self.key = self.name.lower()    # for case-insensitive comparisons
+        clist = []
+        if r.constraints:
+            # import pdb; pdb.set_trace()
+            for op, s in r.constraints:
+                if s.endswith('.*'):
+                    if op not in ('==', '!='):
+                        raise ValueError('\'.*\' not allowed for '
+                                         '%r constraints' % op)
+                    # Could be a partial version (e.g. for '2.*') which
+                    # won't parse as a version, so keep it as a string
+                    vn, prefix = s[:-2], True
+                    # Just to check that vn is a valid version
+                    self.version_class(vn)
+                else:
+                    # Should parse as a version, so we can create an
+                    # instance for the comparison
+                    vn, prefix = self.version_class(s), False
+                clist.append((op, vn, prefix))
+        self._parts = tuple(clist)
+
+    def match(self, version):
+        """
+        Check if the provided version matches the constraints.
+
+        :param version: The version to match against this instance.
+        :type version: String or :class:`Version` instance.
+        """
+        if isinstance(version, string_types):
+            version = self.version_class(version)
+        for operator, constraint, prefix in self._parts:
+            f = self._operators.get(operator)
+            if isinstance(f, string_types):
+                f = getattr(self, f)
+            if not f:
+                msg = ('%r not implemented '
+                       'for %s' % (operator, self.__class__.__name__))
+                raise NotImplementedError(msg)
+            if not f(version, constraint, prefix):
+                return False
+        return True
+
+    @property
+    def exact_version(self):
+        result = None
+        if len(self._parts) == 1 and self._parts[0][0] in ('==', '==='):
+            result = self._parts[0][1]
+        return result
+
+    def _check_compatible(self, other):
+        if type(self) != type(other) or self.name != other.name:
+            raise TypeError('cannot compare %s and %s' % (self, other))
+
+    def __eq__(self, other):
+        self._check_compatible(other)
+        return self.key == other.key and self._parts == other._parts
+
+    def __ne__(self, other):
+        return not self.__eq__(other)
+
+    # See http://docs.python.org/reference/datamodel#object.__hash__
+    def __hash__(self):
+        return hash(self.key) + hash(self._parts)
+
+    def __repr__(self):
+        return "%s(%r)" % (self.__class__.__name__, self._string)
+
+    def __str__(self):
+        return self._string
+
+
+PEP440_VERSION_RE = re.compile(r'^v?(\d+!)?(\d+(\.\d+)*)((a|b|c|rc)(\d+))?'
+                               r'(\.(post)(\d+))?(\.(dev)(\d+))?'
+                               r'(\+([a-zA-Z\d]+(\.[a-zA-Z\d]+)?))?$')
+
+
+def _pep_440_key(s):
+    s = s.strip()
+    m = PEP440_VERSION_RE.match(s)
+    if not m:
+        raise UnsupportedVersionError('Not a valid version: %s' % s)
+    groups = m.groups()
+    nums = tuple(int(v) for v in groups[1].split('.'))
+    while len(nums) > 1 and nums[-1] == 0:
+        nums = nums[:-1]
+
+    if not groups[0]:
+        epoch = 0
+    else:
+        epoch = int(groups[0])
+    pre = groups[4:6]
+    post = groups[7:9]
+    dev = groups[10:12]
+    local = groups[13]
+    if pre == (None, None):
+        pre = ()
+    else:
+        pre = pre[0], int(pre[1])
+    if post == (None, None):
+        post = ()
+    else:
+        post = post[0], int(post[1])
+    if dev == (None, None):
+        dev = ()
+    else:
+        dev = dev[0], int(dev[1])
+    if local is None:
+        local = ()
+    else:
+        parts = []
+        for part in local.split('.'):
+            # to ensure that numeric compares as > lexicographic, avoid
+            # comparing them directly, but encode a tuple which ensures
+            # correct sorting
+            if part.isdigit():
+                part = (1, int(part))
+            else:
+                part = (0, part)
+            parts.append(part)
+        local = tuple(parts)
+    if not pre:
+        # either before pre-release, or final release and after
+        if not post and dev:
+            # before pre-release
+            pre = ('a', -1)     # to sort before a0
+        else:
+            pre = ('z',)        # to sort after all pre-releases
+    # now look at the state of post and dev.
+    if not post:
+        post = ('_',)   # sort before 'a'
+    if not dev:
+        dev = ('final',)
+
+    #print('%s -> %s' % (s, m.groups()))
+    return epoch, nums, pre, post, dev, local
+
+
+_normalized_key = _pep_440_key
+
+
+class NormalizedVersion(Version):
+    """A rational version.
+
+    Good:
+        1.2         # equivalent to "1.2.0"
+        1.2.0
+        1.2a1
+        1.2.3a2
+        1.2.3b1
+        1.2.3c1
+        1.2.3.4
+        TODO: fill this out
+
+    Bad:
+        1           # minimum two numbers
+        1.2a        # release level must have a release serial
+        1.2.3b
+    """
+    def parse(self, s):
+        result = _normalized_key(s)
+        # _normalized_key loses trailing zeroes in the release
+        # clause, since that's needed to ensure that X.Y == X.Y.0 == X.Y.0.0
+        # However, PEP 440 prefix matching needs it: for example,
+        # (~= 1.4.5.0) matches differently to (~= 1.4.5.0.0).
+        m = PEP440_VERSION_RE.match(s)      # must succeed
+        groups = m.groups()
+        self._release_clause = tuple(int(v) for v in groups[1].split('.'))
+        return result
+
+    PREREL_TAGS = set(['a', 'b', 'c', 'rc', 'dev'])
+
+    @property
+    def is_prerelease(self):
+        return any(t[0] in self.PREREL_TAGS for t in self._parts if t)
+
+
+def _match_prefix(x, y):
+    x = str(x)
+    y = str(y)
+    if x == y:
+        return True
+    if not x.startswith(y):
+        return False
+    n = len(y)
+    return x[n] == '.'
+
+
+class NormalizedMatcher(Matcher):
+    version_class = NormalizedVersion
+
+    # value is either a callable or the name of a method
+    _operators = {
+        '~=': '_match_compatible',
+        '<': '_match_lt',
+        '>': '_match_gt',
+        '<=': '_match_le',
+        '>=': '_match_ge',
+        '==': '_match_eq',
+        '===': '_match_arbitrary',
+        '!=': '_match_ne',
+    }
+
+    def _adjust_local(self, version, constraint, prefix):
+        if prefix:
+            strip_local = '+' not in constraint and version._parts[-1]
+        else:
+            # both constraint and version are
+            # NormalizedVersion instances.
+            # If constraint does not have a local component,
+            # ensure the version doesn't, either.
+            strip_local = not constraint._parts[-1] and version._parts[-1]
+        if strip_local:
+            s = version._string.split('+', 1)[0]
+            version = self.version_class(s)
+        return version, constraint
+
+    def _match_lt(self, version, constraint, prefix):
+        version, constraint = self._adjust_local(version, constraint, prefix)
+        if version >= constraint:
+            return False
+        release_clause = constraint._release_clause
+        pfx = '.'.join([str(i) for i in release_clause])
+        return not _match_prefix(version, pfx)
+
+    def _match_gt(self, version, constraint, prefix):
+        version, constraint = self._adjust_local(version, constraint, prefix)
+        if version <= constraint:
+            return False
+        release_clause = constraint._release_clause
+        pfx = '.'.join([str(i) for i in release_clause])
+        return not _match_prefix(version, pfx)
+
+    def _match_le(self, version, constraint, prefix):
+        version, constraint = self._adjust_local(version, constraint, prefix)
+        return version <= constraint
+
+    def _match_ge(self, version, constraint, prefix):
+        version, constraint = self._adjust_local(version, constraint, prefix)
+        return version >= constraint
+
+    def _match_eq(self, version, constraint, prefix):
+        version, constraint = self._adjust_local(version, constraint, prefix)
+        if not prefix:
+            result = (version == constraint)
+        else:
+            result = _match_prefix(version, constraint)
+        return result
+
+    def _match_arbitrary(self, version, constraint, prefix):
+        return str(version) == str(constraint)
+
+    def _match_ne(self, version, constraint, prefix):
+        version, constraint = self._adjust_local(version, constraint, prefix)
+        if not prefix:
+            result = (version != constraint)
+        else:
+            result = not _match_prefix(version, constraint)
+        return result
+
+    def _match_compatible(self, version, constraint, prefix):
+        version, constraint = self._adjust_local(version, constraint, prefix)
+        if version == constraint:
+            return True
+        if version < constraint:
+            return False
+#        if not prefix:
+#            return True
+        release_clause = constraint._release_clause
+        if len(release_clause) > 1:
+            release_clause = release_clause[:-1]
+        pfx = '.'.join([str(i) for i in release_clause])
+        return _match_prefix(version, pfx)
+
+_REPLACEMENTS = (
+    (re.compile('[.+-]$'), ''),                     # remove trailing puncts
+    (re.compile(r'^[.](\d)'), r'0.\1'),             # .N -> 0.N at start
+    (re.compile('^[.-]'), ''),                      # remove leading puncts
+    (re.compile(r'^\((.*)\)$'), r'\1'),             # remove parentheses
+    (re.compile(r'^v(ersion)?\s*(\d+)'), r'\2'),    # remove leading v(ersion)
+    (re.compile(r'^r(ev)?\s*(\d+)'), r'\2'),        # remove leading v(ersion)
+    (re.compile('[.]{2,}'), '.'),                   # multiple runs of '.'
+    (re.compile(r'\b(alfa|apha)\b'), 'alpha'),      # misspelt alpha
+    (re.compile(r'\b(pre-alpha|prealpha)\b'),
+                'pre.alpha'),                       # standardise
+    (re.compile(r'\(beta\)$'), 'beta'),             # remove parentheses
+)
+
+_SUFFIX_REPLACEMENTS = (
+    (re.compile('^[:~._+-]+'), ''),                   # remove leading puncts
+    (re.compile('[,*")([\\]]'), ''),                  # remove unwanted chars
+    (re.compile('[~:+_ -]'), '.'),                    # replace illegal chars
+    (re.compile('[.]{2,}'), '.'),                   # multiple runs of '.'
+    (re.compile(r'\.$'), ''),                       # trailing '.'
+)
+
+_NUMERIC_PREFIX = re.compile(r'(\d+(\.\d+)*)')
+
+
+def _suggest_semantic_version(s):
+    """
+    Try to suggest a semantic form for a version for which
+    _suggest_normalized_version couldn't come up with anything.
+    """
+    result = s.strip().lower()
+    for pat, repl in _REPLACEMENTS:
+        result = pat.sub(repl, result)
+    if not result:
+        result = '0.0.0'
+
+    # Now look for numeric prefix, and separate it out from
+    # the rest.
+    #import pdb; pdb.set_trace()
+    m = _NUMERIC_PREFIX.match(result)
+    if not m:
+        prefix = '0.0.0'
+        suffix = result
+    else:
+        prefix = m.groups()[0].split('.')
+        prefix = [int(i) for i in prefix]
+        while len(prefix) < 3:
+            prefix.append(0)
+        if len(prefix) == 3:
+            suffix = result[m.end():]
+        else:
+            suffix = '.'.join([str(i) for i in prefix[3:]]) + result[m.end():]
+            prefix = prefix[:3]
+        prefix = '.'.join([str(i) for i in prefix])
+        suffix = suffix.strip()
+    if suffix:
+        #import pdb; pdb.set_trace()
+        # massage the suffix.
+        for pat, repl in _SUFFIX_REPLACEMENTS:
+            suffix = pat.sub(repl, suffix)
+
+    if not suffix:
+        result = prefix
+    else:
+        sep = '-' if 'dev' in suffix else '+'
+        result = prefix + sep + suffix
+    if not is_semver(result):
+        result = None
+    return result
+
+
+def _suggest_normalized_version(s):
+    """Suggest a normalized version close to the given version string.
+
+    If you have a version string that isn't rational (i.e. NormalizedVersion
+    doesn't like it) then you might be able to get an equivalent (or close)
+    rational version from this function.
+
+    This does a number of simple normalizations to the given string, based
+    on observation of versions currently in use on PyPI. Given a dump of
+    those version during PyCon 2009, 4287 of them:
+    - 2312 (53.93%) match NormalizedVersion without change
+      with the automatic suggestion
+    - 3474 (81.04%) match when using this suggestion method
+
+    @param s {str} An irrational version string.
+    @returns A rational version string, or None, if couldn't determine one.
+    """
+    try:
+        _normalized_key(s)
+        return s   # already rational
+    except UnsupportedVersionError:
+        pass
+
+    rs = s.lower()
+
+    # part of this could use maketrans
+    for orig, repl in (('-alpha', 'a'), ('-beta', 'b'), ('alpha', 'a'),
+                       ('beta', 'b'), ('rc', 'c'), ('-final', ''),
+                       ('-pre', 'c'),
+                       ('-release', ''), ('.release', ''), ('-stable', ''),
+                       ('+', '.'), ('_', '.'), (' ', ''), ('.final', ''),
+                       ('final', '')):
+        rs = rs.replace(orig, repl)
+
+    # if something ends with dev or pre, we add a 0
+    rs = re.sub(r"pre$", r"pre0", rs)
+    rs = re.sub(r"dev$", r"dev0", rs)
+
+    # if we have something like "b-2" or "a.2" at the end of the
+    # version, that is probably beta, alpha, etc
+    # let's remove the dash or dot
+    rs = re.sub(r"([abc]|rc)[\-\.](\d+)$", r"\1\2", rs)
+
+    # 1.0-dev-r371 -> 1.0.dev371
+    # 0.1-dev-r79 -> 0.1.dev79
+    rs = re.sub(r"[\-\.](dev)[\-\.]?r?(\d+)$", r".\1\2", rs)
+
+    # Clean: 2.0.a.3, 2.0.b1, 0.9.0~c1
+    rs = re.sub(r"[.~]?([abc])\.?", r"\1", rs)
+
+    # Clean: v0.3, v1.0
+    if rs.startswith('v'):
+        rs = rs[1:]
+
+    # Clean leading '0's on numbers.
+    #TODO: unintended side-effect on, e.g., "2003.05.09"
+    # PyPI stats: 77 (~2%) better
+    rs = re.sub(r"\b0+(\d+)(?!\d)", r"\1", rs)
+
+    # Clean a/b/c with no version. E.g. "1.0a" -> "1.0a0". Setuptools infers
+    # zero.
+    # PyPI stats: 245 (7.56%) better
+    rs = re.sub(r"(\d+[abc])$", r"\g<1>0", rs)
+
+    # the 'dev-rNNN' tag is a dev tag
+    rs = re.sub(r"\.?(dev-r|dev\.r)\.?(\d+)$", r".dev\2", rs)
+
+    # clean the - when used as a pre delimiter
+    rs = re.sub(r"-(a|b|c)(\d+)$", r"\1\2", rs)
+
+    # a terminal "dev" or "devel" can be changed into ".dev0"
+    rs = re.sub(r"[\.\-](dev|devel)$", r".dev0", rs)
+
+    # a terminal "dev" can be changed into ".dev0"
+    rs = re.sub(r"(?![\.\-])dev$", r".dev0", rs)
+
+    # a terminal "final" or "stable" can be removed
+    rs = re.sub(r"(final|stable)$", "", rs)
+
+    # The 'r' and the '-' tags are post release tags
+    #   0.4a1.r10       ->  0.4a1.post10
+    #   0.9.33-17222    ->  0.9.33.post17222
+    #   0.9.33-r17222   ->  0.9.33.post17222
+    rs = re.sub(r"\.?(r|-|-r)\.?(\d+)$", r".post\2", rs)
+
+    # Clean 'r' instead of 'dev' usage:
+    #   0.9.33+r17222   ->  0.9.33.dev17222
+    #   1.0dev123       ->  1.0.dev123
+    #   1.0.git123      ->  1.0.dev123
+    #   1.0.bzr123      ->  1.0.dev123
+    #   0.1a0dev.123    ->  0.1a0.dev123
+    # PyPI stats:  ~150 (~4%) better
+    rs = re.sub(r"\.?(dev|git|bzr)\.?(\d+)$", r".dev\2", rs)
+
+    # Clean '.pre' (normalized from '-pre' above) instead of 'c' usage:
+    #   0.2.pre1        ->  0.2c1
+    #   0.2-c1         ->  0.2c1
+    #   1.0preview123   ->  1.0c123
+    # PyPI stats: ~21 (0.62%) better
+    rs = re.sub(r"\.?(pre|preview|-c)(\d+)$", r"c\g<2>", rs)
+
+    # Tcl/Tk uses "px" for their post release markers
+    rs = re.sub(r"p(\d+)$", r".post\1", rs)
+
+    try:
+        _normalized_key(rs)
+    except UnsupportedVersionError:
+        rs = None
+    return rs
+
+#
+#   Legacy version processing (distribute-compatible)
+#
+
+_VERSION_PART = re.compile(r'([a-z]+|\d+|[\.-])', re.I)
+_VERSION_REPLACE = {
+    'pre': 'c',
+    'preview': 'c',
+    '-': 'final-',
+    'rc': 'c',
+    'dev': '@',
+    '': None,
+    '.': None,
+}
+
+
+def _legacy_key(s):
+    def get_parts(s):
+        result = []
+        for p in _VERSION_PART.split(s.lower()):
+            p = _VERSION_REPLACE.get(p, p)
+            if p:
+                if '0' <= p[:1] <= '9':
+                    p = p.zfill(8)
+                else:
+                    p = '*' + p
+                result.append(p)
+        result.append('*final')
+        return result
+
+    result = []
+    for p in get_parts(s):
+        if p.startswith('*'):
+            if p < '*final':
+                while result and result[-1] == '*final-':
+                    result.pop()
+            while result and result[-1] == '00000000':
+                result.pop()
+        result.append(p)
+    return tuple(result)
+
+
+class LegacyVersion(Version):
+    def parse(self, s):
+        return _legacy_key(s)
+
+    @property
+    def is_prerelease(self):
+        result = False
+        for x in self._parts:
+            if (isinstance(x, string_types) and x.startswith('*') and
+                x < '*final'):
+                result = True
+                break
+        return result
+
+
+class LegacyMatcher(Matcher):
+    version_class = LegacyVersion
+
+    _operators = dict(Matcher._operators)
+    _operators['~='] = '_match_compatible'
+
+    numeric_re = re.compile(r'^(\d+(\.\d+)*)')
+
+    def _match_compatible(self, version, constraint, prefix):
+        if version < constraint:
+            return False
+        m = self.numeric_re.match(str(constraint))
+        if not m:
+            logger.warning('Cannot compute compatible match for version %s '
+                           ' and constraint %s', version, constraint)
+            return True
+        s = m.groups()[0]
+        if '.' in s:
+            s = s.rsplit('.', 1)[0]
+        return _match_prefix(version, s)
+
+#
+#   Semantic versioning
+#
+
+_SEMVER_RE = re.compile(r'^(\d+)\.(\d+)\.(\d+)'
+                        r'(-[a-z0-9]+(\.[a-z0-9-]+)*)?'
+                        r'(\+[a-z0-9]+(\.[a-z0-9-]+)*)?$', re.I)
+
+
+def is_semver(s):
+    return _SEMVER_RE.match(s)
+
+
+def _semantic_key(s):
+    def make_tuple(s, absent):
+        if s is None:
+            result = (absent,)
+        else:
+            parts = s[1:].split('.')
+            # We can't compare ints and strings on Python 3, so fudge it
+            # by zero-filling numeric values so simulate a numeric comparison
+            result = tuple([p.zfill(8) if p.isdigit() else p for p in parts])
+        return result
+
+    m = is_semver(s)
+    if not m:
+        raise UnsupportedVersionError(s)
+    groups = m.groups()
+    major, minor, patch = [int(i) for i in groups[:3]]
+    # choose the '|' and '*' so that versions sort correctly
+    pre, build = make_tuple(groups[3], '|'), make_tuple(groups[5], '*')
+    return (major, minor, patch), pre, build
+
+
+class SemanticVersion(Version):
+    def parse(self, s):
+        return _semantic_key(s)
+
+    @property
+    def is_prerelease(self):
+        return self._parts[1][0] != '|'
+
+
+class SemanticMatcher(Matcher):
+    version_class = SemanticVersion
+
+
+class VersionScheme(object):
+    def __init__(self, key, matcher, suggester=None):
+        self.key = key
+        self.matcher = matcher
+        self.suggester = suggester
+
+    def is_valid_version(self, s):
+        try:
+            self.matcher.version_class(s)
+            result = True
+        except UnsupportedVersionError:
+            result = False
+        return result
+
+    def is_valid_matcher(self, s):
+        try:
+            self.matcher(s)
+            result = True
+        except UnsupportedVersionError:
+            result = False
+        return result
+
+    def is_valid_constraint_list(self, s):
+        """
+        Used for processing some metadata fields
+        """
+        return self.is_valid_matcher('dummy_name (%s)' % s)
+
+    def suggest(self, s):
+        if self.suggester is None:
+            result = None
+        else:
+            result = self.suggester(s)
+        return result
+
+_SCHEMES = {
+    'normalized': VersionScheme(_normalized_key, NormalizedMatcher,
+                                _suggest_normalized_version),
+    'legacy': VersionScheme(_legacy_key, LegacyMatcher, lambda self, s: s),
+    'semantic': VersionScheme(_semantic_key, SemanticMatcher,
+                              _suggest_semantic_version),
+}
+
+_SCHEMES['default'] = _SCHEMES['normalized']
+
+
+def get_scheme(name):
+    if name not in _SCHEMES:
+        raise ValueError('unknown scheme name: %r' % name)
+    return _SCHEMES[name]
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/version.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/version.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..ba684eff634ddb4b158f4ecb265c55f267951993
GIT binary patch
literal 29804
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%0AeVw2W|ItZF9>7v8VkG)
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
V#v-N+nseo16l3IM<Yne#1^~~4O_=}y

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/w32.exe b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/w32.exe
new file mode 100644
index 0000000000000000000000000000000000000000..732215a9d34ccb7b417d637a7646d9b843ecafa8
GIT binary patch
literal 89088
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%0Af}9)KdZ08U
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

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/w64.exe b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/w64.exe
new file mode 100644
index 0000000000000000000000000000000000000000..c41bd0a011fd760ce20ba795d9e535e0d2c39876
GIT binary patch
literal 99328
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

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/wheel.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/wheel.py
new file mode 100644
index 0000000..b04bfae
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/wheel.py
@@ -0,0 +1,988 @@
+# -*- coding: utf-8 -*-
+#
+# Copyright (C) 2013-2017 Vinay Sajip.
+# Licensed to the Python Software Foundation under a contributor agreement.
+# See LICENSE.txt and CONTRIBUTORS.txt.
+#
+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
+import posixpath
+import re
+import shutil
+import sys
+import tempfile
+import zipfile
+
+from . import __version__, DistlibException
+from .compat import sysconfig, ZipFile, fsdecode, text_type, filter
+from .database import InstalledDistribution
+from .metadata import Metadata, METADATA_FILENAME, WHEEL_METADATA_FILENAME
+from .util import (FileOperator, convert_path, CSVReader, CSVWriter, Cache,
+                   cached_property, get_cache_base, read_exports, tempdir)
+from .version import NormalizedVersion, UnsupportedVersionError
+
+logger = logging.getLogger(__name__)
+
+cache = None    # created when needed
+
+if hasattr(sys, 'pypy_version_info'):  # pragma: no cover
+    IMP_PREFIX = 'pp'
+elif sys.platform.startswith('java'):  # pragma: no cover
+    IMP_PREFIX = 'jy'
+elif sys.platform == 'cli':  # pragma: no cover
+    IMP_PREFIX = 'ip'
+else:
+    IMP_PREFIX = 'cp'
+
+VER_SUFFIX = sysconfig.get_config_var('py_version_nodot')
+if not VER_SUFFIX:   # pragma: no cover
+    VER_SUFFIX = '%s%s' % sys.version_info[:2]
+PYVER = 'py' + VER_SUFFIX
+IMPVER = IMP_PREFIX + VER_SUFFIX
+
+ARCH = distutils.util.get_platform().replace('-', '_').replace('.', '_')
+
+ABI = sysconfig.get_config_var('SOABI')
+if ABI and ABI.startswith('cpython-'):
+    ABI = ABI.replace('cpython-', 'cp')
+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')
+        return ''.join(parts)
+    ABI = _derive_abi()
+    del _derive_abi
+
+FILENAME_RE = re.compile(r'''
+(?P<nm>[^-]+)
+-(?P<vn>\d+[^-]*)
+(-(?P<bn>\d+[^-]*))?
+-(?P<py>\w+\d+(\.\w+\d+)*)
+-(?P<bi>\w+)
+-(?P<ar>\w+(\.\w+)*)
+\.whl$
+''', re.IGNORECASE | re.VERBOSE)
+
+NAME_VERSION_RE = re.compile(r'''
+(?P<nm>[^-]+)
+-(?P<vn>\d+[^-]*)
+(-(?P<bn>\d+[^-]*))?$
+''', re.IGNORECASE | re.VERBOSE)
+
+SHEBANG_RE = re.compile(br'\s*#![^\r\n]*')
+SHEBANG_DETAIL_RE = re.compile(br'^(\s*#!("[^"]+"|\S+))\s+(.*)$')
+SHEBANG_PYTHON = b'#!python'
+SHEBANG_PYTHONW = b'#!pythonw'
+
+if os.sep == '/':
+    to_posix = lambda o: o
+else:
+    to_posix = lambda o: o.replace(os.sep, '/')
+
+
+class Mounter(object):
+    def __init__(self):
+        self.impure_wheels = {}
+        self.libs = {}
+
+    def add(self, pathname, extensions):
+        self.impure_wheels[pathname] = extensions
+        self.libs.update(extensions)
+
+    def remove(self, pathname):
+        extensions = self.impure_wheels.pop(pathname)
+        for k, v in extensions:
+            if k in self.libs:
+                del self.libs[k]
+
+    def find_module(self, fullname, path=None):
+        if fullname in self.libs:
+            result = self
+        else:
+            result = None
+        return result
+
+    def load_module(self, fullname):
+        if fullname in sys.modules:
+            result = sys.modules[fullname]
+        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.__loader__ = self
+            parts = fullname.rsplit('.', 1)
+            if len(parts) > 1:
+                result.__package__ = parts[0]
+        return result
+
+_hook = Mounter()
+
+
+class Wheel(object):
+    """
+    Class to build and install from Wheel files (PEP 427).
+    """
+
+    wheel_version = (1, 1)
+    hash_kind = 'sha256'
+
+    def __init__(self, filename=None, sign=False, verify=False):
+        """
+        Initialise an instance using a (valid) filename.
+        """
+        self.sign = sign
+        self.should_verify = verify
+        self.buildver = ''
+        self.pyver = [PYVER]
+        self.abi = ['none']
+        self.arch = ['any']
+        self.dirname = os.getcwd()
+        if filename is None:
+            self.name = 'dummy'
+            self.version = '0.1'
+            self._filename = self.filename
+        else:
+            m = NAME_VERSION_RE.match(filename)
+            if m:
+                info = m.groupdict('')
+                self.name = info['nm']
+                # Reinstate the local version separator
+                self.version = info['vn'].replace('_', '-')
+                self.buildver = info['bn']
+                self._filename = self.filename
+            else:
+                dirname, filename = os.path.split(filename)
+                m = FILENAME_RE.match(filename)
+                if not m:
+                    raise DistlibException('Invalid name or '
+                                           'filename: %r' % filename)
+                if dirname:
+                    self.dirname = os.path.abspath(dirname)
+                self._filename = filename
+                info = m.groupdict('')
+                self.name = info['nm']
+                self.version = info['vn']
+                self.buildver = info['bn']
+                self.pyver = info['py'].split('.')
+                self.abi = info['bi'].split('.')
+                self.arch = info['ar'].split('.')
+
+    @property
+    def filename(self):
+        """
+        Build and return a filename from the various components.
+        """
+        if self.buildver:
+            buildver = '-' + self.buildver
+        else:
+            buildver = ''
+        pyver = '.'.join(self.pyver)
+        abi = '.'.join(self.abi)
+        arch = '.'.join(self.arch)
+        # replace - with _ as a local version separator
+        version = self.version.replace('-', '_')
+        return '%s-%s%s-%s-%s-%s.whl' % (self.name, version, buildver,
+                                         pyver, abi, arch)
+
+    @property
+    def exists(self):
+        path = os.path.join(self.dirname, self.filename)
+        return os.path.isfile(path)
+
+    @property
+    def tags(self):
+        for pyver in self.pyver:
+            for abi in self.abi:
+                for arch in self.arch:
+                    yield pyver, abi, arch
+
+    @cached_property
+    def metadata(self):
+        pathname = os.path.join(self.dirname, self.filename)
+        name_ver = '%s-%s' % (self.name, self.version)
+        info_dir = '%s.dist-info' % name_ver
+        wrapper = codecs.getreader('utf-8')
+        with ZipFile(pathname, 'r') as zf:
+            wheel_metadata = self.get_wheel_metadata(zf)
+            wv = wheel_metadata['Wheel-Version'].split('.', 1)
+            file_version = tuple([int(i) for i in wv])
+            if file_version < (1, 1):
+                fns = [WHEEL_METADATA_FILENAME, METADATA_FILENAME, 'METADATA']
+            else:
+                fns = [WHEEL_METADATA_FILENAME, METADATA_FILENAME]
+            result = None
+            for fn in fns:
+                try:
+                    metadata_filename = posixpath.join(info_dir, fn)
+                    with zf.open(metadata_filename) as bf:
+                        wf = wrapper(bf)
+                        result = Metadata(fileobj=wf)
+                        if result:
+                            break
+                except KeyError:
+                    pass
+            if not result:
+                raise ValueError('Invalid wheel, because metadata is '
+                                 'missing: looked in %s' % ', '.join(fns))
+        return result
+
+    def get_wheel_metadata(self, zf):
+        name_ver = '%s-%s' % (self.name, self.version)
+        info_dir = '%s.dist-info' % name_ver
+        metadata_filename = posixpath.join(info_dir, 'WHEEL')
+        with zf.open(metadata_filename) as bf:
+            wf = codecs.getreader('utf-8')(bf)
+            message = message_from_file(wf)
+        return dict(message)
+
+    @cached_property
+    def info(self):
+        pathname = os.path.join(self.dirname, self.filename)
+        with ZipFile(pathname, 'r') as zf:
+            result = self.get_wheel_metadata(zf)
+        return result
+
+    def process_shebang(self, data):
+        m = SHEBANG_RE.match(data)
+        if m:
+            end = m.end()
+            shebang, data_after_shebang = data[:end], data[end:]
+            # Preserve any arguments after the interpreter
+            if b'pythonw' in shebang.lower():
+                shebang_python = SHEBANG_PYTHONW
+            else:
+                shebang_python = SHEBANG_PYTHON
+            m = SHEBANG_DETAIL_RE.match(shebang)
+            if m:
+                args = b' ' + m.groups()[-1]
+            else:
+                args = b''
+            shebang = shebang_python + args
+            data = shebang + data_after_shebang
+        else:
+            cr = data.find(b'\r')
+            lf = data.find(b'\n')
+            if cr < 0 or cr > lf:
+                term = b'\n'
+            else:
+                if data[cr:cr + 2] == b'\r\n':
+                    term = b'\r\n'
+                else:
+                    term = b'\r'
+            data = SHEBANG_PYTHON + term + data
+        return data
+
+    def get_hash(self, data, hash_kind=None):
+        if hash_kind is None:
+            hash_kind = self.hash_kind
+        try:
+            hasher = getattr(hashlib, hash_kind)
+        except AttributeError:
+            raise DistlibException('Unsupported hash algorithm: %r' % hash_kind)
+        result = hasher(data).digest()
+        result = base64.urlsafe_b64encode(result).rstrip(b'=').decode('ascii')
+        return hash_kind, result
+
+    def write_record(self, records, record_path, base):
+        records = list(records) # make a copy for sorting
+        p = to_posix(os.path.relpath(record_path, base))
+        records.append((p, '', ''))
+        records.sort()
+        with CSVWriter(record_path) as writer:
+            for row in records:
+                writer.writerow(row)
+
+    def write_records(self, info, libdir, archive_paths):
+        records = []
+        distinfo, info_dir = info
+        hasher = getattr(hashlib, self.hash_kind)
+        for ap, p in archive_paths:
+            with open(p, 'rb') as f:
+                data = f.read()
+            digest = '%s=%s' % self.get_hash(data)
+            size = os.path.getsize(p)
+            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'))
+        archive_paths.append((ap, p))
+
+    def build_zip(self, pathname, archive_paths):
+        with ZipFile(pathname, 'w', zipfile.ZIP_DEFLATED) as zf:
+            for ap, p in archive_paths:
+                logger.debug('Wrote %s to %s in wheel', p, ap)
+                zf.write(p, ap)
+
+    def build(self, paths, tags=None, wheel_version=None):
+        """
+        Build a wheel from files in specified paths, and use any specified tags
+        when determining the name of the wheel.
+        """
+        if tags is None:
+            tags = {}
+
+        libkey = list(filter(lambda o: o in paths, ('purelib', 'platlib')))[0]
+        if libkey == 'platlib':
+            is_pure = 'false'
+            default_pyver = [IMPVER]
+            default_abi = [ABI]
+            default_arch = [ARCH]
+        else:
+            is_pure = 'true'
+            default_pyver = [PYVER]
+            default_abi = ['none']
+            default_arch = ['any']
+
+        self.pyver = tags.get('pyver', default_pyver)
+        self.abi = tags.get('abi', default_abi)
+        self.arch = tags.get('arch', default_arch)
+
+        libdir = paths[libkey]
+
+        name_ver = '%s-%s' % (self.name, self.version)
+        data_dir = '%s.data' % name_ver
+        info_dir = '%s.dist-info' % name_ver
+
+        archive_paths = []
+
+        # First, stuff which is not in site-packages
+        for key in ('data', 'headers', 'scripts'):
+            if key not in paths:
+                continue
+            path = paths[key]
+            if os.path.isdir(path):
+                for root, dirs, files in os.walk(path):
+                    for fn in files:
+                        p = fsdecode(os.path.join(root, fn))
+                        rp = os.path.relpath(p, path)
+                        ap = to_posix(os.path.join(data_dir, key, rp))
+                        archive_paths.append((ap, p))
+                        if key == 'scripts' and not p.endswith('.exe'):
+                            with open(p, 'rb') as f:
+                                data = f.read()
+                            data = self.process_shebang(data)
+                            with open(p, 'wb') as f:
+                                f.write(data)
+
+        # Now, stuff which is in site-packages, other than the
+        # distinfo stuff.
+        path = libdir
+        distinfo = None
+        for root, dirs, files in os.walk(path):
+            if root == path:
+                # At the top level only, save distinfo for later
+                # and skip it for now
+                for i, dn in enumerate(dirs):
+                    dn = fsdecode(dn)
+                    if dn.endswith('.dist-info'):
+                        distinfo = os.path.join(root, dn)
+                        del dirs[i]
+                        break
+                assert distinfo, '.dist-info directory expected, not found'
+
+            for fn in files:
+                # comment out next suite to leave .pyc files in
+                if fsdecode(fn).endswith(('.pyc', '.pyo')):
+                    continue
+                p = os.path.join(root, fn)
+                rp = to_posix(os.path.relpath(p, path))
+                archive_paths.append((rp, p))
+
+        # Now distinfo. Assumed to be flat, i.e. os.listdir is enough.
+        files = os.listdir(distinfo)
+        for fn in files:
+            if fn not in ('RECORD', 'INSTALLER', 'SHARED', 'WHEEL'):
+                p = fsdecode(os.path.join(distinfo, fn))
+                ap = to_posix(os.path.join(info_dir, fn))
+                archive_paths.append((ap, p))
+
+        wheel_metadata = [
+            'Wheel-Version: %d.%d' % (wheel_version or self.wheel_version),
+            'Generator: distlib %s' % __version__,
+            'Root-Is-Purelib: %s' % is_pure,
+        ]
+        for pyver, abi, arch in self.tags:
+            wheel_metadata.append('Tag: %s-%s-%s' % (pyver, abi, arch))
+        p = os.path.join(distinfo, 'WHEEL')
+        with open(p, 'w') as f:
+            f.write('\n'.join(wheel_metadata))
+        ap = to_posix(os.path.join(info_dir, 'WHEEL'))
+        archive_paths.append((ap, p))
+
+        # Now, at last, RECORD.
+        # Paths in here are archive paths - nothing else makes sense.
+        self.write_records((distinfo, info_dir), libdir, archive_paths)
+        # Now, ready to build the zip file
+        pathname = os.path.join(self.dirname, self.filename)
+        self.build_zip(pathname, archive_paths)
+        return pathname
+
+    def install(self, paths, maker, **kwargs):
+        """
+        Install a wheel to the specified paths. If kwarg ``warner`` is
+        specified, it should be a callable, which will be called with two
+        tuples indicating the wheel version of this software and the wheel
+        version in the file, if there is a discrepancy in the versions.
+        This can be used to issue any warnings to raise any exceptions.
+        If kwarg ``lib_only`` is True, only the purelib/platlib files are
+        installed, and the headers, scripts, data and dist-info metadata are
+        not written. If kwarg ``bytecode_hashed_invalidation`` is True, written
+        bytecode will try to use file-hash based invalidation (PEP-552) on
+        supported interpreter versions (CPython 2.7+).
+
+        The return value is a :class:`InstalledDistribution` instance unless
+        ``options.lib_only`` is True, in which case the return value is ``None``.
+        """
+
+        dry_run = maker.dry_run
+        warner = kwargs.get('warner')
+        lib_only = kwargs.get('lib_only', False)
+        bc_hashed_invalidation = kwargs.get('bytecode_hashed_invalidation', False)
+
+        pathname = os.path.join(self.dirname, self.filename)
+        name_ver = '%s-%s' % (self.name, self.version)
+        data_dir = '%s.data' % name_ver
+        info_dir = '%s.dist-info' % name_ver
+
+        metadata_name = posixpath.join(info_dir, METADATA_FILENAME)
+        wheel_metadata_name = posixpath.join(info_dir, 'WHEEL')
+        record_name = posixpath.join(info_dir, 'RECORD')
+
+        wrapper = codecs.getreader('utf-8')
+
+        with ZipFile(pathname, 'r') as zf:
+            with zf.open(wheel_metadata_name) as bwf:
+                wf = wrapper(bwf)
+                message = message_from_file(wf)
+            wv = message['Wheel-Version'].split('.', 1)
+            file_version = tuple([int(i) for i in wv])
+            if (file_version != self.wheel_version) and warner:
+                warner(self.wheel_version, file_version)
+
+            if message['Root-Is-Purelib'] == 'true':
+                libdir = paths['purelib']
+            else:
+                libdir = paths['platlib']
+
+            records = {}
+            with zf.open(record_name) as bf:
+                with CSVReader(stream=bf) as reader:
+                    for row in reader:
+                        p = row[0]
+                        records[p] = row
+
+            data_pfx = posixpath.join(data_dir, '')
+            info_pfx = posixpath.join(info_dir, '')
+            script_pfx = posixpath.join(data_dir, 'scripts', '')
+
+            # make a new instance rather than a copy of maker's,
+            # as we mutate it
+            fileop = FileOperator(dry_run=dry_run)
+            fileop.record = True    # so we can rollback if needed
+
+            bc = not sys.dont_write_bytecode    # Double negatives. Lovely!
+
+            outfiles = []   # for RECORD writing
+
+            # for script copying/shebang processing
+            workdir = tempfile.mkdtemp()
+            # set target dir later
+            # we default add_launchers to False, as the
+            # Python Launcher should be used instead
+            maker.source_dir = workdir
+            maker.target_dir = None
+            try:
+                for zinfo in zf.infolist():
+                    arcname = zinfo.filename
+                    if isinstance(arcname, text_type):
+                        u_arcname = arcname
+                    else:
+                        u_arcname = arcname.decode('utf-8')
+                    # The signature file won't be in RECORD,
+                    # and we  don't currently don't do anything with it
+                    if u_arcname.endswith('/RECORD.jws'):
+                        continue
+                    row = records[u_arcname]
+                    if row[2] and str(zinfo.file_size) != row[2]:
+                        raise DistlibException('size mismatch for '
+                                               '%s' % u_arcname)
+                    if row[1]:
+                        kind, value = row[1].split('=', 1)
+                        with zf.open(arcname) as bf:
+                            data = bf.read()
+                        _, digest = self.get_hash(data, kind)
+                        if digest != value:
+                            raise DistlibException('digest mismatch for '
+                                                   '%s' % arcname)
+
+                    if lib_only and u_arcname.startswith((info_pfx, data_pfx)):
+                        logger.debug('lib_only: skipping %s', u_arcname)
+                        continue
+                    is_script = (u_arcname.startswith(script_pfx)
+                                 and not u_arcname.endswith('.exe'))
+
+                    if u_arcname.startswith(data_pfx):
+                        _, where, rp = u_arcname.split('/', 2)
+                        outfile = os.path.join(paths[where], convert_path(rp))
+                    else:
+                        # meant for site-packages.
+                        if u_arcname in (wheel_metadata_name, record_name):
+                            continue
+                        outfile = os.path.join(libdir, convert_path(u_arcname))
+                    if not is_script:
+                        with zf.open(arcname) as bf:
+                            fileop.copy_stream(bf, outfile)
+                        outfiles.append(outfile)
+                        # Double check the digest of the written file
+                        if not dry_run and row[1]:
+                            with open(outfile, 'rb') as bf:
+                                data = bf.read()
+                                _, newdigest = self.get_hash(data, kind)
+                                if newdigest != digest:
+                                    raise DistlibException('digest mismatch '
+                                                           'on write for '
+                                                           '%s' % outfile)
+                        if bc and outfile.endswith('.py'):
+                            try:
+                                pyc = fileop.byte_compile(outfile,
+                                                          hashed_invalidation=bc_hashed_invalidation)
+                                outfiles.append(pyc)
+                            except Exception:
+                                # Don't give up if byte-compilation fails,
+                                # but log it and perhaps warn the user
+                                logger.warning('Byte-compilation failed',
+                                               exc_info=True)
+                    else:
+                        fn = os.path.basename(convert_path(arcname))
+                        workname = os.path.join(workdir, fn)
+                        with zf.open(arcname) as bf:
+                            fileop.copy_stream(bf, workname)
+
+                        dn, fn = os.path.split(outfile)
+                        maker.target_dir = dn
+                        filenames = maker.make(fn)
+                        fileop.set_executable_mode(filenames)
+                        outfiles.extend(filenames)
+
+                if lib_only:
+                    logger.debug('lib_only: returning None')
+                    dist = None
+                else:
+                    # Generate scripts
+
+                    # Try to get pydist.json so we can see if there are
+                    # any commands to generate. If this fails (e.g. because
+                    # of a legacy wheel), log a warning but don't give up.
+                    commands = None
+                    file_version = self.info['Wheel-Version']
+                    if file_version == '1.0':
+                        # Use legacy info
+                        ep = posixpath.join(info_dir, 'entry_points.txt')
+                        try:
+                            with zf.open(ep) as bwf:
+                                epdata = read_exports(bwf)
+                            commands = {}
+                            for key in ('console', 'gui'):
+                                k = '%s_scripts' % key
+                                if k in epdata:
+                                    commands['wrap_%s' % key] = d = {}
+                                    for v in epdata[k].values():
+                                        s = '%s:%s' % (v.prefix, v.suffix)
+                                        if v.flags:
+                                            s += ' %s' % v.flags
+                                        d[v.name] = s
+                        except Exception:
+                            logger.warning('Unable to read legacy script '
+                                           'metadata, so cannot generate '
+                                           'scripts')
+                    else:
+                        try:
+                            with zf.open(metadata_name) as bwf:
+                                wf = wrapper(bwf)
+                                commands = json.load(wf).get('extensions')
+                                if commands:
+                                    commands = commands.get('python.commands')
+                        except Exception:
+                            logger.warning('Unable to read JSON metadata, so '
+                                           'cannot generate scripts')
+                    if commands:
+                        console_scripts = commands.get('wrap_console', {})
+                        gui_scripts = commands.get('wrap_gui', {})
+                        if console_scripts or gui_scripts:
+                            script_dir = paths.get('scripts', '')
+                            if not os.path.isdir(script_dir):
+                                raise ValueError('Valid script path not '
+                                                 'specified')
+                            maker.target_dir = script_dir
+                            for k, v in console_scripts.items():
+                                script = '%s = %s' % (k, v)
+                                filenames = maker.make(script)
+                                fileop.set_executable_mode(filenames)
+
+                            if gui_scripts:
+                                options = {'gui': True }
+                                for k, v in gui_scripts.items():
+                                    script = '%s = %s' % (k, v)
+                                    filenames = maker.make(script, options)
+                                    fileop.set_executable_mode(filenames)
+
+                    p = os.path.join(libdir, info_dir)
+                    dist = InstalledDistribution(p)
+
+                    # Write SHARED
+                    paths = dict(paths)     # don't change passed in dict
+                    del paths['purelib']
+                    del paths['platlib']
+                    paths['lib'] = libdir
+                    p = dist.write_shared_locations(paths, dry_run)
+                    if p:
+                        outfiles.append(p)
+
+                    # Write RECORD
+                    dist.write_installed_files(outfiles, paths['prefix'],
+                                               dry_run)
+                return dist
+            except Exception:  # pragma: no cover
+                logger.exception('installation failed.')
+                fileop.rollback()
+                raise
+            finally:
+                shutil.rmtree(workdir)
+
+    def _get_dylib_cache(self):
+        global cache
+        if cache is None:
+            # Use native string to avoid issues on 2.x: see Python #20140.
+            base = os.path.join(get_cache_base(), str('dylib-cache'),
+                                sys.version[:3])
+            cache = Cache(base)
+        return cache
+
+    def _get_extensions(self):
+        pathname = os.path.join(self.dirname, self.filename)
+        name_ver = '%s-%s' % (self.name, self.version)
+        info_dir = '%s.dist-info' % name_ver
+        arcname = posixpath.join(info_dir, 'EXTENSIONS')
+        wrapper = codecs.getreader('utf-8')
+        result = []
+        with ZipFile(pathname, 'r') as zf:
+            try:
+                with zf.open(arcname) as bf:
+                    wf = wrapper(bf)
+                    extensions = json.load(wf)
+                    cache = self._get_dylib_cache()
+                    prefix = cache.prefix_to_dir(pathname)
+                    cache_base = os.path.join(cache.base, prefix)
+                    if not os.path.isdir(cache_base):
+                        os.makedirs(cache_base)
+                    for name, relpath in extensions.items():
+                        dest = os.path.join(cache_base, convert_path(relpath))
+                        if not os.path.exists(dest):
+                            extract = True
+                        else:
+                            file_time = os.stat(dest).st_mtime
+                            file_time = datetime.datetime.fromtimestamp(file_time)
+                            info = zf.getinfo(relpath)
+                            wheel_time = datetime.datetime(*info.date_time)
+                            extract = wheel_time > file_time
+                        if extract:
+                            zf.extract(relpath, cache_base)
+                        result.append((name, dest))
+            except KeyError:
+                pass
+        return result
+
+    def is_compatible(self):
+        """
+        Determine if a wheel is compatible with the running system.
+        """
+        return is_compatible(self)
+
+    def is_mountable(self):
+        """
+        Determine if a wheel is asserted as mountable by its metadata.
+        """
+        return True # for now - metadata details TBD
+
+    def mount(self, append=False):
+        pathname = os.path.abspath(os.path.join(self.dirname, self.filename))
+        if not self.is_compatible():
+            msg = 'Wheel %s not compatible with this Python.' % pathname
+            raise DistlibException(msg)
+        if not self.is_mountable():
+            msg = 'Wheel %s is marked as not mountable.' % pathname
+            raise DistlibException(msg)
+        if pathname in sys.path:
+            logger.debug('%s already in path', pathname)
+        else:
+            if append:
+                sys.path.append(pathname)
+            else:
+                sys.path.insert(0, pathname)
+            extensions = self._get_extensions()
+            if extensions:
+                if _hook not in sys.meta_path:
+                    sys.meta_path.append(_hook)
+                _hook.add(pathname, extensions)
+
+    def unmount(self):
+        pathname = os.path.abspath(os.path.join(self.dirname, self.filename))
+        if pathname not in sys.path:
+            logger.debug('%s not in path', pathname)
+        else:
+            sys.path.remove(pathname)
+            if pathname in _hook.impure_wheels:
+                _hook.remove(pathname)
+            if not _hook.impure_wheels:
+                if _hook in sys.meta_path:
+                    sys.meta_path.remove(_hook)
+
+    def verify(self):
+        pathname = os.path.join(self.dirname, self.filename)
+        name_ver = '%s-%s' % (self.name, self.version)
+        data_dir = '%s.data' % name_ver
+        info_dir = '%s.dist-info' % name_ver
+
+        metadata_name = posixpath.join(info_dir, METADATA_FILENAME)
+        wheel_metadata_name = posixpath.join(info_dir, 'WHEEL')
+        record_name = posixpath.join(info_dir, 'RECORD')
+
+        wrapper = codecs.getreader('utf-8')
+
+        with ZipFile(pathname, 'r') as zf:
+            with zf.open(wheel_metadata_name) as bwf:
+                wf = wrapper(bwf)
+                message = message_from_file(wf)
+            wv = message['Wheel-Version'].split('.', 1)
+            file_version = tuple([int(i) for i in wv])
+            # TODO version verification
+
+            records = {}
+            with zf.open(record_name) as bf:
+                with CSVReader(stream=bf) as reader:
+                    for row in reader:
+                        p = row[0]
+                        records[p] = row
+
+            for zinfo in zf.infolist():
+                arcname = zinfo.filename
+                if isinstance(arcname, text_type):
+                    u_arcname = arcname
+                else:
+                    u_arcname = arcname.decode('utf-8')
+                if '..' in u_arcname:
+                    raise DistlibException('invalid entry in '
+                                           'wheel: %r' % u_arcname)
+
+                # The signature file won't be in RECORD,
+                # and we  don't currently don't do anything with it
+                if u_arcname.endswith('/RECORD.jws'):
+                    continue
+                row = records[u_arcname]
+                if row[2] and str(zinfo.file_size) != row[2]:
+                    raise DistlibException('size mismatch for '
+                                           '%s' % u_arcname)
+                if row[1]:
+                    kind, value = row[1].split('=', 1)
+                    with zf.open(arcname) as bf:
+                        data = bf.read()
+                    _, digest = self.get_hash(data, kind)
+                    if digest != value:
+                        raise DistlibException('digest mismatch for '
+                                               '%s' % arcname)
+
+    def update(self, modifier, dest_dir=None, **kwargs):
+        """
+        Update the contents of a wheel in a generic way. The modifier should
+        be a callable which expects a dictionary argument: its keys are
+        archive-entry paths, and its values are absolute filesystem paths
+        where the contents the corresponding archive entries can be found. The
+        modifier is free to change the contents of the files pointed to, add
+        new entries and remove entries, before returning. This method will
+        extract the entire contents of the wheel to a temporary location, call
+        the modifier, and then use the passed (and possibly updated)
+        dictionary to write a new wheel. If ``dest_dir`` is specified, the new
+        wheel is written there -- otherwise, the original wheel is overwritten.
+
+        The modifier should return True if it updated the wheel, else False.
+        This method returns the same value the modifier returns.
+        """
+
+        def get_version(path_map, info_dir):
+            version = path = None
+            key = '%s/%s' % (info_dir, METADATA_FILENAME)
+            if key not in path_map:
+                key = '%s/PKG-INFO' % info_dir
+            if key in path_map:
+                path = path_map[key]
+                version = Metadata(path=path).version
+            return version, path
+
+        def update_version(version, path):
+            updated = None
+            try:
+                v = NormalizedVersion(version)
+                i = version.find('-')
+                if i < 0:
+                    updated = '%s+1' % version
+                else:
+                    parts = [int(s) for s in version[i + 1:].split('.')]
+                    parts[-1] += 1
+                    updated = '%s+%s' % (version[:i],
+                                         '.'.join(str(i) for i in parts))
+            except UnsupportedVersionError:
+                logger.debug('Cannot update non-compliant (PEP-440) '
+                             'version %r', version)
+            if updated:
+                md = Metadata(path=path)
+                md.version = updated
+                legacy = not path.endswith(METADATA_FILENAME)
+                md.write(path=path, legacy=legacy)
+                logger.debug('Version updated from %r to %r', version,
+                             updated)
+
+        pathname = os.path.join(self.dirname, self.filename)
+        name_ver = '%s-%s' % (self.name, self.version)
+        info_dir = '%s.dist-info' % name_ver
+        record_name = posixpath.join(info_dir, 'RECORD')
+        with tempdir() as workdir:
+            with ZipFile(pathname, 'r') as zf:
+                path_map = {}
+                for zinfo in zf.infolist():
+                    arcname = zinfo.filename
+                    if isinstance(arcname, text_type):
+                        u_arcname = arcname
+                    else:
+                        u_arcname = arcname.decode('utf-8')
+                    if u_arcname == record_name:
+                        continue
+                    if '..' in u_arcname:
+                        raise DistlibException('invalid entry in '
+                                               'wheel: %r' % u_arcname)
+                    zf.extract(zinfo, workdir)
+                    path = os.path.join(workdir, convert_path(u_arcname))
+                    path_map[u_arcname] = path
+
+            # Remember the version.
+            original_version, _ = get_version(path_map, info_dir)
+            # Files extracted. Call the modifier.
+            modified = modifier(path_map, **kwargs)
+            if modified:
+                # Something changed - need to build a new wheel.
+                current_version, path = get_version(path_map, info_dir)
+                if current_version and (current_version == original_version):
+                    # Add or update local version to signify changes.
+                    update_version(current_version, path)
+                # Decide where the new wheel goes.
+                if dest_dir is None:
+                    fd, newpath = tempfile.mkstemp(suffix='.whl',
+                                                   prefix='wheel-update-',
+                                                   dir=workdir)
+                    os.close(fd)
+                else:
+                    if not os.path.isdir(dest_dir):
+                        raise DistlibException('Not a directory: %r' % dest_dir)
+                    newpath = os.path.join(dest_dir, self.filename)
+                archive_paths = list(path_map.items())
+                distinfo = os.path.join(workdir, info_dir)
+                info = distinfo, info_dir
+                self.write_records(info, workdir, archive_paths)
+                self.build_zip(newpath, archive_paths)
+                if dest_dir is None:
+                    shutil.copyfile(newpath, pathname)
+        return modified
+
+def compatible_tags():
+    """
+    Return (pyver, abi, arch) tuples compatible with this Python.
+    """
+    versions = [VER_SUFFIX]
+    major = VER_SUFFIX[0]
+    for minor in range(sys.version_info[1] - 1, - 1, -1):
+        versions.append(''.join([major, str(minor)]))
+
+    abis = []
+    for suffix, _, _ in imp.get_suffixes():
+        if suffix.startswith('.abi'):
+            abis.append(suffix.split('.', 2)[1])
+    abis.sort()
+    if ABI != 'none':
+        abis.insert(0, ABI)
+    abis.append('none')
+    result = []
+
+    arches = [ARCH]
+    if sys.platform == 'darwin':
+        m = re.match(r'(\w+)_(\d+)_(\d+)_(\w+)$', ARCH)
+        if m:
+            name, major, minor, arch = m.groups()
+            minor = int(minor)
+            matches = [arch]
+            if arch in ('i386', 'ppc'):
+                matches.append('fat')
+            if arch in ('i386', 'ppc', 'x86_64'):
+                matches.append('fat3')
+            if arch in ('ppc64', 'x86_64'):
+                matches.append('fat64')
+            if arch in ('i386', 'x86_64'):
+                matches.append('intel')
+            if arch in ('i386', 'x86_64', 'intel', 'ppc', 'ppc64'):
+                matches.append('universal')
+            while minor >= 0:
+                for match in matches:
+                    s = '%s_%s_%s_%s' % (name, major, minor, match)
+                    if s != ARCH:   # already there
+                        arches.append(s)
+                minor -= 1
+
+    # Most specific - our Python version, ABI and arch
+    for abi in abis:
+        for arch in arches:
+            result.append((''.join((IMP_PREFIX, versions[0])), abi, arch))
+
+    # where no ABI / arch dependency, but IMP_PREFIX dependency
+    for i, version in enumerate(versions):
+        result.append((''.join((IMP_PREFIX, version)), 'none', 'any'))
+        if i == 0:
+            result.append((''.join((IMP_PREFIX, version[0])), 'none', 'any'))
+
+    # no IMP_PREFIX, ABI or arch dependency
+    for i, version in enumerate(versions):
+        result.append((''.join(('py', version)), 'none', 'any'))
+        if i == 0:
+            result.append((''.join(('py', version[0])), 'none', 'any'))
+    return set(result)
+
+
+COMPATIBLE_TAGS = compatible_tags()
+
+del compatible_tags
+
+
+def is_compatible(wheel, tags=None):
+    if not isinstance(wheel, Wheel):
+        wheel = Wheel(wheel)    # assume it's a filename
+    result = False
+    if tags is None:
+        tags = COMPATIBLE_TAGS
+    for ver, abi, arch in tags:
+        if ver in wheel.pyver and abi in wheel.abi and arch in wheel.arch:
+            result = True
+            break
+    return result
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/wheel.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distlib/wheel.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..cb57ee16362d05ee22c95362ddd0f6e3806e82ee
GIT binary patch
literal 33453
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

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distro.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distro.py
new file mode 100644
index 0000000..3306163
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distro.py
@@ -0,0 +1,1216 @@
+# 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 Enterprise 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 = {
+    'enterpriseenterprise': 'oracle',  # Oracle Enterprise Linux
+    'redhatenterpriseworkstation': 'rhel',  # RHEL 6, 7 Workstation
+    'redhatenterpriseserver': 'rhel',  # RHEL 6, 7 Server
+}
+
+#: 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'
+)
+
+
+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
+    ==============  =========================================
+
+    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_name`` (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 = u'{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)
+                if isinstance(v, bytes):
+                    v = v.decode('utf-8')
+                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 = stdout.decode(sys.getfilesystemencoding()).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 = stdout.decode(sys.getfilesystemencoding()).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
+
+    @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.
+        """
+        if isinstance(line, bytes):
+            line = line.decode('utf-8')
+        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/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distro.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/distro.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..dd9e7207eba3f0cf0d41fc47417b1ee4a5d10368
GIT binary patch
literal 42880
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
K$;>Iv!w3LmHrQ$a

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/__init__.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/__init__.py
new file mode 100644
index 0000000..0491234
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/__init__.py
@@ -0,0 +1,35 @@
+"""
+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.0.1"
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/__init__.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/__init__.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..4f2551c1ac58653c119475ad1c3c5e88330924bc
GIT binary patch
literal 1495
zcmZSn%**AGdLky70Sed{7#JK9m>7yDFfcHrFfc?hFr+Xtq%bk$Ff!yaF+?#j<T5iv
zF*D?{FhsF1Fs3jwq_8mLurlPbF+{O3<gznFu`}dyFhp@c<X9PUI2m%e7^1i!d^Uz0
zZiZYQhA18gpPeCxmm!yrA&QTIF@=L6g_9wLiy?)ZA%%w_g_j|njUkGkA%%}2N`N7S
zpCMR7fPsObbPW>&1D8jLua81OVo`BsUb;d~W>QgNQKdpsVsUDULVlh?Nk*zdLb!)x
zNVvNKSY>fRYI0^;W^!UlW_})*O-4ycL9vy-etAY>NqM?neo?x9MoDgtT|&H`LP$m`
z*x=M6h0J1wl+@zP^t{v*g_3-Qq*R6E{M>@XlFX!>RE6@)k_@iYip=5?kQ2bRq~(|9
zr6^=V>@UyENl{1y@pB7uQgc)DN{SWAQ*&~3Q&Q71K_;da73CKx6s0ETm!%d}DwJd-
zmT+YjE94{=rKjdpqFbeqo1c<elm~K9c1eDLLV0SELQ+wFd2wn{u^tzfYegc+8ims0
z#Pn1vD=sbt1qFq)qWoNig3JQF__EZzl>8!v%-n+fq7ns=Urlo|lfa5V{!qv-NX^qw
z%B_q~$xki?xm6FOMoC9OsVGTFQz5ZfA<YV`8f0uqQEIA!E!-46P&A}!q-k<-x#brr
zB<JUqrRHU(<|U`<D3oMm7K2<~nv<$fl&YIr0kXds96xFKIXU^|ps>qJ%uOw};^NX$
zuu3b<OSVd=1KVy2Hn#|3d;(rsx1z*!kgLI}l5-M^i_r}M#ZN$DQE_S!SPje`kXMpQ
zGjmcvp_rap5>k|!>IC6qs4Gv*$wpEZ4(6h$Do!oROw7rwN-ffZGZVNnL0L<KnSp_!
zgr9+dAu*{qKc}=LH69WfB^;oPmRXiroSC0j0#4w0naTMnsqs0PC8<S;ImMZb3=9kq
z{ag$T3<#f;ure?(fCH(77si5xga$}c2_FLk1FEke;vnTvafmk{!ki2Y3~+~+qFPo8
zx2zPT8*DAivQkWYz=}|;C`C0LWSpU%fu5nCh9D?t*cliY;z7wTKE4EGb9{VSX-R2O
zYJ7YUDExvz{t03NspMv0U;w2~X!-~Og=`QD0|P@4$jlNRkeZ^@R9LhIfr_*ekS0)M
zLnAQ=WF6QZxPOa+KrvAQl8BE_%*lz52WyItFH0=~#Z7#?2FM`@qPT#8fkD5ZD6=fF
zBvrpGu}D8HADoc%lT!4{lalgsO>>Kl43o^$tI{n@Ey{DUs>}>PAU#h%M86=jKsPh5
zxFj(rN7t>)!_znbBm~CL+zKv|K-pA3K0Y%qvm`!Vub>i~Tx@dlQ%ZAE?L<NG1xhk(
ROfpO|i~=CY#KXwL0szjNt;_%b

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/_ihatexml.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/_ihatexml.py
new file mode 100644
index 0000000..4c77717
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/_ihatexml.py
@@ -0,0 +1,288 @@
+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", 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", 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/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/_ihatexml.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/_ihatexml.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..c508f1929883836d2efe46e351d2864181813fc9
GIT binary patch
literal 16440
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
K&&1En&kO($Rm$rC

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/_inputstream.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/_inputstream.py
new file mode 100644
index 0000000..a65e55f
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/_inputstream.py
@@ -0,0 +1,923 @@
+from __future__ import absolute_import, division, unicode_literals
+
+from pip._vendor.six import text_type, binary_type
+from pip._vendor.six.moves import http_client, urllib
+
+import codecs
+import re
+
+from pip._vendor import webencodings
+
+from .constants import EOF, spaceCharacters, asciiLetters, asciiUppercase
+from .constants import _ReparseException
+from . import _utils
+
+from io import StringIO
+
+try:
+    from io import BytesIO
+except ImportError:
+    BytesIO = StringIO
+
+# 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 = set([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 None:
+            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:  # pylint:disable=bare-except
+            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 overriden, we've been overriden
+        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"""
+        p = self.position
+        data = self[p:p + len(bytes)]
+        rv = data.startswith(bytes)
+        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"""
+        newPosition = self[self.position:].find(bytes)
+        if newPosition > -1:
+            # XXX: This is ugly, but I can't see a nicer way to fix this.
+            if self._position == -1:
+                self._position = 0
+            self._position += (newPosition + len(bytes) - 1)
+            return True
+        else:
+            raise StopIteration
+
+
+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):
+        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
+            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, binary_type):
+        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/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/_inputstream.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/_inputstream.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..235e092c5432f2340eb3e28ba7be2556b649816a
GIT binary patch
literal 30522
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
W&&<Xw=EW&4_Dt-AScceEF?9fzB5PUz

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/_tokenizer.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/_tokenizer.py
new file mode 100644
index 0000000..178f6e7
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/_tokenizer.py
@@ -0,0 +1,1721 @@
+from __future__ import absolute_import, division, unicode_literals
+
+from pip._vendor.six import unichr as chr
+
+from collections import deque
+
+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)
+
+
+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["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/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/_tokenizer.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/_tokenizer.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..e0160345159e10d5ab0c924543f41b00ac35a70e
GIT binary patch
literal 57395
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%0AY(<4
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
U06|6pMlnVi(CJhl9up5U04~xWEC2ui

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/_trie/__init__.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/_trie/__init__.py
new file mode 100644
index 0000000..a5ba4bf
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/_trie/__init__.py
@@ -0,0 +1,14 @@
+from __future__ import absolute_import, division, unicode_literals
+
+from .py import Trie as PyTrie
+
+Trie = PyTrie
+
+# pylint:disable=wrong-import-position
+try:
+    from .datrie import Trie as DATrie
+except ImportError:
+    pass
+else:
+    Trie = DATrie
+# pylint:enable=wrong-import-position
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/_trie/__init__.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/_trie/__init__.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..b76def41637f9da93e1be1888a1d286a4cdac310
GIT binary patch
literal 489
zcmZSn%**AGdLky70SZ_d7#JK9m>7yv7#J8*7#LC*8FCmHav2$-7#VVz7^0XMa+w*T
zm>C#Tm>5!+8FE+{a#<Oo*ccd7*%+c&87f5>pc3q02@VFv@H{~VmQ+rLY%YePNCrkm
z#yob0h*S=c>J%1+U=5IsnIPLWm>C!tO86NV7!s3;^K(i|QsXmo3-XIfN;p7n$t=q(
z&dkp%5ny0oD9y`E&QD2=&&e!FElSKO&SYd@V9)>&B`gdK3?W6CseT$<Amczpe0*AI
zNoi4Pe0&hdo*<CAASRG3h$yHG0$a?+z`zht3DQ~uVx}aP6lJD@nJ$iCQEmnX22Zeq
zT#JhGi!?xHA&BBK1_lQGf}+f_#FA9~vcw|&wEUcu)S_bjq!j(~q@=uD)7)Ys!zA<c
zs&orei}IYTDl-ERNYB#`(J#m>(9O&%E=kPE(RC~H@H7qp34w8ZS!!NNevy7gNp6m5
zPG*vRJjh}C@$s2?nI-Y@dIgo>@Uh9wPbtkwwF7ysn2&*hL54|yiH(_=QG}6~k%b8W
D-8F2>

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/_trie/_base.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/_trie/_base.py
new file mode 100644
index 0000000..a1158bb
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/_trie/_base.py
@@ -0,0 +1,37 @@
+from __future__ import absolute_import, division, unicode_literals
+
+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/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/_trie/_base.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/_trie/_base.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..65f54ca18cd4a352f82f783d32a8205058848795
GIT binary patch
literal 2266
zcmZSn%**AGdLky70ScHI7#JK9m>7!P7#J8*7#LC*8FCmHav2$-7#VVz7^0XMa+w*T
zm>C#Ba!d?4EDX7<3{k8Mj48|vsjLiXj0`C(3@r={%?u2YQEUt;tPH^#YzzzxnIQ8u
zK&F@QGcYhDCKc!Bl$NB%XXX~<7nPK7fNaYw%Ph{!&nppNU|=ZC%S_HsNsZ6REJ-a&
z%qiAjWME(@VP{}q@J%cz$jnPGVPRlk2r0@;g*%;zfq}sZ<aAR828L7ykc(3oKrT*U
z1$m=|ks*qOA%zL#x+qqL6lO4k4eH(~c7`B`OG{-L7#JLric5+TlS>qm5{pw6l5-M^
zixtxHixf(VGE<9_K{kQB0>&U4?Lm%XU?^c^s9|7eW@5-<0tG-V6GI0$5VJWLinJL@
zSQu)U7@8Rwg4-Fu0maDB#sCs>0f}jV4E0L}c@x9}`A!&Qv?>DwLk0uL+*oObT1JK%
zMusc~kh#r_3`J}p?j$CLLN<nA4R8p9^p|ikFfbICBo>tvmuHq_fK4s|8LDSc0+O$Q
z1STk23W`$GGAqDZi;Ec;81xH@GRqQ6QuWIci}cg-b5c@^iuIFH^vjcy@^Vdci;WDE
z%+ssVEle%SbF!+;3_u_~Pd`MzAhSR>Gq1QLF(*gYt<1yIH~=IB#_?sTc`5lt`WYp;
zIi@+8N&4}iP}GkH1+88|WiclM1A|R*YDsc_Zh;*r?u$Wg<z&!c1%)bzC@w8XEeZk!
z2{_iXQ!9(X48Q!m)Dlo66sMLz(iTWfacWLl5GX+ffx-doH?W7nVguz%uv<VrEe5%a
zfk~8!hmng3B_%n7qFaxFfuTYj6x~_iOym+P$xzD#N+ns~xCg~LFGC3vLvSH4LwE@@
zLonEHei|U3gDnXHg%~(^LW)XLOF%rg#GK+(Z~z7IGB7ZJ0|Fdw*{PL~@ByWrfeM-u
z5l|9OERF}oYdk2$#zT^&5GWaggNsp^k)M$R5nLe8f`coLfdP~SY8V)@*%*ohK<wZO
zYlaeV!3D~WjGzpc!pI=r%*5als{js5Mo@5aD?l}Afi%@HF>osc7iuwtmoS0&&5R69
zjG*!_7@T|jGC}zU9D?8gElSKwhorom)I4zE<(*pTT2z!@1XhC-${>B2gCLCg7#J9G
z^7GPDi%X!PD+vl+9#F(H@-VV6DKH8$@*+YQl&ioY3@Qz47(iuC4LB?ziLnM;a7m^y
z!P6heqd{T}3=HTY04lR{AQ3tU!a*1#9O5%eQgf9-fdNWY42=AYej1=e2aeYG_`Jm2
z)cAOCks2SLo1ape1LA@_6(66HpBx__#0|<)prR&75X1t7L68I}AV6U|@LmR&o1n73
z801DaMm8oMPEK}CE<X*BC!iinD=jH4N{x>X0=YQ|9G9R%xCG?4<oukR)Z~)P{Ji2I
gP_h6Ui0~JfHDF~2D5h*6(P9U3b}=XtWtaq*0ie$W@&Et;

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/_trie/datrie.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/_trie/datrie.py
new file mode 100644
index 0000000..e2e5f86
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/_trie/datrie.py
@@ -0,0 +1,44 @@
+from __future__ import absolute_import, division, unicode_literals
+
+from datrie import Trie as DATrie
+from pip._vendor.six import text_type
+
+from ._base import Trie as ABCTrie
+
+
+class Trie(ABCTrie):
+    def __init__(self, data):
+        chars = set()
+        for key in data.keys():
+            if not isinstance(key, text_type):
+                raise TypeError("All keys must be strings")
+            for char in key:
+                chars.add(char)
+
+        self._data = DATrie("".join(chars))
+        for key, value in data.items():
+            self._data[key] = value
+
+    def __contains__(self, key):
+        return key in self._data
+
+    def __len__(self):
+        return len(self._data)
+
+    def __iter__(self):
+        raise NotImplementedError()
+
+    def __getitem__(self, key):
+        return self._data[key]
+
+    def keys(self, prefix=None):
+        return self._data.keys(prefix)
+
+    def has_keys_with_prefix(self, prefix):
+        return self._data.has_keys_with_prefix(prefix)
+
+    def longest_prefix(self, prefix):
+        return self._data.longest_prefix(prefix)
+
+    def longest_prefix_item(self, prefix):
+        return self._data.longest_prefix_item(prefix)
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/_trie/datrie.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/_trie/datrie.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..853e4c36cfd6510022a22829b5caf407b81c6b5e
GIT binary patch
literal 3296
zcmZSn%**AGdLky70ScHI7#JK9m>7!F7#J8*7#LC*8FCmHav2$-7#VVz7^0XMa+w*T
zm>C#Ba!d?4EDX7<3{h+lJ~KlOJ3}r9Llg%CV+spH3KK&PCs>|~fiZ=ZA(e|EjgcXR
zjiH5sp_zdpGK!TUg`FW-gM)#AAroZ32FUgjeg+1H#H8Z<oYIoi_{`jb{GyT)kdl<l
zvdrSl{JatY1_p-Gyv*eMl+^f~%#zfi#GGOcMg|6k5*7vqhLEDnR0xj~B$QfF5?@kT
zkeUfn5CpOS?pG!T1_mdPUt<^;7*ZKPUQA&CIWCF`<nI;+kVjLPz#=RRDa>F7D?<tk
zn8C)7!pV@r%Fx0H@-M_!QJf$jfi!Y4q;P<haWe!3Yj80zFeHPlV`E@o06EebWbGo5
z`@lg_%fwI-z)-`;ki`fJ8JAcmhFWHZ5+;TkW`+`GhGr&)Vk?mEQWzPU85x=w8S)qy
zDx^WOF0sN4wJZ!ZObl793^gnuX~sfFhVVi$hVT+LP!wdbgJhe*I%^mh;yD;9)WKG9
zLadTxh+zWRR?Esz!^%*@z>viOGT5fDks&;Vfgu<iDSo9A3=9m8IXMd1sg=bFxuwM=
z3Q4I7#U(|VdFjQa;K&1cvIG>s#i=FWm;fm)0f}Z7XXX``B<3Zj27x?Z0*aWB%7Rqa
zqN4mFu$IJ>loC+bxHy8M53D;YKQpg{m4SgFJ|(dv5zNXgNzE<R0I373C{E2u12f<X
zk~0#EiophEr&fZcKq6qhWr;bZsTyF1f{5Z01_lQGf}+f_#FA9~vcw|&wEUcu)S_bj
zq!j(~q@=uD)7)Ys!zA<cs&orei}IYTDl-ERNYB#`(J#m>&;@%bCr8(<%)`?-03-y)
z@nxxbDfvbE86~+nra75O`tc=2nW_3Ii6Ba^pc0&v<Kr{)GE3s)L4i{&1ac1}C!;VU
zKO;XQFQX`v1fwJ)IJtn53<!gh3oio$DBeIZ#K4fv#t;ln<$ho?h=+lJK?9^Th>wAR
zAxIF!1(^%>@xXZ&<gEDk<ovvn#LT?n_;@h}28LpgGZ`3@K^YQ+L0q^8OBldO5S&_J
z9t0@>M`})L9>k*{ZD5ary$2=+&X4S%G#a0inin50iN$*$w<3G5nE{l6!8r>g1&O~B
zVFm^Uzx)!<+=86c+|<01)D&>$fJ81RO2M8469eZ{P$?WA4=Qov<7JS%3W^{Y278qo
zlvEiQvcL&e5*Cjj??U1aq!=83gC?PZTpS;to>~GbW8&lG@%au^|3GqK79%J}HZ#KW
zBG_Y~L>~kyr4ShsT(}h!rKV+8fa4HM3|K^h9j8R87fVDK7#K1Vi{nA%e0+IkNk%->
zhu}~ECE6hA!BGwcfl{j~#U2KEDJMTKJ+-)G@Oo7i8sxBI78DsU49=XyBwuiOgz8mL
zzRyLZ=s^>;atsU%+K8z2(*R{ZXf2zUn420O4{n3R$LHp!l;)(y#|MGZZICFaniK~S
zph7!H3e*+@HBS8U^HRb21Ds}pK%p4~vI3lA5yZgdT~G^)6Xah|yMc|7lZTTT0(ro+
zp9ZKXgL*lww4}5M<YiD(AP8Lkf|3HbG=j89z%Ak+P&)+N?k>nI(1W&M^olbpAk8&!
vBP=PgIJE>+)j2vjgW70_pa8Q5EIhz5Z3Bs0JCF~HLA8_&lK`UtlK?XSDmM1F

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/_trie/py.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/_trie/py.py
new file mode 100644
index 0000000..c178b21
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/_trie/py.py
@@ -0,0 +1,67 @@
+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/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/_trie/py.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/_trie/py.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..12cf223a9d53e1799568fdf3ecbfd63c26762d1b
GIT binary patch
literal 3489
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

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/_utils.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/_utils.py
new file mode 100644
index 0000000..0703afb
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/_utils.py
@@ -0,0 +1,124 @@
+from __future__ import absolute_import, division, unicode_literals
+
+from types import ModuleType
+
+from pip._vendor.six import text_type
+
+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:  # pylint:disable=bare-except
+    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=()):
+        # Using _dictEntries instead of directly assigning to self is about
+        # twice as fast. Please do careful performance testing before changing
+        # anything here.
+        _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)
+
+
+# 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/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/_utils.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/_utils.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..12cdeb6bd45194b7d00ef4f3fad872adfce10ea4
GIT binary patch
literal 4808
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

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/constants.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/constants.py
new file mode 100644
index 0000000..1ff8041
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/constants.py
@@ -0,0 +1,2947 @@
+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 = dict([((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 = dict([(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 = dict([(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/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/constants.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/constants.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..1322be94e90a9a050ea5d11d2411ed05bbc12ff3
GIT binary patch
literal 83207
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
BVB!D(

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/filters/__init__.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/filters/__init__.py
new file mode 100644
index 0000000..e69de29
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/filters/__init__.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/filters/__init__.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..98b5792fbf7c056fc1edfda99c793490956a4a2f
GIT binary patch
literal 207
zcmZSn%**AGdLky70SXuy7#JKF7#NCK7#J8*7#M;zKq7t`AZawBxPpO!LBF6Vvn;VB
zRlh8;NIxw<CndG0SU)L6zdR`^FV{4;*vK%+JiRL2!qlQXC#%ZL00h$W^h5LuG7EGw
z^NLFnb8>Xu$~-)c13*Gx9AB22my%zkpHY&VW15qhq@R|VQvxzKK0Y%qvm`!Vub{Go
VgMop;CO1E&G$+*#<iui-3jwr%HFE#}

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/filters/alphabeticalattributes.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/filters/alphabeticalattributes.py
new file mode 100644
index 0000000..5ba926e
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/filters/alphabeticalattributes.py
@@ -0,0 +1,29 @@
+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/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/filters/alphabeticalattributes.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/filters/alphabeticalattributes.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..ac1ae11990b008aecadbc2df2f47962b7cf0d4f2
GIT binary patch
literal 1876
zcmZSn%**AGdLky70ScHI7#JK9m>7za7#J8*7#LC*8FCmHav2$-7#VVz7^0XMa+w*T
zm>C#Tm>5!+8FE+{a#<OoSQ!{WYFQX^*cfuz8KT%37*kjoS{N9jI2cmc7*bgovN##i
z7#UL7L4wT;43SZs3@IE8!5W+l3=EkdyEQ;Im+&(%FeD}w=jW7`q{e6F7UUO|lyHDt
zl3A8noSC0jBEZ1FP@0#SoS%{!pOaaVT9lYmoXN<*z@PylN>~^e7?Ki;Qz1NV1_lQI
zqLkF4)D)M@<dS5N5)cMi<qYzq0s{j>4cL>CDU1w~1%eDIOmG2a2FWxghF}elnWaA&
z7#M<5OG=CK6cY0k5(^57@(YSG6H8JRvQsM+((;SI!X+g|nMtK3sbGQP{GyV~ymT%u
z1qB5KN0?NxLPla)szRbdUSe))aY15oszOOdVu?a>VxB@$szPdJNk(dsLPCOHeqL%q
zf&$23h2oN;%)E3xh456cS;>ic>Lm)v`MCv&MIha&3MJ+F3Q4KSiKWG0ex-U*szOR;
zT3TvRYF>##No7H5v5rD<zCwAbLUMjyS!z)U*dVwqCHWxdr{)%vR6;FNNXslLF42QH
z9vnfXpjd(gHHZZXVNlp4mXs7}fQ3LraT@~zgML9#W?5oMs(x8wk$zf!PD*M~v3^pD
zetA+-Uao0wv5{etd3sg4g{eh(PF9tf0SKh$>4)eSWESXV<`tJD=H%$Qm3ep?2Y`gY
zIKC`3FD1W7Kcgf!$22E1Nk1(!rvzkfVopIuVp3{JW^!T<$SvR)DAp^eECD61c#u$h
zc4{Rk85J{uoXAna#=yYf2G$Nw_@H#*1WFU)3=9mZ450L$!T?I|DU6^r8^z2J6s!T#
zUaG>tz~Bh8vnsV%0b~QjQgFPd=A`DP=9LtKlN&1o0|N*rgN$xwU|^`IVJKl>$YNy3
z0;jZQMh2JI42D`ph8jjtW|K@|W5{M>C@NzpVP<G%V5ntcs4!tDVF63CFi2*xf<#kT
z8A{j~ni&~gV#OF@m>6oA8ERP=YFHR*m>6o98Egvu8NxwKMurp?2AezvknS+XLScsR
z6b6Q14R!_w2ES5J+<}rtDJW!uOA?DpLK4%#99K|60C7M{QW8rNOF%g$JGBxL065iy
z4GsdS4FXvK&bjgNpj;Xs9|STB9Pprgk(yEh3YE-~)ZF4AP;6*`xZvztoSKscmMqE7
zPR#?eKml9~mIP%QuuxfIPHF0(Om#t^R42;7z)%b-s~8w183h<Q8O0cd8TlA_8NsCq
zG+;oUiH|SgVqjp1kI&6dDa}cZk1qj*Tzq^=esX*~*eHZ2!K^`)zrc|!4Du-`ZrK>w
z82vOro`L!(t+b@HC^bGl2$bi7K=~^Olz&RVTu>q@0hQ0m`8heM$t9WjdBxx)0!|HJ
hlfm9a5QE6$;P|tF#F!n(W5u8>A;ToVB*4tc4FGMT*02Bo

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/filters/base.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/filters/base.py
new file mode 100644
index 0000000..c7dbaed
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/filters/base.py
@@ -0,0 +1,12 @@
+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/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/filters/base.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/filters/base.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..513885f72563d90f71fe4e9958cbfd731f014651
GIT binary patch
literal 1341
zcmZSn%**AGdLky70ScHI7#JK9m>7!97#J8*7#LC*8FCmHav2$-7#VVz7^0XMa+w*T
zm>C#Tm>5!77}6LSQkWT97#Nxv7$T!s8B$mnf;Ctf7#K1^=4pUTE8%BgU`R|V&d(_=
zNsZ6UEyyn_Dd7N_o>`VzoSC0jBEZ1FP@0#SoS%{!pOaaVT9lYmT*Ah{z~GjdQ<7Q)
zcN-%E1A`ODZORM`45<ttC#5ieERSLWxwC}<<ggSbum}r7P%zl~WF`g%1{ih*>E>l%
zV5nhas9|7;2YWGC17xrtm;_r}oL^d$oT>rRRKmi*z)+l;lNJPGXn;KhB8p2G7#Q>m
ziZaU*OH%dA5{vZH@^eyBi;DG=QuND{lJas*bBm1(lg!hr(k)Ca%5$=+%nU#vJx@PG
zzaX<fH#4ueBrzvP*R9OM(>MSm1jg}Ysd*{+Mfw>fxjCjenMwL-;4moGPf9FK)hnn3
zhg^JoW?p7Vd^{+ii$Tt0U`z)20fa$ZxHn4}K;Fz^WN2n&fO!+70PHPLNJG2@(ia3W
zY!G>{B(*3$9+XUA9t61?gh6Qv>_JenfqSrqk)fFh)sO593=HY1C5a^^MG$X-bc4MK
z_I_SsZt7t0FE;}NLwr2cq4Dt`F4W85j0BBvkZa@POSr&_bMsS5b5i5ugFu-i2oy*`
zAZ-ZWfLQ~UMuR|61j;YPAosB`ax!x=`)PpKQ1_>mmXsEO+z-l1LEzK}iW_j|%TLNm
dO)dc&0rmxg7%=~Uqre6d=yo92g5yVq82}erKVkp?

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/filters/inject_meta_charset.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/filters/inject_meta_charset.py
new file mode 100644
index 0000000..aefb5c8
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/filters/inject_meta_charset.py
@@ -0,0 +1,73 @@
+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/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/filters/inject_meta_charset.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/filters/inject_meta_charset.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..19bee51225c26e0367595851795691be32cf6bee
GIT binary patch
literal 2648
zcmZSn%**AGdLky70ScHI7#JK9m>7yZ85kH+7#LC*8FCmHav2$-7#VVz7^0XMa+w*T
zm>C#Tm>5!+8FE+{a#<OoSQ!{oSQt`S8M4?I(ij<1SQ%Ov7@8RvBBR(CQrH-RHP{&#
z7&1XtXn-sz;b&lANK7iu&nYcQjnB+2$S*1>;Q(2fS(aIxnV(l8z`(#znwOcJpOPA%
zlUb5ll$cYT$;iOKpaCLESQr=>k`jwkOV}6~7~C>*N>Yp9J^(3j0{K9Jfq@~F0p#!$
z29U#37(uRzVrEET0y9_`f`Y-$DYa!_VDQY#N=+^)R!B&&$xSUuR7lQ9EGkYdv32!x
z_IL60bGJ)KP$)@ESIEpO$ydloO-xb9Pg6+APcF?(%_~U;`3i=eVV0LLFk~?@WHB++
zFfi0GGBh(WFxG%M@ywub4c1@+`Lcw8fx)>bHL)bMSRqjX;u$V31t_peEJ{}>&Mz%W
zPPI}f$w-B=6-x56Q}YyxONvqxbJ0|%<|XH+Wagzq)WdiRCHV@)sU--tej1=q3<9}2
z2*d(MKzw{=US>&rJeUL13JxT2m=~w!q=Ca6;-Vl>@N0mh6+{#_GcYjd7ZhcdC6=V>
zmn9bIr{(9Qq!tzHC#C3@Cne?On&uW8877&hSEXB+T9oHxRhb!pKzg2jh<-t4fo^7A
zaY<rMj;>poho^A>NC=GM%Tn`F@{9B{N^)~db25|k)4)+)te**vw0Ka2#X}=Zub?uB
zm4Sf)l$?q|{$k(|W=sYp3N8i)29Sf3LGd$#37ocT89|Yg1y1VO91OKg4CxFEwag3^
zWlSYZ3|Y(!Su7w0&5R5#u}Ms|EDSX)pyVT2%gRv03d#W4ObkUiU{MwZ$t+e-qEBIE
z0Ey-^rLZy7GBOnAGvzTefmE}D#qTqM%s{B-0E@;kmas9@vN2S+f~7ebB(vB-hPlMn
zF~l%|P%S${EeAs_CqoT8C}U=GG8CO;C|n9cH5?33tGU32{Q<c-ivjE`P6o*uc7_@b
zhBPJyn-Z`W0}7Xd1X8%cikC9faKg0nKt(|6*gz&1E@cR>VPhz|!<ZrjGcFs#=Yv`z
z2J#LkgJg;@%>2STjD`73AYp_rVPR6k#K2RO&y>jw3cM612D21ah7=YCGmvVKA)E|m
zVT>SIc2GE*rEq{{GvU!B!eEvHQNzTL!VggcF(Hf*<Z32{LOpPhPXI>{KiES!9mC8}
zl+RSd%#g*&kRrg)%*YT1%Av(hVE5s0fhf!cc?=8{5)3uW3`H?$W)!+Ig+m;ZA_z+Y
z;36P}4eXw7uzD^~fHpHSFc#{8SYaSKJcWTFSVN3~fx)j7l!6P2QsY5|O(`fPmsA#{
zf<=Q%5{pVg64Sw=d5O8HU<OznxS-90=m8nvnp;p(2~!HnCt#&1i6x1pAf?buQwqu(
z86_nJx~YYwnPsIs3=9m(`FSO&c_q4FTfu4}0;Qr13=Acy6(!*8XbmqYRf|hOxyv;#
zB_uH&T-KLzGB7X{<QJEKodYiI{2;bMOu{b$DSwgGKt;G27#P4M54cG3%g;;2EW}Du
zi{j%;K;=MAetBvUnB|t3Q=AHBWtODo7K3$%6qTlyfQrC^`~q;nmRL}bnwO#h3XdR=
zr@`urOA<>`OF&|v5R6aDFU?CS0m*{YX6B`X6@g1+u%Vz3E0JbkV8}=;jt7NmJUCS2
zp&=R%mIs9mDC&v}5|dNG+CV(8No9#SrKy9kSOo=uFarZaaRjKeXJljKXJliNWaMJx
zVH9KJVd7yFV`5`eX5?XHV-#W(XJlh!VU%O!WfEf)W#nO!WfElMWfWu-W)x;*W8`Gw
zVU%IwV`O6#WE5lMWE5g#1DhbgqydUFaP<=(4+@d^cyPeS$LHp!l;)(y$AbetK0YNs
zIX)g-(g%Uug$OP%YtU3hpnMC;7R4Zf4diofKX7XZ>Z`QUlG38o`1l}DkOqOOsUT3R
i0Msa8KqPChpAf`g@f|ptY#<S12XZ^O!j)kXU<LrW@mq}m

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/filters/lint.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/filters/lint.py
new file mode 100644
index 0000000..fcc07ee
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/filters/lint.py
@@ -0,0 +1,93 @@
+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/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/filters/lint.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/filters/lint.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..7c84589acbf97736d2bfc3ccfdcfd48d705c2552
GIT binary patch
literal 3500
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
C1PN&X

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/filters/optionaltags.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/filters/optionaltags.py
new file mode 100644
index 0000000..4a86501
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/filters/optionaltags.py
@@ -0,0 +1,207 @@
+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/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/filters/optionaltags.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/filters/optionaltags.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..7e770b8a2f6149cd0071229a2bb7636173bd672c
GIT binary patch
literal 4754
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
RBx3A9jxGlIRfb7`836wE4x|78

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/filters/sanitizer.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/filters/sanitizer.py
new file mode 100644
index 0000000..af8e77b
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/filters/sanitizer.py
@@ -0,0 +1,896 @@
+from __future__ import absolute_import, division, unicode_literals
+
+import re
+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"]
+
+
+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)
+        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/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/filters/sanitizer.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/filters/sanitizer.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..f9888a3b6270bf03184a3fc23752cae04af451ca
GIT binary patch
literal 27270
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

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/filters/whitespace.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/filters/whitespace.py
new file mode 100644
index 0000000..0d12584
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/filters/whitespace.py
@@ -0,0 +1,38 @@
+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/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/filters/whitespace.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/filters/whitespace.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..7ca0277055924d6be770ad0c4789236066c0712e
GIT binary patch
literal 1941
zcmZSn%**AGdLky70ScHI7#JK9m>7zuF)%QsFfgPrGUPBY<T5fuF*4*bF+?#j<T5iv
zF*7iN<d_(8SQw&M7*d!SQdk&rSQ&EJ7^2u17*kjoQrH-B*coy;7@{~Bayc2II2jmI
z*cr087*aVIni)a-R2GITZiW;Nkcb#ah=(DClOdIjA&ZwGjgcXRi=l;qp_zdpGK!ZW
zg&V|);$ui*VhGmYVPIg$1i4oO<k}K`1_p-2q~iRX(vsBp%-n+fqLLC0kn1zcGK(|w
z^GXC57#K?PGL!RDQsZ+nOHzvxbBg^k85tNDG(bcN3j+f~QetsxCKE^qM3nF`FfbG)
zrzDmny5^+jrskCtgRLnpNK8(3&PXguOfE?+DlP>%qLh_^fgxJ8I99uaje&u|Ei<Pi
zwFn-bAhVr7;c3jkz>vxS3dR%$P%x%4gTgk2i6NbdA(e$8l@$~$;-GL~1BGV`149%$
zLr|~=$beEu1_lP_{G6P`g5uO-h4PHdl2ou$6jCdaQwvHIGV>G)ic)nHN>VFI5{pt3
zbrcfwQWT1li!uvJ6jGr+C<TR9K~ZWcC~#mZlR+T>vIB&ZK@PnQ3OYuHT1JM7a||U6
z3|Wi}SxgKy3?TQp#O`9KWn!pd0!4&mEi*$6Gsv;oObkWQ3^j}l#eQHp76!>028JwV
zhHN&dL<%c|c`YMDUNKk)8v{s36-Y-Bm`q`1umDMifP{F8mVi~UgH<g7o5;Z+S+oR{
zK0sD;Fxcd2K~$attK<T!JjYPN0#n?~2xZyiF@RWMjD?a6;VBFZ!5Z8Q3=DqY<Wmar
zb4g_ZBt(Ks5{pVg64Sw=d5O8H;1p5{ic{CT6p#ccp#`I*0FV)&WKs$WM}<-@P(;Dg
zhXyEV1c8D*2xJU6RmR7IQeb?1i6{dD12_@`ic*VHi^@__Qd%-Jw&TG{iowYMoKTBX
zbJD;D6+pF>fGjD=&rZz)%Y*!*0ZNx(qPU8IfkD5ZD6=fFBvrpGu}D8HKPM%%s8~NK
zMZY{LDKFPFx7f%q$vnL(-NMwOJSVHl%m4(^^YlaX3o;9IGxLf|5_58N-O4;XjRQbJ
zU>skTnwOGaq@Pien`4@jnWUcvPWQ$7h{UN^P#MI|z`y{?e#KHCCo!@yN-}aW@-Rv=
z@-hiA@-oRX@iGZBiZf||lO%|Uj|T;Pe0&KgB;(_A^HWN5Qsd)GKnBIfr{pKc$Cq$2
zFfgPQ<yWQV6{nVfJ)M(TToMF|iXe~~U|Yf7M-T%Y5TN)6m0QIi1{)(AqYM)`>w%ID
zD1kVGvK}a;AUQ6D5uD>dr5&g|@`EHV4G_BoWK3{?qqA#pe2}ZVYeWf1e{pFNqA&wx
z?!n`AP6h@BRZwCFxt@Vh1C))R(VJFUQd*Q6A0Grt9YLV52m&c80TD&1C16pI@4!)>
zoDWKhc_qb=m<A_%P@HGwXXb&^M{<5{L1s>BkT3%S131G4fviRZ1ei6z2?3mSZ6L|o
Z4&>otP*o$t#KR=OD8|UoB+M)+2>@G|z;FNn

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/html5parser.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/html5parser.py
new file mode 100644
index 0000000..ae41a13
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/html5parser.py
@@ -0,0 +1,2791 @@
+from __future__ import absolute_import, division, unicode_literals
+from pip._vendor.six import with_metaclass, viewkeys
+
+import types
+from collections import OrderedDict
+
+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 = dict([(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.normalizedTokens():
+            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 normalizedTokens(self):
+        for token in self.tokenizer:
+            yield self.normalizeToken(token)
+
+    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 normalizeToken(self, token):
+        # HTML5 specific normalizations to the token stream
+        if token["type"] == tokenTypes["StartTag"]:
+            raw = token["data"]
+            token["data"] = OrderedDict(raw)
+            if len(raw) > len(token["data"]):
+                # we had some duplicated attribute, fix so first wins
+                token["data"].update(raw[::-1])
+
+        return token
+
+    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 = dict((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]
+                try:
+                    info = {"type": type_names[token['type']]}
+                except:
+                    raise
+                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
+        """
+
+        def __init__(self, parser, tree):
+            self.parser = parser
+            self.tree = tree
+
+        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):
+            return self.startTagHandler[token["name"]](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):
+            return self.endTagHandler[token["name"]](token)
+
+    class InitialPhase(Phase):
+        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):
+        # 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):
+        def __init__(self, parser, tree):
+            Phase.__init__(self, parser, tree)
+
+            self.startTagHandler = _utils.MethodDispatcher([
+                ("html", self.startTagHtml),
+                ("head", self.startTagHead)
+            ])
+            self.startTagHandler.default = self.startTagOther
+
+            self.endTagHandler = _utils.MethodDispatcher([
+                (("head", "body", "html", "br"), self.endTagImplyHead)
+            ])
+            self.endTagHandler.default = self.endTagOther
+
+        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"]})
+
+    class InHeadPhase(Phase):
+        def __init__(self, parser, tree):
+            Phase.__init__(self, parser, tree)
+
+            self.startTagHandler = _utils.MethodDispatcher([
+                ("html", self.startTagHtml),
+                ("title", self.startTagTitle),
+                (("noframes", "style"), self.startTagNoFramesStyle),
+                ("noscript", self.startTagNoscript),
+                ("script", self.startTagScript),
+                (("base", "basefont", "bgsound", "command", "link"),
+                 self.startTagBaseLinkCommand),
+                ("meta", self.startTagMeta),
+                ("head", self.startTagHead)
+            ])
+            self.startTagHandler.default = self.startTagOther
+
+            self.endTagHandler = _utils.MethodDispatcher([
+                ("head", self.endTagHead),
+                (("br", "html", "body"), self.endTagHtmlBodyBr)
+            ])
+            self.endTagHandler.default = self.endTagOther
+
+        # 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"))
+
+    class InHeadNoscriptPhase(Phase):
+        def __init__(self, parser, tree):
+            Phase.__init__(self, parser, tree)
+
+            self.startTagHandler = _utils.MethodDispatcher([
+                ("html", self.startTagHtml),
+                (("basefont", "bgsound", "link", "meta", "noframes", "style"), self.startTagBaseLinkCommand),
+                (("head", "noscript"), self.startTagHeadNoscript),
+            ])
+            self.startTagHandler.default = self.startTagOther
+
+            self.endTagHandler = _utils.MethodDispatcher([
+                ("noscript", self.endTagNoscript),
+                ("br", self.endTagBr),
+            ])
+            self.endTagHandler.default = self.endTagOther
+
+        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"))
+
+    class AfterHeadPhase(Phase):
+        def __init__(self, parser, tree):
+            Phase.__init__(self, parser, tree)
+
+            self.startTagHandler = _utils.MethodDispatcher([
+                ("html", self.startTagHtml),
+                ("body", self.startTagBody),
+                ("frameset", self.startTagFrameset),
+                (("base", "basefont", "bgsound", "link", "meta", "noframes", "script",
+                  "style", "title"),
+                 self.startTagFromHead),
+                ("head", self.startTagHead)
+            ])
+            self.startTagHandler.default = self.startTagOther
+            self.endTagHandler = _utils.MethodDispatcher([(("body", "html", "br"),
+                                                           self.endTagHtmlBodyBr)])
+            self.endTagHandler.default = self.endTagOther
+
+        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
+
+    class InBodyPhase(Phase):
+        # http://www.whatwg.org/specs/web-apps/current-work/#parsing-main-inbody
+        # the really-really-really-very crazy mode
+        def __init__(self, parser, tree):
+            Phase.__init__(self, parser, tree)
+
+            # Set this to the default handler
+            self.processSpaceCharacters = self.processSpaceCharactersNonPre
+
+            self.startTagHandler = _utils.MethodDispatcher([
+                ("html", self.startTagHtml),
+                (("base", "basefont", "bgsound", "command", "link", "meta",
+                  "script", "style", "title"),
+                 self.startTagProcessInHead),
+                ("body", self.startTagBody),
+                ("frameset", self.startTagFrameset),
+                (("address", "article", "aside", "blockquote", "center", "details",
+                  "dir", "div", "dl", "fieldset", "figcaption", "figure",
+                  "footer", "header", "hgroup", "main", "menu", "nav", "ol", "p",
+                  "section", "summary", "ul"),
+                 self.startTagCloseP),
+                (headingElements, self.startTagHeading),
+                (("pre", "listing"), self.startTagPreListing),
+                ("form", self.startTagForm),
+                (("li", "dd", "dt"), self.startTagListItem),
+                ("plaintext", self.startTagPlaintext),
+                ("a", self.startTagA),
+                (("b", "big", "code", "em", "font", "i", "s", "small", "strike",
+                  "strong", "tt", "u"), self.startTagFormatting),
+                ("nobr", self.startTagNobr),
+                ("button", self.startTagButton),
+                (("applet", "marquee", "object"), self.startTagAppletMarqueeObject),
+                ("xmp", self.startTagXmp),
+                ("table", self.startTagTable),
+                (("area", "br", "embed", "img", "keygen", "wbr"),
+                 self.startTagVoidFormatting),
+                (("param", "source", "track"), self.startTagParamSource),
+                ("input", self.startTagInput),
+                ("hr", self.startTagHr),
+                ("image", self.startTagImage),
+                ("isindex", self.startTagIsIndex),
+                ("textarea", self.startTagTextarea),
+                ("iframe", self.startTagIFrame),
+                ("noscript", self.startTagNoscript),
+                (("noembed", "noframes"), self.startTagRawtext),
+                ("select", self.startTagSelect),
+                (("rp", "rt"), self.startTagRpRt),
+                (("option", "optgroup"), self.startTagOpt),
+                (("math"), self.startTagMath),
+                (("svg"), self.startTagSvg),
+                (("caption", "col", "colgroup", "frame", "head",
+                  "tbody", "td", "tfoot", "th", "thead",
+                  "tr"), self.startTagMisplaced)
+            ])
+            self.startTagHandler.default = self.startTagOther
+
+            self.endTagHandler = _utils.MethodDispatcher([
+                ("body", self.endTagBody),
+                ("html", self.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"), self.endTagBlock),
+                ("form", self.endTagForm),
+                ("p", self.endTagP),
+                (("dd", "dt", "li"), self.endTagListItem),
+                (headingElements, self.endTagHeading),
+                (("a", "b", "big", "code", "em", "font", "i", "nobr", "s", "small",
+                  "strike", "strong", "tt", "u"), self.endTagFormatting),
+                (("applet", "marquee", "object"), self.endTagAppletMarqueeObject),
+                ("br", self.endTagBr),
+            ])
+            self.endTagHandler.default = self.endTagOther
+
+        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
+
+    class TextPhase(Phase):
+        def __init__(self, parser, tree):
+            Phase.__init__(self, parser, tree)
+            self.startTagHandler = _utils.MethodDispatcher([])
+            self.startTagHandler.default = self.startTagOther
+            self.endTagHandler = _utils.MethodDispatcher([
+                ("script", self.endTagScript)])
+            self.endTagHandler.default = self.endTagOther
+
+        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
+
+    class InTablePhase(Phase):
+        # http://www.whatwg.org/specs/web-apps/current-work/#in-table
+        def __init__(self, parser, tree):
+            Phase.__init__(self, parser, tree)
+            self.startTagHandler = _utils.MethodDispatcher([
+                ("html", self.startTagHtml),
+                ("caption", self.startTagCaption),
+                ("colgroup", self.startTagColgroup),
+                ("col", self.startTagCol),
+                (("tbody", "tfoot", "thead"), self.startTagRowGroup),
+                (("td", "th", "tr"), self.startTagImplyTbody),
+                ("table", self.startTagTable),
+                (("style", "script"), self.startTagStyleScript),
+                ("input", self.startTagInput),
+                ("form", self.startTagForm)
+            ])
+            self.startTagHandler.default = self.startTagOther
+
+            self.endTagHandler = _utils.MethodDispatcher([
+                ("table", self.endTagTable),
+                (("body", "caption", "col", "colgroup", "html", "tbody", "td",
+                  "tfoot", "th", "thead", "tr"), self.endTagIgnore)
+            ])
+            self.endTagHandler.default = self.endTagOther
+
+        # 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
+
+    class InTableTextPhase(Phase):
+        def __init__(self, parser, tree):
+            Phase.__init__(self, parser, tree)
+            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
+        def __init__(self, parser, tree):
+            Phase.__init__(self, parser, tree)
+
+            self.startTagHandler = _utils.MethodDispatcher([
+                ("html", self.startTagHtml),
+                (("caption", "col", "colgroup", "tbody", "td", "tfoot", "th",
+                  "thead", "tr"), self.startTagTableElement)
+            ])
+            self.startTagHandler.default = self.startTagOther
+
+            self.endTagHandler = _utils.MethodDispatcher([
+                ("caption", self.endTagCaption),
+                ("table", self.endTagTable),
+                (("body", "col", "colgroup", "html", "tbody", "td", "tfoot", "th",
+                  "thead", "tr"), self.endTagIgnore)
+            ])
+            self.endTagHandler.default = self.endTagOther
+
+        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)
+
+    class InColumnGroupPhase(Phase):
+        # http://www.whatwg.org/specs/web-apps/current-work/#in-column
+
+        def __init__(self, parser, tree):
+            Phase.__init__(self, parser, tree)
+
+            self.startTagHandler = _utils.MethodDispatcher([
+                ("html", self.startTagHtml),
+                ("col", self.startTagCol)
+            ])
+            self.startTagHandler.default = self.startTagOther
+
+            self.endTagHandler = _utils.MethodDispatcher([
+                ("colgroup", self.endTagColgroup),
+                ("col", self.endTagCol)
+            ])
+            self.endTagHandler.default = self.endTagOther
+
+        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
+
+    class InTableBodyPhase(Phase):
+        # http://www.whatwg.org/specs/web-apps/current-work/#in-table0
+        def __init__(self, parser, tree):
+            Phase.__init__(self, parser, tree)
+            self.startTagHandler = _utils.MethodDispatcher([
+                ("html", self.startTagHtml),
+                ("tr", self.startTagTr),
+                (("td", "th"), self.startTagTableCell),
+                (("caption", "col", "colgroup", "tbody", "tfoot", "thead"),
+                 self.startTagTableOther)
+            ])
+            self.startTagHandler.default = self.startTagOther
+
+            self.endTagHandler = _utils.MethodDispatcher([
+                (("tbody", "tfoot", "thead"), self.endTagTableRowGroup),
+                ("table", self.endTagTable),
+                (("body", "caption", "col", "colgroup", "html", "td", "th",
+                  "tr"), self.endTagIgnore)
+            ])
+            self.endTagHandler.default = self.endTagOther
+
+        # 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)
+
+    class InRowPhase(Phase):
+        # http://www.whatwg.org/specs/web-apps/current-work/#in-row
+        def __init__(self, parser, tree):
+            Phase.__init__(self, parser, tree)
+            self.startTagHandler = _utils.MethodDispatcher([
+                ("html", self.startTagHtml),
+                (("td", "th"), self.startTagTableCell),
+                (("caption", "col", "colgroup", "tbody", "tfoot", "thead",
+                  "tr"), self.startTagTableOther)
+            ])
+            self.startTagHandler.default = self.startTagOther
+
+            self.endTagHandler = _utils.MethodDispatcher([
+                ("tr", self.endTagTr),
+                ("table", self.endTagTable),
+                (("tbody", "tfoot", "thead"), self.endTagTableRowGroup),
+                (("body", "caption", "col", "colgroup", "html", "td", "th"),
+                 self.endTagIgnore)
+            ])
+            self.endTagHandler.default = self.endTagOther
+
+        # 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)
+
+    class InCellPhase(Phase):
+        # http://www.whatwg.org/specs/web-apps/current-work/#in-cell
+        def __init__(self, parser, tree):
+            Phase.__init__(self, parser, tree)
+            self.startTagHandler = _utils.MethodDispatcher([
+                ("html", self.startTagHtml),
+                (("caption", "col", "colgroup", "tbody", "td", "tfoot", "th",
+                  "thead", "tr"), self.startTagTableOther)
+            ])
+            self.startTagHandler.default = self.startTagOther
+
+            self.endTagHandler = _utils.MethodDispatcher([
+                (("td", "th"), self.endTagTableCell),
+                (("body", "caption", "col", "colgroup", "html"), self.endTagIgnore),
+                (("table", "tbody", "tfoot", "thead", "tr"), self.endTagImply)
+            ])
+            self.endTagHandler.default = self.endTagOther
+
+        # 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)
+
+    class InSelectPhase(Phase):
+        def __init__(self, parser, tree):
+            Phase.__init__(self, parser, tree)
+
+            self.startTagHandler = _utils.MethodDispatcher([
+                ("html", self.startTagHtml),
+                ("option", self.startTagOption),
+                ("optgroup", self.startTagOptgroup),
+                ("select", self.startTagSelect),
+                (("input", "keygen", "textarea"), self.startTagInput),
+                ("script", self.startTagScript)
+            ])
+            self.startTagHandler.default = self.startTagOther
+
+            self.endTagHandler = _utils.MethodDispatcher([
+                ("option", self.endTagOption),
+                ("optgroup", self.endTagOptgroup),
+                ("select", self.endTagSelect)
+            ])
+            self.endTagHandler.default = self.endTagOther
+
+        # 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"]})
+
+    class InSelectInTablePhase(Phase):
+        def __init__(self, parser, tree):
+            Phase.__init__(self, parser, tree)
+
+            self.startTagHandler = _utils.MethodDispatcher([
+                (("caption", "table", "tbody", "tfoot", "thead", "tr", "td", "th"),
+                 self.startTagTable)
+            ])
+            self.startTagHandler.default = self.startTagOther
+
+            self.endTagHandler = _utils.MethodDispatcher([
+                (("caption", "table", "tbody", "tfoot", "thead", "tr", "td", "th"),
+                 self.endTagTable)
+            ])
+            self.endTagHandler.default = self.endTagOther
+
+        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)
+
+    class InForeignContentPhase(Phase):
+        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 __init__(self, parser, tree):
+            Phase.__init__(self, parser, tree)
+
+        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()) & set(["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):
+        def __init__(self, parser, tree):
+            Phase.__init__(self, parser, tree)
+
+            self.startTagHandler = _utils.MethodDispatcher([
+                ("html", self.startTagHtml)
+            ])
+            self.startTagHandler.default = self.startTagOther
+
+            self.endTagHandler = _utils.MethodDispatcher([("html", self.endTagHtml)])
+            self.endTagHandler.default = self.endTagOther
+
+        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
+
+    class InFramesetPhase(Phase):
+        # http://www.whatwg.org/specs/web-apps/current-work/#in-frameset
+        def __init__(self, parser, tree):
+            Phase.__init__(self, parser, tree)
+
+            self.startTagHandler = _utils.MethodDispatcher([
+                ("html", self.startTagHtml),
+                ("frameset", self.startTagFrameset),
+                ("frame", self.startTagFrame),
+                ("noframes", self.startTagNoframes)
+            ])
+            self.startTagHandler.default = self.startTagOther
+
+            self.endTagHandler = _utils.MethodDispatcher([
+                ("frameset", self.endTagFrameset)
+            ])
+            self.endTagHandler.default = self.endTagOther
+
+        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"]})
+
+    class AfterFramesetPhase(Phase):
+        # http://www.whatwg.org/specs/web-apps/current-work/#after3
+        def __init__(self, parser, tree):
+            Phase.__init__(self, parser, tree)
+
+            self.startTagHandler = _utils.MethodDispatcher([
+                ("html", self.startTagHtml),
+                ("noframes", self.startTagNoframes)
+            ])
+            self.startTagHandler.default = self.startTagOther
+
+            self.endTagHandler = _utils.MethodDispatcher([
+                ("html", self.endTagHtml)
+            ])
+            self.endTagHandler.default = self.endTagOther
+
+        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"]})
+
+    class AfterAfterBodyPhase(Phase):
+        def __init__(self, parser, tree):
+            Phase.__init__(self, parser, tree)
+
+            self.startTagHandler = _utils.MethodDispatcher([
+                ("html", self.startTagHtml)
+            ])
+            self.startTagHandler.default = self.startTagOther
+
+        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
+
+    class AfterAfterFramesetPhase(Phase):
+        def __init__(self, parser, tree):
+            Phase.__init__(self, parser, tree)
+
+            self.startTagHandler = _utils.MethodDispatcher([
+                ("html", self.startTagHtml),
+                ("noframes", self.startTagNoFrames)
+            ])
+            self.startTagHandler.default = self.startTagOther
+
+        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"]})
+    # 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'] = OrderedDict((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/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/html5parser.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/html5parser.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..2b997e4040ccc55fddce695302fec5e4d421355c
GIT binary patch
literal 141299
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
Dz6zZ^

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/serializer.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/serializer.py
new file mode 100644
index 0000000..53f4d44
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/serializer.py
@@ -0,0 +1,409 @@
+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 identifer 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/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/serializer.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/serializer.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..d9232ca9c90881a4c56e00026fe6d937bc2d125e
GIT binary patch
literal 13932
zcmZSn%**AGdLky70SZ_c7#JK9m>7yBm>3vR7#LC*8FCmHav2$-7#VVz7^0XMa+w*T
zm>C#Ba!d?4EDX7<3{k8QJ~KlO8$%QuSRV^R4m(3G2SXGGLoO#n6ej~?3M)ej8$%8k
zLoPQ%6gNXI4?`3WLoP2v6fZ=M9W2Mk5XHxk%g+$S&yXv?5G4SS<6y`UWXKg_h!SGR
z6=sMMhS<l+kR!s7E6NZh%D|Yy#gHY&kjl%@%*c?!%^)5n&XCH+kR`#8!o!d%&LEz`
z%OKv&$PguoCd>yBmSV_cV2F}tNR?qo;Rl<+%8<>(5GBh{v6~@Pjv<wwAxoa2nE@o_
z61$ushKV6cfgwtfAyt+k-;yy^h9OlEB$vX<kj=tS5X6`&%fOQ#gd`yVk|>I1ER<l(
zV*sg65oE|_W+>W^s)mW7sGBiWm?29Eqz2?-MTR^chE!z)H&u}#Rhl82ouOb2W2yo}
zmI}ySMSDQ(RB4bhn>+@FJO+kB3C8dgA%+$PhA35rR1Ss|VTM#yhGr%P#uO2TR5gYa
zQHB;KhA4H06fuTW4TdyEh7@s->ShLp$S6&Q6bXh@EwHF0TvVGOg_$8(LyCa`6kZGr
z8q5p~3?=*w3=D}$#rZj<C8_b5xdr(}B_$jT3=AomWtqj9`FSM*3=9mVd6~)iDXH-}
znI)-3i8;j@j3BL?AR@J*B)+7wAk|NU3B=`NU|=XpP0uVYNiB*`Eh@?{Dv@AdV5rE=
zNzO<tDoRZ&N-fAqOiqQ!6=#ABf;fbSfq|hcKQqNOCp9-UucWv{kb!|ADL+3aH8Ibz
zq@*Y_sk9`u80_BSg2d!h=ZwUn#N?9HqGE`Cu+7OSi6x0}6F~k*%`3?)$xJOS;f6TF
z70QP=7bI9xl$u(en3J7aR9wQwz`zh+T9OI#B8Z<_oSayYS_;Z!r69hNx~+{}LMh1Q
z(O@#RG#(_$$i&RT%Er#Y$;HjX%f~MuC?qT*Dkd%=DJ3l<D<`j@pKxfw!&wav7xX<`
z(Eq5R;ZZ~5qlTtO4b6`lS{^mDK5A%t)X@H@q2p0Q=c9(MM-3|;HLQHpu>Miw{KpLq
zv8ABg{iT2Z{!CCfgY8vI2DyQYfq?<!QD;!juV-XnC}CizVPGg>WGG=`NMiz}nW93*
zbOwf6Mg|bc#8AS_P|M6vv4x?81*9^I6-=^$Np=RsW<~~=*lD0#Qp>_n%gRv0%utjB
z)l}#LN}M$ieQXTkwQLL}91K~UV7;siHEaweTwpdkh@Ha7AfC<y%32^piw=U-a)af;
zYHQd)Wt2EbvX-5pga_oTJRXJ;UWOW0kgi&Gh8iY@EIx)Bb`Y1b(1jtqq6#GD5?jPj
z%K=KgSpp0-93a_RPKFvzh9Vor8b*+o6tKNeP7NnW1!D~-LzW;Y7c?_66o*6QQkcPV
zh2e~aPZ^+kSr|%$pvI;!GRTWHGctf=!&6upvV=j3ni;{qU<U<oaES<r)6B>aoWj5m
ztN}_Ren_zdjw@?$(os{cP%X9wCnXJ0P<8=DUS@G-UU5lcUUF)Q5Ca24C?v1B=7DmY
zD>w&%ltP6=iW2jRa}rBZAu_BC3=D3GImM|ZoD2*Msd=TjsYQt;so->+pOlrFTv7s3
zQe2W)R8j)U@2PnyLA)TFLHRzjIJmT^C_g>1BsCy0vk0spH!}~MV~dexLh_ySQ&J1^
zGxJJHK<O}~s5BL<I=?6dY*%7IL26zK*!}UTV3)^(GhStUZejsgWqK;4TuIGKDK5_}
z$p8yxq*j2<%gWEp3j#S*0~8=&snm*OFkO^dTmljVg$CFG#b6!9*_j0;pyZzkCX>P5
z%*;zktpJAvTy+U3w<JT9rfPt)DVQiOVqjp<FDS|^ODsv%FH0=aPs`6qNi8bYPfF1*
zPfE(mHO(zHGE6d0uS&NtwJ6WYsxmVGf%H865dDJ80$p&N<>ctPm3ep?2Y`gYIKC`3
zFD1W7Kcgf!$22E1NxwL?C^Io9vnsVnub>hfvLGo);GmX;S_}*f#RecJGKw;?fuSat
zWMkxI)M1om<YeMu6lCOO<YxqlfM{VRc}6j&Qb7g=1`Jb6LE)JSD%_Gm5f4h0Ale&L
zOc;Vv00To7BQ!17vVaPU8fJ!G25^pNWyoS?r~&74P)Y|EBEjH7zjOu@14A&(PsIu)
z8L0}Hc?G2<3MKj3sd);;B}J);xeBGlnR)48$>M_4<jl0p)D#7fQy}Fm7ng#9f`V0I
zQ94Ag6<8&T0VVkg@Q_1N4l)C(8eVEEl;kUv7N;Vq0;j;tymW|47!Ok&+=im~{DP8V
zD}}_oN`?G_lFa<PVvy>B#9}aAl938_G1%1wl~&0)iN(cM37{Yc#jzg396gT^Umtkz
z6eTE>WF(d-q^Fh?D<l`CCYGe8K%H5XT2fk+R}66>$X5vOrYIy9D<pzKGBYn7qTID2
zF}ENm)e6G1v$Io3E6UGRfI9%pC`c?SPAyV^)Zq$X9@y2G$`S5`sfLTdb%0|d9vYpt
z5aTq|Z9q2J*(BwsRNC1T*m-0s+UOV9+2}(Az^UF&T@!8y+*l1{<8&1Ab2CdoL7thP
zmzWb@l9*m>3ogYVI$^eCq$Z}=+2}(khz+=`ganKRsB8-20VQrw8JC_~5>k|!8V;`8
zOZXTV7*JyeTyhnq=B1<-feUSD8B$ORDda%00&WVy5)h>A0ZaRkGy^sRlB&T4Q8Bo9
z0TTmN#(-)9c))vu3KdY^XOQ4$<Y5fbV_;x_cNjoH;sh!W7J@1d22ejCg#px0NMQu^
z6H-|~y#o-*#sDJOK@HI;PB5Db%;pA@JYW%CFq;p|<_EI{z@#9kWf~>KkRkwTiAD)C
zqzHl;A`H;>tthCqnj*~5!pIOM4rYsh*%F{eZi*O~Ey)lRtRV?%iGuu+lbW8GTnVmM
zmB58xVQGFzYJ6fzNl|=RVoqslaVe<EfQW+Hou$Gct;MPFNvXvp@krvJ3KugmmP#`)
zFyv<DW#(p9rN%?spkU)6jnGmNsBtAliJ3W>dFk=R`8k;>rNyPPpx_3zPUDkO)AEZ_
z<1ti#Y=pEZ<8w;lGxNa47MFt3D^$1$+=wj&wY!T_i}Q2JQXzF|W@>S%IH<LrQ;?CE
zlv<LRoR|aF4RsXAkC}O(IzK))wInef<niLv60kwVB}JJ9@#PtrC8@<A=aqt5jKzt0
znI)N3so-WLDC>Yy4!C~U2+BeX(8>YQp3GtdHIpQ2nZPv#xN()j2<{enf!c;COrX|e
z2`i{^)(ln(YBV)5f|`pd%pjAp*}%<6Hc(qBo*g7!VFqGnfts7zpr&652Z&z-Rt;)W
zGD91aHO!z!Y%>!>GcyBYVGcuhIs-^yJU2rL#55j;6c&bH4N!$w>cqvs;0f{<xYAWX
z&GC?80$hwkDj$r{vQh}oNG-`oEmFuYQpn2(Rci{6Kn2%Ppnz3?2CN>!G?0ldscDI&
zIVIo<BOw9QLP|(LQUb2+ASn+iog%C&$yWf&Du86cF{%Jb%8)7~B|lHS1YE9y>;mDU
z)WXutqExUhP-R<?TBHEU7z#;6`Q@OhASpE?u`DycNI@eZK?x$Kl#rmQqfnlanupD>
z6osTpus=cV(UioZ6tGTE6%NstU!;(jQ=V8^3>JqlK{81G1UU^gC=fOyDMJblP;go)
zgcheNq-U0;=7Bww3Jzp&_f8=VWGk!#2$s#vOGh#ai;W2h3gsD@$r%denK?P2#(_dg
zerZw;B(PG86-x7RQj3cbL5&g?;9yrs&d)1J%*+GT#K?Me6f*OmW+x{Wrz(KjIS6wT
zix3S3kh4mQQ&W&!3idQKmm_6<L?S?>IfyESgan&}1dx^RRDtQ#Vk8?tmZF9}xL(Cf
zi4gPSA!QB10VVkg5E(@HgW7nBB?@_|sVSf~Q4*>TA*xdpKu!A0JcYdcqTIwBg;Z!C
z9wrR21|eKrnw+7KSd8MA;*!doRC2t6UPz+&1}dqLmzbNHg7B0AxB;G-3h^9@J3w8T
z#3E3bgW9&m`K3k4so=J&o<c}QszQXXk3vCFYD#KaW?pIv!W^}n5^Dvu^b%_n!_*RU
z3#=8?Ksno5K`pT$zt~zKu_#rcG%qnNEj76$6`JERixrAfOG*eOZ0w~9df|>10J-^P
zsS3rZxruq;DkG;-AvZNKFEcM4lm}2;i>M#;6f{CIGK&?G^K%P|Qj3dIixm=cazF_m
zT7iI)LLw~ngR2x2lTs^^QwvI9(Vvh|P?VaGpr?ti#Ke(M@l?ZB3c(rqMJ1_u#R||m
z8j+*H#W1KmL2*`AX>kd-e1m5vNFl2OE@V=nt!!vB8<dwI*ap(WNy#iuOv*`3u~mYx
zl<ZJ_l$4sBpPO22MaTp+ZKydGdnA_@V>TwN6g=~ib4pV{v7?ZjlV6;wTauWrP@I!k
zoS~2i@o8#aib8%G$kQkx0Ui-h0IAMTQveOSAu^{%YHmSEC4yg`kzbsu05S)pJQFq7
zrsWqUWu~O0=4t9Fxay_rfl925B7HlQ5(gBDsD8u|+2DkPtLbE=5C9rE1eM5Obqble
zxv43ci6yByl?ssN7K#@^*%uTjpvn;vB$;^%iC{lNx~GW>u-2IZwEYJ01BxjL2{su;
z3SbW@1VO6YVugeRY|&wh5p$Rx$4~;U6JRYdD}`WCLk*nQO7n^n(^5grkkY*Dy!`S!
zP?c0%QdF8;QVi+-<(HNel$PkBI5#*oRly2N7d0(22Q*Zw2eYY2&kZbs+(f~2Eskiy
zY%yCY_~&MpD1cLyJ~XL7%2sf3mk;h!C+6TS-mwQwBKFp<l|oQzeo;zl5n7f{0u4tf
zAZt<pE5mCurZ+P|!!V^rpwZy?%)HE!_;?LXh4lOqg~U9C(!A7)0!Z1NomyF*UzDPd
zSd?B08njkWS1ndY>wEZVfZF!pQK__|{HoMEP(jbmz`y_rlw$BGS59gkSVc%>0d!;!
z)E>`Et$=hzLBsArpq@hssF4p!duSb*5|Dw#sU@ItEl3X3dIt%lLj=HmRPb0lWPlq~
zUnG}+JIj!<wA7q5u$t`h#G-V_5Ie$?@nA8Kb3lfJd$wR=pt`r9o=ZG5Qrbb?El{{H
z_)9VhG0HRYF!C@8FlsV#GA4rt{y-Qs=mj1dw*&<XxKmTY2<lK2i-Ni`O^l$vL>4nc
zks+v;lEnh$rhwH1*T6<~K}Pw3JDZ>(5ODLM5;}ed?sx=&22_JUmVrka9E*!ni$DWO
z;Bnd@P)Y&^F?cK?6+HP6<OFgMs6Pveki2wosDg<B3fdqK1_p))pdbZ>F$1G0BPXLU
z6Kw(#=I!JXw9pH3XJB9ehZop6h>!~MWME(b2M?GSpfD=o0S%RaN4P;nb#lpbjPL@b
z0Z^I*c`+F@x{}An0O}UkFfhb}=VfY{K@%|`E)z(+$P=36iabHnAt|t#*;*C`M$i~6
zBS=v*6KMV>58Uz1Vq+*OgeheQP2wVyHZvlr<6tP72~)?3M;#YK(LtCxZanIE7>ZuP
z)bZj_S5e1W1M1P2v4W<KSV6NblC^B$*&r6stZdN}&}4EAcs^ND3^c>T%8<g&AX#L|
zSi{bc!U3B40rADmYuOp{#KBxn2FaoTurwC~SeOAWe3B7l6eojZ79VKp7&L**!;sC&
zP_z_T0y47<k(k3+!@!Wm&yd0g8qfgE=ce$2=92Q*KnB!ufF_$#_(8KjP?Kvo7}A&-
zAnsuR%L;&90WwAa#BXL~2xBb#0QRFX18AHhkqI=lB?R(sF%uJL0?iFf8Zv>*6o$A~
z1Y~~-#8HM!Ak+9kBVM4nCTKhhg1srsAPKP{jSZwo5Ii@<3YrlHi9@6ymYaYr*JA})
z!p0y8nh|4Q$PxgJsnu{YfCgm3KyzRv!eDhPz;=o-@D#0JDiH+@z~qU6C;Rq+CHNUq
zBtb3&g;0eI+~H!N32T>FE~XeJ@Dw2zLoGK$Ee}HtH$yEiLk$l@Egv{J3oxWefwYH#
zgIj>11{?<vo;U+fu_tp4FGGn0LzX0H+O9+jWNb4NLpD1@(Rn7gREjhMx)j7mG6=J!
z8B%1yAzi^-BEwJvj#f~xGBFf2GJ`zE&yW`dc9S$iiX2E~(F*1gS%xe*m|_NoY)*z+
zeug|_m@;{=vh&O(3fPqKFq9}Vq$q%#0IELtKokBciVP`AplSu`e`SUuZk8H|lrlq#
z3RDUdv-}K2Cs;sHsRBxOAciVKQ3gv2FUUQh<m1AU!VPA#GZcZ@wHyqE88AUMB*pAd
zHbeo)a1MqPUa;dkVYc%!q<~ir)bcUp34x5wQUay)6g8-mKn@T9rFU>r0`UYvs^C0?
zT;WZyvk}sT=a~x6Glkc1GL)!+)08YLNWVHm5rm<^P{ack5nxDB2L)FcV<ALFfFVT#
zA^>tU19)Cm03ra*Nt$3^v>+#DP6lYwjbtrhL`tyvU^|c#EXWlC3@KWmv;|4`P*b(R
zrrrRXD$F2RE5J}A0G=+^0a*@8HmnRq`(ftkf&@Vs0BW8dEJLE0sSh?Ylnp7{aWbSB
zFo@R*GSmn%lxTuewFEf#@-w6u!W;!NSc{>^iVdVt8?4ZZtwa-~59GK!E`}5%uzHY7
z!AZXcDVV?o8OT~l838JU!ohRUrVI=Wevri#ph;42(*x4r2d^UlE!ZdpwGdtMlfi6I
zt!AU>;_n<18Q`j*S`1bN8Z!Y86c>~x<zyy%rj&w|DFlQ%`FJ`jD5(}Jfn|#;i%U{-
zJyXC2Dg;Lchq(Ge#^xcdXpjTcOC1>)7=pnn6*5ym&8M`~B2bS8GRT&cUy=bEO-Rg3
zK^d+?jM@}KtWYfmL9i8e;Knv$DM%@(6&4H{;YJbzwOv8$LP|kxI2-*^G4L!qyb*7s
z4;t)oc5w`G1p6l#G+7>!m=5N+g8ITB4yabQQ7tajM%A30k(rYM>nnpg+KCEalVCz%
zS1N#K{J~6H@Hzm<$SF9GL4&JcG06CAsXYS&18BGiWjaG47c_8@l&X-Qm#UDTW~HDG
zF+p8NK^<g(x(=wHs17kg9c+;rc>WhW{siXRfNcYfQb8n?jV+;T5<s?DgTqEaAFNa#
z>>k&=6p+6`gX%W=s>OETuy@YS1@&{ls&#e2(<)FQL|p3XmU1#MFxV*S>Z%s&>e@j~
zE6FT@OxakMf>s29*Wpwus1}1q*^5$>^V9P(t5Q=S&QvY72Dki(h+c>~P>U67#A)cj
z+moP1S&##$(GBWFK}Pjarb<dc^FFYiG8XwD&}>=>o;jEjP}d7)0CFc3)O7+6>KB98
zQ-K=%$kQ?4g%dD+h*3E3>?5ql4qguhQv(w$0_()=kC%XEs9=gA9nHiX&^#-+!<Uws
zmjdpkz^4fzy%aA{P=PuDL3|(<C>BdVoma>pFLbat2(*9<GF4iVnp+GGGdzQIL7-v=
z(j^5YrIONuoK&z^K*<gzkq3c0XrQQp%+SFXeFcMh+o0BTacW{wat7E7e))N+C7^XN
zXli}HQ-k0YBVnMKK(NQay<=!+4IE%l4<U`ggLOch1e%WsvIPYI$WCxbf_mJru_D-9
zUkSmvz97&fBsjjIqtNhqydcoJGYxQh1a|_#3gHVHz`Y-E+-K&+gC_$a2@f28pj8&&
z5CE0iV2`Ch%J85RP|60Cb)a$^JQ*Di9#a6Ny?C$~$Qm#YJjDT4k_{%ykh~940JZ>B
zWP%4LvQsO;T`n*&K>e;DGX@5Rcc8x34badG6DK1ZBPSC-qX4523n!xhBR?~kWJDsF
zcp14Ec^LVaxEMtlxfnq_Nk&OV0Y*+HHbyxnE=EBn9`K-n0HY|AG!qXa7o!lP7$eAJ
z0Y+se&<Y$rCO$?kMrlTAMm|PGMovb4MhOsR;$aeE<OHwM;bi1wlmKJU(1R$G5F;NW
zAEO|XD7g15$Rr511>_EhxuRfuL>UDbCBZC^j0mGBBQMB3%;1$epqd60)!;!3R|at3
zu}Brv@5%yqA3<#qCeT<#4R~D+WVSUpg^2-88Y0mQ8o&Up`vj$o(mc%7JJ2N_-~}b1
zAyd$@2grg3h0MH?e6*D)pfN)5kR?JHVhsya8|K;_xUN)C&l$cl2UHB^r7OS$L30Z5
zg*;#_D63@Pg%xBe5n|*Wb#)9#BgT>!*g6;Rsu&&6f*i!k5cv2hhAyOqJum~%=958|
zfiOrb@)8#XtSe@~%Vi)7Sx}bBz)XOKpDn8UG}Kc;fel?&15*nRjUokGv{`Nq%=!R%
zc@3rsdeB8M5c^Tq>S#ii<bd?xUY3LDFGS>&fU+yN{o@B-ryHaQE2eTXi%Y=S8X^uV
z2!k>}#V%;D3|!WLiGeC`^cff!${86Lib1sig9sa=JQKL#5)l!h;2IR<AEe;x8XWBC
z?yBJD>gwX^0v{&>wKBnZR}GYR89><*zR(Wb8D?TAQUa}+fUb@Jtr-Qik^R6Uvfu_v
zkPIjsKuu<FH4R@-2CmJ(4Ic2|VGt;A!GQ!O1}db&85kHQz(a~jfRU3?1Jr;3kCsB}
zR8XZdx-=&>xdf%XNqA|FA9%SwxGfM5uEXQw!Bus9d~SY9X-;Z<d{7K1setN!aKjAJ
za0vm4MS%!#8zU9ON&^v~rC&i2AXYkv@B<M(AR+)n1c3+(5a9+Qz%4;=n-H|V9h_Bz
zK)E6a6ye|$had(j?Sa;_feMXc69xtbHfB(z4J8?&G(?P%jfsH~2HBW6BRSbQ*?Bs7
zB!eoDSHywxA$Ua`DE+1)t%wVPE`J4gT|kSnL48Je84RhBAmvykDCnv{g&e5m8y}yN
zpBx{L2q-XXph64e*Xf{~3Th01!V26wf~Kgn(vs35P>KST*g>F>2m%#l;8l+WnFV^#
zrOkT9nH7+E4v=gSWUV=9y>)VN5Xe~YI&N^oGdUl;uDzr<2vmeZIs%}6S`esX0d5?F
z+rdF)pb!HMEkIVL3qUq%=oKecfG~JB2Bbp*t~x+5fY#^-br3-P{bF!?7_?>~Gbc4D
z7G!J!hyb<JA-xNb_3@d-@ukVdCPC#OxkwOE2qHjB!h=9-41+-3K(JAn#X0%qsYOBH
zJ|rR&fI3&;m6Tv_x`Nj_Waj6AlM*<75ySw+G`PgDfs_$;pr|aiVqjp9VH9BEVG?7K
yVU%GMV-#Q#W)ufCi#gdq&0r=8MoC6CMo^Pjh>3?$f=Ps#Q;wIJUsmitg8=|xXwa<y

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/treeadapters/__init__.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/treeadapters/__init__.py
new file mode 100644
index 0000000..7ef5959
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/treeadapters/__init__.py
@@ -0,0 +1,30 @@
+"""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/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/treeadapters/__init__.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/treeadapters/__init__.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..0831e45cf1849fe20cf428985ddab31b915e17f8
GIT binary patch
literal 1022
zcmZSn%**AGdLky70SZ_d7#JK9m>7yn7#J8*7#N}$7*ZG+QkWQW7#VVz7^0XMa+w*T
zm>F_e7@}Ah7*m)TQdk&rSQ&EJ7^2u17*kjo(is_|*cmEC7(jAtU^xzkC=Le3@H{~V
zmQ+rLY%YePBnC!C#ymcTh*WllEG~u=c7|p~2F4T)hF}d&1_p-G3ycg5Aw{XF3W+I+
z1tqCP#R@s8B?^`Kr3%UUd1a|ZB?@Up`MC=Dd8rB|AZ5iRMWx9lrA4U<CHV@8dHE$7
zsYP5|t`&*71v#l!TwHp33d#8?sk%uy`N`Q<Rtg1`B^mj7TwDqY5Q7Rb3-sd4Qu9*s
zixe_*3-XIf6f#P3b4+tGld!4LgGuUvY=^rMsxv(`uQ($UY<Nn3vVyIGx(!IZolR1H
zN~N7grlO5Lm}R367FGw@05T`3G&3h9wMfAhZns`~Y6&P9oFFn9>Zu@g>Y5-O1&Kw)
zsER#8e0>7Iq8cD&wjcs(CRhiEuVAYH(WnQeG*a@D!Ezv5!V`0{QB8ze50OCF4zeEN
z$#|%l5T0I1emsPwfiMs37EMhqu1ru8(_m&`U?|~dU|>j0D$dU-ElG`sgjxv)D8Xfx
zWfo`V=amS65<y-jD9++@GD}j65_5_(85tNDG(bcN$dKa1ic%;I5oBXvV1U?OieUO_
zaDyylXJBB6k59=@j*l<l0<+UfLCGaPJ_zKhAdsm+OdyqDF38*xh@QlpocQ=47LXLk
zBu{YSa4jmzFDe1ql2}lXnwO#h(uE+3YZ(|A^b3kI%Mwdc^~(~A^waV|F<Y#kl%ijr
zl$4iinp<pSm}H(_m2P2bQJ#}kWo7^Z>3RAg`URN<x|w;!C5bsXx^872p2h(nAuxs}
zQE<8erA>WM@WYayetdjpUS>&ryk0>iI5cf?^HWN5QtgBo7#NB{A<D)m!z94O$;8Yk
K!pO_W!UO<pFBypd

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/treeadapters/genshi.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/treeadapters/genshi.py
new file mode 100644
index 0000000..61d5fb6
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/treeadapters/genshi.py
@@ -0,0 +1,54 @@
+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/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/treeadapters/genshi.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/treeadapters/genshi.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..58d4189e090b93158161433caf1f452a083aa6d8
GIT binary patch
literal 1973
zcmZSn%**AGdLky70ScHH7#JK9m>7!F85kH+7#LC*8FCmHav2$-7#VVz7^0XMa+w*T
zm>C#Ba!d?4EDX7<3{k8MxoiwkY!FdquqZo26gxvM2SXGGLoO#n6emM27ef>mLoPQ%
z6gLB73JXIE149%KLkcTHum&3g14Aar0UFE<3=Adw3=9m3NyYg&r6sBHnYjh|MI|L1
zAm?P3Wfo`V=amRBFff$nWhUpRq{ioDmZTOX<`ipyTwcP;z`zjbmzbLhW;vFW6cuZL
z#K7F(5XYd95|9<Hel8^}3=9k*t`Q+6><kPH&i=l>u6_`<i@$S7WPocjBLf2i$Xbwm
zGAKyCF)}cuGceRLGE|&otYKhqi9N_z%fwK_1PUd|T4shCW`-0IhHN&5B3p(UMusc~
zupA46WHTcJW1bpFtSFhGgc0QHEG7`QnUNtylp&3oA&e1XavlTN6fv+Vnv5W`IT<92
zrZA*%feqtikOYZwGf1W}F^JW&FyukRxfvvDSr|%KKn?^cU}2EVVr6IsInst9hKZq;
zm7$i6p@fa0hLs_Ohe0w$m?4{!q3AZ)Tvi6LJa(`QFW9X$Yz%2k3~@{hg_{_f85wHX
z8A{l}dRai+8g`Iuia5mCAU|_3WHT`oX)>npG1M|M6lyX;eZdD7uZH^~ijg>9a3Cy8
zk$_lJ$O{e^ez1vi7)v<8p~1o+nIegzKme?Om!Sk6ETGU3goK(9gJc>rLy8n!M<Fjm
zcnu>%(I-aqNRfu9$zxzh5oQS1kO8H*si1_CpI4SzRHBfmP*Rkds!)=zkf@NJnpd2W
z2^QeuQczG(uu3dSS13=+$xbb@QYgtt1xrErARVQ}V2vOFxGYFK8ESTB3DlUP)RNMo
zykaYm4XH(mCHX}P`Dq{y$hy4zl+<E~!ctILE~zX?E#(3^F(a`kF}WnQsJIlAlY$Ep
zlT)1$Vj#6Ci6x1ppbVG!|NsC0rJz(ET#{H+5|Wq>=D6k-lvIK^oD2*Md5O8H#UMjU
zLHV>=wYXNb7;Ga*0-S9#L0JVX>zbDW(gw;h&iT2ysd*)(Aht_>GT3<_iwa7Uax#-W
zQ@|D#R~DC~=6a_1fwM0W&Igweeqd*V35Y(BxmZ1bp&XR^k+qY`=LQu}pm0bmC`ipq
z2?F^JT$E(xXXb$!e))N+L7+eempPdwsky~LAX|b!<xmhvYY@n}L7<@30I^CyVxYv3
zS_C$rB(<UhthXdTI~8IkDDc2?pdbe`5=%;oz>3Neb4nql9Z0BH0~D)ZqPUuYfkD5Z
zD6=fFBvrpGu}D8HKPM%%s8~NKMZY{LDKFPFx7f%q$vnL(-NMwOJSVHl%m4(^^YlaX
z3o;9IGxLf|5_58N-O4;XjRQbJU>skTnwOGaq@Pien`4@jnWPWO35h9*1)wCS56KLA
z1(hWr50>P|Lj*wKRBQus90waCFC!Nt52FYp8>2WQCle1N7o#*27b6>EFrySB4<ipu
zgh`x<hf$P?hf$DGl$nKzjnPko7Zm)UL>?cXR$5Y8lo}r&1Tr)TlmdgmRRAc4Aa?2{
z=NF|y!X6YKND%;X4I&nT#26SDz+r|U20ZjYDZ?f=KczG$)ehvjVo)lPVG?81U<LpK
CfzuZN

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/treeadapters/sax.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/treeadapters/sax.py
new file mode 100644
index 0000000..f4ccea5
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/treeadapters/sax.py
@@ -0,0 +1,50 @@
+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/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/treeadapters/sax.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/treeadapters/sax.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..7ce8f36e6a95d2078f32f0174ed82a809c6fad88
GIT binary patch
literal 1970
zcmZSn%**AGdLky70SZ_c7#JK9m>7!t7#J8*7#LC*8FCmHav2$-7#VVz7^0XMa+w*T
zm>C#Ba!d?4EDX7<3{k8Mj48|vDJ%>*Yz(>V3{mV1xf~2p91M(^3=C163>9V!sq73{
zTnx<&3@))63^B|MQQQnsJPc9145{1<DQpbcoD4;w45_>fshl7Yo5E0r!cd0r6jp{7
z28Jkpkdj~xb_NE9OprS@m>C!tO86NV7!s3;^K(i|QsXmo3-XIfN;p8S&MeC;&dkp%
z5ny0oD9y`E&QD2=&&e!FElSKO)?fr_1<5#;loVwqm6oIy`vrUE7UX0yF)%P_fQS-t
zkjW`orNt#~`9-Oj>3ImXC6Zu66S2!CgS3O3$;!aM;0y}JHbw@98b*dJ29VzwE3_C&
z7#XsdKpdA?8HN}phFT_uT4t~kW`-Ijh8kvuW+n#4LUD%h3K7N{P<Zh$*0M0vuz;dM
zvX+&hhLs_Oi6NVbp(uf&&<=z^B76+lYz##=7)l^YSs5ftSV1P$vVqNJ0~^4`APF*u
zok22<2`s?QAX&r4(9F!h2r`2OY^oO{$i3`fd2AZM&hug{v;(_@1FVOW7(EaT{9uP_
zf;Dh}En#JlY-VJD8ORMb&;rCQ;bbVbV<_QbNa0~<W@Kn$1bH^RLLE5_B~inW8x)3M
z)1n!}LH^(Y1vO&|FGH{fDAG$;gCZs|Cr2UJF+w*dGdoowIX|x?HLpY=BQY-}C$&f+
zDX};;MIk>=p`<7^wLCE=JGDpwLUC~^C@3gcB^ISa1*{ZGGE$M%mE<dw7N;td<bxH!
zWkCYT`FUljMI{QEB}m3V?X&{92JQfeArMuip!`@;S&&)^N>wiT$zV1pl?Rt37L|k~
zrk8>^uDJyzl^_mCc}ikQVksvB14CY7ZfbEsVsa|j6cDeJje&u|H7^CElnWFR8Hq)S
z$t9^p#igL!6bw@Aj1U9a>71XNo0?ZrD#XCR5So{rmtUTzP?DdWnx_DAiXS+`fZc%A
zK@e%eR%!5pvL%Qp2Kmb+Ke-fSYY86%14BVkYFcJRd~RYvL1tch2`Fo2mZatumw=oE
zRvrLW;R{g^1S%YYK&rsH!3tb+QbES~1()zJFfgR%r62@AZcB!H8Em>+Voq@?ShHhs
zacWUXW`3S)QBi&oxIjtGOF^-&gd1Wa%*o(Vsst3ykVI1g3Pfl;gM}g9DM5)Ku(jY&
zEdj+KC}hDxi6tdP#Twuu4@4AKFfcIa7ZhcdC6=V>mn9bIr{(9Qq!tzHC#C3@Cne?O
zn&uW8877&hSEXB+T9oHxRhb!pKzg2jh<-t4fo^7AaY<rMj;>poho^A>NC=GM%Tn`F
z@{9B{N^)~db25|kL1{lRC9wdMH1vxTEA$E~!HzG<k1tNF0LPOV$VD7njFOBZOuUR-
zj695Nj6957jGT<(jO>i;j696ujDld2kCBH_gpr4lnMsUEl2MS+51bWCKp`I=pH^B@
zT9g_e9|STk2vj-;feO(QK?VkfirgGMkmVJ*IYp_7DXB%^xCIAYaz4l>c_qa`pa26$
zcMvF~!LBSz%qdMR4iW~XDNs1)<R>TQ_$B7128n=#Ksx;L^HPH(KqWrN-oX;YpuB98
fo1apelWGSFiegaumthiM5@TXxlwssy6l4YfUR2mD

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/treebuilders/__init__.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/treebuilders/__init__.py
new file mode 100644
index 0000000..d44447e
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/treebuilders/__init__.py
@@ -0,0 +1,88 @@
+"""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/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/treebuilders/__init__.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/treebuilders/__init__.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..81538ca1066260a995642a5c5885c0bd0a0f3ad6
GIT binary patch
literal 3662
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
ZsNrD)DOT)2DYzIUz{VuQB*4VR3;@CHLm~hG

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/treebuilders/base.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/treebuilders/base.py
new file mode 100644
index 0000000..73973db
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/treebuilders/base.py
@@ -0,0 +1,417 @@
+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 | set([(namespaces["html"], "button")])), False),
+    "list": (frozenset(scopingElements | set([(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 assocaited 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/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/treebuilders/base.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/treebuilders/base.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..9a40be3a3f3cc912d4b5a90be674e9563e374ebe
GIT binary patch
literal 16123
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
U7^5Pi0HZ9U0HXqnShAP|0OO@9o&W#<

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/treebuilders/dom.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/treebuilders/dom.py
new file mode 100644
index 0000000..dcfac22
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/treebuilders/dom.py
@@ -0,0 +1,236 @@
+from __future__ import absolute_import, division, unicode_literals
+
+
+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/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/treebuilders/dom.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/treebuilders/dom.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..8cb58411ec1266b6502d47825da3789480232e9c
GIT binary patch
literal 13400
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

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/treebuilders/etree.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/treebuilders/etree.py
new file mode 100644
index 0000000..0dedf44
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/treebuilders/etree.py
@@ -0,0 +1,340 @@
+from __future__ import absolute_import, division, unicode_literals
+# pylint:disable=protected-access
+
+from pip._vendor.six import text_type
+
+import re
+
+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):
+            # Delete existing attributes first
+            # XXX - there may be a better way to do this...
+            for key in list(self._element.attrib.keys()):
+                del self._element.attrib[key]
+            for key, value in attributes.items():
+                if isinstance(key, tuple):
+                    name = "{%s}%s" % (key[2], key[1])
+                else:
+                    name = key
+                self._element.set(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)
+            for name, value in self.attributes.items():
+                element.attributes[name] = value
+            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/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/treebuilders/etree.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/treebuilders/etree.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..e648e8f093616755ba1afa5bdcab0ffd80090f88
GIT binary patch
literal 16763
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
Xurka7OrQm%0*qkD#Lvw0pTPwH_Dfd(

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/treebuilders/etree_lxml.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/treebuilders/etree_lxml.py
new file mode 100644
index 0000000..ca12a99
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/treebuilders/etree_lxml.py
@@ -0,0 +1,366 @@
+"""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
+
+from . import base
+from ..constants import DataLossWarning
+from .. import constants
+from . import etree as etree_builders
+from .. import _ihatexml
+
+import lxml.etree as etree
+
+
+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):
+        self._elementTree.getroot().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(dict):
+            def __init__(self, element, value=None):
+                if value is None:
+                    value = {}
+                self._element = element
+                dict.__init__(self, value)  # pylint:disable=non-parent-init-called
+                for key, value in self.items():
+                    if isinstance(key, tuple):
+                        name = "{%s}%s" % (key[2], infosetFilter.coerceAttribute(key[1]))
+                    else:
+                        name = infosetFilter.coerceAttribute(key)
+                    self._element._element.attrib[name] = value
+
+            def __setitem__(self, key, value):
+                dict.__setitem__(self, key, value)
+                if isinstance(key, tuple):
+                    name = "{%s}%s" % (key[2], infosetFilter.coerceAttribute(key[1]))
+                else:
+                    name = infosetFilter.coerceAttribute(key)
+                self._element._element.attrib[name] = value
+
+        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, attributes):
+                self._attributes = Attributes(self, attributes)
+
+            attributes = property(_getAttributes, _setAttributes)
+
+            def insertText(self, data, insertBefore=None):
+                data = infosetFilter.coerceCharacters(data)
+                builder.Element.insertText(self, data, insertBefore)
+
+            def appendChild(self, child):
+                builder.Element.appendChild(self, child)
+
+        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/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/treebuilders/etree_lxml.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/treebuilders/etree_lxml.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..5e35e13e7c43dd4a506eb95dd1cfd4b63c6434e5
GIT binary patch
literal 16913
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
F0st}V(M<pV

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/treewalkers/__init__.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/treewalkers/__init__.py
new file mode 100644
index 0000000..9bec207
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/treewalkers/__init__.py
@@ -0,0 +1,154 @@
+"""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 do
+implement a tree walker object (called TreeWalker by convention) that
+implements a 'serialize' method taking a tree as sole argument and
+returning an iterator generating 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/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/treewalkers/__init__.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/treewalkers/__init__.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..bb49e85ea779f5ebd783ff5685adbc25909c2478
GIT binary patch
literal 5071
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
K8#9j%CqDq<Fzev}

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/treewalkers/base.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/treewalkers/base.py
new file mode 100644
index 0000000..80c474c
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/treewalkers/base.py
@@ -0,0 +1,252 @@
+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/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/treewalkers/base.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/treewalkers/base.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..977f9f0b7da2d99628bcc6371bde3271d2b0a8ea
GIT binary patch
literal 9693
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
Z872Wn875Ii9wtsu5{6<nCVpnI1pvKBIpqKV

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/treewalkers/dom.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/treewalkers/dom.py
new file mode 100644
index 0000000..b0c89b0
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/treewalkers/dom.py
@@ -0,0 +1,43 @@
+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/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/treewalkers/dom.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/treewalkers/dom.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..3fc31b96e1db690b28f27606dc16d4d1d8b07013
GIT binary patch
literal 2517
zcmZSn%**AGdLky70ScHI7#JK9m>7y985kH+7#LC*8FCmHav2$-7#VVz7^0XMa+w*T
zm>C#Ba!d?4EDX7<3{k8Mj48|vDJ%>*Yz(>V3{mV1j47-Psq73{91LlU3@L03Ees6J
z3=EM`oD3=K48a;43=9mJAS*RM7MAccFfb%073b%amZZjK<`(1^m6U*#q-2(57H8(?
zl?X5}FqGzHCg-Q5#^+>~q!uOS6l*XtFff#`FfcIq<)@@(f_Mm_q{QOX5-tV?hLEDv
z)bPZd?9?K-A3-XeKz`I=U|>jP0C_Ei0p!9cCXjzy7(gCOVFHV=Fr+Yp8LSLJ!5SdT
zl9?D77(fhG1_lOakTDUA3=B1l3|R~eC5#MNObppf3`KejCCm(2EMRd~Fv$ic*%{JU
z7=jV1Ily{28Pb>-ve_7lBEj0Yz)HD6f=Ehvzy|*Xg<CBXLq$462`^Y3A43*DC~%t@
z8C+rm7;2fpq5=#x%nZ$pU@kL5mLNmXL6At65JL?Um>~!zg+Z3s6t;soV7U|qFq;)7
z5f1W*DA-IvFewH$fsr9g9As-6E3$Vaz;2Xh1nH3kt48;Q6xhSkAk#q}b^$Au0i}{)
zkS1BMCI*mna0&xMFgQm2G~_^04N4Jt`6;O(l?ACm;B+Izz`)?*?;Psu>K76p5*gqc
z@8|F08U%`+5_X6jNEDn%@)C1X!HKG%G$|)D*)s*qDXuIoNzL_4Dd7aA71xLmun8p~
zgPmO*LmcCSU7bTb{rw=qAcI3(BSOHcK~4!v%qdMR;bCB4aP@Hoy8`3@uzfk1#U<br
zm{?L$l$lgol3ENF&rYo@2B+ur)DlOS6etCQjRCo`xF9h(H8jYx1eC(cz&3zfmy@5I
znBxcX1;`nG`FW{eKSC`A`v&ABunJxV28N8pV&{y^oD`7R#bCpo{e2N`1ceV&pai5G
z9*$rih(SUR60&YVj_wGJplE<82D>2C&)d&G+z*^Pz+Nm)%}E0@K<)wi0u%-i?}Jzx
z;G7R4ipv=o81xH@GRqQ6QuWIci}cg-b5c@^iuIFH^vjcy@^Vdci;WDE%+ssVEle%S
zbF!+;3_u_~Pd`MzAhSR>Gq1QLF(*gYt<1yIH~=IB#_?sTc`5lt`WYp;Ii@+8N%|#4
zsj21Qa-dj0B|lfMpt6LIfq@}CwFDGCE~zDnnK{LvU@lexIgC+=QHDvHQGiK^k&RJ?
zk)M&1QHDv1Q3xy|z$DGc#SAV8K!pLQJOLL3pdf{0ZCJVmNr4kVT4qsk2{<}5Kw5&7
z7#J9Wlo=Qp21!_eQb2lYi5uLRpin3VIhBEtXpeF;Ffin$R+I#1Cgo)2r4LS@!eSla
zPIU$b22#BWs#*#Xi&FEz$!Bo-6dI=iaA#^EJgUJ4D^cU)L1j*SJUE%g$LHp!l;)(y
z#|No_QYa{O27$B%f$B;SZ;&L|AW+!|Dv63g1REo#G$%7Bv!4biUZ6fnD=jH40{H}#
zpMyX-F$k2N!9`X@ZjN3`elDaI0n3BR)Dlps=a-)sl$u;xRGe9sifBB5?Hfe?2N(A?
TkjSzF`K=ffp)yPYOajaR$IeL&

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/treewalkers/etree.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/treewalkers/etree.py
new file mode 100644
index 0000000..95fc0c1
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/treewalkers/etree.py
@@ -0,0 +1,130 @@
+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/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/treewalkers/etree.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/treewalkers/etree.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..ead7060aa8920ca49d3ade3130a63a05d26c4f27
GIT binary patch
literal 4770
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

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/treewalkers/etree_lxml.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/treewalkers/etree_lxml.py
new file mode 100644
index 0000000..e81ddf3
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/treewalkers/etree_lxml.py
@@ -0,0 +1,213 @@
+from __future__ import absolute_import, division, unicode_literals
+from pip._vendor.six import text_type
+
+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 = {}
+            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/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/treewalkers/etree_lxml.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/treewalkers/etree_lxml.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..50f26d5ff778a1969167164d7e0c46c9bb53d31e
GIT binary patch
literal 10584
zcmZSn%**AGdLky70ScHI7#JK9m>7y*F)%QsFfgPrGUPBY<T5fuF*4*bF+?#j<T5iv
zF*7iN<d_(8SQv6y8KPJrd}f9mHilewhA4Ih#uOHY6jp{D4u)J#hA2)3#uPS&6n2Ij
zE{0rghA3``JO`N1!w|*8z?j0x(89nF#mkVw#gNL!kjBW6!VMB>W?+bn;%7+Vfr;|M
zMFkjA_!v_8!D{*8qJj)50x-3La8V(K6d{IGZiXyjuySFzga|{52t%-jC<6mSCMXOv
zKp{}V&%nTtm{gpfQ(BT5pP5^bUsO`U0Sb}KvdrSl{JatY1_p-Gyv*eMl+^f~%#zfi
z#GGOcMg|6k5>612T2T^TQdy7+5n^RvU`Q<~N=?mVVqjo^h;f0GC8oz0rKYD=6l8+5
zLL^ui7#NZgi=kRUrp0GwB$lLB<mM!URDm$ajn1H0GG}05r~yY*HU~qI04T<SOBg{y
zB}@#>ObkWJAa-yK149-wC@xdLqQNN)48dTJ`jvv*mROvenOVxlz`#&kQk0ooq5*P4
z35f8^&r2-<IW@C5Gq1QLF)uka2xNH)NO4Lk$omjigIrat0S-VAQC!Esz@T4Hlv$Qo
zlB!>pSfrnppOcbWRIHzrqF<hrl$UFoTWn;QWS(A?ZeeOso|9E&W&i@|dHNyx1(^l9
zVC!;nblu84JdFcDLSP(UmYSE6U!<Q=lAB|ilbNIs3fA((oNSQU;4qHQsmRUIE2soJ
zJ2kJkv?w*cxTJ^&<U5d07#MjNSs3{lS(v~+49d?hfv0|uFPuQ(ssoBK22i3;VE`qS
zC?-(off6V)LkbgEgoPo68O&g12nq&=STZPfL7~IWz`y{G9sx!Mh8l2m#4|9YgQF^*
zk)bjSB$&knij$&rPy}T$GGwtZl(2%>C2TNRc7|p~1_YM_mCFg@HnV_8#ykdw@H{~V
zmJ%+8Y%YePY6eC|#ym!bh)MylS=<cG3=FkQ4B>g=a5YOoYHAok!XT9uN(?nj3|TxN
zl_?Ai*_;eTrw}5wObmr98Nw@cKtfRIpCHFV9A3i&b_K`)K9B(*<>wf}Qy?DZ2c^my
z28MV@@&u<BKMg@p`sW4(b53e*YF-H_9>G~GIU_SCr6@J81Qd!X`N^4iY564}g_(IJ
zsYQ8-IW8eC;N+KBP>`CJ0#@ddpA5=vL7+$mXTYNT{F3;*#N1Rcub?z3Co?%dGX<O`
ziYtptQgh==i*ic%7#J8FOG=6|lS)fcU5kqHi@?UEr<Q;W0Na|LT2fGyT9%n#S{wu_
z0bmO9QY%Wp38)0lNX*OuXDYC8acWLl2`E9NLX_p@r=$+9`~mV!e0*kJW=VX!7$|pW
zfpRV*CnF~lGb0ZpKN!j~@-nh8F*6D<@-lKUi82Z>@-qrB3NUdpf>S%lgCGn}?Vv~k
zl{DZqFBuGtXi%OC0+pv4AcaA)pm+ymlI+yV!4)1L=f}sVr<P=bl1IEDC`dp~W?+Pu
zyCA=Sy$UKD!G$PD#1HIKaO!}tKz<xlehZRfU|=vI=pjaiU~nY)L8>EAau}o@0_Vc`
z_?*<d_;^qqSPY3M4N$cNE=A(Oxj#N0oa5u;bMsS5b5i5ugA^DT7=n~Q1Sm*?ltJ||
z*q?A>5L8`3ybKHspcY9nD37u+a!PYDb20}BGcYh<R#hN>q~fTmf*|pk465Wo7!*q2
z^lJrbH!y-q@OTDLnGPzR85wGr!6HlyH7sBTGpyuhg)!Jb3|P(v70}@F6;xQpg9<os
z$p<QSgFvna%Rx)q%oK3`2$BW`y$mSSLGA&U20>~dF?A3D(iH^CIUvjcCI&-vfD(-j
zDEIJyQVFPp1YuAa2+IB-3=ddPjRGkHvlu~521!T^KywsG8N|Eb0uiJW90XvWf{DT4
zT~La01$h_bTn0vP+a^c_6hEpU0u&nH0tM_~1Th$#4$30dAg6;0Xf{Sp&Js|RxfLa*
zgW4F_+j=1H63RfJkN{O$phOGKK$Z-U1|1`VOROlU5mf?i?0{NAObl^M42A6A9K;C9
zFD#(k1<6`0AU-VrfD8loG+^!vF9Nk`iomrcdUgTX4o)jz*%FXma7$@$g+C~5c)`M-
zfl+msRGoexFM-m)(8>*(3=9mOAg4of14|I7iHBK*M1q>(II0lL-cAY&xZA@9>feKU
zMC=SHY+w-%P!As@!pV@r0T$r`b&WVd)fOoE!Z0`k)nKiGN|->|22yl_y0112CE$z$
z>1Q-Ef@I@a81gtl`3RJ)SQrpmz<t}Id?YPwpneHR85@!oXdMP}jbAA!WI!!=2m{oD
z2i0oeGP(q$B0nh$+}6lQEKV#bDFXK}Ae9)XY7PR|WFU3mtXTr8x6`17O+2Vp3<7l|
z2VWKq1|<s65C#LNB4ZR{lwjfnlki48$WP#S0;z(OZCQ+<&SWza1FZZ4We9NKq^FjE
z0|)F`kSI7bf<RUJpz=GoLkDi+gPa>59}fx!kb9v`e2}L>80>LS4G6EvYr%fc0;kSq
zaHqM337pOtK`AVSkwGGxfuYD26hJlLp#pJ9@E{Agj{vd(+5i9*+u+27D8)1LQc^3x
zX)Px;4_xYlJCWcZ1UF@iGm~;M^U{mKYBEzQ233%P8v;q7aO48FjX?cIF-9IHctQes
z9vq(BpbXEzkcFjph?Z^?LCr&uX<(lYhGqq*!;l5?B*-_=!~$x(fw*ALfigZkmo$U=
zQ6OnQaBm9SC{D`H&w&&MAPI2ff_(=j27wpBDJ?!8<jnZ^Tr6G%IUDR%P>Bgn)*z9=
z-}MD|LO_E!iJ&p10xUiwE)qfILUBpappHXO)fEpK?2L~uCfB1u7N9mhI7fmaco3#k
zP(czO4;y@sFC*KhMuXg^;L(Xng!eQ+K1c6}8Gt+i>cT)qHOxR<(1=J7sD}~+>gR)v
z0hcofVi1%#;I?QG$ag{v3=C|HoIIS&oE)Hm4hRO1+=LXRriOz@_c2?orsTC+gMu|c
zwJ^Mb0%dG)!IljgnFQBPC5+&?6J2oI5?sTB+K|i)B`lx{9#sD`GUQ2sWShagzIbNv
z*gaTfEqKU2i=82h1Jqcp0UO0w!pV@u1sWO$8N>~0yuun$p#EtPC&+40!J3m<Tmr7=
zi&IO$b4;+-q%(9>JP6dL2agX0fycT)1Gj$pc|obkrA5V=WvPe&gA8?niUe@8)H5$F
zzc{tTEi<PiwFo?Zo(5)ut0-_T2iH@eVfew7Oh8>q&}>pMXlR9j2|O&##KXwLC=3~b
z28A6cD8O-O!o<J;s)rdFpm7)sim@0bhFVyoErpXIn~kB^929#g%%HI^v1UewCPq+e
z4l)M=nQ?*i<eM28(wG>6p+>TUlSK|#DF<jC5hlS2mY5Ef-~!p0#SJETz$7n28VlSE
zKCsd=3?=*^xfB)<m#63qSSw@-h>;;n0Mx1kSzN=&kR`}aA_SVZ%w}RJ`T|xb0!?mN
zqL}K$7(nWj8B3TMvcyr;rLclJYKkCZOC%VwBw><*AVWZjni(_zSQN%s!_1H+1xl=-
zaARSpWo5_{1tr;9xck6bYFR-urnPJg6|D><G9ce%$ueZgfiyOQhDGuiK>FDkYB|6*
zfoHR7*}-h^R2E1a?2a0U6vX<cj5Qn#HEbZKWXXfNn4nG{GXsbXR+h%ZU{lx*RRo%0
zVh6<#NGKfSWd-QiWtJjCmJ&k^E68s(Yz!sJAon#hf;y(zEDQxYOrVezWk_RX0JqaM
zK&@9Sy}?q@h*wBzMTr7vc(Yg`u_#pm)Lm4_FH$H;%*@eINXswHOHoiQE(Mh%C5h?a
zq4UiD|Ns97PxeCQltE1lNDni$q6ESKbv40bYM}HB9?mH#EyziQOi2|NrxulD=I4Q@
zq#zj`R62yXMub3mp!%R<9^B{zbwgeJokM+H{X)Pa#NZy8i@$S7WPmHU3kDvG1&^vi
zid<cgUQh)OE@(;;(}O@}gS9#5=Yqz`AZ&kMu$iC{TX1>dnpcupQVC)Dg?NTU27$^^
zu+wuBOOi9dGU-M6r3H|gvLMiqDOeEH+saG=s|3xh6oXk{m0+7(eO$pdIf6<-P#u?6
zl%E@so8y<5n;HbFq%}Zc1TLe3<Ux)Hbr6DlL8?I#pz-G7g2d$1AP<lb$Wb5*i@}};
zTUC~rQ#!~d-#~>~dTNPZeoCrKDkvotcY>-yP<_q7$j`{bD8nej#LvjZ#Lp<hB+n?u
zBm~B?EE0@tjG|0zjQosjj7p54auCE)WfEbOfRu-zv<6Cx;PNmA6e37<8c(qdxZnd<
zRggjtR6{W`6odP&Su7w%2@`0J8&WEQvIz@AQ2;3Wq%ecBT5t^`LkbH6q<;&pO8rVf
zX#^>kWF(fQD&*xWfCngxQu9hh7#J8pURB6QEJl$4r@YjP5=b@yMIE><3~~lVvkQm-
z#Xoq!1yNCf6TzUWq`)<7I;eInDlP$6)tf-E2`W?=7-g6g895obAYEcm%z!XBb~?~v
zrzjf~%%D;eUR$x^sI4HQ44|Su4pb#TBC#kOq#qtRg<#{dSV1Lna2_}nWU(<6)qxc;
z!Qv7s51u-ss04(>At?DlN;s6F4%8088nvME3p|K`HkJmC<RDN^A6zjF%ebi(CBcw^
zncbkM2DM>f8JCBdhmnJcorxDql&7OdxfdulP@<fLV3fy#^aSS#gDB7t6*EXjQ7ovA
z2IWpzjDoTgMKKD_a#$i0)Z9XkOgm6!1xF^R_kkF~8m#dMsyx$EO9H^d0-&<#G$<Mc
zK*LVZ@|TB^oe8u|NCTX9!F4sLH2`T>hl9Ku0U|(y=Rr{@LssAvI~clHpsBE0kiS4B
z5gQ{XH>V~iC#QfPc)1(6gB2g2R$2mDA{7tniZKL%`~09h44#-O$Slx<uDH@G&a8ke
z{Q{NQpfy&IW&<eUgE|dKrJ3LbUV5n@9;9gi3QTb8B?ugZpso(MJ&>Q2m6}`v>BWF%
z>>!;Q(A-3jJt#;)&IX4ef*1s$2_7P|fvhC31BFvDsPiSmD8K|-5F@}Oz|6@hrY6QG
I#wn%^0DhrN!T<mO

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/treewalkers/genshi.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/treewalkers/genshi.py
new file mode 100644
index 0000000..7483be2
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/treewalkers/genshi.py
@@ -0,0 +1,69 @@
+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/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/treewalkers/genshi.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/html5lib/treewalkers/genshi.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..624a6a2fc7fc155d3e1739e552fb4e5226de77b9
GIT binary patch
literal 2626
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
Ur5F^3GE4%D8jN~O0!(7e0LD5assI20

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/idna/__init__.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/idna/__init__.py
new file mode 100644
index 0000000..847bf93
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/idna/__init__.py
@@ -0,0 +1,2 @@
+from .package_data import __version__
+from .core import *
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/idna/__init__.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/idna/__init__.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..871122e3fb764e1ca7c20bb919836f21e96c143e
GIT binary patch
literal 291
zcmZSn%**AGdLky70ScHH7#JKF7#ND>7#J8*7#LC*8FCmHav2$-7#SErd?tn*CWep{
zW`<x576t}}OhyI<1`QBV!p*?I5FcNbT2!2wpBEnw5d_I-`DrjSFff$xFfcF_BqnDk
zrl-cIB$gxwf$S^+nUb7el&S&ZA&BA}1_lQGf}+f_#FA9~vcw|&wEUcu)S_bjq!j(~
zq@=uD)7)Ys!zA<cs&orei}IYTDl-ERNYB#`(J#m>(9O&%E=kPE(RC~H@H7qp34w8Z
wS!!NNevy7=N?xLVe0*kJW=VX!UO{CE2Ll6xO>TZlX-=vg$l1l9un=Gb0Q}%WkN^Mx

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/idna/codec.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/idna/codec.py
new file mode 100644
index 0000000..98c65ea
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/idna/codec.py
@@ -0,0 +1,118 @@
+from .core import encode, decode, alabel, ulabel, IDNAError
+import codecs
+import re
+
+_unicode_dots_re = re.compile(u'[\u002e\u3002\uff0e\uff61]')
+
+class Codec(codecs.Codec):
+
+    def encode(self, data, errors='strict'):
+
+        if errors != 'strict':
+            raise IDNAError("Unsupported error handling \"{0}\"".format(errors))
+
+        if not data:
+            return "", 0
+
+        return encode(data), len(data)
+
+    def decode(self, data, errors='strict'):
+
+        if errors != 'strict':
+            raise IDNAError("Unsupported error handling \"{0}\"".format(errors))
+
+        if not data:
+            return u"", 0
+
+        return decode(data), len(data)
+
+class IncrementalEncoder(codecs.BufferedIncrementalEncoder):
+    def _buffer_encode(self, data, errors, final):
+        if errors != 'strict':
+            raise IDNAError("Unsupported error handling \"{0}\"".format(errors))
+
+        if not data:
+            return ("", 0)
+
+        labels = _unicode_dots_re.split(data)
+        trailing_dot = u''
+        if labels:
+            if not labels[-1]:
+                trailing_dot = '.'
+                del labels[-1]
+            elif not final:
+                # Keep potentially unfinished label until the next call
+                del labels[-1]
+                if labels:
+                    trailing_dot = '.'
+
+        result = []
+        size = 0
+        for label in labels:
+            result.append(alabel(label))
+            if size:
+                size += 1
+            size += len(label)
+
+        # Join with U+002E
+        result = ".".join(result) + trailing_dot
+        size += len(trailing_dot)
+        return (result, size)
+
+class IncrementalDecoder(codecs.BufferedIncrementalDecoder):
+    def _buffer_decode(self, data, errors, final):
+        if errors != 'strict':
+            raise IDNAError("Unsupported error handling \"{0}\"".format(errors))
+
+        if not data:
+            return (u"", 0)
+
+        # IDNA allows decoding to operate on Unicode strings, too.
+        if isinstance(data, unicode):
+            labels = _unicode_dots_re.split(data)
+        else:
+            # Must be ASCII string
+            data = str(data)
+            unicode(data, "ascii")
+            labels = data.split(".")
+
+        trailing_dot = u''
+        if labels:
+            if not labels[-1]:
+                trailing_dot = u'.'
+                del labels[-1]
+            elif not final:
+                # Keep potentially unfinished label until the next call
+                del labels[-1]
+                if labels:
+                    trailing_dot = u'.'
+
+        result = []
+        size = 0
+        for label in labels:
+            result.append(ulabel(label))
+            if size:
+                size += 1
+            size += len(label)
+
+        result = u".".join(result) + trailing_dot
+        size += len(trailing_dot)
+        return (result, size)
+
+
+class StreamWriter(Codec, codecs.StreamWriter):
+    pass
+
+class StreamReader(Codec, codecs.StreamReader):
+    pass
+
+def getregentry():
+    return codecs.CodecInfo(
+        name='idna',
+        encode=Codec().encode,
+        decode=Codec().decode,
+        incrementalencoder=IncrementalEncoder,
+        incrementaldecoder=IncrementalDecoder,
+        streamwriter=StreamWriter,
+        streamreader=StreamReader,
+    )
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/idna/codec.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/idna/codec.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..e598f71b0a3a0cc5edc948411d05ca017cb8666d
GIT binary patch
literal 4486
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

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/idna/compat.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/idna/compat.py
new file mode 100644
index 0000000..4d47f33
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/idna/compat.py
@@ -0,0 +1,12 @@
+from .core import *
+from .codec import *
+
+def ToASCII(label):
+    return encode(label)
+
+def ToUnicode(label):
+    return decode(label)
+
+def nameprep(s):
+    raise NotImplementedError("IDNA 2008 does not utilise nameprep protocol")
+
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/idna/compat.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/idna/compat.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..9784929cc340f16a1be1273c37c64cddbe090d0b
GIT binary patch
literal 999
zcmZSn%**AGdLky70ScHH7#JKF7#NC;85kH+7#LC*8FCmHLZB>0hL98{h86~fC?<v!
zW-x=9A%z9ZU|~pMWeC<_V_;y&WMp7q&;Su7AVMn{M1nBLbZ3z1Tnr2hB@7HT3=GYT
z48dTfeqgc$q(3z;IX@*8!e?b*V8}^KO3l##xe!bgXE87^=ob`amL-;?>X#)J>8IuA
zq@)%V>nEk?mnS9V<(lRe8yO~<r&pz0m|B$QWL23NfIxbleu#cSW`S;IUU5lcPL8fy
znTMxw07wXo<I7U>Qu2%RGgI;s^^@~+3ldB83Mxz385kHs@*RVnJv~`KjtBXIfss^C
zrKG|=6$CN?>=iIUZ~t(D{S%s(333p~bHyO{VDpgxB$`qfLDAI22ucva8X(1f#X1ZO
z44y82jtWKw1{Mk_`KiSUdHE#@r6rj;nZ>CJd5O8H1x2X^3I#>^CHcwuIgr>CW?*3O
z%P;ZFEyzjDP0cGwO>r$M$}fUQf>KB^I7Gk%y@Q2=fq?<$Y*6}yhKipCC<&H;Vm>*)
yD76H{0|i`i5HkY<LlB4?1kwt2GlCch*W2Xgr<CTT+JOTS<R&ggE+$T9PG$g;VC&fc

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/idna/core.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/idna/core.py
new file mode 100644
index 0000000..104624a
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/idna/core.py
@@ -0,0 +1,396 @@
+from . import idnadata
+import bisect
+import unicodedata
+import re
+import sys
+from .intranges import intranges_contain
+
+_virama_combining_class = 9
+_alabel_prefix = b'xn--'
+_unicode_dots_re = re.compile(u'[\u002e\u3002\uff0e\uff61]')
+
+if sys.version_info[0] == 3:
+    unicode = str
+    unichr = chr
+
+class IDNAError(UnicodeError):
+    """ Base exception for all IDNA-encoding related problems """
+    pass
+
+
+class IDNABidiError(IDNAError):
+    """ Exception when bidirectional requirements are not satisfied """
+    pass
+
+
+class InvalidCodepoint(IDNAError):
+    """ Exception when a disallowed or unallocated codepoint is used """
+    pass
+
+
+class InvalidCodepointContext(IDNAError):
+    """ Exception when the codepoint is not valid in the context it is used """
+    pass
+
+
+def _combining_class(cp):
+    v = unicodedata.combining(unichr(cp))
+    if v == 0:
+        if not unicodedata.name(unichr(cp)):
+            raise ValueError("Unknown character in unicodedata")
+    return v
+
+def _is_script(cp, script):
+    return intranges_contain(ord(cp), idnadata.scripts[script])
+
+def _punycode(s):
+    return s.encode('punycode')
+
+def _unot(s):
+    return 'U+{0:04X}'.format(s)
+
+
+def valid_label_length(label):
+
+    if len(label) > 63:
+        return False
+    return True
+
+
+def valid_string_length(label, trailing_dot):
+
+    if len(label) > (254 if trailing_dot else 253):
+        return False
+    return True
+
+
+def check_bidi(label, check_ltr=False):
+
+    # Bidi rules should only be applied if string contains RTL characters
+    bidi_label = False
+    for (idx, cp) in enumerate(label, 1):
+        direction = unicodedata.bidirectional(cp)
+        if direction == '':
+            # String likely comes from a newer version of Unicode
+            raise IDNABidiError('Unknown directionality in label {0} at position {1}'.format(repr(label), idx))
+        if direction in ['R', 'AL', 'AN']:
+            bidi_label = True
+    if not bidi_label and not check_ltr:
+        return True
+
+    # Bidi rule 1
+    direction = unicodedata.bidirectional(label[0])
+    if direction in ['R', 'AL']:
+        rtl = True
+    elif direction == 'L':
+        rtl = False
+    else:
+        raise IDNABidiError('First codepoint in label {0} must be directionality L, R or AL'.format(repr(label)))
+
+    valid_ending = False
+    number_type = False
+    for (idx, cp) in enumerate(label, 1):
+        direction = unicodedata.bidirectional(cp)
+
+        if rtl:
+            # Bidi rule 2
+            if not direction in ['R', 'AL', 'AN', 'EN', 'ES', 'CS', 'ET', 'ON', 'BN', 'NSM']:
+                raise IDNABidiError('Invalid direction for codepoint at position {0} in a right-to-left label'.format(idx))
+            # Bidi rule 3
+            if direction in ['R', 'AL', 'EN', 'AN']:
+                valid_ending = True
+            elif direction != 'NSM':
+                valid_ending = False
+            # Bidi rule 4
+            if direction in ['AN', 'EN']:
+                if not number_type:
+                    number_type = direction
+                else:
+                    if number_type != direction:
+                        raise IDNABidiError('Can not mix numeral types in a right-to-left label')
+        else:
+            # Bidi rule 5
+            if not direction in ['L', 'EN', 'ES', 'CS', 'ET', 'ON', 'BN', 'NSM']:
+                raise IDNABidiError('Invalid direction for codepoint at position {0} in a left-to-right label'.format(idx))
+            # Bidi rule 6
+            if direction in ['L', 'EN']:
+                valid_ending = True
+            elif direction != 'NSM':
+                valid_ending = False
+
+    if not valid_ending:
+        raise IDNABidiError('Label ends with illegal codepoint directionality')
+
+    return True
+
+
+def check_initial_combiner(label):
+
+    if unicodedata.category(label[0])[0] == 'M':
+        raise IDNAError('Label begins with an illegal combining character')
+    return True
+
+
+def check_hyphen_ok(label):
+
+    if label[2:4] == '--':
+        raise IDNAError('Label has disallowed hyphens in 3rd and 4th position')
+    if label[0] == '-' or label[-1] == '-':
+        raise IDNAError('Label must not start or end with a hyphen')
+    return True
+
+
+def check_nfc(label):
+
+    if unicodedata.normalize('NFC', label) != label:
+        raise IDNAError('Label must be in Normalization Form C')
+
+
+def valid_contextj(label, pos):
+
+    cp_value = ord(label[pos])
+
+    if cp_value == 0x200c:
+
+        if pos > 0:
+            if _combining_class(ord(label[pos - 1])) == _virama_combining_class:
+                return True
+
+        ok = False
+        for i in range(pos-1, -1, -1):
+            joining_type = idnadata.joining_types.get(ord(label[i]))
+            if joining_type == ord('T'):
+                continue
+            if joining_type in [ord('L'), ord('D')]:
+                ok = True
+                break
+
+        if not ok:
+            return False
+
+        ok = False
+        for i in range(pos+1, len(label)):
+            joining_type = idnadata.joining_types.get(ord(label[i]))
+            if joining_type == ord('T'):
+                continue
+            if joining_type in [ord('R'), ord('D')]:
+                ok = True
+                break
+        return ok
+
+    if cp_value == 0x200d:
+
+        if pos > 0:
+            if _combining_class(ord(label[pos - 1])) == _virama_combining_class:
+                return True
+        return False
+
+    else:
+
+        return False
+
+
+def valid_contexto(label, pos, exception=False):
+
+    cp_value = ord(label[pos])
+
+    if cp_value == 0x00b7:
+        if 0 < pos < len(label)-1:
+            if ord(label[pos - 1]) == 0x006c and ord(label[pos + 1]) == 0x006c:
+                return True
+        return False
+
+    elif cp_value == 0x0375:
+        if pos < len(label)-1 and len(label) > 1:
+            return _is_script(label[pos + 1], 'Greek')
+        return False
+
+    elif cp_value == 0x05f3 or cp_value == 0x05f4:
+        if pos > 0:
+            return _is_script(label[pos - 1], 'Hebrew')
+        return False
+
+    elif cp_value == 0x30fb:
+        for cp in label:
+            if cp == u'\u30fb':
+                continue
+            if _is_script(cp, 'Hiragana') or _is_script(cp, 'Katakana') or _is_script(cp, 'Han'):
+                return True
+        return False
+
+    elif 0x660 <= cp_value <= 0x669:
+        for cp in label:
+            if 0x6f0 <= ord(cp) <= 0x06f9:
+                return False
+        return True
+
+    elif 0x6f0 <= cp_value <= 0x6f9:
+        for cp in label:
+            if 0x660 <= ord(cp) <= 0x0669:
+                return False
+        return True
+
+
+def check_label(label):
+
+    if isinstance(label, (bytes, bytearray)):
+        label = label.decode('utf-8')
+    if len(label) == 0:
+        raise IDNAError('Empty Label')
+
+    check_nfc(label)
+    check_hyphen_ok(label)
+    check_initial_combiner(label)
+
+    for (pos, cp) in enumerate(label):
+        cp_value = ord(cp)
+        if intranges_contain(cp_value, idnadata.codepoint_classes['PVALID']):
+            continue
+        elif intranges_contain(cp_value, idnadata.codepoint_classes['CONTEXTJ']):
+            try:
+                if not valid_contextj(label, pos):
+                    raise InvalidCodepointContext('Joiner {0} not allowed at position {1} in {2}'.format(
+                        _unot(cp_value), pos+1, repr(label)))
+            except ValueError:
+                raise IDNAError('Unknown codepoint adjacent to joiner {0} at position {1} in {2}'.format(
+                    _unot(cp_value), pos+1, repr(label)))
+        elif intranges_contain(cp_value, idnadata.codepoint_classes['CONTEXTO']):
+            if not valid_contexto(label, pos):
+                raise InvalidCodepointContext('Codepoint {0} not allowed at position {1} in {2}'.format(_unot(cp_value), pos+1, repr(label)))
+        else:
+            raise InvalidCodepoint('Codepoint {0} at position {1} of {2} not allowed'.format(_unot(cp_value), pos+1, repr(label)))
+
+    check_bidi(label)
+
+
+def alabel(label):
+
+    try:
+        label = label.encode('ascii')
+        ulabel(label)
+        if not valid_label_length(label):
+            raise IDNAError('Label too long')
+        return label
+    except UnicodeEncodeError:
+        pass
+
+    if not label:
+        raise IDNAError('No Input')
+
+    label = unicode(label)
+    check_label(label)
+    label = _punycode(label)
+    label = _alabel_prefix + label
+
+    if not valid_label_length(label):
+        raise IDNAError('Label too long')
+
+    return label
+
+
+def ulabel(label):
+
+    if not isinstance(label, (bytes, bytearray)):
+        try:
+            label = label.encode('ascii')
+        except UnicodeEncodeError:
+            check_label(label)
+            return label
+
+    label = label.lower()
+    if label.startswith(_alabel_prefix):
+        label = label[len(_alabel_prefix):]
+    else:
+        check_label(label)
+        return label.decode('ascii')
+
+    label = label.decode('punycode')
+    check_label(label)
+    return label
+
+
+def uts46_remap(domain, std3_rules=True, transitional=False):
+    """Re-map the characters in the string according to UTS46 processing."""
+    from .uts46data import uts46data
+    output = u""
+    try:
+        for pos, char in enumerate(domain):
+            code_point = ord(char)
+            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
+            if (status == "V" or
+                    (status == "D" and not transitional) or
+                    (status == "3" and not std3_rules and replacement is None)):
+                output += char
+            elif replacement is not None and (status == "M" or
+                    (status == "3" and not std3_rules) or
+                    (status == "D" and transitional)):
+                output += replacement
+            elif status != "I":
+                raise IndexError()
+        return unicodedata.normalize("NFC", output)
+    except IndexError:
+        raise InvalidCodepoint(
+            "Codepoint {0} not allowed at position {1} in {2}".format(
+            _unot(code_point), pos + 1, repr(domain)))
+
+
+def encode(s, strict=False, uts46=False, std3_rules=False, transitional=False):
+
+    if isinstance(s, (bytes, bytearray)):
+        s = s.decode("ascii")
+    if uts46:
+        s = uts46_remap(s, std3_rules, transitional)
+    trailing_dot = False
+    result = []
+    if strict:
+        labels = s.split('.')
+    else:
+        labels = _unicode_dots_re.split(s)
+    if not labels or labels == ['']:
+        raise IDNAError('Empty domain')
+    if labels[-1] == '':
+        del labels[-1]
+        trailing_dot = True
+    for label in labels:
+        s = alabel(label)
+        if s:
+            result.append(s)
+        else:
+            raise IDNAError('Empty label')
+    if trailing_dot:
+        result.append(b'')
+    s = b'.'.join(result)
+    if not valid_string_length(s, trailing_dot):
+        raise IDNAError('Domain too long')
+    return s
+
+
+def decode(s, strict=False, uts46=False, std3_rules=False):
+
+    if isinstance(s, (bytes, bytearray)):
+        s = s.decode("ascii")
+    if uts46:
+        s = uts46_remap(s, std3_rules, False)
+    trailing_dot = False
+    result = []
+    if not strict:
+        labels = _unicode_dots_re.split(s)
+    else:
+        labels = s.split(u'.')
+    if not labels or labels == ['']:
+        raise IDNAError('Empty domain')
+    if not labels[-1]:
+        del labels[-1]
+        trailing_dot = True
+    for label in labels:
+        s = ulabel(label)
+        if s:
+            result.append(s)
+        else:
+            raise IDNAError('Empty label')
+    if trailing_dot:
+        result.append(u'')
+    return u'.'.join(result)
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/idna/core.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/idna/core.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..197a7b6b269131d7bccb2f1e6bbee9c717daf172
GIT binary patch
literal 13150
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%0DFO`HjL?8Q##mtju~P?RXNn*=V8N9-MEO?6
z6d{E2N#JZ)IEgVFWPFMs!q~eg>SUQvjpau-mWK)16)z#izJwYJs**qh5`LN6LBlAZ
zrXwV4=YY7S%nYDXjDf+uC^a=Z^D`?0L*^G&2G9Tk1A|9uQc-Go=5GTA29P?2$IZLJ
zdCw!WC^0=TFA>b~PAo~x25~@X(<3o2Gl7kPAu|(1d;k$Y*%%nW!`DIJVgfvP18Ta1
zi-I5#&<GAFMT2vAkUOmUgU|2<fjVd4b~`v5gNXso%lQXEc^TAO2Ipl)HAWLgc2GWL
z)L;~4WMPs3k6yDdftux@2DdIF2O|rU3?nb25(*34<Obzr(7-e}H(!QVoF(8YFpUYE
z{?tK<Dhr&eK?5-ipqiqD1tbW{WRT{#2Phg*n&WIx1)!k^NUmor;ed%%#4y6EESFe6
zM$qUIBWOIRgbP$vgREg@DB%Vr$r2uhEM8Dm3mRfCTFy{d3_>V!tl;7IA_vAwM}`tU
zkR3JP0iEK%3?=-ax%w;th7xf4ZiY;murr942!YgrYD}a)M0nvrMwSv`hHNf|A{$0V
zM#d6W(0o2o+6xadMidsKI+_#WuxX4XA|TtKt~$sFaupW?vBrW-6$O<a#AzsI2rm%>
zS=S6&?f}YvJfNzz7?jLQOVV^L!1Ze}Xg0?+x1gj_0o*?VkJtx<Ir@0Ifb*5Jzh8)J
zM2J_hE&~IDSAJ$*Y7ux)2h{2Y%}0VJC(#CYKuybPqgrtGE(VPw!>5(tvzCb|S&7N1
zc_j)Z`3j(l5^5-RgOJ_f5AMmqXIP1J3KmW1R^_KDR2$WThistU(g3w0z&-fPV(`>?
zUUDk9&5%@Cl3ENNF95L;i;5B}!J(Ft3K}Z{w-&&y<si`FlOWLKcaSxxX#$#YfRsMq
zej}&|ECCfpAYI@QCddR-YH<)~o-YX0=LC;61WAE(gL<$*pf*ZSFo+AvtU(r_VhfaY
z5ycj`i~^Td;4%tK(6^uhB`8P}9Xw?B3RFsg9M8Z6noAR6<Y(ey<YMGvl4Rsz6k}v#
z6k}v&<Y(k$)MVrZlVXhgjD}45h@k*bf(4gL8yFZEDs4bX8b0$>i!=!bsvaRFOtCqr
zk(z?kC8}Xy2oBE^WMC;_0q1Ie21Z84JVu6y8U}{qRIqBK{10l~gJ)Mk#$y&>AW?7;
zCJtgTfgIG#$WXinYz&&E;6VgGaJoq>PR`6M=7aadO7im+a`N-ii$O8%m#^TNS5R7_
z0qWrdiGeC0P>Zt^9EL%ld0}vxDgjM)ghFOyT|w(iAXBQ~Nk!1CYko><Pz)%2NPtWL
z*%hA%HX^>DC^ap!V&HplAYVb8#Kp+KP^<*X227w7z{SYJ$j`{Z$O~?L@-y);f<(BO
zc#wyM;AvqE$baA-8*&|0?8Q(i42lorYAU?Y3m)%opm>KzFC!>fM1Y3i85pwIK<lt-
z!A54WGn9ZkKSdQF!%8@zT=`lChCFdl6$eRYApM|~U*KW?V9<;x7pSQVs<y!G8H6h6
zRC`b?C~iP2M>Ig$Bq$ujjQ|mmAOaNaLGd6KC=S7i2DJPGGL8ry<0u9V<OU^zlz^Ks
zQJ@k4T%5>(SfIe9f0hr5V_;xV2F0cf$N@~EjLeL}jJ%9oj2xiYV-#lMV&rAwXXIi8
z_Z&bz2c-gVo?ZxAo5u(WHPG5T22l5!F$FxqRO!K3VF>C%LPF6cRvFwpU<FP1fR;ai
zd&{-#pteB`JE&m*YU2kp)UY$;NrG}>77I*@l>yR%NnvD=kgVlksNn$hOeAYL!7&Mr
z=oIh(SJ5=E96N&~Xc~~8p_YrGh7(ltXEQMr-vYBC-Q3-v)(H<(2-4Dj4(fC86g_9C
z;bKVPXUOJY0I^vZYS<XeYgrfy)nF2w3`K^FAY-{fJ%nNvFdJfq5U6{>0~LbUWXM><
z1lGU;(hoC<6SP<mH1?wgnwn{5059uM16dMY!oiTm3F<+BrskMHrJfA~O9?x;)SClt
z%W#3#6lQTVl<<H83)B>11%-!r2`?zIqcnvW86r~n8G<zgK!rGHRa{W2Zf;@$WK9ih
zkqCI?4z$V!GR>%vn4Fwn1RA>r)$XAo!6s&)6>!O^#l@L<>3ZO10k{|fSD~dP#U^H;
zwI!vXq?5@2YI=gwa};=u9(WWH+^G%=0$C4c8V6Z|GCxR_XAr3Ui=}!e+&uBq0F{nG
zsi3R`ubIL1cv5C@YH|s9;2pw@2Tibm>vizdw_ko<D!5(XnU|7U0bbGq9wiO}wRM8P
z6*Fjx08wp&^E%k*l>FSp%sjB>;*u2O_@dIB)MD^(0caItF?fzFF$e4@u=@Pcl7i9_
zNPh%W&x01`fOUh~4DsMb1Gser4#lGUa<Hc2lEjkIVzB#*QVVhtlfmoiz{LWXpnr1!
z?7aA*)ZD}Z3s5luX$}Z5vN19<f|>!MjIxYej7p3=jKYlajJ%8zjKYjUjJ%9Ii~@`z
zjJ%A@jBJd_prRjCIfB9gTy!{q(h9h|My>*iuys>FdB_RY*@w(pGc$k+b8s<T%gT_>
z04i2Ms{qnKnIMY|R3d@Oadw70eo!9EVgrdoL~7U>c#6A0nJ0yrAssT5Hw#onfCd7=
zORPXu3Oi)v95S%J3#^)z!M22xp_UcYbE>cb3Ax0YFw}A|fVw;2atKoY6ukr$8(G{?
zD;Wz9f=vgPc%TJb2N}X^SQ(1=8Ee=WvbaIRC7?DwXkjrEXz6hcSRtrw0?yGjtf1~&
zu??u-1zDsFAKMQGPk{M>t0i#W(hCAr$i<+Z0;E#_NwMGoIHaxuxJgkA8p?J7r)ULO
zTLzM;(5f|1B^6W-%4nea0bH#W7vyA?K-OPDn=PP~62<XFkb!2%C|wdLn}ceK#Dap<
zycBTe1N9by6hU<zC@p|j+dvb2QD$-p*lciW3(5!CR{$bFE8D<oic*V9b4tKWhzG#U
zW^kSW6LifO;5J?eC^vwniy@6;HbzlK(2N-yqYx86Bd8%Pz{t+X3C;;@i~>xc93#NU
z4~EI0d;n@Wf@pAl5F<N3l&~^1Bj*PeaDD&}aTlk724S+;p-B<6*n%I#&SHn<5H?U+
z1?LAgP)fv^AK1Y8p?C{Oc?vWqu)uNx8v{5eu!C~~c=#Kd6CQ(>I3VSO-KaTXH$!+0
z3quhnXvqX9CxEqr#??|FIe`^4q>h}*OF`8JDXAP>FKK`~UU-vrP!%YxRe}ikY!kR)
z6jTios{tihP;`NlY)~yotPVtg(<vy427#vRf*L?#1KE}XW!7R)veW@p$lyL3X0qhM
zk}Nf}Ku!l0AK>xypezs<lu5y3<3*|9ar5FzNY6PFwrn4~Kr#rFe!;C;a7QLNKer$=
zClwr`;L5QqwWv5VKQBHrFD)NpOi58t0;qHVjrJvH6a|6WlwhT>z7c3mKe)#PnX?Di
z%HZG!HD$o#eL<iu5~Pv_cdtN&3S=}8)UAee*}<K6a5o;@B?tGsK~3`@P|*a5UGN|x
zxNrlv-a)|!E=&*vU5gcPbHFASyq~}hl-7$u?Ir<69w-z5Ps#H$34^EL#aJPblbw^9
ilbMr+lbw^D$A*)glarH;Q-?>BQ-M>GQ<PsuR2~4CbqkaL

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/idna/idnadata.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/idna/idnadata.py
new file mode 100644
index 0000000..a80c959
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/idna/idnadata.py
@@ -0,0 +1,1979 @@
+# This file is automatically generated by tools/idna-data
+
+__version__ = "11.0.0"
+scripts = {
+    'Greek': (
+        0x37000000374,
+        0x37500000378,
+        0x37a0000037e,
+        0x37f00000380,
+        0x38400000385,
+        0x38600000387,
+        0x3880000038b,
+        0x38c0000038d,
+        0x38e000003a2,
+        0x3a3000003e2,
+        0x3f000000400,
+        0x1d2600001d2b,
+        0x1d5d00001d62,
+        0x1d6600001d6b,
+        0x1dbf00001dc0,
+        0x1f0000001f16,
+        0x1f1800001f1e,
+        0x1f2000001f46,
+        0x1f4800001f4e,
+        0x1f5000001f58,
+        0x1f5900001f5a,
+        0x1f5b00001f5c,
+        0x1f5d00001f5e,
+        0x1f5f00001f7e,
+        0x1f8000001fb5,
+        0x1fb600001fc5,
+        0x1fc600001fd4,
+        0x1fd600001fdc,
+        0x1fdd00001ff0,
+        0x1ff200001ff5,
+        0x1ff600001fff,
+        0x212600002127,
+        0xab650000ab66,
+        0x101400001018f,
+        0x101a0000101a1,
+        0x1d2000001d246,
+    ),
+    'Han': (
+        0x2e8000002e9a,
+        0x2e9b00002ef4,
+        0x2f0000002fd6,
+        0x300500003006,
+        0x300700003008,
+        0x30210000302a,
+        0x30380000303c,
+        0x340000004db6,
+        0x4e0000009ff0,
+        0xf9000000fa6e,
+        0xfa700000fada,
+        0x200000002a6d7,
+        0x2a7000002b735,
+        0x2b7400002b81e,
+        0x2b8200002cea2,
+        0x2ceb00002ebe1,
+        0x2f8000002fa1e,
+    ),
+    'Hebrew': (
+        0x591000005c8,
+        0x5d0000005eb,
+        0x5ef000005f5,
+        0xfb1d0000fb37,
+        0xfb380000fb3d,
+        0xfb3e0000fb3f,
+        0xfb400000fb42,
+        0xfb430000fb45,
+        0xfb460000fb50,
+    ),
+    'Hiragana': (
+        0x304100003097,
+        0x309d000030a0,
+        0x1b0010001b11f,
+        0x1f2000001f201,
+    ),
+    'Katakana': (
+        0x30a1000030fb,
+        0x30fd00003100,
+        0x31f000003200,
+        0x32d0000032ff,
+        0x330000003358,
+        0xff660000ff70,
+        0xff710000ff9e,
+        0x1b0000001b001,
+    ),
+}
+joining_types = {
+    0x600: 85,
+    0x601: 85,
+    0x602: 85,
+    0x603: 85,
+    0x604: 85,
+    0x605: 85,
+    0x608: 85,
+    0x60b: 85,
+    0x620: 68,
+    0x621: 85,
+    0x622: 82,
+    0x623: 82,
+    0x624: 82,
+    0x625: 82,
+    0x626: 68,
+    0x627: 82,
+    0x628: 68,
+    0x629: 82,
+    0x62a: 68,
+    0x62b: 68,
+    0x62c: 68,
+    0x62d: 68,
+    0x62e: 68,
+    0x62f: 82,
+    0x630: 82,
+    0x631: 82,
+    0x632: 82,
+    0x633: 68,
+    0x634: 68,
+    0x635: 68,
+    0x636: 68,
+    0x637: 68,
+    0x638: 68,
+    0x639: 68,
+    0x63a: 68,
+    0x63b: 68,
+    0x63c: 68,
+    0x63d: 68,
+    0x63e: 68,
+    0x63f: 68,
+    0x640: 67,
+    0x641: 68,
+    0x642: 68,
+    0x643: 68,
+    0x644: 68,
+    0x645: 68,
+    0x646: 68,
+    0x647: 68,
+    0x648: 82,
+    0x649: 68,
+    0x64a: 68,
+    0x66e: 68,
+    0x66f: 68,
+    0x671: 82,
+    0x672: 82,
+    0x673: 82,
+    0x674: 85,
+    0x675: 82,
+    0x676: 82,
+    0x677: 82,
+    0x678: 68,
+    0x679: 68,
+    0x67a: 68,
+    0x67b: 68,
+    0x67c: 68,
+    0x67d: 68,
+    0x67e: 68,
+    0x67f: 68,
+    0x680: 68,
+    0x681: 68,
+    0x682: 68,
+    0x683: 68,
+    0x684: 68,
+    0x685: 68,
+    0x686: 68,
+    0x687: 68,
+    0x688: 82,
+    0x689: 82,
+    0x68a: 82,
+    0x68b: 82,
+    0x68c: 82,
+    0x68d: 82,
+    0x68e: 82,
+    0x68f: 82,
+    0x690: 82,
+    0x691: 82,
+    0x692: 82,
+    0x693: 82,
+    0x694: 82,
+    0x695: 82,
+    0x696: 82,
+    0x697: 82,
+    0x698: 82,
+    0x699: 82,
+    0x69a: 68,
+    0x69b: 68,
+    0x69c: 68,
+    0x69d: 68,
+    0x69e: 68,
+    0x69f: 68,
+    0x6a0: 68,
+    0x6a1: 68,
+    0x6a2: 68,
+    0x6a3: 68,
+    0x6a4: 68,
+    0x6a5: 68,
+    0x6a6: 68,
+    0x6a7: 68,
+    0x6a8: 68,
+    0x6a9: 68,
+    0x6aa: 68,
+    0x6ab: 68,
+    0x6ac: 68,
+    0x6ad: 68,
+    0x6ae: 68,
+    0x6af: 68,
+    0x6b0: 68,
+    0x6b1: 68,
+    0x6b2: 68,
+    0x6b3: 68,
+    0x6b4: 68,
+    0x6b5: 68,
+    0x6b6: 68,
+    0x6b7: 68,
+    0x6b8: 68,
+    0x6b9: 68,
+    0x6ba: 68,
+    0x6bb: 68,
+    0x6bc: 68,
+    0x6bd: 68,
+    0x6be: 68,
+    0x6bf: 68,
+    0x6c0: 82,
+    0x6c1: 68,
+    0x6c2: 68,
+    0x6c3: 82,
+    0x6c4: 82,
+    0x6c5: 82,
+    0x6c6: 82,
+    0x6c7: 82,
+    0x6c8: 82,
+    0x6c9: 82,
+    0x6ca: 82,
+    0x6cb: 82,
+    0x6cc: 68,
+    0x6cd: 82,
+    0x6ce: 68,
+    0x6cf: 82,
+    0x6d0: 68,
+    0x6d1: 68,
+    0x6d2: 82,
+    0x6d3: 82,
+    0x6d5: 82,
+    0x6dd: 85,
+    0x6ee: 82,
+    0x6ef: 82,
+    0x6fa: 68,
+    0x6fb: 68,
+    0x6fc: 68,
+    0x6ff: 68,
+    0x70f: 84,
+    0x710: 82,
+    0x712: 68,
+    0x713: 68,
+    0x714: 68,
+    0x715: 82,
+    0x716: 82,
+    0x717: 82,
+    0x718: 82,
+    0x719: 82,
+    0x71a: 68,
+    0x71b: 68,
+    0x71c: 68,
+    0x71d: 68,
+    0x71e: 82,
+    0x71f: 68,
+    0x720: 68,
+    0x721: 68,
+    0x722: 68,
+    0x723: 68,
+    0x724: 68,
+    0x725: 68,
+    0x726: 68,
+    0x727: 68,
+    0x728: 82,
+    0x729: 68,
+    0x72a: 82,
+    0x72b: 68,
+    0x72c: 82,
+    0x72d: 68,
+    0x72e: 68,
+    0x72f: 82,
+    0x74d: 82,
+    0x74e: 68,
+    0x74f: 68,
+    0x750: 68,
+    0x751: 68,
+    0x752: 68,
+    0x753: 68,
+    0x754: 68,
+    0x755: 68,
+    0x756: 68,
+    0x757: 68,
+    0x758: 68,
+    0x759: 82,
+    0x75a: 82,
+    0x75b: 82,
+    0x75c: 68,
+    0x75d: 68,
+    0x75e: 68,
+    0x75f: 68,
+    0x760: 68,
+    0x761: 68,
+    0x762: 68,
+    0x763: 68,
+    0x764: 68,
+    0x765: 68,
+    0x766: 68,
+    0x767: 68,
+    0x768: 68,
+    0x769: 68,
+    0x76a: 68,
+    0x76b: 82,
+    0x76c: 82,
+    0x76d: 68,
+    0x76e: 68,
+    0x76f: 68,
+    0x770: 68,
+    0x771: 82,
+    0x772: 68,
+    0x773: 82,
+    0x774: 82,
+    0x775: 68,
+    0x776: 68,
+    0x777: 68,
+    0x778: 82,
+    0x779: 82,
+    0x77a: 68,
+    0x77b: 68,
+    0x77c: 68,
+    0x77d: 68,
+    0x77e: 68,
+    0x77f: 68,
+    0x7ca: 68,
+    0x7cb: 68,
+    0x7cc: 68,
+    0x7cd: 68,
+    0x7ce: 68,
+    0x7cf: 68,
+    0x7d0: 68,
+    0x7d1: 68,
+    0x7d2: 68,
+    0x7d3: 68,
+    0x7d4: 68,
+    0x7d5: 68,
+    0x7d6: 68,
+    0x7d7: 68,
+    0x7d8: 68,
+    0x7d9: 68,
+    0x7da: 68,
+    0x7db: 68,
+    0x7dc: 68,
+    0x7dd: 68,
+    0x7de: 68,
+    0x7df: 68,
+    0x7e0: 68,
+    0x7e1: 68,
+    0x7e2: 68,
+    0x7e3: 68,
+    0x7e4: 68,
+    0x7e5: 68,
+    0x7e6: 68,
+    0x7e7: 68,
+    0x7e8: 68,
+    0x7e9: 68,
+    0x7ea: 68,
+    0x7fa: 67,
+    0x840: 82,
+    0x841: 68,
+    0x842: 68,
+    0x843: 68,
+    0x844: 68,
+    0x845: 68,
+    0x846: 82,
+    0x847: 82,
+    0x848: 68,
+    0x849: 82,
+    0x84a: 68,
+    0x84b: 68,
+    0x84c: 68,
+    0x84d: 68,
+    0x84e: 68,
+    0x84f: 68,
+    0x850: 68,
+    0x851: 68,
+    0x852: 68,
+    0x853: 68,
+    0x854: 82,
+    0x855: 68,
+    0x856: 85,
+    0x857: 85,
+    0x858: 85,
+    0x860: 68,
+    0x861: 85,
+    0x862: 68,
+    0x863: 68,
+    0x864: 68,
+    0x865: 68,
+    0x866: 85,
+    0x867: 82,
+    0x868: 68,
+    0x869: 82,
+    0x86a: 82,
+    0x8a0: 68,
+    0x8a1: 68,
+    0x8a2: 68,
+    0x8a3: 68,
+    0x8a4: 68,
+    0x8a5: 68,
+    0x8a6: 68,
+    0x8a7: 68,
+    0x8a8: 68,
+    0x8a9: 68,
+    0x8aa: 82,
+    0x8ab: 82,
+    0x8ac: 82,
+    0x8ad: 85,
+    0x8ae: 82,
+    0x8af: 68,
+    0x8b0: 68,
+    0x8b1: 82,
+    0x8b2: 82,
+    0x8b3: 68,
+    0x8b4: 68,
+    0x8b6: 68,
+    0x8b7: 68,
+    0x8b8: 68,
+    0x8b9: 82,
+    0x8ba: 68,
+    0x8bb: 68,
+    0x8bc: 68,
+    0x8bd: 68,
+    0x8e2: 85,
+    0x1806: 85,
+    0x1807: 68,
+    0x180a: 67,
+    0x180e: 85,
+    0x1820: 68,
+    0x1821: 68,
+    0x1822: 68,
+    0x1823: 68,
+    0x1824: 68,
+    0x1825: 68,
+    0x1826: 68,
+    0x1827: 68,
+    0x1828: 68,
+    0x1829: 68,
+    0x182a: 68,
+    0x182b: 68,
+    0x182c: 68,
+    0x182d: 68,
+    0x182e: 68,
+    0x182f: 68,
+    0x1830: 68,
+    0x1831: 68,
+    0x1832: 68,
+    0x1833: 68,
+    0x1834: 68,
+    0x1835: 68,
+    0x1836: 68,
+    0x1837: 68,
+    0x1838: 68,
+    0x1839: 68,
+    0x183a: 68,
+    0x183b: 68,
+    0x183c: 68,
+    0x183d: 68,
+    0x183e: 68,
+    0x183f: 68,
+    0x1840: 68,
+    0x1841: 68,
+    0x1842: 68,
+    0x1843: 68,
+    0x1844: 68,
+    0x1845: 68,
+    0x1846: 68,
+    0x1847: 68,
+    0x1848: 68,
+    0x1849: 68,
+    0x184a: 68,
+    0x184b: 68,
+    0x184c: 68,
+    0x184d: 68,
+    0x184e: 68,
+    0x184f: 68,
+    0x1850: 68,
+    0x1851: 68,
+    0x1852: 68,
+    0x1853: 68,
+    0x1854: 68,
+    0x1855: 68,
+    0x1856: 68,
+    0x1857: 68,
+    0x1858: 68,
+    0x1859: 68,
+    0x185a: 68,
+    0x185b: 68,
+    0x185c: 68,
+    0x185d: 68,
+    0x185e: 68,
+    0x185f: 68,
+    0x1860: 68,
+    0x1861: 68,
+    0x1862: 68,
+    0x1863: 68,
+    0x1864: 68,
+    0x1865: 68,
+    0x1866: 68,
+    0x1867: 68,
+    0x1868: 68,
+    0x1869: 68,
+    0x186a: 68,
+    0x186b: 68,
+    0x186c: 68,
+    0x186d: 68,
+    0x186e: 68,
+    0x186f: 68,
+    0x1870: 68,
+    0x1871: 68,
+    0x1872: 68,
+    0x1873: 68,
+    0x1874: 68,
+    0x1875: 68,
+    0x1876: 68,
+    0x1877: 68,
+    0x1878: 68,
+    0x1880: 85,
+    0x1881: 85,
+    0x1882: 85,
+    0x1883: 85,
+    0x1884: 85,
+    0x1885: 84,
+    0x1886: 84,
+    0x1887: 68,
+    0x1888: 68,
+    0x1889: 68,
+    0x188a: 68,
+    0x188b: 68,
+    0x188c: 68,
+    0x188d: 68,
+    0x188e: 68,
+    0x188f: 68,
+    0x1890: 68,
+    0x1891: 68,
+    0x1892: 68,
+    0x1893: 68,
+    0x1894: 68,
+    0x1895: 68,
+    0x1896: 68,
+    0x1897: 68,
+    0x1898: 68,
+    0x1899: 68,
+    0x189a: 68,
+    0x189b: 68,
+    0x189c: 68,
+    0x189d: 68,
+    0x189e: 68,
+    0x189f: 68,
+    0x18a0: 68,
+    0x18a1: 68,
+    0x18a2: 68,
+    0x18a3: 68,
+    0x18a4: 68,
+    0x18a5: 68,
+    0x18a6: 68,
+    0x18a7: 68,
+    0x18a8: 68,
+    0x18aa: 68,
+    0x200c: 85,
+    0x200d: 67,
+    0x202f: 85,
+    0x2066: 85,
+    0x2067: 85,
+    0x2068: 85,
+    0x2069: 85,
+    0xa840: 68,
+    0xa841: 68,
+    0xa842: 68,
+    0xa843: 68,
+    0xa844: 68,
+    0xa845: 68,
+    0xa846: 68,
+    0xa847: 68,
+    0xa848: 68,
+    0xa849: 68,
+    0xa84a: 68,
+    0xa84b: 68,
+    0xa84c: 68,
+    0xa84d: 68,
+    0xa84e: 68,
+    0xa84f: 68,
+    0xa850: 68,
+    0xa851: 68,
+    0xa852: 68,
+    0xa853: 68,
+    0xa854: 68,
+    0xa855: 68,
+    0xa856: 68,
+    0xa857: 68,
+    0xa858: 68,
+    0xa859: 68,
+    0xa85a: 68,
+    0xa85b: 68,
+    0xa85c: 68,
+    0xa85d: 68,
+    0xa85e: 68,
+    0xa85f: 68,
+    0xa860: 68,
+    0xa861: 68,
+    0xa862: 68,
+    0xa863: 68,
+    0xa864: 68,
+    0xa865: 68,
+    0xa866: 68,
+    0xa867: 68,
+    0xa868: 68,
+    0xa869: 68,
+    0xa86a: 68,
+    0xa86b: 68,
+    0xa86c: 68,
+    0xa86d: 68,
+    0xa86e: 68,
+    0xa86f: 68,
+    0xa870: 68,
+    0xa871: 68,
+    0xa872: 76,
+    0xa873: 85,
+    0x10ac0: 68,
+    0x10ac1: 68,
+    0x10ac2: 68,
+    0x10ac3: 68,
+    0x10ac4: 68,
+    0x10ac5: 82,
+    0x10ac6: 85,
+    0x10ac7: 82,
+    0x10ac8: 85,
+    0x10ac9: 82,
+    0x10aca: 82,
+    0x10acb: 85,
+    0x10acc: 85,
+    0x10acd: 76,
+    0x10ace: 82,
+    0x10acf: 82,
+    0x10ad0: 82,
+    0x10ad1: 82,
+    0x10ad2: 82,
+    0x10ad3: 68,
+    0x10ad4: 68,
+    0x10ad5: 68,
+    0x10ad6: 68,
+    0x10ad7: 76,
+    0x10ad8: 68,
+    0x10ad9: 68,
+    0x10ada: 68,
+    0x10adb: 68,
+    0x10adc: 68,
+    0x10add: 82,
+    0x10ade: 68,
+    0x10adf: 68,
+    0x10ae0: 68,
+    0x10ae1: 82,
+    0x10ae2: 85,
+    0x10ae3: 85,
+    0x10ae4: 82,
+    0x10aeb: 68,
+    0x10aec: 68,
+    0x10aed: 68,
+    0x10aee: 68,
+    0x10aef: 82,
+    0x10b80: 68,
+    0x10b81: 82,
+    0x10b82: 68,
+    0x10b83: 82,
+    0x10b84: 82,
+    0x10b85: 82,
+    0x10b86: 68,
+    0x10b87: 68,
+    0x10b88: 68,
+    0x10b89: 82,
+    0x10b8a: 68,
+    0x10b8b: 68,
+    0x10b8c: 82,
+    0x10b8d: 68,
+    0x10b8e: 82,
+    0x10b8f: 82,
+    0x10b90: 68,
+    0x10b91: 82,
+    0x10ba9: 82,
+    0x10baa: 82,
+    0x10bab: 82,
+    0x10bac: 82,
+    0x10bad: 68,
+    0x10bae: 68,
+    0x10baf: 85,
+    0x10d00: 76,
+    0x10d01: 68,
+    0x10d02: 68,
+    0x10d03: 68,
+    0x10d04: 68,
+    0x10d05: 68,
+    0x10d06: 68,
+    0x10d07: 68,
+    0x10d08: 68,
+    0x10d09: 68,
+    0x10d0a: 68,
+    0x10d0b: 68,
+    0x10d0c: 68,
+    0x10d0d: 68,
+    0x10d0e: 68,
+    0x10d0f: 68,
+    0x10d10: 68,
+    0x10d11: 68,
+    0x10d12: 68,
+    0x10d13: 68,
+    0x10d14: 68,
+    0x10d15: 68,
+    0x10d16: 68,
+    0x10d17: 68,
+    0x10d18: 68,
+    0x10d19: 68,
+    0x10d1a: 68,
+    0x10d1b: 68,
+    0x10d1c: 68,
+    0x10d1d: 68,
+    0x10d1e: 68,
+    0x10d1f: 68,
+    0x10d20: 68,
+    0x10d21: 68,
+    0x10d22: 82,
+    0x10d23: 68,
+    0x10f30: 68,
+    0x10f31: 68,
+    0x10f32: 68,
+    0x10f33: 82,
+    0x10f34: 68,
+    0x10f35: 68,
+    0x10f36: 68,
+    0x10f37: 68,
+    0x10f38: 68,
+    0x10f39: 68,
+    0x10f3a: 68,
+    0x10f3b: 68,
+    0x10f3c: 68,
+    0x10f3d: 68,
+    0x10f3e: 68,
+    0x10f3f: 68,
+    0x10f40: 68,
+    0x10f41: 68,
+    0x10f42: 68,
+    0x10f43: 68,
+    0x10f44: 68,
+    0x10f45: 85,
+    0x10f51: 68,
+    0x10f52: 68,
+    0x10f53: 68,
+    0x10f54: 82,
+    0x110bd: 85,
+    0x110cd: 85,
+    0x1e900: 68,
+    0x1e901: 68,
+    0x1e902: 68,
+    0x1e903: 68,
+    0x1e904: 68,
+    0x1e905: 68,
+    0x1e906: 68,
+    0x1e907: 68,
+    0x1e908: 68,
+    0x1e909: 68,
+    0x1e90a: 68,
+    0x1e90b: 68,
+    0x1e90c: 68,
+    0x1e90d: 68,
+    0x1e90e: 68,
+    0x1e90f: 68,
+    0x1e910: 68,
+    0x1e911: 68,
+    0x1e912: 68,
+    0x1e913: 68,
+    0x1e914: 68,
+    0x1e915: 68,
+    0x1e916: 68,
+    0x1e917: 68,
+    0x1e918: 68,
+    0x1e919: 68,
+    0x1e91a: 68,
+    0x1e91b: 68,
+    0x1e91c: 68,
+    0x1e91d: 68,
+    0x1e91e: 68,
+    0x1e91f: 68,
+    0x1e920: 68,
+    0x1e921: 68,
+    0x1e922: 68,
+    0x1e923: 68,
+    0x1e924: 68,
+    0x1e925: 68,
+    0x1e926: 68,
+    0x1e927: 68,
+    0x1e928: 68,
+    0x1e929: 68,
+    0x1e92a: 68,
+    0x1e92b: 68,
+    0x1e92c: 68,
+    0x1e92d: 68,
+    0x1e92e: 68,
+    0x1e92f: 68,
+    0x1e930: 68,
+    0x1e931: 68,
+    0x1e932: 68,
+    0x1e933: 68,
+    0x1e934: 68,
+    0x1e935: 68,
+    0x1e936: 68,
+    0x1e937: 68,
+    0x1e938: 68,
+    0x1e939: 68,
+    0x1e93a: 68,
+    0x1e93b: 68,
+    0x1e93c: 68,
+    0x1e93d: 68,
+    0x1e93e: 68,
+    0x1e93f: 68,
+    0x1e940: 68,
+    0x1e941: 68,
+    0x1e942: 68,
+    0x1e943: 68,
+}
+codepoint_classes = {
+    'PVALID': (
+        0x2d0000002e,
+        0x300000003a,
+        0x610000007b,
+        0xdf000000f7,
+        0xf800000100,
+        0x10100000102,
+        0x10300000104,
+        0x10500000106,
+        0x10700000108,
+        0x1090000010a,
+        0x10b0000010c,
+        0x10d0000010e,
+        0x10f00000110,
+        0x11100000112,
+        0x11300000114,
+        0x11500000116,
+        0x11700000118,
+        0x1190000011a,
+        0x11b0000011c,
+        0x11d0000011e,
+        0x11f00000120,
+        0x12100000122,
+        0x12300000124,
+        0x12500000126,
+        0x12700000128,
+        0x1290000012a,
+        0x12b0000012c,
+        0x12d0000012e,
+        0x12f00000130,
+        0x13100000132,
+        0x13500000136,
+        0x13700000139,
+        0x13a0000013b,
+        0x13c0000013d,
+        0x13e0000013f,
+        0x14200000143,
+        0x14400000145,
+        0x14600000147,
+        0x14800000149,
+        0x14b0000014c,
+        0x14d0000014e,
+        0x14f00000150,
+        0x15100000152,
+        0x15300000154,
+        0x15500000156,
+        0x15700000158,
+        0x1590000015a,
+        0x15b0000015c,
+        0x15d0000015e,
+        0x15f00000160,
+        0x16100000162,
+        0x16300000164,
+        0x16500000166,
+        0x16700000168,
+        0x1690000016a,
+        0x16b0000016c,
+        0x16d0000016e,
+        0x16f00000170,
+        0x17100000172,
+        0x17300000174,
+        0x17500000176,
+        0x17700000178,
+        0x17a0000017b,
+        0x17c0000017d,
+        0x17e0000017f,
+        0x18000000181,
+        0x18300000184,
+        0x18500000186,
+        0x18800000189,
+        0x18c0000018e,
+        0x19200000193,
+        0x19500000196,
+        0x1990000019c,
+        0x19e0000019f,
+        0x1a1000001a2,
+        0x1a3000001a4,
+        0x1a5000001a6,
+        0x1a8000001a9,
+        0x1aa000001ac,
+        0x1ad000001ae,
+        0x1b0000001b1,
+        0x1b4000001b5,
+        0x1b6000001b7,
+        0x1b9000001bc,
+        0x1bd000001c4,
+        0x1ce000001cf,
+        0x1d0000001d1,
+        0x1d2000001d3,
+        0x1d4000001d5,
+        0x1d6000001d7,
+        0x1d8000001d9,
+        0x1da000001db,
+        0x1dc000001de,
+        0x1df000001e0,
+        0x1e1000001e2,
+        0x1e3000001e4,
+        0x1e5000001e6,
+        0x1e7000001e8,
+        0x1e9000001ea,
+        0x1eb000001ec,
+        0x1ed000001ee,
+        0x1ef000001f1,
+        0x1f5000001f6,
+        0x1f9000001fa,
+        0x1fb000001fc,
+        0x1fd000001fe,
+        0x1ff00000200,
+        0x20100000202,
+        0x20300000204,
+        0x20500000206,
+        0x20700000208,
+        0x2090000020a,
+        0x20b0000020c,
+        0x20d0000020e,
+        0x20f00000210,
+        0x21100000212,
+        0x21300000214,
+        0x21500000216,
+        0x21700000218,
+        0x2190000021a,
+        0x21b0000021c,
+        0x21d0000021e,
+        0x21f00000220,
+        0x22100000222,
+        0x22300000224,
+        0x22500000226,
+        0x22700000228,
+        0x2290000022a,
+        0x22b0000022c,
+        0x22d0000022e,
+        0x22f00000230,
+        0x23100000232,
+        0x2330000023a,
+        0x23c0000023d,
+        0x23f00000241,
+        0x24200000243,
+        0x24700000248,
+        0x2490000024a,
+        0x24b0000024c,
+        0x24d0000024e,
+        0x24f000002b0,
+        0x2b9000002c2,
+        0x2c6000002d2,
+        0x2ec000002ed,
+        0x2ee000002ef,
+        0x30000000340,
+        0x34200000343,
+        0x3460000034f,
+        0x35000000370,
+        0x37100000372,
+        0x37300000374,
+        0x37700000378,
+        0x37b0000037e,
+        0x39000000391,
+        0x3ac000003cf,
+        0x3d7000003d8,
+        0x3d9000003da,
+        0x3db000003dc,
+        0x3dd000003de,
+        0x3df000003e0,
+        0x3e1000003e2,
+        0x3e3000003e4,
+        0x3e5000003e6,
+        0x3e7000003e8,
+        0x3e9000003ea,
+        0x3eb000003ec,
+        0x3ed000003ee,
+        0x3ef000003f0,
+        0x3f3000003f4,
+        0x3f8000003f9,
+        0x3fb000003fd,
+        0x43000000460,
+        0x46100000462,
+        0x46300000464,
+        0x46500000466,
+        0x46700000468,
+        0x4690000046a,
+        0x46b0000046c,
+        0x46d0000046e,
+        0x46f00000470,
+        0x47100000472,
+        0x47300000474,
+        0x47500000476,
+        0x47700000478,
+        0x4790000047a,
+        0x47b0000047c,
+        0x47d0000047e,
+        0x47f00000480,
+        0x48100000482,
+        0x48300000488,
+        0x48b0000048c,
+        0x48d0000048e,
+        0x48f00000490,
+        0x49100000492,
+        0x49300000494,
+        0x49500000496,
+        0x49700000498,
+        0x4990000049a,
+        0x49b0000049c,
+        0x49d0000049e,
+        0x49f000004a0,
+        0x4a1000004a2,
+        0x4a3000004a4,
+        0x4a5000004a6,
+        0x4a7000004a8,
+        0x4a9000004aa,
+        0x4ab000004ac,
+        0x4ad000004ae,
+        0x4af000004b0,
+        0x4b1000004b2,
+        0x4b3000004b4,
+        0x4b5000004b6,
+        0x4b7000004b8,
+        0x4b9000004ba,
+        0x4bb000004bc,
+        0x4bd000004be,
+        0x4bf000004c0,
+        0x4c2000004c3,
+        0x4c4000004c5,
+        0x4c6000004c7,
+        0x4c8000004c9,
+        0x4ca000004cb,
+        0x4cc000004cd,
+        0x4ce000004d0,
+        0x4d1000004d2,
+        0x4d3000004d4,
+        0x4d5000004d6,
+        0x4d7000004d8,
+        0x4d9000004da,
+        0x4db000004dc,
+        0x4dd000004de,
+        0x4df000004e0,
+        0x4e1000004e2,
+        0x4e3000004e4,
+        0x4e5000004e6,
+        0x4e7000004e8,
+        0x4e9000004ea,
+        0x4eb000004ec,
+        0x4ed000004ee,
+        0x4ef000004f0,
+        0x4f1000004f2,
+        0x4f3000004f4,
+        0x4f5000004f6,
+        0x4f7000004f8,
+        0x4f9000004fa,
+        0x4fb000004fc,
+        0x4fd000004fe,
+        0x4ff00000500,
+        0x50100000502,
+        0x50300000504,
+        0x50500000506,
+        0x50700000508,
+        0x5090000050a,
+        0x50b0000050c,
+        0x50d0000050e,
+        0x50f00000510,
+        0x51100000512,
+        0x51300000514,
+        0x51500000516,
+        0x51700000518,
+        0x5190000051a,
+        0x51b0000051c,
+        0x51d0000051e,
+        0x51f00000520,
+        0x52100000522,
+        0x52300000524,
+        0x52500000526,
+        0x52700000528,
+        0x5290000052a,
+        0x52b0000052c,
+        0x52d0000052e,
+        0x52f00000530,
+        0x5590000055a,
+        0x56000000587,
+        0x58800000589,
+        0x591000005be,
+        0x5bf000005c0,
+        0x5c1000005c3,
+        0x5c4000005c6,
+        0x5c7000005c8,
+        0x5d0000005eb,
+        0x5ef000005f3,
+        0x6100000061b,
+        0x62000000640,
+        0x64100000660,
+        0x66e00000675,
+        0x679000006d4,
+        0x6d5000006dd,
+        0x6df000006e9,
+        0x6ea000006f0,
+        0x6fa00000700,
+        0x7100000074b,
+        0x74d000007b2,
+        0x7c0000007f6,
+        0x7fd000007fe,
+        0x8000000082e,
+        0x8400000085c,
+        0x8600000086b,
+        0x8a0000008b5,
+        0x8b6000008be,
+        0x8d3000008e2,
+        0x8e300000958,
+        0x96000000964,
+        0x96600000970,
+        0x97100000984,
+        0x9850000098d,
+        0x98f00000991,
+        0x993000009a9,
+        0x9aa000009b1,
+        0x9b2000009b3,
+        0x9b6000009ba,
+        0x9bc000009c5,
+        0x9c7000009c9,
+        0x9cb000009cf,
+        0x9d7000009d8,
+        0x9e0000009e4,
+        0x9e6000009f2,
+        0x9fc000009fd,
+        0x9fe000009ff,
+        0xa0100000a04,
+        0xa0500000a0b,
+        0xa0f00000a11,
+        0xa1300000a29,
+        0xa2a00000a31,
+        0xa3200000a33,
+        0xa3500000a36,
+        0xa3800000a3a,
+        0xa3c00000a3d,
+        0xa3e00000a43,
+        0xa4700000a49,
+        0xa4b00000a4e,
+        0xa5100000a52,
+        0xa5c00000a5d,
+        0xa6600000a76,
+        0xa8100000a84,
+        0xa8500000a8e,
+        0xa8f00000a92,
+        0xa9300000aa9,
+        0xaaa00000ab1,
+        0xab200000ab4,
+        0xab500000aba,
+        0xabc00000ac6,
+        0xac700000aca,
+        0xacb00000ace,
+        0xad000000ad1,
+        0xae000000ae4,
+        0xae600000af0,
+        0xaf900000b00,
+        0xb0100000b04,
+        0xb0500000b0d,
+        0xb0f00000b11,
+        0xb1300000b29,
+        0xb2a00000b31,
+        0xb3200000b34,
+        0xb3500000b3a,
+        0xb3c00000b45,
+        0xb4700000b49,
+        0xb4b00000b4e,
+        0xb5600000b58,
+        0xb5f00000b64,
+        0xb6600000b70,
+        0xb7100000b72,
+        0xb8200000b84,
+        0xb8500000b8b,
+        0xb8e00000b91,
+        0xb9200000b96,
+        0xb9900000b9b,
+        0xb9c00000b9d,
+        0xb9e00000ba0,
+        0xba300000ba5,
+        0xba800000bab,
+        0xbae00000bba,
+        0xbbe00000bc3,
+        0xbc600000bc9,
+        0xbca00000bce,
+        0xbd000000bd1,
+        0xbd700000bd8,
+        0xbe600000bf0,
+        0xc0000000c0d,
+        0xc0e00000c11,
+        0xc1200000c29,
+        0xc2a00000c3a,
+        0xc3d00000c45,
+        0xc4600000c49,
+        0xc4a00000c4e,
+        0xc5500000c57,
+        0xc5800000c5b,
+        0xc6000000c64,
+        0xc6600000c70,
+        0xc8000000c84,
+        0xc8500000c8d,
+        0xc8e00000c91,
+        0xc9200000ca9,
+        0xcaa00000cb4,
+        0xcb500000cba,
+        0xcbc00000cc5,
+        0xcc600000cc9,
+        0xcca00000cce,
+        0xcd500000cd7,
+        0xcde00000cdf,
+        0xce000000ce4,
+        0xce600000cf0,
+        0xcf100000cf3,
+        0xd0000000d04,
+        0xd0500000d0d,
+        0xd0e00000d11,
+        0xd1200000d45,
+        0xd4600000d49,
+        0xd4a00000d4f,
+        0xd5400000d58,
+        0xd5f00000d64,
+        0xd6600000d70,
+        0xd7a00000d80,
+        0xd8200000d84,
+        0xd8500000d97,
+        0xd9a00000db2,
+        0xdb300000dbc,
+        0xdbd00000dbe,
+        0xdc000000dc7,
+        0xdca00000dcb,
+        0xdcf00000dd5,
+        0xdd600000dd7,
+        0xdd800000de0,
+        0xde600000df0,
+        0xdf200000df4,
+        0xe0100000e33,
+        0xe3400000e3b,
+        0xe4000000e4f,
+        0xe5000000e5a,
+        0xe8100000e83,
+        0xe8400000e85,
+        0xe8700000e89,
+        0xe8a00000e8b,
+        0xe8d00000e8e,
+        0xe9400000e98,
+        0xe9900000ea0,
+        0xea100000ea4,
+        0xea500000ea6,
+        0xea700000ea8,
+        0xeaa00000eac,
+        0xead00000eb3,
+        0xeb400000eba,
+        0xebb00000ebe,
+        0xec000000ec5,
+        0xec600000ec7,
+        0xec800000ece,
+        0xed000000eda,
+        0xede00000ee0,
+        0xf0000000f01,
+        0xf0b00000f0c,
+        0xf1800000f1a,
+        0xf2000000f2a,
+        0xf3500000f36,
+        0xf3700000f38,
+        0xf3900000f3a,
+        0xf3e00000f43,
+        0xf4400000f48,
+        0xf4900000f4d,
+        0xf4e00000f52,
+        0xf5300000f57,
+        0xf5800000f5c,
+        0xf5d00000f69,
+        0xf6a00000f6d,
+        0xf7100000f73,
+        0xf7400000f75,
+        0xf7a00000f81,
+        0xf8200000f85,
+        0xf8600000f93,
+        0xf9400000f98,
+        0xf9900000f9d,
+        0xf9e00000fa2,
+        0xfa300000fa7,
+        0xfa800000fac,
+        0xfad00000fb9,
+        0xfba00000fbd,
+        0xfc600000fc7,
+        0x10000000104a,
+        0x10500000109e,
+        0x10d0000010fb,
+        0x10fd00001100,
+        0x120000001249,
+        0x124a0000124e,
+        0x125000001257,
+        0x125800001259,
+        0x125a0000125e,
+        0x126000001289,
+        0x128a0000128e,
+        0x1290000012b1,
+        0x12b2000012b6,
+        0x12b8000012bf,
+        0x12c0000012c1,
+        0x12c2000012c6,
+        0x12c8000012d7,
+        0x12d800001311,
+        0x131200001316,
+        0x13180000135b,
+        0x135d00001360,
+        0x138000001390,
+        0x13a0000013f6,
+        0x14010000166d,
+        0x166f00001680,
+        0x16810000169b,
+        0x16a0000016eb,
+        0x16f1000016f9,
+        0x17000000170d,
+        0x170e00001715,
+        0x172000001735,
+        0x174000001754,
+        0x17600000176d,
+        0x176e00001771,
+        0x177200001774,
+        0x1780000017b4,
+        0x17b6000017d4,
+        0x17d7000017d8,
+        0x17dc000017de,
+        0x17e0000017ea,
+        0x18100000181a,
+        0x182000001879,
+        0x1880000018ab,
+        0x18b0000018f6,
+        0x19000000191f,
+        0x19200000192c,
+        0x19300000193c,
+        0x19460000196e,
+        0x197000001975,
+        0x1980000019ac,
+        0x19b0000019ca,
+        0x19d0000019da,
+        0x1a0000001a1c,
+        0x1a2000001a5f,
+        0x1a6000001a7d,
+        0x1a7f00001a8a,
+        0x1a9000001a9a,
+        0x1aa700001aa8,
+        0x1ab000001abe,
+        0x1b0000001b4c,
+        0x1b5000001b5a,
+        0x1b6b00001b74,
+        0x1b8000001bf4,
+        0x1c0000001c38,
+        0x1c4000001c4a,
+        0x1c4d00001c7e,
+        0x1cd000001cd3,
+        0x1cd400001cfa,
+        0x1d0000001d2c,
+        0x1d2f00001d30,
+        0x1d3b00001d3c,
+        0x1d4e00001d4f,
+        0x1d6b00001d78,
+        0x1d7900001d9b,
+        0x1dc000001dfa,
+        0x1dfb00001e00,
+        0x1e0100001e02,
+        0x1e0300001e04,
+        0x1e0500001e06,
+        0x1e0700001e08,
+        0x1e0900001e0a,
+        0x1e0b00001e0c,
+        0x1e0d00001e0e,
+        0x1e0f00001e10,
+        0x1e1100001e12,
+        0x1e1300001e14,
+        0x1e1500001e16,
+        0x1e1700001e18,
+        0x1e1900001e1a,
+        0x1e1b00001e1c,
+        0x1e1d00001e1e,
+        0x1e1f00001e20,
+        0x1e2100001e22,
+        0x1e2300001e24,
+        0x1e2500001e26,
+        0x1e2700001e28,
+        0x1e2900001e2a,
+        0x1e2b00001e2c,
+        0x1e2d00001e2e,
+        0x1e2f00001e30,
+        0x1e3100001e32,
+        0x1e3300001e34,
+        0x1e3500001e36,
+        0x1e3700001e38,
+        0x1e3900001e3a,
+        0x1e3b00001e3c,
+        0x1e3d00001e3e,
+        0x1e3f00001e40,
+        0x1e4100001e42,
+        0x1e4300001e44,
+        0x1e4500001e46,
+        0x1e4700001e48,
+        0x1e4900001e4a,
+        0x1e4b00001e4c,
+        0x1e4d00001e4e,
+        0x1e4f00001e50,
+        0x1e5100001e52,
+        0x1e5300001e54,
+        0x1e5500001e56,
+        0x1e5700001e58,
+        0x1e5900001e5a,
+        0x1e5b00001e5c,
+        0x1e5d00001e5e,
+        0x1e5f00001e60,
+        0x1e6100001e62,
+        0x1e6300001e64,
+        0x1e6500001e66,
+        0x1e6700001e68,
+        0x1e6900001e6a,
+        0x1e6b00001e6c,
+        0x1e6d00001e6e,
+        0x1e6f00001e70,
+        0x1e7100001e72,
+        0x1e7300001e74,
+        0x1e7500001e76,
+        0x1e7700001e78,
+        0x1e7900001e7a,
+        0x1e7b00001e7c,
+        0x1e7d00001e7e,
+        0x1e7f00001e80,
+        0x1e8100001e82,
+        0x1e8300001e84,
+        0x1e8500001e86,
+        0x1e8700001e88,
+        0x1e8900001e8a,
+        0x1e8b00001e8c,
+        0x1e8d00001e8e,
+        0x1e8f00001e90,
+        0x1e9100001e92,
+        0x1e9300001e94,
+        0x1e9500001e9a,
+        0x1e9c00001e9e,
+        0x1e9f00001ea0,
+        0x1ea100001ea2,
+        0x1ea300001ea4,
+        0x1ea500001ea6,
+        0x1ea700001ea8,
+        0x1ea900001eaa,
+        0x1eab00001eac,
+        0x1ead00001eae,
+        0x1eaf00001eb0,
+        0x1eb100001eb2,
+        0x1eb300001eb4,
+        0x1eb500001eb6,
+        0x1eb700001eb8,
+        0x1eb900001eba,
+        0x1ebb00001ebc,
+        0x1ebd00001ebe,
+        0x1ebf00001ec0,
+        0x1ec100001ec2,
+        0x1ec300001ec4,
+        0x1ec500001ec6,
+        0x1ec700001ec8,
+        0x1ec900001eca,
+        0x1ecb00001ecc,
+        0x1ecd00001ece,
+        0x1ecf00001ed0,
+        0x1ed100001ed2,
+        0x1ed300001ed4,
+        0x1ed500001ed6,
+        0x1ed700001ed8,
+        0x1ed900001eda,
+        0x1edb00001edc,
+        0x1edd00001ede,
+        0x1edf00001ee0,
+        0x1ee100001ee2,
+        0x1ee300001ee4,
+        0x1ee500001ee6,
+        0x1ee700001ee8,
+        0x1ee900001eea,
+        0x1eeb00001eec,
+        0x1eed00001eee,
+        0x1eef00001ef0,
+        0x1ef100001ef2,
+        0x1ef300001ef4,
+        0x1ef500001ef6,
+        0x1ef700001ef8,
+        0x1ef900001efa,
+        0x1efb00001efc,
+        0x1efd00001efe,
+        0x1eff00001f08,
+        0x1f1000001f16,
+        0x1f2000001f28,
+        0x1f3000001f38,
+        0x1f4000001f46,
+        0x1f5000001f58,
+        0x1f6000001f68,
+        0x1f7000001f71,
+        0x1f7200001f73,
+        0x1f7400001f75,
+        0x1f7600001f77,
+        0x1f7800001f79,
+        0x1f7a00001f7b,
+        0x1f7c00001f7d,
+        0x1fb000001fb2,
+        0x1fb600001fb7,
+        0x1fc600001fc7,
+        0x1fd000001fd3,
+        0x1fd600001fd8,
+        0x1fe000001fe3,
+        0x1fe400001fe8,
+        0x1ff600001ff7,
+        0x214e0000214f,
+        0x218400002185,
+        0x2c3000002c5f,
+        0x2c6100002c62,
+        0x2c6500002c67,
+        0x2c6800002c69,
+        0x2c6a00002c6b,
+        0x2c6c00002c6d,
+        0x2c7100002c72,
+        0x2c7300002c75,
+        0x2c7600002c7c,
+        0x2c8100002c82,
+        0x2c8300002c84,
+        0x2c8500002c86,
+        0x2c8700002c88,
+        0x2c8900002c8a,
+        0x2c8b00002c8c,
+        0x2c8d00002c8e,
+        0x2c8f00002c90,
+        0x2c9100002c92,
+        0x2c9300002c94,
+        0x2c9500002c96,
+        0x2c9700002c98,
+        0x2c9900002c9a,
+        0x2c9b00002c9c,
+        0x2c9d00002c9e,
+        0x2c9f00002ca0,
+        0x2ca100002ca2,
+        0x2ca300002ca4,
+        0x2ca500002ca6,
+        0x2ca700002ca8,
+        0x2ca900002caa,
+        0x2cab00002cac,
+        0x2cad00002cae,
+        0x2caf00002cb0,
+        0x2cb100002cb2,
+        0x2cb300002cb4,
+        0x2cb500002cb6,
+        0x2cb700002cb8,
+        0x2cb900002cba,
+        0x2cbb00002cbc,
+        0x2cbd00002cbe,
+        0x2cbf00002cc0,
+        0x2cc100002cc2,
+        0x2cc300002cc4,
+        0x2cc500002cc6,
+        0x2cc700002cc8,
+        0x2cc900002cca,
+        0x2ccb00002ccc,
+        0x2ccd00002cce,
+        0x2ccf00002cd0,
+        0x2cd100002cd2,
+        0x2cd300002cd4,
+        0x2cd500002cd6,
+        0x2cd700002cd8,
+        0x2cd900002cda,
+        0x2cdb00002cdc,
+        0x2cdd00002cde,
+        0x2cdf00002ce0,
+        0x2ce100002ce2,
+        0x2ce300002ce5,
+        0x2cec00002ced,
+        0x2cee00002cf2,
+        0x2cf300002cf4,
+        0x2d0000002d26,
+        0x2d2700002d28,
+        0x2d2d00002d2e,
+        0x2d3000002d68,
+        0x2d7f00002d97,
+        0x2da000002da7,
+        0x2da800002daf,
+        0x2db000002db7,
+        0x2db800002dbf,
+        0x2dc000002dc7,
+        0x2dc800002dcf,
+        0x2dd000002dd7,
+        0x2dd800002ddf,
+        0x2de000002e00,
+        0x2e2f00002e30,
+        0x300500003008,
+        0x302a0000302e,
+        0x303c0000303d,
+        0x304100003097,
+        0x30990000309b,
+        0x309d0000309f,
+        0x30a1000030fb,
+        0x30fc000030ff,
+        0x310500003130,
+        0x31a0000031bb,
+        0x31f000003200,
+        0x340000004db6,
+        0x4e0000009ff0,
+        0xa0000000a48d,
+        0xa4d00000a4fe,
+        0xa5000000a60d,
+        0xa6100000a62c,
+        0xa6410000a642,
+        0xa6430000a644,
+        0xa6450000a646,
+        0xa6470000a648,
+        0xa6490000a64a,
+        0xa64b0000a64c,
+        0xa64d0000a64e,
+        0xa64f0000a650,
+        0xa6510000a652,
+        0xa6530000a654,
+        0xa6550000a656,
+        0xa6570000a658,
+        0xa6590000a65a,
+        0xa65b0000a65c,
+        0xa65d0000a65e,
+        0xa65f0000a660,
+        0xa6610000a662,
+        0xa6630000a664,
+        0xa6650000a666,
+        0xa6670000a668,
+        0xa6690000a66a,
+        0xa66b0000a66c,
+        0xa66d0000a670,
+        0xa6740000a67e,
+        0xa67f0000a680,
+        0xa6810000a682,
+        0xa6830000a684,
+        0xa6850000a686,
+        0xa6870000a688,
+        0xa6890000a68a,
+        0xa68b0000a68c,
+        0xa68d0000a68e,
+        0xa68f0000a690,
+        0xa6910000a692,
+        0xa6930000a694,
+        0xa6950000a696,
+        0xa6970000a698,
+        0xa6990000a69a,
+        0xa69b0000a69c,
+        0xa69e0000a6e6,
+        0xa6f00000a6f2,
+        0xa7170000a720,
+        0xa7230000a724,
+        0xa7250000a726,
+        0xa7270000a728,
+        0xa7290000a72a,
+        0xa72b0000a72c,
+        0xa72d0000a72e,
+        0xa72f0000a732,
+        0xa7330000a734,
+        0xa7350000a736,
+        0xa7370000a738,
+        0xa7390000a73a,
+        0xa73b0000a73c,
+        0xa73d0000a73e,
+        0xa73f0000a740,
+        0xa7410000a742,
+        0xa7430000a744,
+        0xa7450000a746,
+        0xa7470000a748,
+        0xa7490000a74a,
+        0xa74b0000a74c,
+        0xa74d0000a74e,
+        0xa74f0000a750,
+        0xa7510000a752,
+        0xa7530000a754,
+        0xa7550000a756,
+        0xa7570000a758,
+        0xa7590000a75a,
+        0xa75b0000a75c,
+        0xa75d0000a75e,
+        0xa75f0000a760,
+        0xa7610000a762,
+        0xa7630000a764,
+        0xa7650000a766,
+        0xa7670000a768,
+        0xa7690000a76a,
+        0xa76b0000a76c,
+        0xa76d0000a76e,
+        0xa76f0000a770,
+        0xa7710000a779,
+        0xa77a0000a77b,
+        0xa77c0000a77d,
+        0xa77f0000a780,
+        0xa7810000a782,
+        0xa7830000a784,
+        0xa7850000a786,
+        0xa7870000a789,
+        0xa78c0000a78d,
+        0xa78e0000a790,
+        0xa7910000a792,
+        0xa7930000a796,
+        0xa7970000a798,
+        0xa7990000a79a,
+        0xa79b0000a79c,
+        0xa79d0000a79e,
+        0xa79f0000a7a0,
+        0xa7a10000a7a2,
+        0xa7a30000a7a4,
+        0xa7a50000a7a6,
+        0xa7a70000a7a8,
+        0xa7a90000a7aa,
+        0xa7af0000a7b0,
+        0xa7b50000a7b6,
+        0xa7b70000a7b8,
+        0xa7b90000a7ba,
+        0xa7f70000a7f8,
+        0xa7fa0000a828,
+        0xa8400000a874,
+        0xa8800000a8c6,
+        0xa8d00000a8da,
+        0xa8e00000a8f8,
+        0xa8fb0000a8fc,
+        0xa8fd0000a92e,
+        0xa9300000a954,
+        0xa9800000a9c1,
+        0xa9cf0000a9da,
+        0xa9e00000a9ff,
+        0xaa000000aa37,
+        0xaa400000aa4e,
+        0xaa500000aa5a,
+        0xaa600000aa77,
+        0xaa7a0000aac3,
+        0xaadb0000aade,
+        0xaae00000aaf0,
+        0xaaf20000aaf7,
+        0xab010000ab07,
+        0xab090000ab0f,
+        0xab110000ab17,
+        0xab200000ab27,
+        0xab280000ab2f,
+        0xab300000ab5b,
+        0xab600000ab66,
+        0xabc00000abeb,
+        0xabec0000abee,
+        0xabf00000abfa,
+        0xac000000d7a4,
+        0xfa0e0000fa10,
+        0xfa110000fa12,
+        0xfa130000fa15,
+        0xfa1f0000fa20,
+        0xfa210000fa22,
+        0xfa230000fa25,
+        0xfa270000fa2a,
+        0xfb1e0000fb1f,
+        0xfe200000fe30,
+        0xfe730000fe74,
+        0x100000001000c,
+        0x1000d00010027,
+        0x100280001003b,
+        0x1003c0001003e,
+        0x1003f0001004e,
+        0x100500001005e,
+        0x10080000100fb,
+        0x101fd000101fe,
+        0x102800001029d,
+        0x102a0000102d1,
+        0x102e0000102e1,
+        0x1030000010320,
+        0x1032d00010341,
+        0x103420001034a,
+        0x103500001037b,
+        0x103800001039e,
+        0x103a0000103c4,
+        0x103c8000103d0,
+        0x104280001049e,
+        0x104a0000104aa,
+        0x104d8000104fc,
+        0x1050000010528,
+        0x1053000010564,
+        0x1060000010737,
+        0x1074000010756,
+        0x1076000010768,
+        0x1080000010806,
+        0x1080800010809,
+        0x1080a00010836,
+        0x1083700010839,
+        0x1083c0001083d,
+        0x1083f00010856,
+        0x1086000010877,
+        0x108800001089f,
+        0x108e0000108f3,
+        0x108f4000108f6,
+        0x1090000010916,
+        0x109200001093a,
+        0x10980000109b8,
+        0x109be000109c0,
+        0x10a0000010a04,
+        0x10a0500010a07,
+        0x10a0c00010a14,
+        0x10a1500010a18,
+        0x10a1900010a36,
+        0x10a3800010a3b,
+        0x10a3f00010a40,
+        0x10a6000010a7d,
+        0x10a8000010a9d,
+        0x10ac000010ac8,
+        0x10ac900010ae7,
+        0x10b0000010b36,
+        0x10b4000010b56,
+        0x10b6000010b73,
+        0x10b8000010b92,
+        0x10c0000010c49,
+        0x10cc000010cf3,
+        0x10d0000010d28,
+        0x10d3000010d3a,
+        0x10f0000010f1d,
+        0x10f2700010f28,
+        0x10f3000010f51,
+        0x1100000011047,
+        0x1106600011070,
+        0x1107f000110bb,
+        0x110d0000110e9,
+        0x110f0000110fa,
+        0x1110000011135,
+        0x1113600011140,
+        0x1114400011147,
+        0x1115000011174,
+        0x1117600011177,
+        0x11180000111c5,
+        0x111c9000111cd,
+        0x111d0000111db,
+        0x111dc000111dd,
+        0x1120000011212,
+        0x1121300011238,
+        0x1123e0001123f,
+        0x1128000011287,
+        0x1128800011289,
+        0x1128a0001128e,
+        0x1128f0001129e,
+        0x1129f000112a9,
+        0x112b0000112eb,
+        0x112f0000112fa,
+        0x1130000011304,
+        0x113050001130d,
+        0x1130f00011311,
+        0x1131300011329,
+        0x1132a00011331,
+        0x1133200011334,
+        0x113350001133a,
+        0x1133b00011345,
+        0x1134700011349,
+        0x1134b0001134e,
+        0x1135000011351,
+        0x1135700011358,
+        0x1135d00011364,
+        0x113660001136d,
+        0x1137000011375,
+        0x114000001144b,
+        0x114500001145a,
+        0x1145e0001145f,
+        0x11480000114c6,
+        0x114c7000114c8,
+        0x114d0000114da,
+        0x11580000115b6,
+        0x115b8000115c1,
+        0x115d8000115de,
+        0x1160000011641,
+        0x1164400011645,
+        0x116500001165a,
+        0x11680000116b8,
+        0x116c0000116ca,
+        0x117000001171b,
+        0x1171d0001172c,
+        0x117300001173a,
+        0x118000001183b,
+        0x118c0000118ea,
+        0x118ff00011900,
+        0x11a0000011a3f,
+        0x11a4700011a48,
+        0x11a5000011a84,
+        0x11a8600011a9a,
+        0x11a9d00011a9e,
+        0x11ac000011af9,
+        0x11c0000011c09,
+        0x11c0a00011c37,
+        0x11c3800011c41,
+        0x11c5000011c5a,
+        0x11c7200011c90,
+        0x11c9200011ca8,
+        0x11ca900011cb7,
+        0x11d0000011d07,
+        0x11d0800011d0a,
+        0x11d0b00011d37,
+        0x11d3a00011d3b,
+        0x11d3c00011d3e,
+        0x11d3f00011d48,
+        0x11d5000011d5a,
+        0x11d6000011d66,
+        0x11d6700011d69,
+        0x11d6a00011d8f,
+        0x11d9000011d92,
+        0x11d9300011d99,
+        0x11da000011daa,
+        0x11ee000011ef7,
+        0x120000001239a,
+        0x1248000012544,
+        0x130000001342f,
+        0x1440000014647,
+        0x1680000016a39,
+        0x16a4000016a5f,
+        0x16a6000016a6a,
+        0x16ad000016aee,
+        0x16af000016af5,
+        0x16b0000016b37,
+        0x16b4000016b44,
+        0x16b5000016b5a,
+        0x16b6300016b78,
+        0x16b7d00016b90,
+        0x16e6000016e80,
+        0x16f0000016f45,
+        0x16f5000016f7f,
+        0x16f8f00016fa0,
+        0x16fe000016fe2,
+        0x17000000187f2,
+        0x1880000018af3,
+        0x1b0000001b11f,
+        0x1b1700001b2fc,
+        0x1bc000001bc6b,
+        0x1bc700001bc7d,
+        0x1bc800001bc89,
+        0x1bc900001bc9a,
+        0x1bc9d0001bc9f,
+        0x1da000001da37,
+        0x1da3b0001da6d,
+        0x1da750001da76,
+        0x1da840001da85,
+        0x1da9b0001daa0,
+        0x1daa10001dab0,
+        0x1e0000001e007,
+        0x1e0080001e019,
+        0x1e01b0001e022,
+        0x1e0230001e025,
+        0x1e0260001e02b,
+        0x1e8000001e8c5,
+        0x1e8d00001e8d7,
+        0x1e9220001e94b,
+        0x1e9500001e95a,
+        0x200000002a6d7,
+        0x2a7000002b735,
+        0x2b7400002b81e,
+        0x2b8200002cea2,
+        0x2ceb00002ebe1,
+    ),
+    'CONTEXTJ': (
+        0x200c0000200e,
+    ),
+    'CONTEXTO': (
+        0xb7000000b8,
+        0x37500000376,
+        0x5f3000005f5,
+        0x6600000066a,
+        0x6f0000006fa,
+        0x30fb000030fc,
+    ),
+}
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/idna/idnadata.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/idna/idnadata.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..6c354d72ccbd17e21573ed9de08587883a83c332
GIT binary patch
literal 35078
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

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/idna/intranges.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/idna/intranges.py
new file mode 100644
index 0000000..fa8a735
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/idna/intranges.py
@@ -0,0 +1,53 @@
+"""
+Given a list of integers, made up of (hopefully) a small number of long runs
+of consecutive integers, compute a representation of the form
+((start1, end1), (start2, end2) ...). Then answer the question "was x present
+in the original list?" in time O(log(# runs)).
+"""
+
+import bisect
+
+def intranges_from_list(list_):
+    """Represent a list of integers as a sequence of ranges:
+    ((start_0, end_0), (start_1, end_1), ...), such that the original
+    integers are exactly those x such that start_i <= x < end_i for some i.
+
+    Ranges are encoded as single integers (start << 32 | end), not as tuples.
+    """
+
+    sorted_list = sorted(list_)
+    ranges = []
+    last_write = -1
+    for i in range(len(sorted_list)):
+        if i+1 < len(sorted_list):
+            if sorted_list[i] == sorted_list[i+1]-1:
+                continue
+        current_range = sorted_list[last_write+1:i+1]
+        ranges.append(_encode_range(current_range[0], current_range[-1] + 1))
+        last_write = i
+
+    return tuple(ranges)
+
+def _encode_range(start, end):
+    return (start << 32) | end
+
+def _decode_range(r):
+    return (r >> 32), (r & ((1 << 32) - 1))
+
+
+def intranges_contain(int_, ranges):
+    """Determine if `int_` falls into one of the ranges in `ranges`."""
+    tuple_ = _encode_range(int_, 0)
+    pos = bisect.bisect_left(ranges, tuple_)
+    # we could be immediately ahead of a tuple (start, end)
+    # with start < int_ <= end
+    if pos > 0:
+        left, right = _decode_range(ranges[pos-1])
+        if left <= int_ < right:
+            return True
+    # or we could be immediately behind a tuple (int_, end)
+    if pos < len(ranges):
+        left, _ = _decode_range(ranges[pos])
+        if left == int_:
+            return True
+    return False
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/idna/intranges.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/idna/intranges.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..970b5cc55170051e09b53cbb0eb4089764c42d5a
GIT binary patch
literal 2452
zcmZSn%**AGdLky70ScHH7#JKF7#NDJ7#J8*7#N}$7*ZG+QkWQW7#X4%8B&-TS{N9j
zm>5!6zzk-F6jm^Ug&~Cv%wPp64%T1?nZe1(z`*66S(ciokf@N8SzMx!pQezRSCX2Z
zT2!o~keis2s!&=064c1ZFGx)*&B>|MR7g}P&P~k8QOGOJO-d~S$>!wer7IMb<`r}0
zrzs@o=M|?WmzHFfr6QS?oS$1zT9T@es8EzzP?TDnnpcuol9`_e(q590s*sjnl*^@|
zQCyN(RAQ*3keZibsHvj>;TwVZMw$wGdU~3A3LzOF_vRIsrxq!Iv=)}87K4paDo-p{
zs8E0!&y|@6md-EAOwY_q%mI7QUP%EYoSB=d;IEOBpRS<{cDJUc9#`i7|NsB{B{MQG
zFt9<fGboU@GcYieFfi0GFf=nV)G{)pGceRLfdajjnW175LkS~82@^vNBS^NHk-;Ul
zj-i%?p@sz%%;IpFYzBs+9FVFS76!>0Mwq;03KN4wHWNs$P@ADJharyvtcV$`8)}GR
zEh|F}6GIj=LkSB*4J#;)B|#J;14z4gGZV;a#u^reT4shqZHDj?u<~X`hF}dAkO!n0
z85n|KfsQ4j6%va<ahh6KnwpoK3W|`T#Ju#>Vk<5M1qB6YoWvV|BO%@Z9xL&XXo?5L
z6DVSI6pBleGZacP5=&6R9c&6LQ7I%Ar7EOWBqo>SR4SBY<QJzZR3PaCM}K^#f{m?0
zg@O$z6~t$Pl7>QYer~ElrXCmAupqGWAV%dS=clBmfV@zgnU|h}NOI7$qhMpBU~HsN
z12RifM<Fl21f;g4v>+$7SPyI(INmcs(Vhv)V;Z2yF98w7`9&qEDJ8573=H4^DPd+{
zV8}_$14||r6r|>*l<+bzFvO>V9T5*v1X2z*9%2xP3(8sXCETF602>((5&)Y5)>2%;
z1u{6XxFo*3D6=HB1nd^D(aEJnMX7lu5TiA~&I1v}xeN>p`UORqWr-!J`elhl`f2$&
zDXB%p`bjDJ<w;3-xu&_rMuth|=~d|#rWWNnSyg5RAdsG?AEIB7S)iMlS6q^qlcVca
z=HY1^01^V@__EZzl>8$7%#^%D{mi@)i2L*kDocbJ7#QFJ@o7c*xnN&_TwW{&auWv+
zBO4<dqa>pkqYNV_qbQ>iBNtOLsJMb*aBkvZ0B5BXMh3eYMh2%~4Unu~rUC;41H^wI
zJ~+(5X#pJOsd*_7IgmZ{_j?d17s-QS59BrmMsN`UiX)IX*i%AqPubTnfQnv+G$w{%
z4N%-eyarBQo*?Ig^m&3x8W0EKE07R4&Wj*?kPQ8O2~KbEDXF0R1W9j7NL~i{98_h%
zy}S}$DyA?pG&6yU#1ck^EO1F!!vq##W~gBXm6O>l3`JQCCCrGDO+vDnks*c&R8WG-
zHWpCf%EFw@$dDfgD&Vpi81k4Hm>5C2SQvsqWg;^Js8j<NvY?`LDZ)4;qu4;jY7GMe
zs6br`Dl9=-OV}8KH9$GH*p`8T!6mgMwJ0|;FI6EkO(7vOuOvP}AuTZ{rx;XK<tyap
zfy+NotpZ8<pxPn<!c5Qumk;2m1XrKnbOFxBNtwl|$tB<%4q?XUq^6Yw34p=~6k;Jo
zrKv%nAOt6Dx5S*{RImvpAW4uTf;d1*L4^*u=!gd=`-1#pumX@-V2wqY=@}*9loCIn
zDMb*aEJ)7JD@n}EQv;<Ia7n<#&nU#q!zjfl!^qAg#3;td!^qAEDGfnMC_X+VKRG@=
z2xLkS4+8@OI2^%&6(kKW20)nr?8yPh382WZ$<0qG%}KQb#Yr)!lw)J!Vd50!WaeZ6
E0NH$KK>z>%

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/idna/package_data.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/idna/package_data.py
new file mode 100644
index 0000000..257e898
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/idna/package_data.py
@@ -0,0 +1,2 @@
+__version__ = '2.8'
+
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/idna/package_data.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/idna/package_data.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..4d231f781c260f7f190f5e4a1664991a75c862f7
GIT binary patch
literal 229
zcmZSn%**AGdLky70SXuy7#JKF7#NDV7#J8*7#N}$7*ZG+f;E^xV$2K-3`Tkuei|TE
zCEN@Q4Ds=0sYS(^`FZj28Xyx8L~#KF1A~4+QD#|UNveKXVv&AYeojhiQL%nfihg-g
zQeLiUZn2SJl6iVnx`nAlc}`Z9nE?o-=jn&&7i1RbX66-_B<AGkx|Ml&8V7)cz&O4v
wH7_N<NIx?rFHyfBF*!RiJvBZhu_RHipt6L6fq}s$H$SB`C)Ez*$YPMA0Q-<RDF6Tf

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/idna/uts46data.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/idna/uts46data.py
new file mode 100644
index 0000000..a68ed4c
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/idna/uts46data.py
@@ -0,0 +1,8205 @@
+# This file is automatically generated by tools/idna-data
+# vim: set fileencoding=utf-8 :
+
+"""IDNA Mapping Table from UTS46."""
+
+
+__version__ = "11.0.0"
+def _seg_0():
+    return [
+    (0x0, '3'),
+    (0x1, '3'),
+    (0x2, '3'),
+    (0x3, '3'),
+    (0x4, '3'),
+    (0x5, '3'),
+    (0x6, '3'),
+    (0x7, '3'),
+    (0x8, '3'),
+    (0x9, '3'),
+    (0xA, '3'),
+    (0xB, '3'),
+    (0xC, '3'),
+    (0xD, '3'),
+    (0xE, '3'),
+    (0xF, '3'),
+    (0x10, '3'),
+    (0x11, '3'),
+    (0x12, '3'),
+    (0x13, '3'),
+    (0x14, '3'),
+    (0x15, '3'),
+    (0x16, '3'),
+    (0x17, '3'),
+    (0x18, '3'),
+    (0x19, '3'),
+    (0x1A, '3'),
+    (0x1B, '3'),
+    (0x1C, '3'),
+    (0x1D, '3'),
+    (0x1E, '3'),
+    (0x1F, '3'),
+    (0x20, '3'),
+    (0x21, '3'),
+    (0x22, '3'),
+    (0x23, '3'),
+    (0x24, '3'),
+    (0x25, '3'),
+    (0x26, '3'),
+    (0x27, '3'),
+    (0x28, '3'),
+    (0x29, '3'),
+    (0x2A, '3'),
+    (0x2B, '3'),
+    (0x2C, '3'),
+    (0x2D, 'V'),
+    (0x2E, 'V'),
+    (0x2F, '3'),
+    (0x30, 'V'),
+    (0x31, 'V'),
+    (0x32, 'V'),
+    (0x33, 'V'),
+    (0x34, 'V'),
+    (0x35, 'V'),
+    (0x36, 'V'),
+    (0x37, 'V'),
+    (0x38, 'V'),
+    (0x39, 'V'),
+    (0x3A, '3'),
+    (0x3B, '3'),
+    (0x3C, '3'),
+    (0x3D, '3'),
+    (0x3E, '3'),
+    (0x3F, '3'),
+    (0x40, '3'),
+    (0x41, 'M', u'a'),
+    (0x42, 'M', u'b'),
+    (0x43, 'M', u'c'),
+    (0x44, 'M', u'd'),
+    (0x45, 'M', u'e'),
+    (0x46, 'M', u'f'),
+    (0x47, 'M', u'g'),
+    (0x48, 'M', u'h'),
+    (0x49, 'M', u'i'),
+    (0x4A, 'M', u'j'),
+    (0x4B, 'M', u'k'),
+    (0x4C, 'M', u'l'),
+    (0x4D, 'M', u'm'),
+    (0x4E, 'M', u'n'),
+    (0x4F, 'M', u'o'),
+    (0x50, 'M', u'p'),
+    (0x51, 'M', u'q'),
+    (0x52, 'M', u'r'),
+    (0x53, 'M', u's'),
+    (0x54, 'M', u't'),
+    (0x55, 'M', u'u'),
+    (0x56, 'M', u'v'),
+    (0x57, 'M', u'w'),
+    (0x58, 'M', u'x'),
+    (0x59, 'M', u'y'),
+    (0x5A, 'M', u'z'),
+    (0x5B, '3'),
+    (0x5C, '3'),
+    (0x5D, '3'),
+    (0x5E, '3'),
+    (0x5F, '3'),
+    (0x60, '3'),
+    (0x61, 'V'),
+    (0x62, 'V'),
+    (0x63, 'V'),
+    ]
+
+def _seg_1():
+    return [
+    (0x64, 'V'),
+    (0x65, 'V'),
+    (0x66, 'V'),
+    (0x67, 'V'),
+    (0x68, 'V'),
+    (0x69, 'V'),
+    (0x6A, 'V'),
+    (0x6B, 'V'),
+    (0x6C, 'V'),
+    (0x6D, 'V'),
+    (0x6E, 'V'),
+    (0x6F, 'V'),
+    (0x70, 'V'),
+    (0x71, 'V'),
+    (0x72, 'V'),
+    (0x73, 'V'),
+    (0x74, 'V'),
+    (0x75, 'V'),
+    (0x76, 'V'),
+    (0x77, 'V'),
+    (0x78, 'V'),
+    (0x79, 'V'),
+    (0x7A, 'V'),
+    (0x7B, '3'),
+    (0x7C, '3'),
+    (0x7D, '3'),
+    (0x7E, '3'),
+    (0x7F, '3'),
+    (0x80, 'X'),
+    (0x81, 'X'),
+    (0x82, 'X'),
+    (0x83, 'X'),
+    (0x84, 'X'),
+    (0x85, 'X'),
+    (0x86, 'X'),
+    (0x87, 'X'),
+    (0x88, 'X'),
+    (0x89, 'X'),
+    (0x8A, 'X'),
+    (0x8B, 'X'),
+    (0x8C, 'X'),
+    (0x8D, 'X'),
+    (0x8E, 'X'),
+    (0x8F, 'X'),
+    (0x90, 'X'),
+    (0x91, 'X'),
+    (0x92, 'X'),
+    (0x93, 'X'),
+    (0x94, 'X'),
+    (0x95, 'X'),
+    (0x96, 'X'),
+    (0x97, 'X'),
+    (0x98, 'X'),
+    (0x99, 'X'),
+    (0x9A, 'X'),
+    (0x9B, 'X'),
+    (0x9C, 'X'),
+    (0x9D, 'X'),
+    (0x9E, 'X'),
+    (0x9F, 'X'),
+    (0xA0, '3', u' '),
+    (0xA1, 'V'),
+    (0xA2, 'V'),
+    (0xA3, 'V'),
+    (0xA4, 'V'),
+    (0xA5, 'V'),
+    (0xA6, 'V'),
+    (0xA7, 'V'),
+    (0xA8, '3', u' ̈'),
+    (0xA9, 'V'),
+    (0xAA, 'M', u'a'),
+    (0xAB, 'V'),
+    (0xAC, 'V'),
+    (0xAD, 'I'),
+    (0xAE, 'V'),
+    (0xAF, '3', u' ̄'),
+    (0xB0, 'V'),
+    (0xB1, 'V'),
+    (0xB2, 'M', u'2'),
+    (0xB3, 'M', u'3'),
+    (0xB4, '3', u' ́'),
+    (0xB5, 'M', u'μ'),
+    (0xB6, 'V'),
+    (0xB7, 'V'),
+    (0xB8, '3', u' ̧'),
+    (0xB9, 'M', u'1'),
+    (0xBA, 'M', u'o'),
+    (0xBB, 'V'),
+    (0xBC, 'M', u'1⁄4'),
+    (0xBD, 'M', u'1⁄2'),
+    (0xBE, 'M', u'3⁄4'),
+    (0xBF, 'V'),
+    (0xC0, 'M', u'à'),
+    (0xC1, 'M', u'á'),
+    (0xC2, 'M', u'â'),
+    (0xC3, 'M', u'ã'),
+    (0xC4, 'M', u'ä'),
+    (0xC5, 'M', u'å'),
+    (0xC6, 'M', u'æ'),
+    (0xC7, 'M', u'ç'),
+    ]
+
+def _seg_2():
+    return [
+    (0xC8, 'M', u'è'),
+    (0xC9, 'M', u'é'),
+    (0xCA, 'M', u'ê'),
+    (0xCB, 'M', u'ë'),
+    (0xCC, 'M', u'ì'),
+    (0xCD, 'M', u'í'),
+    (0xCE, 'M', u'î'),
+    (0xCF, 'M', u'ï'),
+    (0xD0, 'M', u'ð'),
+    (0xD1, 'M', u'ñ'),
+    (0xD2, 'M', u'ò'),
+    (0xD3, 'M', u'ó'),
+    (0xD4, 'M', u'ô'),
+    (0xD5, 'M', u'õ'),
+    (0xD6, 'M', u'ö'),
+    (0xD7, 'V'),
+    (0xD8, 'M', u'ø'),
+    (0xD9, 'M', u'ù'),
+    (0xDA, 'M', u'ú'),
+    (0xDB, 'M', u'û'),
+    (0xDC, 'M', u'ü'),
+    (0xDD, 'M', u'ý'),
+    (0xDE, 'M', u'þ'),
+    (0xDF, 'D', u'ss'),
+    (0xE0, 'V'),
+    (0xE1, 'V'),
+    (0xE2, 'V'),
+    (0xE3, 'V'),
+    (0xE4, 'V'),
+    (0xE5, 'V'),
+    (0xE6, 'V'),
+    (0xE7, 'V'),
+    (0xE8, 'V'),
+    (0xE9, 'V'),
+    (0xEA, 'V'),
+    (0xEB, 'V'),
+    (0xEC, 'V'),
+    (0xED, 'V'),
+    (0xEE, 'V'),
+    (0xEF, 'V'),
+    (0xF0, 'V'),
+    (0xF1, 'V'),
+    (0xF2, 'V'),
+    (0xF3, 'V'),
+    (0xF4, 'V'),
+    (0xF5, 'V'),
+    (0xF6, 'V'),
+    (0xF7, 'V'),
+    (0xF8, 'V'),
+    (0xF9, 'V'),
+    (0xFA, 'V'),
+    (0xFB, 'V'),
+    (0xFC, 'V'),
+    (0xFD, 'V'),
+    (0xFE, 'V'),
+    (0xFF, 'V'),
+    (0x100, 'M', u'ā'),
+    (0x101, 'V'),
+    (0x102, 'M', u'ă'),
+    (0x103, 'V'),
+    (0x104, 'M', u'ą'),
+    (0x105, 'V'),
+    (0x106, 'M', u'ć'),
+    (0x107, 'V'),
+    (0x108, 'M', u'ĉ'),
+    (0x109, 'V'),
+    (0x10A, 'M', u'ċ'),
+    (0x10B, 'V'),
+    (0x10C, 'M', u'č'),
+    (0x10D, 'V'),
+    (0x10E, 'M', u'ď'),
+    (0x10F, 'V'),
+    (0x110, 'M', u'đ'),
+    (0x111, 'V'),
+    (0x112, 'M', u'ē'),
+    (0x113, 'V'),
+    (0x114, 'M', u'ĕ'),
+    (0x115, 'V'),
+    (0x116, 'M', u'ė'),
+    (0x117, 'V'),
+    (0x118, 'M', u'ę'),
+    (0x119, 'V'),
+    (0x11A, 'M', u'ě'),
+    (0x11B, 'V'),
+    (0x11C, 'M', u'ĝ'),
+    (0x11D, 'V'),
+    (0x11E, 'M', u'ğ'),
+    (0x11F, 'V'),
+    (0x120, 'M', u'ġ'),
+    (0x121, 'V'),
+    (0x122, 'M', u'ģ'),
+    (0x123, 'V'),
+    (0x124, 'M', u'ĥ'),
+    (0x125, 'V'),
+    (0x126, 'M', u'ħ'),
+    (0x127, 'V'),
+    (0x128, 'M', u'ĩ'),
+    (0x129, 'V'),
+    (0x12A, 'M', u'ī'),
+    (0x12B, 'V'),
+    ]
+
+def _seg_3():
+    return [
+    (0x12C, 'M', u'ĭ'),
+    (0x12D, 'V'),
+    (0x12E, 'M', u'į'),
+    (0x12F, 'V'),
+    (0x130, 'M', u'i̇'),
+    (0x131, 'V'),
+    (0x132, 'M', u'ij'),
+    (0x134, 'M', u'ĵ'),
+    (0x135, 'V'),
+    (0x136, 'M', u'ķ'),
+    (0x137, 'V'),
+    (0x139, 'M', u'ĺ'),
+    (0x13A, 'V'),
+    (0x13B, 'M', u'ļ'),
+    (0x13C, 'V'),
+    (0x13D, 'M', u'ľ'),
+    (0x13E, 'V'),
+    (0x13F, 'M', u'l·'),
+    (0x141, 'M', u'ł'),
+    (0x142, 'V'),
+    (0x143, 'M', u'ń'),
+    (0x144, 'V'),
+    (0x145, 'M', u'ņ'),
+    (0x146, 'V'),
+    (0x147, 'M', u'ň'),
+    (0x148, 'V'),
+    (0x149, 'M', u'ʼn'),
+    (0x14A, 'M', u'ŋ'),
+    (0x14B, 'V'),
+    (0x14C, 'M', u'ō'),
+    (0x14D, 'V'),
+    (0x14E, 'M', u'ŏ'),
+    (0x14F, 'V'),
+    (0x150, 'M', u'ő'),
+    (0x151, 'V'),
+    (0x152, 'M', u'œ'),
+    (0x153, 'V'),
+    (0x154, 'M', u'ŕ'),
+    (0x155, 'V'),
+    (0x156, 'M', u'ŗ'),
+    (0x157, 'V'),
+    (0x158, 'M', u'ř'),
+    (0x159, 'V'),
+    (0x15A, 'M', u'ś'),
+    (0x15B, 'V'),
+    (0x15C, 'M', u'ŝ'),
+    (0x15D, 'V'),
+    (0x15E, 'M', u'ş'),
+    (0x15F, 'V'),
+    (0x160, 'M', u'š'),
+    (0x161, 'V'),
+    (0x162, 'M', u'ţ'),
+    (0x163, 'V'),
+    (0x164, 'M', u'ť'),
+    (0x165, 'V'),
+    (0x166, 'M', u'ŧ'),
+    (0x167, 'V'),
+    (0x168, 'M', u'ũ'),
+    (0x169, 'V'),
+    (0x16A, 'M', u'ū'),
+    (0x16B, 'V'),
+    (0x16C, 'M', u'ŭ'),
+    (0x16D, 'V'),
+    (0x16E, 'M', u'ů'),
+    (0x16F, 'V'),
+    (0x170, 'M', u'ű'),
+    (0x171, 'V'),
+    (0x172, 'M', u'ų'),
+    (0x173, 'V'),
+    (0x174, 'M', u'ŵ'),
+    (0x175, 'V'),
+    (0x176, 'M', u'ŷ'),
+    (0x177, 'V'),
+    (0x178, 'M', u'ÿ'),
+    (0x179, 'M', u'ź'),
+    (0x17A, 'V'),
+    (0x17B, 'M', u'ż'),
+    (0x17C, 'V'),
+    (0x17D, 'M', u'ž'),
+    (0x17E, 'V'),
+    (0x17F, 'M', u's'),
+    (0x180, 'V'),
+    (0x181, 'M', u'ɓ'),
+    (0x182, 'M', u'ƃ'),
+    (0x183, 'V'),
+    (0x184, 'M', u'ƅ'),
+    (0x185, 'V'),
+    (0x186, 'M', u'ɔ'),
+    (0x187, 'M', u'ƈ'),
+    (0x188, 'V'),
+    (0x189, 'M', u'ɖ'),
+    (0x18A, 'M', u'ɗ'),
+    (0x18B, 'M', u'ƌ'),
+    (0x18C, 'V'),
+    (0x18E, 'M', u'ǝ'),
+    (0x18F, 'M', u'ə'),
+    (0x190, 'M', u'ɛ'),
+    (0x191, 'M', u'ƒ'),
+    (0x192, 'V'),
+    (0x193, 'M', u'ɠ'),
+    ]
+
+def _seg_4():
+    return [
+    (0x194, 'M', u'ɣ'),
+    (0x195, 'V'),
+    (0x196, 'M', u'ɩ'),
+    (0x197, 'M', u'ɨ'),
+    (0x198, 'M', u'ƙ'),
+    (0x199, 'V'),
+    (0x19C, 'M', u'ɯ'),
+    (0x19D, 'M', u'ɲ'),
+    (0x19E, 'V'),
+    (0x19F, 'M', u'ɵ'),
+    (0x1A0, 'M', u'ơ'),
+    (0x1A1, 'V'),
+    (0x1A2, 'M', u'ƣ'),
+    (0x1A3, 'V'),
+    (0x1A4, 'M', u'ƥ'),
+    (0x1A5, 'V'),
+    (0x1A6, 'M', u'ʀ'),
+    (0x1A7, 'M', u'ƨ'),
+    (0x1A8, 'V'),
+    (0x1A9, 'M', u'ʃ'),
+    (0x1AA, 'V'),
+    (0x1AC, 'M', u'ƭ'),
+    (0x1AD, 'V'),
+    (0x1AE, 'M', u'ʈ'),
+    (0x1AF, 'M', u'ư'),
+    (0x1B0, 'V'),
+    (0x1B1, 'M', u'ʊ'),
+    (0x1B2, 'M', u'ʋ'),
+    (0x1B3, 'M', u'ƴ'),
+    (0x1B4, 'V'),
+    (0x1B5, 'M', u'ƶ'),
+    (0x1B6, 'V'),
+    (0x1B7, 'M', u'ʒ'),
+    (0x1B8, 'M', u'ƹ'),
+    (0x1B9, 'V'),
+    (0x1BC, 'M', u'ƽ'),
+    (0x1BD, 'V'),
+    (0x1C4, 'M', u'dž'),
+    (0x1C7, 'M', u'lj'),
+    (0x1CA, 'M', u'nj'),
+    (0x1CD, 'M', u'ǎ'),
+    (0x1CE, 'V'),
+    (0x1CF, 'M', u'ǐ'),
+    (0x1D0, 'V'),
+    (0x1D1, 'M', u'ǒ'),
+    (0x1D2, 'V'),
+    (0x1D3, 'M', u'ǔ'),
+    (0x1D4, 'V'),
+    (0x1D5, 'M', u'ǖ'),
+    (0x1D6, 'V'),
+    (0x1D7, 'M', u'ǘ'),
+    (0x1D8, 'V'),
+    (0x1D9, 'M', u'ǚ'),
+    (0x1DA, 'V'),
+    (0x1DB, 'M', u'ǜ'),
+    (0x1DC, 'V'),
+    (0x1DE, 'M', u'ǟ'),
+    (0x1DF, 'V'),
+    (0x1E0, 'M', u'ǡ'),
+    (0x1E1, 'V'),
+    (0x1E2, 'M', u'ǣ'),
+    (0x1E3, 'V'),
+    (0x1E4, 'M', u'ǥ'),
+    (0x1E5, 'V'),
+    (0x1E6, 'M', u'ǧ'),
+    (0x1E7, 'V'),
+    (0x1E8, 'M', u'ǩ'),
+    (0x1E9, 'V'),
+    (0x1EA, 'M', u'ǫ'),
+    (0x1EB, 'V'),
+    (0x1EC, 'M', u'ǭ'),
+    (0x1ED, 'V'),
+    (0x1EE, 'M', u'ǯ'),
+    (0x1EF, 'V'),
+    (0x1F1, 'M', u'dz'),
+    (0x1F4, 'M', u'ǵ'),
+    (0x1F5, 'V'),
+    (0x1F6, 'M', u'ƕ'),
+    (0x1F7, 'M', u'ƿ'),
+    (0x1F8, 'M', u'ǹ'),
+    (0x1F9, 'V'),
+    (0x1FA, 'M', u'ǻ'),
+    (0x1FB, 'V'),
+    (0x1FC, 'M', u'ǽ'),
+    (0x1FD, 'V'),
+    (0x1FE, 'M', u'ǿ'),
+    (0x1FF, 'V'),
+    (0x200, 'M', u'ȁ'),
+    (0x201, 'V'),
+    (0x202, 'M', u'ȃ'),
+    (0x203, 'V'),
+    (0x204, 'M', u'ȅ'),
+    (0x205, 'V'),
+    (0x206, 'M', u'ȇ'),
+    (0x207, 'V'),
+    (0x208, 'M', u'ȉ'),
+    (0x209, 'V'),
+    (0x20A, 'M', u'ȋ'),
+    (0x20B, 'V'),
+    (0x20C, 'M', u'ȍ'),
+    ]
+
+def _seg_5():
+    return [
+    (0x20D, 'V'),
+    (0x20E, 'M', u'ȏ'),
+    (0x20F, 'V'),
+    (0x210, 'M', u'ȑ'),
+    (0x211, 'V'),
+    (0x212, 'M', u'ȓ'),
+    (0x213, 'V'),
+    (0x214, 'M', u'ȕ'),
+    (0x215, 'V'),
+    (0x216, 'M', u'ȗ'),
+    (0x217, 'V'),
+    (0x218, 'M', u'ș'),
+    (0x219, 'V'),
+    (0x21A, 'M', u'ț'),
+    (0x21B, 'V'),
+    (0x21C, 'M', u'ȝ'),
+    (0x21D, 'V'),
+    (0x21E, 'M', u'ȟ'),
+    (0x21F, 'V'),
+    (0x220, 'M', u'ƞ'),
+    (0x221, 'V'),
+    (0x222, 'M', u'ȣ'),
+    (0x223, 'V'),
+    (0x224, 'M', u'ȥ'),
+    (0x225, 'V'),
+    (0x226, 'M', u'ȧ'),
+    (0x227, 'V'),
+    (0x228, 'M', u'ȩ'),
+    (0x229, 'V'),
+    (0x22A, 'M', u'ȫ'),
+    (0x22B, 'V'),
+    (0x22C, 'M', u'ȭ'),
+    (0x22D, 'V'),
+    (0x22E, 'M', u'ȯ'),
+    (0x22F, 'V'),
+    (0x230, 'M', u'ȱ'),
+    (0x231, 'V'),
+    (0x232, 'M', u'ȳ'),
+    (0x233, 'V'),
+    (0x23A, 'M', u'ⱥ'),
+    (0x23B, 'M', u'ȼ'),
+    (0x23C, 'V'),
+    (0x23D, 'M', u'ƚ'),
+    (0x23E, 'M', u'ⱦ'),
+    (0x23F, 'V'),
+    (0x241, 'M', u'ɂ'),
+    (0x242, 'V'),
+    (0x243, 'M', u'ƀ'),
+    (0x244, 'M', u'ʉ'),
+    (0x245, 'M', u'ʌ'),
+    (0x246, 'M', u'ɇ'),
+    (0x247, 'V'),
+    (0x248, 'M', u'ɉ'),
+    (0x249, 'V'),
+    (0x24A, 'M', u'ɋ'),
+    (0x24B, 'V'),
+    (0x24C, 'M', u'ɍ'),
+    (0x24D, 'V'),
+    (0x24E, 'M', u'ɏ'),
+    (0x24F, 'V'),
+    (0x2B0, 'M', u'h'),
+    (0x2B1, 'M', u'ɦ'),
+    (0x2B2, 'M', u'j'),
+    (0x2B3, 'M', u'r'),
+    (0x2B4, 'M', u'ɹ'),
+    (0x2B5, 'M', u'ɻ'),
+    (0x2B6, 'M', u'ʁ'),
+    (0x2B7, 'M', u'w'),
+    (0x2B8, 'M', u'y'),
+    (0x2B9, 'V'),
+    (0x2D8, '3', u' ̆'),
+    (0x2D9, '3', u' ̇'),
+    (0x2DA, '3', u' ̊'),
+    (0x2DB, '3', u' ̨'),
+    (0x2DC, '3', u' ̃'),
+    (0x2DD, '3', u' ̋'),
+    (0x2DE, 'V'),
+    (0x2E0, 'M', u'ɣ'),
+    (0x2E1, 'M', u'l'),
+    (0x2E2, 'M', u's'),
+    (0x2E3, 'M', u'x'),
+    (0x2E4, 'M', u'ʕ'),
+    (0x2E5, 'V'),
+    (0x340, 'M', u'̀'),
+    (0x341, 'M', u'́'),
+    (0x342, 'V'),
+    (0x343, 'M', u'̓'),
+    (0x344, 'M', u'̈́'),
+    (0x345, 'M', u'ι'),
+    (0x346, 'V'),
+    (0x34F, 'I'),
+    (0x350, 'V'),
+    (0x370, 'M', u'ͱ'),
+    (0x371, 'V'),
+    (0x372, 'M', u'ͳ'),
+    (0x373, 'V'),
+    (0x374, 'M', u'ʹ'),
+    (0x375, 'V'),
+    (0x376, 'M', u'ͷ'),
+    (0x377, 'V'),
+    ]
+
+def _seg_6():
+    return [
+    (0x378, 'X'),
+    (0x37A, '3', u' ι'),
+    (0x37B, 'V'),
+    (0x37E, '3', u';'),
+    (0x37F, 'M', u'ϳ'),
+    (0x380, 'X'),
+    (0x384, '3', u' ́'),
+    (0x385, '3', u' ̈́'),
+    (0x386, 'M', u'ά'),
+    (0x387, 'M', u'·'),
+    (0x388, 'M', u'έ'),
+    (0x389, 'M', u'ή'),
+    (0x38A, 'M', u'ί'),
+    (0x38B, 'X'),
+    (0x38C, 'M', u'ό'),
+    (0x38D, 'X'),
+    (0x38E, 'M', u'ύ'),
+    (0x38F, 'M', u'ώ'),
+    (0x390, 'V'),
+    (0x391, 'M', u'α'),
+    (0x392, 'M', u'β'),
+    (0x393, 'M', u'γ'),
+    (0x394, 'M', u'δ'),
+    (0x395, 'M', u'ε'),
+    (0x396, 'M', u'ζ'),
+    (0x397, 'M', u'η'),
+    (0x398, 'M', u'θ'),
+    (0x399, 'M', u'ι'),
+    (0x39A, 'M', u'κ'),
+    (0x39B, 'M', u'λ'),
+    (0x39C, 'M', u'μ'),
+    (0x39D, 'M', u'ν'),
+    (0x39E, 'M', u'ξ'),
+    (0x39F, 'M', u'ο'),
+    (0x3A0, 'M', u'π'),
+    (0x3A1, 'M', u'ρ'),
+    (0x3A2, 'X'),
+    (0x3A3, 'M', u'σ'),
+    (0x3A4, 'M', u'τ'),
+    (0x3A5, 'M', u'υ'),
+    (0x3A6, 'M', u'φ'),
+    (0x3A7, 'M', u'χ'),
+    (0x3A8, 'M', u'ψ'),
+    (0x3A9, 'M', u'ω'),
+    (0x3AA, 'M', u'ϊ'),
+    (0x3AB, 'M', u'ϋ'),
+    (0x3AC, 'V'),
+    (0x3C2, 'D', u'σ'),
+    (0x3C3, 'V'),
+    (0x3CF, 'M', u'ϗ'),
+    (0x3D0, 'M', u'β'),
+    (0x3D1, 'M', u'θ'),
+    (0x3D2, 'M', u'υ'),
+    (0x3D3, 'M', u'ύ'),
+    (0x3D4, 'M', u'ϋ'),
+    (0x3D5, 'M', u'φ'),
+    (0x3D6, 'M', u'π'),
+    (0x3D7, 'V'),
+    (0x3D8, 'M', u'ϙ'),
+    (0x3D9, 'V'),
+    (0x3DA, 'M', u'ϛ'),
+    (0x3DB, 'V'),
+    (0x3DC, 'M', u'ϝ'),
+    (0x3DD, 'V'),
+    (0x3DE, 'M', u'ϟ'),
+    (0x3DF, 'V'),
+    (0x3E0, 'M', u'ϡ'),
+    (0x3E1, 'V'),
+    (0x3E2, 'M', u'ϣ'),
+    (0x3E3, 'V'),
+    (0x3E4, 'M', u'ϥ'),
+    (0x3E5, 'V'),
+    (0x3E6, 'M', u'ϧ'),
+    (0x3E7, 'V'),
+    (0x3E8, 'M', u'ϩ'),
+    (0x3E9, 'V'),
+    (0x3EA, 'M', u'ϫ'),
+    (0x3EB, 'V'),
+    (0x3EC, 'M', u'ϭ'),
+    (0x3ED, 'V'),
+    (0x3EE, 'M', u'ϯ'),
+    (0x3EF, 'V'),
+    (0x3F0, 'M', u'κ'),
+    (0x3F1, 'M', u'ρ'),
+    (0x3F2, 'M', u'σ'),
+    (0x3F3, 'V'),
+    (0x3F4, 'M', u'θ'),
+    (0x3F5, 'M', u'ε'),
+    (0x3F6, 'V'),
+    (0x3F7, 'M', u'ϸ'),
+    (0x3F8, 'V'),
+    (0x3F9, 'M', u'σ'),
+    (0x3FA, 'M', u'ϻ'),
+    (0x3FB, 'V'),
+    (0x3FD, 'M', u'ͻ'),
+    (0x3FE, 'M', u'ͼ'),
+    (0x3FF, 'M', u'ͽ'),
+    (0x400, 'M', u'ѐ'),
+    (0x401, 'M', u'ё'),
+    (0x402, 'M', u'ђ'),
+    ]
+
+def _seg_7():
+    return [
+    (0x403, 'M', u'ѓ'),
+    (0x404, 'M', u'є'),
+    (0x405, 'M', u'ѕ'),
+    (0x406, 'M', u'і'),
+    (0x407, 'M', u'ї'),
+    (0x408, 'M', u'ј'),
+    (0x409, 'M', u'љ'),
+    (0x40A, 'M', u'њ'),
+    (0x40B, 'M', u'ћ'),
+    (0x40C, 'M', u'ќ'),
+    (0x40D, 'M', u'ѝ'),
+    (0x40E, 'M', u'ў'),
+    (0x40F, 'M', u'џ'),
+    (0x410, 'M', u'а'),
+    (0x411, 'M', u'б'),
+    (0x412, 'M', u'в'),
+    (0x413, 'M', u'г'),
+    (0x414, 'M', u'д'),
+    (0x415, 'M', u'е'),
+    (0x416, 'M', u'ж'),
+    (0x417, 'M', u'з'),
+    (0x418, 'M', u'и'),
+    (0x419, 'M', u'й'),
+    (0x41A, 'M', u'к'),
+    (0x41B, 'M', u'л'),
+    (0x41C, 'M', u'м'),
+    (0x41D, 'M', u'н'),
+    (0x41E, 'M', u'о'),
+    (0x41F, 'M', u'п'),
+    (0x420, 'M', u'р'),
+    (0x421, 'M', u'с'),
+    (0x422, 'M', u'т'),
+    (0x423, 'M', u'у'),
+    (0x424, 'M', u'ф'),
+    (0x425, 'M', u'х'),
+    (0x426, 'M', u'ц'),
+    (0x427, 'M', u'ч'),
+    (0x428, 'M', u'ш'),
+    (0x429, 'M', u'щ'),
+    (0x42A, 'M', u'ъ'),
+    (0x42B, 'M', u'ы'),
+    (0x42C, 'M', u'ь'),
+    (0x42D, 'M', u'э'),
+    (0x42E, 'M', u'ю'),
+    (0x42F, 'M', u'я'),
+    (0x430, 'V'),
+    (0x460, 'M', u'ѡ'),
+    (0x461, 'V'),
+    (0x462, 'M', u'ѣ'),
+    (0x463, 'V'),
+    (0x464, 'M', u'ѥ'),
+    (0x465, 'V'),
+    (0x466, 'M', u'ѧ'),
+    (0x467, 'V'),
+    (0x468, 'M', u'ѩ'),
+    (0x469, 'V'),
+    (0x46A, 'M', u'ѫ'),
+    (0x46B, 'V'),
+    (0x46C, 'M', u'ѭ'),
+    (0x46D, 'V'),
+    (0x46E, 'M', u'ѯ'),
+    (0x46F, 'V'),
+    (0x470, 'M', u'ѱ'),
+    (0x471, 'V'),
+    (0x472, 'M', u'ѳ'),
+    (0x473, 'V'),
+    (0x474, 'M', u'ѵ'),
+    (0x475, 'V'),
+    (0x476, 'M', u'ѷ'),
+    (0x477, 'V'),
+    (0x478, 'M', u'ѹ'),
+    (0x479, 'V'),
+    (0x47A, 'M', u'ѻ'),
+    (0x47B, 'V'),
+    (0x47C, 'M', u'ѽ'),
+    (0x47D, 'V'),
+    (0x47E, 'M', u'ѿ'),
+    (0x47F, 'V'),
+    (0x480, 'M', u'ҁ'),
+    (0x481, 'V'),
+    (0x48A, 'M', u'ҋ'),
+    (0x48B, 'V'),
+    (0x48C, 'M', u'ҍ'),
+    (0x48D, 'V'),
+    (0x48E, 'M', u'ҏ'),
+    (0x48F, 'V'),
+    (0x490, 'M', u'ґ'),
+    (0x491, 'V'),
+    (0x492, 'M', u'ғ'),
+    (0x493, 'V'),
+    (0x494, 'M', u'ҕ'),
+    (0x495, 'V'),
+    (0x496, 'M', u'җ'),
+    (0x497, 'V'),
+    (0x498, 'M', u'ҙ'),
+    (0x499, 'V'),
+    (0x49A, 'M', u'қ'),
+    (0x49B, 'V'),
+    (0x49C, 'M', u'ҝ'),
+    (0x49D, 'V'),
+    ]
+
+def _seg_8():
+    return [
+    (0x49E, 'M', u'ҟ'),
+    (0x49F, 'V'),
+    (0x4A0, 'M', u'ҡ'),
+    (0x4A1, 'V'),
+    (0x4A2, 'M', u'ң'),
+    (0x4A3, 'V'),
+    (0x4A4, 'M', u'ҥ'),
+    (0x4A5, 'V'),
+    (0x4A6, 'M', u'ҧ'),
+    (0x4A7, 'V'),
+    (0x4A8, 'M', u'ҩ'),
+    (0x4A9, 'V'),
+    (0x4AA, 'M', u'ҫ'),
+    (0x4AB, 'V'),
+    (0x4AC, 'M', u'ҭ'),
+    (0x4AD, 'V'),
+    (0x4AE, 'M', u'ү'),
+    (0x4AF, 'V'),
+    (0x4B0, 'M', u'ұ'),
+    (0x4B1, 'V'),
+    (0x4B2, 'M', u'ҳ'),
+    (0x4B3, 'V'),
+    (0x4B4, 'M', u'ҵ'),
+    (0x4B5, 'V'),
+    (0x4B6, 'M', u'ҷ'),
+    (0x4B7, 'V'),
+    (0x4B8, 'M', u'ҹ'),
+    (0x4B9, 'V'),
+    (0x4BA, 'M', u'һ'),
+    (0x4BB, 'V'),
+    (0x4BC, 'M', u'ҽ'),
+    (0x4BD, 'V'),
+    (0x4BE, 'M', u'ҿ'),
+    (0x4BF, 'V'),
+    (0x4C0, 'X'),
+    (0x4C1, 'M', u'ӂ'),
+    (0x4C2, 'V'),
+    (0x4C3, 'M', u'ӄ'),
+    (0x4C4, 'V'),
+    (0x4C5, 'M', u'ӆ'),
+    (0x4C6, 'V'),
+    (0x4C7, 'M', u'ӈ'),
+    (0x4C8, 'V'),
+    (0x4C9, 'M', u'ӊ'),
+    (0x4CA, 'V'),
+    (0x4CB, 'M', u'ӌ'),
+    (0x4CC, 'V'),
+    (0x4CD, 'M', u'ӎ'),
+    (0x4CE, 'V'),
+    (0x4D0, 'M', u'ӑ'),
+    (0x4D1, 'V'),
+    (0x4D2, 'M', u'ӓ'),
+    (0x4D3, 'V'),
+    (0x4D4, 'M', u'ӕ'),
+    (0x4D5, 'V'),
+    (0x4D6, 'M', u'ӗ'),
+    (0x4D7, 'V'),
+    (0x4D8, 'M', u'ә'),
+    (0x4D9, 'V'),
+    (0x4DA, 'M', u'ӛ'),
+    (0x4DB, 'V'),
+    (0x4DC, 'M', u'ӝ'),
+    (0x4DD, 'V'),
+    (0x4DE, 'M', u'ӟ'),
+    (0x4DF, 'V'),
+    (0x4E0, 'M', u'ӡ'),
+    (0x4E1, 'V'),
+    (0x4E2, 'M', u'ӣ'),
+    (0x4E3, 'V'),
+    (0x4E4, 'M', u'ӥ'),
+    (0x4E5, 'V'),
+    (0x4E6, 'M', u'ӧ'),
+    (0x4E7, 'V'),
+    (0x4E8, 'M', u'ө'),
+    (0x4E9, 'V'),
+    (0x4EA, 'M', u'ӫ'),
+    (0x4EB, 'V'),
+    (0x4EC, 'M', u'ӭ'),
+    (0x4ED, 'V'),
+    (0x4EE, 'M', u'ӯ'),
+    (0x4EF, 'V'),
+    (0x4F0, 'M', u'ӱ'),
+    (0x4F1, 'V'),
+    (0x4F2, 'M', u'ӳ'),
+    (0x4F3, 'V'),
+    (0x4F4, 'M', u'ӵ'),
+    (0x4F5, 'V'),
+    (0x4F6, 'M', u'ӷ'),
+    (0x4F7, 'V'),
+    (0x4F8, 'M', u'ӹ'),
+    (0x4F9, 'V'),
+    (0x4FA, 'M', u'ӻ'),
+    (0x4FB, 'V'),
+    (0x4FC, 'M', u'ӽ'),
+    (0x4FD, 'V'),
+    (0x4FE, 'M', u'ӿ'),
+    (0x4FF, 'V'),
+    (0x500, 'M', u'ԁ'),
+    (0x501, 'V'),
+    (0x502, 'M', u'ԃ'),
+    ]
+
+def _seg_9():
+    return [
+    (0x503, 'V'),
+    (0x504, 'M', u'ԅ'),
+    (0x505, 'V'),
+    (0x506, 'M', u'ԇ'),
+    (0x507, 'V'),
+    (0x508, 'M', u'ԉ'),
+    (0x509, 'V'),
+    (0x50A, 'M', u'ԋ'),
+    (0x50B, 'V'),
+    (0x50C, 'M', u'ԍ'),
+    (0x50D, 'V'),
+    (0x50E, 'M', u'ԏ'),
+    (0x50F, 'V'),
+    (0x510, 'M', u'ԑ'),
+    (0x511, 'V'),
+    (0x512, 'M', u'ԓ'),
+    (0x513, 'V'),
+    (0x514, 'M', u'ԕ'),
+    (0x515, 'V'),
+    (0x516, 'M', u'ԗ'),
+    (0x517, 'V'),
+    (0x518, 'M', u'ԙ'),
+    (0x519, 'V'),
+    (0x51A, 'M', u'ԛ'),
+    (0x51B, 'V'),
+    (0x51C, 'M', u'ԝ'),
+    (0x51D, 'V'),
+    (0x51E, 'M', u'ԟ'),
+    (0x51F, 'V'),
+    (0x520, 'M', u'ԡ'),
+    (0x521, 'V'),
+    (0x522, 'M', u'ԣ'),
+    (0x523, 'V'),
+    (0x524, 'M', u'ԥ'),
+    (0x525, 'V'),
+    (0x526, 'M', u'ԧ'),
+    (0x527, 'V'),
+    (0x528, 'M', u'ԩ'),
+    (0x529, 'V'),
+    (0x52A, 'M', u'ԫ'),
+    (0x52B, 'V'),
+    (0x52C, 'M', u'ԭ'),
+    (0x52D, 'V'),
+    (0x52E, 'M', u'ԯ'),
+    (0x52F, 'V'),
+    (0x530, 'X'),
+    (0x531, 'M', u'ա'),
+    (0x532, 'M', u'բ'),
+    (0x533, 'M', u'գ'),
+    (0x534, 'M', u'դ'),
+    (0x535, 'M', u'ե'),
+    (0x536, 'M', u'զ'),
+    (0x537, 'M', u'է'),
+    (0x538, 'M', u'ը'),
+    (0x539, 'M', u'թ'),
+    (0x53A, 'M', u'ժ'),
+    (0x53B, 'M', u'ի'),
+    (0x53C, 'M', u'լ'),
+    (0x53D, 'M', u'խ'),
+    (0x53E, 'M', u'ծ'),
+    (0x53F, 'M', u'կ'),
+    (0x540, 'M', u'հ'),
+    (0x541, 'M', u'ձ'),
+    (0x542, 'M', u'ղ'),
+    (0x543, 'M', u'ճ'),
+    (0x544, 'M', u'մ'),
+    (0x545, 'M', u'յ'),
+    (0x546, 'M', u'ն'),
+    (0x547, 'M', u'շ'),
+    (0x548, 'M', u'ո'),
+    (0x549, 'M', u'չ'),
+    (0x54A, 'M', u'պ'),
+    (0x54B, 'M', u'ջ'),
+    (0x54C, 'M', u'ռ'),
+    (0x54D, 'M', u'ս'),
+    (0x54E, 'M', u'վ'),
+    (0x54F, 'M', u'տ'),
+    (0x550, 'M', u'ր'),
+    (0x551, 'M', u'ց'),
+    (0x552, 'M', u'ւ'),
+    (0x553, 'M', u'փ'),
+    (0x554, 'M', u'ք'),
+    (0x555, 'M', u'օ'),
+    (0x556, 'M', u'ֆ'),
+    (0x557, 'X'),
+    (0x559, 'V'),
+    (0x587, 'M', u'եւ'),
+    (0x588, 'V'),
+    (0x58B, 'X'),
+    (0x58D, 'V'),
+    (0x590, 'X'),
+    (0x591, 'V'),
+    (0x5C8, 'X'),
+    (0x5D0, 'V'),
+    (0x5EB, 'X'),
+    (0x5EF, 'V'),
+    (0x5F5, 'X'),
+    (0x606, 'V'),
+    (0x61C, 'X'),
+    (0x61E, 'V'),
+    ]
+
+def _seg_10():
+    return [
+    (0x675, 'M', u'اٴ'),
+    (0x676, 'M', u'وٴ'),
+    (0x677, 'M', u'ۇٴ'),
+    (0x678, 'M', u'يٴ'),
+    (0x679, 'V'),
+    (0x6DD, 'X'),
+    (0x6DE, 'V'),
+    (0x70E, 'X'),
+    (0x710, 'V'),
+    (0x74B, 'X'),
+    (0x74D, 'V'),
+    (0x7B2, 'X'),
+    (0x7C0, 'V'),
+    (0x7FB, 'X'),
+    (0x7FD, 'V'),
+    (0x82E, 'X'),
+    (0x830, 'V'),
+    (0x83F, 'X'),
+    (0x840, 'V'),
+    (0x85C, 'X'),
+    (0x85E, 'V'),
+    (0x85F, 'X'),
+    (0x860, 'V'),
+    (0x86B, 'X'),
+    (0x8A0, 'V'),
+    (0x8B5, 'X'),
+    (0x8B6, 'V'),
+    (0x8BE, 'X'),
+    (0x8D3, 'V'),
+    (0x8E2, 'X'),
+    (0x8E3, 'V'),
+    (0x958, 'M', u'क़'),
+    (0x959, 'M', u'ख़'),
+    (0x95A, 'M', u'ग़'),
+    (0x95B, 'M', u'ज़'),
+    (0x95C, 'M', u'ड़'),
+    (0x95D, 'M', u'ढ़'),
+    (0x95E, 'M', u'फ़'),
+    (0x95F, 'M', u'य़'),
+    (0x960, 'V'),
+    (0x984, 'X'),
+    (0x985, 'V'),
+    (0x98D, 'X'),
+    (0x98F, 'V'),
+    (0x991, 'X'),
+    (0x993, 'V'),
+    (0x9A9, 'X'),
+    (0x9AA, 'V'),
+    (0x9B1, 'X'),
+    (0x9B2, 'V'),
+    (0x9B3, 'X'),
+    (0x9B6, 'V'),
+    (0x9BA, 'X'),
+    (0x9BC, 'V'),
+    (0x9C5, 'X'),
+    (0x9C7, 'V'),
+    (0x9C9, 'X'),
+    (0x9CB, 'V'),
+    (0x9CF, 'X'),
+    (0x9D7, 'V'),
+    (0x9D8, 'X'),
+    (0x9DC, 'M', u'ড়'),
+    (0x9DD, 'M', u'ঢ়'),
+    (0x9DE, 'X'),
+    (0x9DF, 'M', u'য়'),
+    (0x9E0, 'V'),
+    (0x9E4, 'X'),
+    (0x9E6, 'V'),
+    (0x9FF, 'X'),
+    (0xA01, 'V'),
+    (0xA04, 'X'),
+    (0xA05, 'V'),
+    (0xA0B, 'X'),
+    (0xA0F, 'V'),
+    (0xA11, 'X'),
+    (0xA13, 'V'),
+    (0xA29, 'X'),
+    (0xA2A, 'V'),
+    (0xA31, 'X'),
+    (0xA32, 'V'),
+    (0xA33, 'M', u'ਲ਼'),
+    (0xA34, 'X'),
+    (0xA35, 'V'),
+    (0xA36, 'M', u'ਸ਼'),
+    (0xA37, 'X'),
+    (0xA38, 'V'),
+    (0xA3A, 'X'),
+    (0xA3C, 'V'),
+    (0xA3D, 'X'),
+    (0xA3E, 'V'),
+    (0xA43, 'X'),
+    (0xA47, 'V'),
+    (0xA49, 'X'),
+    (0xA4B, 'V'),
+    (0xA4E, 'X'),
+    (0xA51, 'V'),
+    (0xA52, 'X'),
+    (0xA59, 'M', u'ਖ਼'),
+    (0xA5A, 'M', u'ਗ਼'),
+    (0xA5B, 'M', u'ਜ਼'),
+    ]
+
+def _seg_11():
+    return [
+    (0xA5C, 'V'),
+    (0xA5D, 'X'),
+    (0xA5E, 'M', u'ਫ਼'),
+    (0xA5F, 'X'),
+    (0xA66, 'V'),
+    (0xA77, 'X'),
+    (0xA81, 'V'),
+    (0xA84, 'X'),
+    (0xA85, 'V'),
+    (0xA8E, 'X'),
+    (0xA8F, 'V'),
+    (0xA92, 'X'),
+    (0xA93, 'V'),
+    (0xAA9, 'X'),
+    (0xAAA, 'V'),
+    (0xAB1, 'X'),
+    (0xAB2, 'V'),
+    (0xAB4, 'X'),
+    (0xAB5, 'V'),
+    (0xABA, 'X'),
+    (0xABC, 'V'),
+    (0xAC6, 'X'),
+    (0xAC7, 'V'),
+    (0xACA, 'X'),
+    (0xACB, 'V'),
+    (0xACE, 'X'),
+    (0xAD0, 'V'),
+    (0xAD1, 'X'),
+    (0xAE0, 'V'),
+    (0xAE4, 'X'),
+    (0xAE6, 'V'),
+    (0xAF2, 'X'),
+    (0xAF9, 'V'),
+    (0xB00, 'X'),
+    (0xB01, 'V'),
+    (0xB04, 'X'),
+    (0xB05, 'V'),
+    (0xB0D, 'X'),
+    (0xB0F, 'V'),
+    (0xB11, 'X'),
+    (0xB13, 'V'),
+    (0xB29, 'X'),
+    (0xB2A, 'V'),
+    (0xB31, 'X'),
+    (0xB32, 'V'),
+    (0xB34, 'X'),
+    (0xB35, 'V'),
+    (0xB3A, 'X'),
+    (0xB3C, 'V'),
+    (0xB45, 'X'),
+    (0xB47, 'V'),
+    (0xB49, 'X'),
+    (0xB4B, 'V'),
+    (0xB4E, 'X'),
+    (0xB56, 'V'),
+    (0xB58, 'X'),
+    (0xB5C, 'M', u'ଡ଼'),
+    (0xB5D, 'M', u'ଢ଼'),
+    (0xB5E, 'X'),
+    (0xB5F, 'V'),
+    (0xB64, 'X'),
+    (0xB66, 'V'),
+    (0xB78, 'X'),
+    (0xB82, 'V'),
+    (0xB84, 'X'),
+    (0xB85, 'V'),
+    (0xB8B, 'X'),
+    (0xB8E, 'V'),
+    (0xB91, 'X'),
+    (0xB92, 'V'),
+    (0xB96, 'X'),
+    (0xB99, 'V'),
+    (0xB9B, 'X'),
+    (0xB9C, 'V'),
+    (0xB9D, 'X'),
+    (0xB9E, 'V'),
+    (0xBA0, 'X'),
+    (0xBA3, 'V'),
+    (0xBA5, 'X'),
+    (0xBA8, 'V'),
+    (0xBAB, 'X'),
+    (0xBAE, 'V'),
+    (0xBBA, 'X'),
+    (0xBBE, 'V'),
+    (0xBC3, 'X'),
+    (0xBC6, 'V'),
+    (0xBC9, 'X'),
+    (0xBCA, 'V'),
+    (0xBCE, 'X'),
+    (0xBD0, 'V'),
+    (0xBD1, 'X'),
+    (0xBD7, 'V'),
+    (0xBD8, 'X'),
+    (0xBE6, 'V'),
+    (0xBFB, 'X'),
+    (0xC00, 'V'),
+    (0xC0D, 'X'),
+    (0xC0E, 'V'),
+    (0xC11, 'X'),
+    (0xC12, 'V'),
+    ]
+
+def _seg_12():
+    return [
+    (0xC29, 'X'),
+    (0xC2A, 'V'),
+    (0xC3A, 'X'),
+    (0xC3D, 'V'),
+    (0xC45, 'X'),
+    (0xC46, 'V'),
+    (0xC49, 'X'),
+    (0xC4A, 'V'),
+    (0xC4E, 'X'),
+    (0xC55, 'V'),
+    (0xC57, 'X'),
+    (0xC58, 'V'),
+    (0xC5B, 'X'),
+    (0xC60, 'V'),
+    (0xC64, 'X'),
+    (0xC66, 'V'),
+    (0xC70, 'X'),
+    (0xC78, 'V'),
+    (0xC8D, 'X'),
+    (0xC8E, 'V'),
+    (0xC91, 'X'),
+    (0xC92, 'V'),
+    (0xCA9, 'X'),
+    (0xCAA, 'V'),
+    (0xCB4, 'X'),
+    (0xCB5, 'V'),
+    (0xCBA, 'X'),
+    (0xCBC, 'V'),
+    (0xCC5, 'X'),
+    (0xCC6, 'V'),
+    (0xCC9, 'X'),
+    (0xCCA, 'V'),
+    (0xCCE, 'X'),
+    (0xCD5, 'V'),
+    (0xCD7, 'X'),
+    (0xCDE, 'V'),
+    (0xCDF, 'X'),
+    (0xCE0, 'V'),
+    (0xCE4, 'X'),
+    (0xCE6, 'V'),
+    (0xCF0, 'X'),
+    (0xCF1, 'V'),
+    (0xCF3, 'X'),
+    (0xD00, 'V'),
+    (0xD04, 'X'),
+    (0xD05, 'V'),
+    (0xD0D, 'X'),
+    (0xD0E, 'V'),
+    (0xD11, 'X'),
+    (0xD12, 'V'),
+    (0xD45, 'X'),
+    (0xD46, 'V'),
+    (0xD49, 'X'),
+    (0xD4A, 'V'),
+    (0xD50, 'X'),
+    (0xD54, 'V'),
+    (0xD64, 'X'),
+    (0xD66, 'V'),
+    (0xD80, 'X'),
+    (0xD82, 'V'),
+    (0xD84, 'X'),
+    (0xD85, 'V'),
+    (0xD97, 'X'),
+    (0xD9A, 'V'),
+    (0xDB2, 'X'),
+    (0xDB3, 'V'),
+    (0xDBC, 'X'),
+    (0xDBD, 'V'),
+    (0xDBE, 'X'),
+    (0xDC0, 'V'),
+    (0xDC7, 'X'),
+    (0xDCA, 'V'),
+    (0xDCB, 'X'),
+    (0xDCF, 'V'),
+    (0xDD5, 'X'),
+    (0xDD6, 'V'),
+    (0xDD7, 'X'),
+    (0xDD8, 'V'),
+    (0xDE0, 'X'),
+    (0xDE6, 'V'),
+    (0xDF0, 'X'),
+    (0xDF2, 'V'),
+    (0xDF5, 'X'),
+    (0xE01, 'V'),
+    (0xE33, 'M', u'ํา'),
+    (0xE34, 'V'),
+    (0xE3B, 'X'),
+    (0xE3F, 'V'),
+    (0xE5C, 'X'),
+    (0xE81, 'V'),
+    (0xE83, 'X'),
+    (0xE84, 'V'),
+    (0xE85, 'X'),
+    (0xE87, 'V'),
+    (0xE89, 'X'),
+    (0xE8A, 'V'),
+    (0xE8B, 'X'),
+    (0xE8D, 'V'),
+    (0xE8E, 'X'),
+    (0xE94, 'V'),
+    ]
+
+def _seg_13():
+    return [
+    (0xE98, 'X'),
+    (0xE99, 'V'),
+    (0xEA0, 'X'),
+    (0xEA1, 'V'),
+    (0xEA4, 'X'),
+    (0xEA5, 'V'),
+    (0xEA6, 'X'),
+    (0xEA7, 'V'),
+    (0xEA8, 'X'),
+    (0xEAA, 'V'),
+    (0xEAC, 'X'),
+    (0xEAD, 'V'),
+    (0xEB3, 'M', u'ໍາ'),
+    (0xEB4, 'V'),
+    (0xEBA, 'X'),
+    (0xEBB, 'V'),
+    (0xEBE, 'X'),
+    (0xEC0, 'V'),
+    (0xEC5, 'X'),
+    (0xEC6, 'V'),
+    (0xEC7, 'X'),
+    (0xEC8, 'V'),
+    (0xECE, 'X'),
+    (0xED0, 'V'),
+    (0xEDA, 'X'),
+    (0xEDC, 'M', u'ຫນ'),
+    (0xEDD, 'M', u'ຫມ'),
+    (0xEDE, 'V'),
+    (0xEE0, 'X'),
+    (0xF00, 'V'),
+    (0xF0C, 'M', u'་'),
+    (0xF0D, 'V'),
+    (0xF43, 'M', u'གྷ'),
+    (0xF44, 'V'),
+    (0xF48, 'X'),
+    (0xF49, 'V'),
+    (0xF4D, 'M', u'ཌྷ'),
+    (0xF4E, 'V'),
+    (0xF52, 'M', u'དྷ'),
+    (0xF53, 'V'),
+    (0xF57, 'M', u'བྷ'),
+    (0xF58, 'V'),
+    (0xF5C, 'M', u'ཛྷ'),
+    (0xF5D, 'V'),
+    (0xF69, 'M', u'ཀྵ'),
+    (0xF6A, 'V'),
+    (0xF6D, 'X'),
+    (0xF71, 'V'),
+    (0xF73, 'M', u'ཱི'),
+    (0xF74, 'V'),
+    (0xF75, 'M', u'ཱུ'),
+    (0xF76, 'M', u'ྲྀ'),
+    (0xF77, 'M', u'ྲཱྀ'),
+    (0xF78, 'M', u'ླྀ'),
+    (0xF79, 'M', u'ླཱྀ'),
+    (0xF7A, 'V'),
+    (0xF81, 'M', u'ཱྀ'),
+    (0xF82, 'V'),
+    (0xF93, 'M', u'ྒྷ'),
+    (0xF94, 'V'),
+    (0xF98, 'X'),
+    (0xF99, 'V'),
+    (0xF9D, 'M', u'ྜྷ'),
+    (0xF9E, 'V'),
+    (0xFA2, 'M', u'ྡྷ'),
+    (0xFA3, 'V'),
+    (0xFA7, 'M', u'ྦྷ'),
+    (0xFA8, 'V'),
+    (0xFAC, 'M', u'ྫྷ'),
+    (0xFAD, 'V'),
+    (0xFB9, 'M', u'ྐྵ'),
+    (0xFBA, 'V'),
+    (0xFBD, 'X'),
+    (0xFBE, 'V'),
+    (0xFCD, 'X'),
+    (0xFCE, 'V'),
+    (0xFDB, 'X'),
+    (0x1000, 'V'),
+    (0x10A0, 'X'),
+    (0x10C7, 'M', u'ⴧ'),
+    (0x10C8, 'X'),
+    (0x10CD, 'M', u'ⴭ'),
+    (0x10CE, 'X'),
+    (0x10D0, 'V'),
+    (0x10FC, 'M', u'ნ'),
+    (0x10FD, 'V'),
+    (0x115F, 'X'),
+    (0x1161, 'V'),
+    (0x1249, 'X'),
+    (0x124A, 'V'),
+    (0x124E, 'X'),
+    (0x1250, 'V'),
+    (0x1257, 'X'),
+    (0x1258, 'V'),
+    (0x1259, 'X'),
+    (0x125A, 'V'),
+    (0x125E, 'X'),
+    (0x1260, 'V'),
+    (0x1289, 'X'),
+    (0x128A, 'V'),
+    ]
+
+def _seg_14():
+    return [
+    (0x128E, 'X'),
+    (0x1290, 'V'),
+    (0x12B1, 'X'),
+    (0x12B2, 'V'),
+    (0x12B6, 'X'),
+    (0x12B8, 'V'),
+    (0x12BF, 'X'),
+    (0x12C0, 'V'),
+    (0x12C1, 'X'),
+    (0x12C2, 'V'),
+    (0x12C6, 'X'),
+    (0x12C8, 'V'),
+    (0x12D7, 'X'),
+    (0x12D8, 'V'),
+    (0x1311, 'X'),
+    (0x1312, 'V'),
+    (0x1316, 'X'),
+    (0x1318, 'V'),
+    (0x135B, 'X'),
+    (0x135D, 'V'),
+    (0x137D, 'X'),
+    (0x1380, 'V'),
+    (0x139A, 'X'),
+    (0x13A0, 'V'),
+    (0x13F6, 'X'),
+    (0x13F8, 'M', u'Ᏸ'),
+    (0x13F9, 'M', u'Ᏹ'),
+    (0x13FA, 'M', u'Ᏺ'),
+    (0x13FB, 'M', u'Ᏻ'),
+    (0x13FC, 'M', u'Ᏼ'),
+    (0x13FD, 'M', u'Ᏽ'),
+    (0x13FE, 'X'),
+    (0x1400, 'V'),
+    (0x1680, 'X'),
+    (0x1681, 'V'),
+    (0x169D, 'X'),
+    (0x16A0, 'V'),
+    (0x16F9, 'X'),
+    (0x1700, 'V'),
+    (0x170D, 'X'),
+    (0x170E, 'V'),
+    (0x1715, 'X'),
+    (0x1720, 'V'),
+    (0x1737, 'X'),
+    (0x1740, 'V'),
+    (0x1754, 'X'),
+    (0x1760, 'V'),
+    (0x176D, 'X'),
+    (0x176E, 'V'),
+    (0x1771, 'X'),
+    (0x1772, 'V'),
+    (0x1774, 'X'),
+    (0x1780, 'V'),
+    (0x17B4, 'X'),
+    (0x17B6, 'V'),
+    (0x17DE, 'X'),
+    (0x17E0, 'V'),
+    (0x17EA, 'X'),
+    (0x17F0, 'V'),
+    (0x17FA, 'X'),
+    (0x1800, 'V'),
+    (0x1806, 'X'),
+    (0x1807, 'V'),
+    (0x180B, 'I'),
+    (0x180E, 'X'),
+    (0x1810, 'V'),
+    (0x181A, 'X'),
+    (0x1820, 'V'),
+    (0x1879, 'X'),
+    (0x1880, 'V'),
+    (0x18AB, 'X'),
+    (0x18B0, 'V'),
+    (0x18F6, 'X'),
+    (0x1900, 'V'),
+    (0x191F, 'X'),
+    (0x1920, 'V'),
+    (0x192C, 'X'),
+    (0x1930, 'V'),
+    (0x193C, 'X'),
+    (0x1940, 'V'),
+    (0x1941, 'X'),
+    (0x1944, 'V'),
+    (0x196E, 'X'),
+    (0x1970, 'V'),
+    (0x1975, 'X'),
+    (0x1980, 'V'),
+    (0x19AC, 'X'),
+    (0x19B0, 'V'),
+    (0x19CA, 'X'),
+    (0x19D0, 'V'),
+    (0x19DB, 'X'),
+    (0x19DE, 'V'),
+    (0x1A1C, 'X'),
+    (0x1A1E, 'V'),
+    (0x1A5F, 'X'),
+    (0x1A60, 'V'),
+    (0x1A7D, 'X'),
+    (0x1A7F, 'V'),
+    (0x1A8A, 'X'),
+    (0x1A90, 'V'),
+    ]
+
+def _seg_15():
+    return [
+    (0x1A9A, 'X'),
+    (0x1AA0, 'V'),
+    (0x1AAE, 'X'),
+    (0x1AB0, 'V'),
+    (0x1ABF, 'X'),
+    (0x1B00, 'V'),
+    (0x1B4C, 'X'),
+    (0x1B50, 'V'),
+    (0x1B7D, 'X'),
+    (0x1B80, 'V'),
+    (0x1BF4, 'X'),
+    (0x1BFC, 'V'),
+    (0x1C38, 'X'),
+    (0x1C3B, 'V'),
+    (0x1C4A, 'X'),
+    (0x1C4D, 'V'),
+    (0x1C80, 'M', u'в'),
+    (0x1C81, 'M', u'д'),
+    (0x1C82, 'M', u'о'),
+    (0x1C83, 'M', u'с'),
+    (0x1C84, 'M', u'т'),
+    (0x1C86, 'M', u'ъ'),
+    (0x1C87, 'M', u'ѣ'),
+    (0x1C88, 'M', u'ꙋ'),
+    (0x1C89, 'X'),
+    (0x1CC0, 'V'),
+    (0x1CC8, 'X'),
+    (0x1CD0, 'V'),
+    (0x1CFA, 'X'),
+    (0x1D00, 'V'),
+    (0x1D2C, 'M', u'a'),
+    (0x1D2D, 'M', u'æ'),
+    (0x1D2E, 'M', u'b'),
+    (0x1D2F, 'V'),
+    (0x1D30, 'M', u'd'),
+    (0x1D31, 'M', u'e'),
+    (0x1D32, 'M', u'ǝ'),
+    (0x1D33, 'M', u'g'),
+    (0x1D34, 'M', u'h'),
+    (0x1D35, 'M', u'i'),
+    (0x1D36, 'M', u'j'),
+    (0x1D37, 'M', u'k'),
+    (0x1D38, 'M', u'l'),
+    (0x1D39, 'M', u'm'),
+    (0x1D3A, 'M', u'n'),
+    (0x1D3B, 'V'),
+    (0x1D3C, 'M', u'o'),
+    (0x1D3D, 'M', u'ȣ'),
+    (0x1D3E, 'M', u'p'),
+    (0x1D3F, 'M', u'r'),
+    (0x1D40, 'M', u't'),
+    (0x1D41, 'M', u'u'),
+    (0x1D42, 'M', u'w'),
+    (0x1D43, 'M', u'a'),
+    (0x1D44, 'M', u'ɐ'),
+    (0x1D45, 'M', u'ɑ'),
+    (0x1D46, 'M', u'ᴂ'),
+    (0x1D47, 'M', u'b'),
+    (0x1D48, 'M', u'd'),
+    (0x1D49, 'M', u'e'),
+    (0x1D4A, 'M', u'ə'),
+    (0x1D4B, 'M', u'ɛ'),
+    (0x1D4C, 'M', u'ɜ'),
+    (0x1D4D, 'M', u'g'),
+    (0x1D4E, 'V'),
+    (0x1D4F, 'M', u'k'),
+    (0x1D50, 'M', u'm'),
+    (0x1D51, 'M', u'ŋ'),
+    (0x1D52, 'M', u'o'),
+    (0x1D53, 'M', u'ɔ'),
+    (0x1D54, 'M', u'ᴖ'),
+    (0x1D55, 'M', u'ᴗ'),
+    (0x1D56, 'M', u'p'),
+    (0x1D57, 'M', u't'),
+    (0x1D58, 'M', u'u'),
+    (0x1D59, 'M', u'ᴝ'),
+    (0x1D5A, 'M', u'ɯ'),
+    (0x1D5B, 'M', u'v'),
+    (0x1D5C, 'M', u'ᴥ'),
+    (0x1D5D, 'M', u'β'),
+    (0x1D5E, 'M', u'γ'),
+    (0x1D5F, 'M', u'δ'),
+    (0x1D60, 'M', u'φ'),
+    (0x1D61, 'M', u'χ'),
+    (0x1D62, 'M', u'i'),
+    (0x1D63, 'M', u'r'),
+    (0x1D64, 'M', u'u'),
+    (0x1D65, 'M', u'v'),
+    (0x1D66, 'M', u'β'),
+    (0x1D67, 'M', u'γ'),
+    (0x1D68, 'M', u'ρ'),
+    (0x1D69, 'M', u'φ'),
+    (0x1D6A, 'M', u'χ'),
+    (0x1D6B, 'V'),
+    (0x1D78, 'M', u'н'),
+    (0x1D79, 'V'),
+    (0x1D9B, 'M', u'ɒ'),
+    (0x1D9C, 'M', u'c'),
+    (0x1D9D, 'M', u'ɕ'),
+    (0x1D9E, 'M', u'ð'),
+    ]
+
+def _seg_16():
+    return [
+    (0x1D9F, 'M', u'ɜ'),
+    (0x1DA0, 'M', u'f'),
+    (0x1DA1, 'M', u'ɟ'),
+    (0x1DA2, 'M', u'ɡ'),
+    (0x1DA3, 'M', u'ɥ'),
+    (0x1DA4, 'M', u'ɨ'),
+    (0x1DA5, 'M', u'ɩ'),
+    (0x1DA6, 'M', u'ɪ'),
+    (0x1DA7, 'M', u'ᵻ'),
+    (0x1DA8, 'M', u'ʝ'),
+    (0x1DA9, 'M', u'ɭ'),
+    (0x1DAA, 'M', u'ᶅ'),
+    (0x1DAB, 'M', u'ʟ'),
+    (0x1DAC, 'M', u'ɱ'),
+    (0x1DAD, 'M', u'ɰ'),
+    (0x1DAE, 'M', u'ɲ'),
+    (0x1DAF, 'M', u'ɳ'),
+    (0x1DB0, 'M', u'ɴ'),
+    (0x1DB1, 'M', u'ɵ'),
+    (0x1DB2, 'M', u'ɸ'),
+    (0x1DB3, 'M', u'ʂ'),
+    (0x1DB4, 'M', u'ʃ'),
+    (0x1DB5, 'M', u'ƫ'),
+    (0x1DB6, 'M', u'ʉ'),
+    (0x1DB7, 'M', u'ʊ'),
+    (0x1DB8, 'M', u'ᴜ'),
+    (0x1DB9, 'M', u'ʋ'),
+    (0x1DBA, 'M', u'ʌ'),
+    (0x1DBB, 'M', u'z'),
+    (0x1DBC, 'M', u'ʐ'),
+    (0x1DBD, 'M', u'ʑ'),
+    (0x1DBE, 'M', u'ʒ'),
+    (0x1DBF, 'M', u'θ'),
+    (0x1DC0, 'V'),
+    (0x1DFA, 'X'),
+    (0x1DFB, 'V'),
+    (0x1E00, 'M', u'ḁ'),
+    (0x1E01, 'V'),
+    (0x1E02, 'M', u'ḃ'),
+    (0x1E03, 'V'),
+    (0x1E04, 'M', u'ḅ'),
+    (0x1E05, 'V'),
+    (0x1E06, 'M', u'ḇ'),
+    (0x1E07, 'V'),
+    (0x1E08, 'M', u'ḉ'),
+    (0x1E09, 'V'),
+    (0x1E0A, 'M', u'ḋ'),
+    (0x1E0B, 'V'),
+    (0x1E0C, 'M', u'ḍ'),
+    (0x1E0D, 'V'),
+    (0x1E0E, 'M', u'ḏ'),
+    (0x1E0F, 'V'),
+    (0x1E10, 'M', u'ḑ'),
+    (0x1E11, 'V'),
+    (0x1E12, 'M', u'ḓ'),
+    (0x1E13, 'V'),
+    (0x1E14, 'M', u'ḕ'),
+    (0x1E15, 'V'),
+    (0x1E16, 'M', u'ḗ'),
+    (0x1E17, 'V'),
+    (0x1E18, 'M', u'ḙ'),
+    (0x1E19, 'V'),
+    (0x1E1A, 'M', u'ḛ'),
+    (0x1E1B, 'V'),
+    (0x1E1C, 'M', u'ḝ'),
+    (0x1E1D, 'V'),
+    (0x1E1E, 'M', u'ḟ'),
+    (0x1E1F, 'V'),
+    (0x1E20, 'M', u'ḡ'),
+    (0x1E21, 'V'),
+    (0x1E22, 'M', u'ḣ'),
+    (0x1E23, 'V'),
+    (0x1E24, 'M', u'ḥ'),
+    (0x1E25, 'V'),
+    (0x1E26, 'M', u'ḧ'),
+    (0x1E27, 'V'),
+    (0x1E28, 'M', u'ḩ'),
+    (0x1E29, 'V'),
+    (0x1E2A, 'M', u'ḫ'),
+    (0x1E2B, 'V'),
+    (0x1E2C, 'M', u'ḭ'),
+    (0x1E2D, 'V'),
+    (0x1E2E, 'M', u'ḯ'),
+    (0x1E2F, 'V'),
+    (0x1E30, 'M', u'ḱ'),
+    (0x1E31, 'V'),
+    (0x1E32, 'M', u'ḳ'),
+    (0x1E33, 'V'),
+    (0x1E34, 'M', u'ḵ'),
+    (0x1E35, 'V'),
+    (0x1E36, 'M', u'ḷ'),
+    (0x1E37, 'V'),
+    (0x1E38, 'M', u'ḹ'),
+    (0x1E39, 'V'),
+    (0x1E3A, 'M', u'ḻ'),
+    (0x1E3B, 'V'),
+    (0x1E3C, 'M', u'ḽ'),
+    (0x1E3D, 'V'),
+    (0x1E3E, 'M', u'ḿ'),
+    (0x1E3F, 'V'),
+    ]
+
+def _seg_17():
+    return [
+    (0x1E40, 'M', u'ṁ'),
+    (0x1E41, 'V'),
+    (0x1E42, 'M', u'ṃ'),
+    (0x1E43, 'V'),
+    (0x1E44, 'M', u'ṅ'),
+    (0x1E45, 'V'),
+    (0x1E46, 'M', u'ṇ'),
+    (0x1E47, 'V'),
+    (0x1E48, 'M', u'ṉ'),
+    (0x1E49, 'V'),
+    (0x1E4A, 'M', u'ṋ'),
+    (0x1E4B, 'V'),
+    (0x1E4C, 'M', u'ṍ'),
+    (0x1E4D, 'V'),
+    (0x1E4E, 'M', u'ṏ'),
+    (0x1E4F, 'V'),
+    (0x1E50, 'M', u'ṑ'),
+    (0x1E51, 'V'),
+    (0x1E52, 'M', u'ṓ'),
+    (0x1E53, 'V'),
+    (0x1E54, 'M', u'ṕ'),
+    (0x1E55, 'V'),
+    (0x1E56, 'M', u'ṗ'),
+    (0x1E57, 'V'),
+    (0x1E58, 'M', u'ṙ'),
+    (0x1E59, 'V'),
+    (0x1E5A, 'M', u'ṛ'),
+    (0x1E5B, 'V'),
+    (0x1E5C, 'M', u'ṝ'),
+    (0x1E5D, 'V'),
+    (0x1E5E, 'M', u'ṟ'),
+    (0x1E5F, 'V'),
+    (0x1E60, 'M', u'ṡ'),
+    (0x1E61, 'V'),
+    (0x1E62, 'M', u'ṣ'),
+    (0x1E63, 'V'),
+    (0x1E64, 'M', u'ṥ'),
+    (0x1E65, 'V'),
+    (0x1E66, 'M', u'ṧ'),
+    (0x1E67, 'V'),
+    (0x1E68, 'M', u'ṩ'),
+    (0x1E69, 'V'),
+    (0x1E6A, 'M', u'ṫ'),
+    (0x1E6B, 'V'),
+    (0x1E6C, 'M', u'ṭ'),
+    (0x1E6D, 'V'),
+    (0x1E6E, 'M', u'ṯ'),
+    (0x1E6F, 'V'),
+    (0x1E70, 'M', u'ṱ'),
+    (0x1E71, 'V'),
+    (0x1E72, 'M', u'ṳ'),
+    (0x1E73, 'V'),
+    (0x1E74, 'M', u'ṵ'),
+    (0x1E75, 'V'),
+    (0x1E76, 'M', u'ṷ'),
+    (0x1E77, 'V'),
+    (0x1E78, 'M', u'ṹ'),
+    (0x1E79, 'V'),
+    (0x1E7A, 'M', u'ṻ'),
+    (0x1E7B, 'V'),
+    (0x1E7C, 'M', u'ṽ'),
+    (0x1E7D, 'V'),
+    (0x1E7E, 'M', u'ṿ'),
+    (0x1E7F, 'V'),
+    (0x1E80, 'M', u'ẁ'),
+    (0x1E81, 'V'),
+    (0x1E82, 'M', u'ẃ'),
+    (0x1E83, 'V'),
+    (0x1E84, 'M', u'ẅ'),
+    (0x1E85, 'V'),
+    (0x1E86, 'M', u'ẇ'),
+    (0x1E87, 'V'),
+    (0x1E88, 'M', u'ẉ'),
+    (0x1E89, 'V'),
+    (0x1E8A, 'M', u'ẋ'),
+    (0x1E8B, 'V'),
+    (0x1E8C, 'M', u'ẍ'),
+    (0x1E8D, 'V'),
+    (0x1E8E, 'M', u'ẏ'),
+    (0x1E8F, 'V'),
+    (0x1E90, 'M', u'ẑ'),
+    (0x1E91, 'V'),
+    (0x1E92, 'M', u'ẓ'),
+    (0x1E93, 'V'),
+    (0x1E94, 'M', u'ẕ'),
+    (0x1E95, 'V'),
+    (0x1E9A, 'M', u'aʾ'),
+    (0x1E9B, 'M', u'ṡ'),
+    (0x1E9C, 'V'),
+    (0x1E9E, 'M', u'ss'),
+    (0x1E9F, 'V'),
+    (0x1EA0, 'M', u'ạ'),
+    (0x1EA1, 'V'),
+    (0x1EA2, 'M', u'ả'),
+    (0x1EA3, 'V'),
+    (0x1EA4, 'M', u'ấ'),
+    (0x1EA5, 'V'),
+    (0x1EA6, 'M', u'ầ'),
+    (0x1EA7, 'V'),
+    (0x1EA8, 'M', u'ẩ'),
+    ]
+
+def _seg_18():
+    return [
+    (0x1EA9, 'V'),
+    (0x1EAA, 'M', u'ẫ'),
+    (0x1EAB, 'V'),
+    (0x1EAC, 'M', u'ậ'),
+    (0x1EAD, 'V'),
+    (0x1EAE, 'M', u'ắ'),
+    (0x1EAF, 'V'),
+    (0x1EB0, 'M', u'ằ'),
+    (0x1EB1, 'V'),
+    (0x1EB2, 'M', u'ẳ'),
+    (0x1EB3, 'V'),
+    (0x1EB4, 'M', u'ẵ'),
+    (0x1EB5, 'V'),
+    (0x1EB6, 'M', u'ặ'),
+    (0x1EB7, 'V'),
+    (0x1EB8, 'M', u'ẹ'),
+    (0x1EB9, 'V'),
+    (0x1EBA, 'M', u'ẻ'),
+    (0x1EBB, 'V'),
+    (0x1EBC, 'M', u'ẽ'),
+    (0x1EBD, 'V'),
+    (0x1EBE, 'M', u'ế'),
+    (0x1EBF, 'V'),
+    (0x1EC0, 'M', u'ề'),
+    (0x1EC1, 'V'),
+    (0x1EC2, 'M', u'ể'),
+    (0x1EC3, 'V'),
+    (0x1EC4, 'M', u'ễ'),
+    (0x1EC5, 'V'),
+    (0x1EC6, 'M', u'ệ'),
+    (0x1EC7, 'V'),
+    (0x1EC8, 'M', u'ỉ'),
+    (0x1EC9, 'V'),
+    (0x1ECA, 'M', u'ị'),
+    (0x1ECB, 'V'),
+    (0x1ECC, 'M', u'ọ'),
+    (0x1ECD, 'V'),
+    (0x1ECE, 'M', u'ỏ'),
+    (0x1ECF, 'V'),
+    (0x1ED0, 'M', u'ố'),
+    (0x1ED1, 'V'),
+    (0x1ED2, 'M', u'ồ'),
+    (0x1ED3, 'V'),
+    (0x1ED4, 'M', u'ổ'),
+    (0x1ED5, 'V'),
+    (0x1ED6, 'M', u'ỗ'),
+    (0x1ED7, 'V'),
+    (0x1ED8, 'M', u'ộ'),
+    (0x1ED9, 'V'),
+    (0x1EDA, 'M', u'ớ'),
+    (0x1EDB, 'V'),
+    (0x1EDC, 'M', u'ờ'),
+    (0x1EDD, 'V'),
+    (0x1EDE, 'M', u'ở'),
+    (0x1EDF, 'V'),
+    (0x1EE0, 'M', u'ỡ'),
+    (0x1EE1, 'V'),
+    (0x1EE2, 'M', u'ợ'),
+    (0x1EE3, 'V'),
+    (0x1EE4, 'M', u'ụ'),
+    (0x1EE5, 'V'),
+    (0x1EE6, 'M', u'ủ'),
+    (0x1EE7, 'V'),
+    (0x1EE8, 'M', u'ứ'),
+    (0x1EE9, 'V'),
+    (0x1EEA, 'M', u'ừ'),
+    (0x1EEB, 'V'),
+    (0x1EEC, 'M', u'ử'),
+    (0x1EED, 'V'),
+    (0x1EEE, 'M', u'ữ'),
+    (0x1EEF, 'V'),
+    (0x1EF0, 'M', u'ự'),
+    (0x1EF1, 'V'),
+    (0x1EF2, 'M', u'ỳ'),
+    (0x1EF3, 'V'),
+    (0x1EF4, 'M', u'ỵ'),
+    (0x1EF5, 'V'),
+    (0x1EF6, 'M', u'ỷ'),
+    (0x1EF7, 'V'),
+    (0x1EF8, 'M', u'ỹ'),
+    (0x1EF9, 'V'),
+    (0x1EFA, 'M', u'ỻ'),
+    (0x1EFB, 'V'),
+    (0x1EFC, 'M', u'ỽ'),
+    (0x1EFD, 'V'),
+    (0x1EFE, 'M', u'ỿ'),
+    (0x1EFF, 'V'),
+    (0x1F08, 'M', u'ἀ'),
+    (0x1F09, 'M', u'ἁ'),
+    (0x1F0A, 'M', u'ἂ'),
+    (0x1F0B, 'M', u'ἃ'),
+    (0x1F0C, 'M', u'ἄ'),
+    (0x1F0D, 'M', u'ἅ'),
+    (0x1F0E, 'M', u'ἆ'),
+    (0x1F0F, 'M', u'ἇ'),
+    (0x1F10, 'V'),
+    (0x1F16, 'X'),
+    (0x1F18, 'M', u'ἐ'),
+    (0x1F19, 'M', u'ἑ'),
+    (0x1F1A, 'M', u'ἒ'),
+    ]
+
+def _seg_19():
+    return [
+    (0x1F1B, 'M', u'ἓ'),
+    (0x1F1C, 'M', u'ἔ'),
+    (0x1F1D, 'M', u'ἕ'),
+    (0x1F1E, 'X'),
+    (0x1F20, 'V'),
+    (0x1F28, 'M', u'ἠ'),
+    (0x1F29, 'M', u'ἡ'),
+    (0x1F2A, 'M', u'ἢ'),
+    (0x1F2B, 'M', u'ἣ'),
+    (0x1F2C, 'M', u'ἤ'),
+    (0x1F2D, 'M', u'ἥ'),
+    (0x1F2E, 'M', u'ἦ'),
+    (0x1F2F, 'M', u'ἧ'),
+    (0x1F30, 'V'),
+    (0x1F38, 'M', u'ἰ'),
+    (0x1F39, 'M', u'ἱ'),
+    (0x1F3A, 'M', u'ἲ'),
+    (0x1F3B, 'M', u'ἳ'),
+    (0x1F3C, 'M', u'ἴ'),
+    (0x1F3D, 'M', u'ἵ'),
+    (0x1F3E, 'M', u'ἶ'),
+    (0x1F3F, 'M', u'ἷ'),
+    (0x1F40, 'V'),
+    (0x1F46, 'X'),
+    (0x1F48, 'M', u'ὀ'),
+    (0x1F49, 'M', u'ὁ'),
+    (0x1F4A, 'M', u'ὂ'),
+    (0x1F4B, 'M', u'ὃ'),
+    (0x1F4C, 'M', u'ὄ'),
+    (0x1F4D, 'M', u'ὅ'),
+    (0x1F4E, 'X'),
+    (0x1F50, 'V'),
+    (0x1F58, 'X'),
+    (0x1F59, 'M', u'ὑ'),
+    (0x1F5A, 'X'),
+    (0x1F5B, 'M', u'ὓ'),
+    (0x1F5C, 'X'),
+    (0x1F5D, 'M', u'ὕ'),
+    (0x1F5E, 'X'),
+    (0x1F5F, 'M', u'ὗ'),
+    (0x1F60, 'V'),
+    (0x1F68, 'M', u'ὠ'),
+    (0x1F69, 'M', u'ὡ'),
+    (0x1F6A, 'M', u'ὢ'),
+    (0x1F6B, 'M', u'ὣ'),
+    (0x1F6C, 'M', u'ὤ'),
+    (0x1F6D, 'M', u'ὥ'),
+    (0x1F6E, 'M', u'ὦ'),
+    (0x1F6F, 'M', u'ὧ'),
+    (0x1F70, 'V'),
+    (0x1F71, 'M', u'ά'),
+    (0x1F72, 'V'),
+    (0x1F73, 'M', u'έ'),
+    (0x1F74, 'V'),
+    (0x1F75, 'M', u'ή'),
+    (0x1F76, 'V'),
+    (0x1F77, 'M', u'ί'),
+    (0x1F78, 'V'),
+    (0x1F79, 'M', u'ό'),
+    (0x1F7A, 'V'),
+    (0x1F7B, 'M', u'ύ'),
+    (0x1F7C, 'V'),
+    (0x1F7D, 'M', u'ώ'),
+    (0x1F7E, 'X'),
+    (0x1F80, 'M', u'ἀι'),
+    (0x1F81, 'M', u'ἁι'),
+    (0x1F82, 'M', u'ἂι'),
+    (0x1F83, 'M', u'ἃι'),
+    (0x1F84, 'M', u'ἄι'),
+    (0x1F85, 'M', u'ἅι'),
+    (0x1F86, 'M', u'ἆι'),
+    (0x1F87, 'M', u'ἇι'),
+    (0x1F88, 'M', u'ἀι'),
+    (0x1F89, 'M', u'ἁι'),
+    (0x1F8A, 'M', u'ἂι'),
+    (0x1F8B, 'M', u'ἃι'),
+    (0x1F8C, 'M', u'ἄι'),
+    (0x1F8D, 'M', u'ἅι'),
+    (0x1F8E, 'M', u'ἆι'),
+    (0x1F8F, 'M', u'ἇι'),
+    (0x1F90, 'M', u'ἠι'),
+    (0x1F91, 'M', u'ἡι'),
+    (0x1F92, 'M', u'ἢι'),
+    (0x1F93, 'M', u'ἣι'),
+    (0x1F94, 'M', u'ἤι'),
+    (0x1F95, 'M', u'ἥι'),
+    (0x1F96, 'M', u'ἦι'),
+    (0x1F97, 'M', u'ἧι'),
+    (0x1F98, 'M', u'ἠι'),
+    (0x1F99, 'M', u'ἡι'),
+    (0x1F9A, 'M', u'ἢι'),
+    (0x1F9B, 'M', u'ἣι'),
+    (0x1F9C, 'M', u'ἤι'),
+    (0x1F9D, 'M', u'ἥι'),
+    (0x1F9E, 'M', u'ἦι'),
+    (0x1F9F, 'M', u'ἧι'),
+    (0x1FA0, 'M', u'ὠι'),
+    (0x1FA1, 'M', u'ὡι'),
+    (0x1FA2, 'M', u'ὢι'),
+    (0x1FA3, 'M', u'ὣι'),
+    ]
+
+def _seg_20():
+    return [
+    (0x1FA4, 'M', u'ὤι'),
+    (0x1FA5, 'M', u'ὥι'),
+    (0x1FA6, 'M', u'ὦι'),
+    (0x1FA7, 'M', u'ὧι'),
+    (0x1FA8, 'M', u'ὠι'),
+    (0x1FA9, 'M', u'ὡι'),
+    (0x1FAA, 'M', u'ὢι'),
+    (0x1FAB, 'M', u'ὣι'),
+    (0x1FAC, 'M', u'ὤι'),
+    (0x1FAD, 'M', u'ὥι'),
+    (0x1FAE, 'M', u'ὦι'),
+    (0x1FAF, 'M', u'ὧι'),
+    (0x1FB0, 'V'),
+    (0x1FB2, 'M', u'ὰι'),
+    (0x1FB3, 'M', u'αι'),
+    (0x1FB4, 'M', u'άι'),
+    (0x1FB5, 'X'),
+    (0x1FB6, 'V'),
+    (0x1FB7, 'M', u'ᾶι'),
+    (0x1FB8, 'M', u'ᾰ'),
+    (0x1FB9, 'M', u'ᾱ'),
+    (0x1FBA, 'M', u'ὰ'),
+    (0x1FBB, 'M', u'ά'),
+    (0x1FBC, 'M', u'αι'),
+    (0x1FBD, '3', u' ̓'),
+    (0x1FBE, 'M', u'ι'),
+    (0x1FBF, '3', u' ̓'),
+    (0x1FC0, '3', u' ͂'),
+    (0x1FC1, '3', u' ̈͂'),
+    (0x1FC2, 'M', u'ὴι'),
+    (0x1FC3, 'M', u'ηι'),
+    (0x1FC4, 'M', u'ήι'),
+    (0x1FC5, 'X'),
+    (0x1FC6, 'V'),
+    (0x1FC7, 'M', u'ῆι'),
+    (0x1FC8, 'M', u'ὲ'),
+    (0x1FC9, 'M', u'έ'),
+    (0x1FCA, 'M', u'ὴ'),
+    (0x1FCB, 'M', u'ή'),
+    (0x1FCC, 'M', u'ηι'),
+    (0x1FCD, '3', u' ̓̀'),
+    (0x1FCE, '3', u' ̓́'),
+    (0x1FCF, '3', u' ̓͂'),
+    (0x1FD0, 'V'),
+    (0x1FD3, 'M', u'ΐ'),
+    (0x1FD4, 'X'),
+    (0x1FD6, 'V'),
+    (0x1FD8, 'M', u'ῐ'),
+    (0x1FD9, 'M', u'ῑ'),
+    (0x1FDA, 'M', u'ὶ'),
+    (0x1FDB, 'M', u'ί'),
+    (0x1FDC, 'X'),
+    (0x1FDD, '3', u' ̔̀'),
+    (0x1FDE, '3', u' ̔́'),
+    (0x1FDF, '3', u' ̔͂'),
+    (0x1FE0, 'V'),
+    (0x1FE3, 'M', u'ΰ'),
+    (0x1FE4, 'V'),
+    (0x1FE8, 'M', u'ῠ'),
+    (0x1FE9, 'M', u'ῡ'),
+    (0x1FEA, 'M', u'ὺ'),
+    (0x1FEB, 'M', u'ύ'),
+    (0x1FEC, 'M', u'ῥ'),
+    (0x1FED, '3', u' ̈̀'),
+    (0x1FEE, '3', u' ̈́'),
+    (0x1FEF, '3', u'`'),
+    (0x1FF0, 'X'),
+    (0x1FF2, 'M', u'ὼι'),
+    (0x1FF3, 'M', u'ωι'),
+    (0x1FF4, 'M', u'ώι'),
+    (0x1FF5, 'X'),
+    (0x1FF6, 'V'),
+    (0x1FF7, 'M', u'ῶι'),
+    (0x1FF8, 'M', u'ὸ'),
+    (0x1FF9, 'M', u'ό'),
+    (0x1FFA, 'M', u'ὼ'),
+    (0x1FFB, 'M', u'ώ'),
+    (0x1FFC, 'M', u'ωι'),
+    (0x1FFD, '3', u' ́'),
+    (0x1FFE, '3', u' ̔'),
+    (0x1FFF, 'X'),
+    (0x2000, '3', u' '),
+    (0x200B, 'I'),
+    (0x200C, 'D', u''),
+    (0x200E, 'X'),
+    (0x2010, 'V'),
+    (0x2011, 'M', u'‐'),
+    (0x2012, 'V'),
+    (0x2017, '3', u' ̳'),
+    (0x2018, 'V'),
+    (0x2024, 'X'),
+    (0x2027, 'V'),
+    (0x2028, 'X'),
+    (0x202F, '3', u' '),
+    (0x2030, 'V'),
+    (0x2033, 'M', u'′′'),
+    (0x2034, 'M', u'′′′'),
+    (0x2035, 'V'),
+    (0x2036, 'M', u'‵‵'),
+    (0x2037, 'M', u'‵‵‵'),
+    ]
+
+def _seg_21():
+    return [
+    (0x2038, 'V'),
+    (0x203C, '3', u'!!'),
+    (0x203D, 'V'),
+    (0x203E, '3', u' ̅'),
+    (0x203F, 'V'),
+    (0x2047, '3', u'??'),
+    (0x2048, '3', u'?!'),
+    (0x2049, '3', u'!?'),
+    (0x204A, 'V'),
+    (0x2057, 'M', u'′′′′'),
+    (0x2058, 'V'),
+    (0x205F, '3', u' '),
+    (0x2060, 'I'),
+    (0x2061, 'X'),
+    (0x2064, 'I'),
+    (0x2065, 'X'),
+    (0x2070, 'M', u'0'),
+    (0x2071, 'M', u'i'),
+    (0x2072, 'X'),
+    (0x2074, 'M', u'4'),
+    (0x2075, 'M', u'5'),
+    (0x2076, 'M', u'6'),
+    (0x2077, 'M', u'7'),
+    (0x2078, 'M', u'8'),
+    (0x2079, 'M', u'9'),
+    (0x207A, '3', u'+'),
+    (0x207B, 'M', u'−'),
+    (0x207C, '3', u'='),
+    (0x207D, '3', u'('),
+    (0x207E, '3', u')'),
+    (0x207F, 'M', u'n'),
+    (0x2080, 'M', u'0'),
+    (0x2081, 'M', u'1'),
+    (0x2082, 'M', u'2'),
+    (0x2083, 'M', u'3'),
+    (0x2084, 'M', u'4'),
+    (0x2085, 'M', u'5'),
+    (0x2086, 'M', u'6'),
+    (0x2087, 'M', u'7'),
+    (0x2088, 'M', u'8'),
+    (0x2089, 'M', u'9'),
+    (0x208A, '3', u'+'),
+    (0x208B, 'M', u'−'),
+    (0x208C, '3', u'='),
+    (0x208D, '3', u'('),
+    (0x208E, '3', u')'),
+    (0x208F, 'X'),
+    (0x2090, 'M', u'a'),
+    (0x2091, 'M', u'e'),
+    (0x2092, 'M', u'o'),
+    (0x2093, 'M', u'x'),
+    (0x2094, 'M', u'ə'),
+    (0x2095, 'M', u'h'),
+    (0x2096, 'M', u'k'),
+    (0x2097, 'M', u'l'),
+    (0x2098, 'M', u'm'),
+    (0x2099, 'M', u'n'),
+    (0x209A, 'M', u'p'),
+    (0x209B, 'M', u's'),
+    (0x209C, 'M', u't'),
+    (0x209D, 'X'),
+    (0x20A0, 'V'),
+    (0x20A8, 'M', u'rs'),
+    (0x20A9, 'V'),
+    (0x20C0, 'X'),
+    (0x20D0, 'V'),
+    (0x20F1, 'X'),
+    (0x2100, '3', u'a/c'),
+    (0x2101, '3', u'a/s'),
+    (0x2102, 'M', u'c'),
+    (0x2103, 'M', u'°c'),
+    (0x2104, 'V'),
+    (0x2105, '3', u'c/o'),
+    (0x2106, '3', u'c/u'),
+    (0x2107, 'M', u'ɛ'),
+    (0x2108, 'V'),
+    (0x2109, 'M', u'°f'),
+    (0x210A, 'M', u'g'),
+    (0x210B, 'M', u'h'),
+    (0x210F, 'M', u'ħ'),
+    (0x2110, 'M', u'i'),
+    (0x2112, 'M', u'l'),
+    (0x2114, 'V'),
+    (0x2115, 'M', u'n'),
+    (0x2116, 'M', u'no'),
+    (0x2117, 'V'),
+    (0x2119, 'M', u'p'),
+    (0x211A, 'M', u'q'),
+    (0x211B, 'M', u'r'),
+    (0x211E, 'V'),
+    (0x2120, 'M', u'sm'),
+    (0x2121, 'M', u'tel'),
+    (0x2122, 'M', u'tm'),
+    (0x2123, 'V'),
+    (0x2124, 'M', u'z'),
+    (0x2125, 'V'),
+    (0x2126, 'M', u'ω'),
+    (0x2127, 'V'),
+    (0x2128, 'M', u'z'),
+    (0x2129, 'V'),
+    ]
+
+def _seg_22():
+    return [
+    (0x212A, 'M', u'k'),
+    (0x212B, 'M', u'å'),
+    (0x212C, 'M', u'b'),
+    (0x212D, 'M', u'c'),
+    (0x212E, 'V'),
+    (0x212F, 'M', u'e'),
+    (0x2131, 'M', u'f'),
+    (0x2132, 'X'),
+    (0x2133, 'M', u'm'),
+    (0x2134, 'M', u'o'),
+    (0x2135, 'M', u'א'),
+    (0x2136, 'M', u'ב'),
+    (0x2137, 'M', u'ג'),
+    (0x2138, 'M', u'ד'),
+    (0x2139, 'M', u'i'),
+    (0x213A, 'V'),
+    (0x213B, 'M', u'fax'),
+    (0x213C, 'M', u'π'),
+    (0x213D, 'M', u'γ'),
+    (0x213F, 'M', u'π'),
+    (0x2140, 'M', u'∑'),
+    (0x2141, 'V'),
+    (0x2145, 'M', u'd'),
+    (0x2147, 'M', u'e'),
+    (0x2148, 'M', u'i'),
+    (0x2149, 'M', u'j'),
+    (0x214A, 'V'),
+    (0x2150, 'M', u'1⁄7'),
+    (0x2151, 'M', u'1⁄9'),
+    (0x2152, 'M', u'1⁄10'),
+    (0x2153, 'M', u'1⁄3'),
+    (0x2154, 'M', u'2⁄3'),
+    (0x2155, 'M', u'1⁄5'),
+    (0x2156, 'M', u'2⁄5'),
+    (0x2157, 'M', u'3⁄5'),
+    (0x2158, 'M', u'4⁄5'),
+    (0x2159, 'M', u'1⁄6'),
+    (0x215A, 'M', u'5⁄6'),
+    (0x215B, 'M', u'1⁄8'),
+    (0x215C, 'M', u'3⁄8'),
+    (0x215D, 'M', u'5⁄8'),
+    (0x215E, 'M', u'7⁄8'),
+    (0x215F, 'M', u'1⁄'),
+    (0x2160, 'M', u'i'),
+    (0x2161, 'M', u'ii'),
+    (0x2162, 'M', u'iii'),
+    (0x2163, 'M', u'iv'),
+    (0x2164, 'M', u'v'),
+    (0x2165, 'M', u'vi'),
+    (0x2166, 'M', u'vii'),
+    (0x2167, 'M', u'viii'),
+    (0x2168, 'M', u'ix'),
+    (0x2169, 'M', u'x'),
+    (0x216A, 'M', u'xi'),
+    (0x216B, 'M', u'xii'),
+    (0x216C, 'M', u'l'),
+    (0x216D, 'M', u'c'),
+    (0x216E, 'M', u'd'),
+    (0x216F, 'M', u'm'),
+    (0x2170, 'M', u'i'),
+    (0x2171, 'M', u'ii'),
+    (0x2172, 'M', u'iii'),
+    (0x2173, 'M', u'iv'),
+    (0x2174, 'M', u'v'),
+    (0x2175, 'M', u'vi'),
+    (0x2176, 'M', u'vii'),
+    (0x2177, 'M', u'viii'),
+    (0x2178, 'M', u'ix'),
+    (0x2179, 'M', u'x'),
+    (0x217A, 'M', u'xi'),
+    (0x217B, 'M', u'xii'),
+    (0x217C, 'M', u'l'),
+    (0x217D, 'M', u'c'),
+    (0x217E, 'M', u'd'),
+    (0x217F, 'M', u'm'),
+    (0x2180, 'V'),
+    (0x2183, 'X'),
+    (0x2184, 'V'),
+    (0x2189, 'M', u'0⁄3'),
+    (0x218A, 'V'),
+    (0x218C, 'X'),
+    (0x2190, 'V'),
+    (0x222C, 'M', u'∫∫'),
+    (0x222D, 'M', u'∫∫∫'),
+    (0x222E, 'V'),
+    (0x222F, 'M', u'∮∮'),
+    (0x2230, 'M', u'∮∮∮'),
+    (0x2231, 'V'),
+    (0x2260, '3'),
+    (0x2261, 'V'),
+    (0x226E, '3'),
+    (0x2270, 'V'),
+    (0x2329, 'M', u'〈'),
+    (0x232A, 'M', u'〉'),
+    (0x232B, 'V'),
+    (0x2427, 'X'),
+    (0x2440, 'V'),
+    (0x244B, 'X'),
+    (0x2460, 'M', u'1'),
+    (0x2461, 'M', u'2'),
+    ]
+
+def _seg_23():
+    return [
+    (0x2462, 'M', u'3'),
+    (0x2463, 'M', u'4'),
+    (0x2464, 'M', u'5'),
+    (0x2465, 'M', u'6'),
+    (0x2466, 'M', u'7'),
+    (0x2467, 'M', u'8'),
+    (0x2468, 'M', u'9'),
+    (0x2469, 'M', u'10'),
+    (0x246A, 'M', u'11'),
+    (0x246B, 'M', u'12'),
+    (0x246C, 'M', u'13'),
+    (0x246D, 'M', u'14'),
+    (0x246E, 'M', u'15'),
+    (0x246F, 'M', u'16'),
+    (0x2470, 'M', u'17'),
+    (0x2471, 'M', u'18'),
+    (0x2472, 'M', u'19'),
+    (0x2473, 'M', u'20'),
+    (0x2474, '3', u'(1)'),
+    (0x2475, '3', u'(2)'),
+    (0x2476, '3', u'(3)'),
+    (0x2477, '3', u'(4)'),
+    (0x2478, '3', u'(5)'),
+    (0x2479, '3', u'(6)'),
+    (0x247A, '3', u'(7)'),
+    (0x247B, '3', u'(8)'),
+    (0x247C, '3', u'(9)'),
+    (0x247D, '3', u'(10)'),
+    (0x247E, '3', u'(11)'),
+    (0x247F, '3', u'(12)'),
+    (0x2480, '3', u'(13)'),
+    (0x2481, '3', u'(14)'),
+    (0x2482, '3', u'(15)'),
+    (0x2483, '3', u'(16)'),
+    (0x2484, '3', u'(17)'),
+    (0x2485, '3', u'(18)'),
+    (0x2486, '3', u'(19)'),
+    (0x2487, '3', u'(20)'),
+    (0x2488, 'X'),
+    (0x249C, '3', u'(a)'),
+    (0x249D, '3', u'(b)'),
+    (0x249E, '3', u'(c)'),
+    (0x249F, '3', u'(d)'),
+    (0x24A0, '3', u'(e)'),
+    (0x24A1, '3', u'(f)'),
+    (0x24A2, '3', u'(g)'),
+    (0x24A3, '3', u'(h)'),
+    (0x24A4, '3', u'(i)'),
+    (0x24A5, '3', u'(j)'),
+    (0x24A6, '3', u'(k)'),
+    (0x24A7, '3', u'(l)'),
+    (0x24A8, '3', u'(m)'),
+    (0x24A9, '3', u'(n)'),
+    (0x24AA, '3', u'(o)'),
+    (0x24AB, '3', u'(p)'),
+    (0x24AC, '3', u'(q)'),
+    (0x24AD, '3', u'(r)'),
+    (0x24AE, '3', u'(s)'),
+    (0x24AF, '3', u'(t)'),
+    (0x24B0, '3', u'(u)'),
+    (0x24B1, '3', u'(v)'),
+    (0x24B2, '3', u'(w)'),
+    (0x24B3, '3', u'(x)'),
+    (0x24B4, '3', u'(y)'),
+    (0x24B5, '3', u'(z)'),
+    (0x24B6, 'M', u'a'),
+    (0x24B7, 'M', u'b'),
+    (0x24B8, 'M', u'c'),
+    (0x24B9, 'M', u'd'),
+    (0x24BA, 'M', u'e'),
+    (0x24BB, 'M', u'f'),
+    (0x24BC, 'M', u'g'),
+    (0x24BD, 'M', u'h'),
+    (0x24BE, 'M', u'i'),
+    (0x24BF, 'M', u'j'),
+    (0x24C0, 'M', u'k'),
+    (0x24C1, 'M', u'l'),
+    (0x24C2, 'M', u'm'),
+    (0x24C3, 'M', u'n'),
+    (0x24C4, 'M', u'o'),
+    (0x24C5, 'M', u'p'),
+    (0x24C6, 'M', u'q'),
+    (0x24C7, 'M', u'r'),
+    (0x24C8, 'M', u's'),
+    (0x24C9, 'M', u't'),
+    (0x24CA, 'M', u'u'),
+    (0x24CB, 'M', u'v'),
+    (0x24CC, 'M', u'w'),
+    (0x24CD, 'M', u'x'),
+    (0x24CE, 'M', u'y'),
+    (0x24CF, 'M', u'z'),
+    (0x24D0, 'M', u'a'),
+    (0x24D1, 'M', u'b'),
+    (0x24D2, 'M', u'c'),
+    (0x24D3, 'M', u'd'),
+    (0x24D4, 'M', u'e'),
+    (0x24D5, 'M', u'f'),
+    (0x24D6, 'M', u'g'),
+    (0x24D7, 'M', u'h'),
+    (0x24D8, 'M', u'i'),
+    ]
+
+def _seg_24():
+    return [
+    (0x24D9, 'M', u'j'),
+    (0x24DA, 'M', u'k'),
+    (0x24DB, 'M', u'l'),
+    (0x24DC, 'M', u'm'),
+    (0x24DD, 'M', u'n'),
+    (0x24DE, 'M', u'o'),
+    (0x24DF, 'M', u'p'),
+    (0x24E0, 'M', u'q'),
+    (0x24E1, 'M', u'r'),
+    (0x24E2, 'M', u's'),
+    (0x24E3, 'M', u't'),
+    (0x24E4, 'M', u'u'),
+    (0x24E5, 'M', u'v'),
+    (0x24E6, 'M', u'w'),
+    (0x24E7, 'M', u'x'),
+    (0x24E8, 'M', u'y'),
+    (0x24E9, 'M', u'z'),
+    (0x24EA, 'M', u'0'),
+    (0x24EB, 'V'),
+    (0x2A0C, 'M', u'∫∫∫∫'),
+    (0x2A0D, 'V'),
+    (0x2A74, '3', u'::='),
+    (0x2A75, '3', u'=='),
+    (0x2A76, '3', u'==='),
+    (0x2A77, 'V'),
+    (0x2ADC, 'M', u'⫝̸'),
+    (0x2ADD, 'V'),
+    (0x2B74, 'X'),
+    (0x2B76, 'V'),
+    (0x2B96, 'X'),
+    (0x2B98, 'V'),
+    (0x2BC9, 'X'),
+    (0x2BCA, 'V'),
+    (0x2BFF, 'X'),
+    (0x2C00, 'M', u'ⰰ'),
+    (0x2C01, 'M', u'ⰱ'),
+    (0x2C02, 'M', u'ⰲ'),
+    (0x2C03, 'M', u'ⰳ'),
+    (0x2C04, 'M', u'ⰴ'),
+    (0x2C05, 'M', u'ⰵ'),
+    (0x2C06, 'M', u'ⰶ'),
+    (0x2C07, 'M', u'ⰷ'),
+    (0x2C08, 'M', u'ⰸ'),
+    (0x2C09, 'M', u'ⰹ'),
+    (0x2C0A, 'M', u'ⰺ'),
+    (0x2C0B, 'M', u'ⰻ'),
+    (0x2C0C, 'M', u'ⰼ'),
+    (0x2C0D, 'M', u'ⰽ'),
+    (0x2C0E, 'M', u'ⰾ'),
+    (0x2C0F, 'M', u'ⰿ'),
+    (0x2C10, 'M', u'ⱀ'),
+    (0x2C11, 'M', u'ⱁ'),
+    (0x2C12, 'M', u'ⱂ'),
+    (0x2C13, 'M', u'ⱃ'),
+    (0x2C14, 'M', u'ⱄ'),
+    (0x2C15, 'M', u'ⱅ'),
+    (0x2C16, 'M', u'ⱆ'),
+    (0x2C17, 'M', u'ⱇ'),
+    (0x2C18, 'M', u'ⱈ'),
+    (0x2C19, 'M', u'ⱉ'),
+    (0x2C1A, 'M', u'ⱊ'),
+    (0x2C1B, 'M', u'ⱋ'),
+    (0x2C1C, 'M', u'ⱌ'),
+    (0x2C1D, 'M', u'ⱍ'),
+    (0x2C1E, 'M', u'ⱎ'),
+    (0x2C1F, 'M', u'ⱏ'),
+    (0x2C20, 'M', u'ⱐ'),
+    (0x2C21, 'M', u'ⱑ'),
+    (0x2C22, 'M', u'ⱒ'),
+    (0x2C23, 'M', u'ⱓ'),
+    (0x2C24, 'M', u'ⱔ'),
+    (0x2C25, 'M', u'ⱕ'),
+    (0x2C26, 'M', u'ⱖ'),
+    (0x2C27, 'M', u'ⱗ'),
+    (0x2C28, 'M', u'ⱘ'),
+    (0x2C29, 'M', u'ⱙ'),
+    (0x2C2A, 'M', u'ⱚ'),
+    (0x2C2B, 'M', u'ⱛ'),
+    (0x2C2C, 'M', u'ⱜ'),
+    (0x2C2D, 'M', u'ⱝ'),
+    (0x2C2E, 'M', u'ⱞ'),
+    (0x2C2F, 'X'),
+    (0x2C30, 'V'),
+    (0x2C5F, 'X'),
+    (0x2C60, 'M', u'ⱡ'),
+    (0x2C61, 'V'),
+    (0x2C62, 'M', u'ɫ'),
+    (0x2C63, 'M', u'ᵽ'),
+    (0x2C64, 'M', u'ɽ'),
+    (0x2C65, 'V'),
+    (0x2C67, 'M', u'ⱨ'),
+    (0x2C68, 'V'),
+    (0x2C69, 'M', u'ⱪ'),
+    (0x2C6A, 'V'),
+    (0x2C6B, 'M', u'ⱬ'),
+    (0x2C6C, 'V'),
+    (0x2C6D, 'M', u'ɑ'),
+    (0x2C6E, 'M', u'ɱ'),
+    (0x2C6F, 'M', u'ɐ'),
+    (0x2C70, 'M', u'ɒ'),
+    ]
+
+def _seg_25():
+    return [
+    (0x2C71, 'V'),
+    (0x2C72, 'M', u'ⱳ'),
+    (0x2C73, 'V'),
+    (0x2C75, 'M', u'ⱶ'),
+    (0x2C76, 'V'),
+    (0x2C7C, 'M', u'j'),
+    (0x2C7D, 'M', u'v'),
+    (0x2C7E, 'M', u'ȿ'),
+    (0x2C7F, 'M', u'ɀ'),
+    (0x2C80, 'M', u'ⲁ'),
+    (0x2C81, 'V'),
+    (0x2C82, 'M', u'ⲃ'),
+    (0x2C83, 'V'),
+    (0x2C84, 'M', u'ⲅ'),
+    (0x2C85, 'V'),
+    (0x2C86, 'M', u'ⲇ'),
+    (0x2C87, 'V'),
+    (0x2C88, 'M', u'ⲉ'),
+    (0x2C89, 'V'),
+    (0x2C8A, 'M', u'ⲋ'),
+    (0x2C8B, 'V'),
+    (0x2C8C, 'M', u'ⲍ'),
+    (0x2C8D, 'V'),
+    (0x2C8E, 'M', u'ⲏ'),
+    (0x2C8F, 'V'),
+    (0x2C90, 'M', u'ⲑ'),
+    (0x2C91, 'V'),
+    (0x2C92, 'M', u'ⲓ'),
+    (0x2C93, 'V'),
+    (0x2C94, 'M', u'ⲕ'),
+    (0x2C95, 'V'),
+    (0x2C96, 'M', u'ⲗ'),
+    (0x2C97, 'V'),
+    (0x2C98, 'M', u'ⲙ'),
+    (0x2C99, 'V'),
+    (0x2C9A, 'M', u'ⲛ'),
+    (0x2C9B, 'V'),
+    (0x2C9C, 'M', u'ⲝ'),
+    (0x2C9D, 'V'),
+    (0x2C9E, 'M', u'ⲟ'),
+    (0x2C9F, 'V'),
+    (0x2CA0, 'M', u'ⲡ'),
+    (0x2CA1, 'V'),
+    (0x2CA2, 'M', u'ⲣ'),
+    (0x2CA3, 'V'),
+    (0x2CA4, 'M', u'ⲥ'),
+    (0x2CA5, 'V'),
+    (0x2CA6, 'M', u'ⲧ'),
+    (0x2CA7, 'V'),
+    (0x2CA8, 'M', u'ⲩ'),
+    (0x2CA9, 'V'),
+    (0x2CAA, 'M', u'ⲫ'),
+    (0x2CAB, 'V'),
+    (0x2CAC, 'M', u'ⲭ'),
+    (0x2CAD, 'V'),
+    (0x2CAE, 'M', u'ⲯ'),
+    (0x2CAF, 'V'),
+    (0x2CB0, 'M', u'ⲱ'),
+    (0x2CB1, 'V'),
+    (0x2CB2, 'M', u'ⲳ'),
+    (0x2CB3, 'V'),
+    (0x2CB4, 'M', u'ⲵ'),
+    (0x2CB5, 'V'),
+    (0x2CB6, 'M', u'ⲷ'),
+    (0x2CB7, 'V'),
+    (0x2CB8, 'M', u'ⲹ'),
+    (0x2CB9, 'V'),
+    (0x2CBA, 'M', u'ⲻ'),
+    (0x2CBB, 'V'),
+    (0x2CBC, 'M', u'ⲽ'),
+    (0x2CBD, 'V'),
+    (0x2CBE, 'M', u'ⲿ'),
+    (0x2CBF, 'V'),
+    (0x2CC0, 'M', u'ⳁ'),
+    (0x2CC1, 'V'),
+    (0x2CC2, 'M', u'ⳃ'),
+    (0x2CC3, 'V'),
+    (0x2CC4, 'M', u'ⳅ'),
+    (0x2CC5, 'V'),
+    (0x2CC6, 'M', u'ⳇ'),
+    (0x2CC7, 'V'),
+    (0x2CC8, 'M', u'ⳉ'),
+    (0x2CC9, 'V'),
+    (0x2CCA, 'M', u'ⳋ'),
+    (0x2CCB, 'V'),
+    (0x2CCC, 'M', u'ⳍ'),
+    (0x2CCD, 'V'),
+    (0x2CCE, 'M', u'ⳏ'),
+    (0x2CCF, 'V'),
+    (0x2CD0, 'M', u'ⳑ'),
+    (0x2CD1, 'V'),
+    (0x2CD2, 'M', u'ⳓ'),
+    (0x2CD3, 'V'),
+    (0x2CD4, 'M', u'ⳕ'),
+    (0x2CD5, 'V'),
+    (0x2CD6, 'M', u'ⳗ'),
+    (0x2CD7, 'V'),
+    (0x2CD8, 'M', u'ⳙ'),
+    (0x2CD9, 'V'),
+    (0x2CDA, 'M', u'ⳛ'),
+    ]
+
+def _seg_26():
+    return [
+    (0x2CDB, 'V'),
+    (0x2CDC, 'M', u'ⳝ'),
+    (0x2CDD, 'V'),
+    (0x2CDE, 'M', u'ⳟ'),
+    (0x2CDF, 'V'),
+    (0x2CE0, 'M', u'ⳡ'),
+    (0x2CE1, 'V'),
+    (0x2CE2, 'M', u'ⳣ'),
+    (0x2CE3, 'V'),
+    (0x2CEB, 'M', u'ⳬ'),
+    (0x2CEC, 'V'),
+    (0x2CED, 'M', u'ⳮ'),
+    (0x2CEE, 'V'),
+    (0x2CF2, 'M', u'ⳳ'),
+    (0x2CF3, 'V'),
+    (0x2CF4, 'X'),
+    (0x2CF9, 'V'),
+    (0x2D26, 'X'),
+    (0x2D27, 'V'),
+    (0x2D28, 'X'),
+    (0x2D2D, 'V'),
+    (0x2D2E, 'X'),
+    (0x2D30, 'V'),
+    (0x2D68, 'X'),
+    (0x2D6F, 'M', u'ⵡ'),
+    (0x2D70, 'V'),
+    (0x2D71, 'X'),
+    (0x2D7F, 'V'),
+    (0x2D97, 'X'),
+    (0x2DA0, 'V'),
+    (0x2DA7, 'X'),
+    (0x2DA8, 'V'),
+    (0x2DAF, 'X'),
+    (0x2DB0, 'V'),
+    (0x2DB7, 'X'),
+    (0x2DB8, 'V'),
+    (0x2DBF, 'X'),
+    (0x2DC0, 'V'),
+    (0x2DC7, 'X'),
+    (0x2DC8, 'V'),
+    (0x2DCF, 'X'),
+    (0x2DD0, 'V'),
+    (0x2DD7, 'X'),
+    (0x2DD8, 'V'),
+    (0x2DDF, 'X'),
+    (0x2DE0, 'V'),
+    (0x2E4F, 'X'),
+    (0x2E80, 'V'),
+    (0x2E9A, 'X'),
+    (0x2E9B, 'V'),
+    (0x2E9F, 'M', u'母'),
+    (0x2EA0, 'V'),
+    (0x2EF3, 'M', u'龟'),
+    (0x2EF4, 'X'),
+    (0x2F00, 'M', u'一'),
+    (0x2F01, 'M', u'丨'),
+    (0x2F02, 'M', u'丶'),
+    (0x2F03, 'M', u'丿'),
+    (0x2F04, 'M', u'乙'),
+    (0x2F05, 'M', u'亅'),
+    (0x2F06, 'M', u'二'),
+    (0x2F07, 'M', u'亠'),
+    (0x2F08, 'M', u'人'),
+    (0x2F09, 'M', u'儿'),
+    (0x2F0A, 'M', u'入'),
+    (0x2F0B, 'M', u'八'),
+    (0x2F0C, 'M', u'冂'),
+    (0x2F0D, 'M', u'冖'),
+    (0x2F0E, 'M', u'冫'),
+    (0x2F0F, 'M', u'几'),
+    (0x2F10, 'M', u'凵'),
+    (0x2F11, 'M', u'刀'),
+    (0x2F12, 'M', u'力'),
+    (0x2F13, 'M', u'勹'),
+    (0x2F14, 'M', u'匕'),
+    (0x2F15, 'M', u'匚'),
+    (0x2F16, 'M', u'匸'),
+    (0x2F17, 'M', u'十'),
+    (0x2F18, 'M', u'卜'),
+    (0x2F19, 'M', u'卩'),
+    (0x2F1A, 'M', u'厂'),
+    (0x2F1B, 'M', u'厶'),
+    (0x2F1C, 'M', u'又'),
+    (0x2F1D, 'M', u'口'),
+    (0x2F1E, 'M', u'囗'),
+    (0x2F1F, 'M', u'土'),
+    (0x2F20, 'M', u'士'),
+    (0x2F21, 'M', u'夂'),
+    (0x2F22, 'M', u'夊'),
+    (0x2F23, 'M', u'夕'),
+    (0x2F24, 'M', u'大'),
+    (0x2F25, 'M', u'女'),
+    (0x2F26, 'M', u'子'),
+    (0x2F27, 'M', u'宀'),
+    (0x2F28, 'M', u'寸'),
+    (0x2F29, 'M', u'小'),
+    (0x2F2A, 'M', u'尢'),
+    (0x2F2B, 'M', u'尸'),
+    (0x2F2C, 'M', u'屮'),
+    (0x2F2D, 'M', u'山'),
+    ]
+
+def _seg_27():
+    return [
+    (0x2F2E, 'M', u'巛'),
+    (0x2F2F, 'M', u'工'),
+    (0x2F30, 'M', u'己'),
+    (0x2F31, 'M', u'巾'),
+    (0x2F32, 'M', u'干'),
+    (0x2F33, 'M', u'幺'),
+    (0x2F34, 'M', u'广'),
+    (0x2F35, 'M', u'廴'),
+    (0x2F36, 'M', u'廾'),
+    (0x2F37, 'M', u'弋'),
+    (0x2F38, 'M', u'弓'),
+    (0x2F39, 'M', u'彐'),
+    (0x2F3A, 'M', u'彡'),
+    (0x2F3B, 'M', u'彳'),
+    (0x2F3C, 'M', u'心'),
+    (0x2F3D, 'M', u'戈'),
+    (0x2F3E, 'M', u'戶'),
+    (0x2F3F, 'M', u'手'),
+    (0x2F40, 'M', u'支'),
+    (0x2F41, 'M', u'攴'),
+    (0x2F42, 'M', u'文'),
+    (0x2F43, 'M', u'斗'),
+    (0x2F44, 'M', u'斤'),
+    (0x2F45, 'M', u'方'),
+    (0x2F46, 'M', u'无'),
+    (0x2F47, 'M', u'日'),
+    (0x2F48, 'M', u'曰'),
+    (0x2F49, 'M', u'月'),
+    (0x2F4A, 'M', u'木'),
+    (0x2F4B, 'M', u'欠'),
+    (0x2F4C, 'M', u'止'),
+    (0x2F4D, 'M', u'歹'),
+    (0x2F4E, 'M', u'殳'),
+    (0x2F4F, 'M', u'毋'),
+    (0x2F50, 'M', u'比'),
+    (0x2F51, 'M', u'毛'),
+    (0x2F52, 'M', u'氏'),
+    (0x2F53, 'M', u'气'),
+    (0x2F54, 'M', u'水'),
+    (0x2F55, 'M', u'火'),
+    (0x2F56, 'M', u'爪'),
+    (0x2F57, 'M', u'父'),
+    (0x2F58, 'M', u'爻'),
+    (0x2F59, 'M', u'爿'),
+    (0x2F5A, 'M', u'片'),
+    (0x2F5B, 'M', u'牙'),
+    (0x2F5C, 'M', u'牛'),
+    (0x2F5D, 'M', u'犬'),
+    (0x2F5E, 'M', u'玄'),
+    (0x2F5F, 'M', u'玉'),
+    (0x2F60, 'M', u'瓜'),
+    (0x2F61, 'M', u'瓦'),
+    (0x2F62, 'M', u'甘'),
+    (0x2F63, 'M', u'生'),
+    (0x2F64, 'M', u'用'),
+    (0x2F65, 'M', u'田'),
+    (0x2F66, 'M', u'疋'),
+    (0x2F67, 'M', u'疒'),
+    (0x2F68, 'M', u'癶'),
+    (0x2F69, 'M', u'白'),
+    (0x2F6A, 'M', u'皮'),
+    (0x2F6B, 'M', u'皿'),
+    (0x2F6C, 'M', u'目'),
+    (0x2F6D, 'M', u'矛'),
+    (0x2F6E, 'M', u'矢'),
+    (0x2F6F, 'M', u'石'),
+    (0x2F70, 'M', u'示'),
+    (0x2F71, 'M', u'禸'),
+    (0x2F72, 'M', u'禾'),
+    (0x2F73, 'M', u'穴'),
+    (0x2F74, 'M', u'立'),
+    (0x2F75, 'M', u'竹'),
+    (0x2F76, 'M', u'米'),
+    (0x2F77, 'M', u'糸'),
+    (0x2F78, 'M', u'缶'),
+    (0x2F79, 'M', u'网'),
+    (0x2F7A, 'M', u'羊'),
+    (0x2F7B, 'M', u'羽'),
+    (0x2F7C, 'M', u'老'),
+    (0x2F7D, 'M', u'而'),
+    (0x2F7E, 'M', u'耒'),
+    (0x2F7F, 'M', u'耳'),
+    (0x2F80, 'M', u'聿'),
+    (0x2F81, 'M', u'肉'),
+    (0x2F82, 'M', u'臣'),
+    (0x2F83, 'M', u'自'),
+    (0x2F84, 'M', u'至'),
+    (0x2F85, 'M', u'臼'),
+    (0x2F86, 'M', u'舌'),
+    (0x2F87, 'M', u'舛'),
+    (0x2F88, 'M', u'舟'),
+    (0x2F89, 'M', u'艮'),
+    (0x2F8A, 'M', u'色'),
+    (0x2F8B, 'M', u'艸'),
+    (0x2F8C, 'M', u'虍'),
+    (0x2F8D, 'M', u'虫'),
+    (0x2F8E, 'M', u'血'),
+    (0x2F8F, 'M', u'行'),
+    (0x2F90, 'M', u'衣'),
+    (0x2F91, 'M', u'襾'),
+    ]
+
+def _seg_28():
+    return [
+    (0x2F92, 'M', u'見'),
+    (0x2F93, 'M', u'角'),
+    (0x2F94, 'M', u'言'),
+    (0x2F95, 'M', u'谷'),
+    (0x2F96, 'M', u'豆'),
+    (0x2F97, 'M', u'豕'),
+    (0x2F98, 'M', u'豸'),
+    (0x2F99, 'M', u'貝'),
+    (0x2F9A, 'M', u'赤'),
+    (0x2F9B, 'M', u'走'),
+    (0x2F9C, 'M', u'足'),
+    (0x2F9D, 'M', u'身'),
+    (0x2F9E, 'M', u'車'),
+    (0x2F9F, 'M', u'辛'),
+    (0x2FA0, 'M', u'辰'),
+    (0x2FA1, 'M', u'辵'),
+    (0x2FA2, 'M', u'邑'),
+    (0x2FA3, 'M', u'酉'),
+    (0x2FA4, 'M', u'釆'),
+    (0x2FA5, 'M', u'里'),
+    (0x2FA6, 'M', u'金'),
+    (0x2FA7, 'M', u'長'),
+    (0x2FA8, 'M', u'門'),
+    (0x2FA9, 'M', u'阜'),
+    (0x2FAA, 'M', u'隶'),
+    (0x2FAB, 'M', u'隹'),
+    (0x2FAC, 'M', u'雨'),
+    (0x2FAD, 'M', u'靑'),
+    (0x2FAE, 'M', u'非'),
+    (0x2FAF, 'M', u'面'),
+    (0x2FB0, 'M', u'革'),
+    (0x2FB1, 'M', u'韋'),
+    (0x2FB2, 'M', u'韭'),
+    (0x2FB3, 'M', u'音'),
+    (0x2FB4, 'M', u'頁'),
+    (0x2FB5, 'M', u'風'),
+    (0x2FB6, 'M', u'飛'),
+    (0x2FB7, 'M', u'食'),
+    (0x2FB8, 'M', u'首'),
+    (0x2FB9, 'M', u'香'),
+    (0x2FBA, 'M', u'馬'),
+    (0x2FBB, 'M', u'骨'),
+    (0x2FBC, 'M', u'高'),
+    (0x2FBD, 'M', u'髟'),
+    (0x2FBE, 'M', u'鬥'),
+    (0x2FBF, 'M', u'鬯'),
+    (0x2FC0, 'M', u'鬲'),
+    (0x2FC1, 'M', u'鬼'),
+    (0x2FC2, 'M', u'魚'),
+    (0x2FC3, 'M', u'鳥'),
+    (0x2FC4, 'M', u'鹵'),
+    (0x2FC5, 'M', u'鹿'),
+    (0x2FC6, 'M', u'麥'),
+    (0x2FC7, 'M', u'麻'),
+    (0x2FC8, 'M', u'黃'),
+    (0x2FC9, 'M', u'黍'),
+    (0x2FCA, 'M', u'黑'),
+    (0x2FCB, 'M', u'黹'),
+    (0x2FCC, 'M', u'黽'),
+    (0x2FCD, 'M', u'鼎'),
+    (0x2FCE, 'M', u'鼓'),
+    (0x2FCF, 'M', u'鼠'),
+    (0x2FD0, 'M', u'鼻'),
+    (0x2FD1, 'M', u'齊'),
+    (0x2FD2, 'M', u'齒'),
+    (0x2FD3, 'M', u'龍'),
+    (0x2FD4, 'M', u'龜'),
+    (0x2FD5, 'M', u'龠'),
+    (0x2FD6, 'X'),
+    (0x3000, '3', u' '),
+    (0x3001, 'V'),
+    (0x3002, 'M', u'.'),
+    (0x3003, 'V'),
+    (0x3036, 'M', u'〒'),
+    (0x3037, 'V'),
+    (0x3038, 'M', u'十'),
+    (0x3039, 'M', u'卄'),
+    (0x303A, 'M', u'卅'),
+    (0x303B, 'V'),
+    (0x3040, 'X'),
+    (0x3041, 'V'),
+    (0x3097, 'X'),
+    (0x3099, 'V'),
+    (0x309B, '3', u' ゙'),
+    (0x309C, '3', u' ゚'),
+    (0x309D, 'V'),
+    (0x309F, 'M', u'より'),
+    (0x30A0, 'V'),
+    (0x30FF, 'M', u'コト'),
+    (0x3100, 'X'),
+    (0x3105, 'V'),
+    (0x3130, 'X'),
+    (0x3131, 'M', u'ᄀ'),
+    (0x3132, 'M', u'ᄁ'),
+    (0x3133, 'M', u'ᆪ'),
+    (0x3134, 'M', u'ᄂ'),
+    (0x3135, 'M', u'ᆬ'),
+    (0x3136, 'M', u'ᆭ'),
+    (0x3137, 'M', u'ᄃ'),
+    (0x3138, 'M', u'ᄄ'),
+    ]
+
+def _seg_29():
+    return [
+    (0x3139, 'M', u'ᄅ'),
+    (0x313A, 'M', u'ᆰ'),
+    (0x313B, 'M', u'ᆱ'),
+    (0x313C, 'M', u'ᆲ'),
+    (0x313D, 'M', u'ᆳ'),
+    (0x313E, 'M', u'ᆴ'),
+    (0x313F, 'M', u'ᆵ'),
+    (0x3140, 'M', u'ᄚ'),
+    (0x3141, 'M', u'ᄆ'),
+    (0x3142, 'M', u'ᄇ'),
+    (0x3143, 'M', u'ᄈ'),
+    (0x3144, 'M', u'ᄡ'),
+    (0x3145, 'M', u'ᄉ'),
+    (0x3146, 'M', u'ᄊ'),
+    (0x3147, 'M', u'ᄋ'),
+    (0x3148, 'M', u'ᄌ'),
+    (0x3149, 'M', u'ᄍ'),
+    (0x314A, 'M', u'ᄎ'),
+    (0x314B, 'M', u'ᄏ'),
+    (0x314C, 'M', u'ᄐ'),
+    (0x314D, 'M', u'ᄑ'),
+    (0x314E, 'M', u'ᄒ'),
+    (0x314F, 'M', u'ᅡ'),
+    (0x3150, 'M', u'ᅢ'),
+    (0x3151, 'M', u'ᅣ'),
+    (0x3152, 'M', u'ᅤ'),
+    (0x3153, 'M', u'ᅥ'),
+    (0x3154, 'M', u'ᅦ'),
+    (0x3155, 'M', u'ᅧ'),
+    (0x3156, 'M', u'ᅨ'),
+    (0x3157, 'M', u'ᅩ'),
+    (0x3158, 'M', u'ᅪ'),
+    (0x3159, 'M', u'ᅫ'),
+    (0x315A, 'M', u'ᅬ'),
+    (0x315B, 'M', u'ᅭ'),
+    (0x315C, 'M', u'ᅮ'),
+    (0x315D, 'M', u'ᅯ'),
+    (0x315E, 'M', u'ᅰ'),
+    (0x315F, 'M', u'ᅱ'),
+    (0x3160, 'M', u'ᅲ'),
+    (0x3161, 'M', u'ᅳ'),
+    (0x3162, 'M', u'ᅴ'),
+    (0x3163, 'M', u'ᅵ'),
+    (0x3164, 'X'),
+    (0x3165, 'M', u'ᄔ'),
+    (0x3166, 'M', u'ᄕ'),
+    (0x3167, 'M', u'ᇇ'),
+    (0x3168, 'M', u'ᇈ'),
+    (0x3169, 'M', u'ᇌ'),
+    (0x316A, 'M', u'ᇎ'),
+    (0x316B, 'M', u'ᇓ'),
+    (0x316C, 'M', u'ᇗ'),
+    (0x316D, 'M', u'ᇙ'),
+    (0x316E, 'M', u'ᄜ'),
+    (0x316F, 'M', u'ᇝ'),
+    (0x3170, 'M', u'ᇟ'),
+    (0x3171, 'M', u'ᄝ'),
+    (0x3172, 'M', u'ᄞ'),
+    (0x3173, 'M', u'ᄠ'),
+    (0x3174, 'M', u'ᄢ'),
+    (0x3175, 'M', u'ᄣ'),
+    (0x3176, 'M', u'ᄧ'),
+    (0x3177, 'M', u'ᄩ'),
+    (0x3178, 'M', u'ᄫ'),
+    (0x3179, 'M', u'ᄬ'),
+    (0x317A, 'M', u'ᄭ'),
+    (0x317B, 'M', u'ᄮ'),
+    (0x317C, 'M', u'ᄯ'),
+    (0x317D, 'M', u'ᄲ'),
+    (0x317E, 'M', u'ᄶ'),
+    (0x317F, 'M', u'ᅀ'),
+    (0x3180, 'M', u'ᅇ'),
+    (0x3181, 'M', u'ᅌ'),
+    (0x3182, 'M', u'ᇱ'),
+    (0x3183, 'M', u'ᇲ'),
+    (0x3184, 'M', u'ᅗ'),
+    (0x3185, 'M', u'ᅘ'),
+    (0x3186, 'M', u'ᅙ'),
+    (0x3187, 'M', u'ᆄ'),
+    (0x3188, 'M', u'ᆅ'),
+    (0x3189, 'M', u'ᆈ'),
+    (0x318A, 'M', u'ᆑ'),
+    (0x318B, 'M', u'ᆒ'),
+    (0x318C, 'M', u'ᆔ'),
+    (0x318D, 'M', u'ᆞ'),
+    (0x318E, 'M', u'ᆡ'),
+    (0x318F, 'X'),
+    (0x3190, 'V'),
+    (0x3192, 'M', u'一'),
+    (0x3193, 'M', u'二'),
+    (0x3194, 'M', u'三'),
+    (0x3195, 'M', u'四'),
+    (0x3196, 'M', u'上'),
+    (0x3197, 'M', u'中'),
+    (0x3198, 'M', u'下'),
+    (0x3199, 'M', u'甲'),
+    (0x319A, 'M', u'乙'),
+    (0x319B, 'M', u'丙'),
+    (0x319C, 'M', u'丁'),
+    (0x319D, 'M', u'天'),
+    ]
+
+def _seg_30():
+    return [
+    (0x319E, 'M', u'地'),
+    (0x319F, 'M', u'人'),
+    (0x31A0, 'V'),
+    (0x31BB, 'X'),
+    (0x31C0, 'V'),
+    (0x31E4, 'X'),
+    (0x31F0, 'V'),
+    (0x3200, '3', u'(ᄀ)'),
+    (0x3201, '3', u'(ᄂ)'),
+    (0x3202, '3', u'(ᄃ)'),
+    (0x3203, '3', u'(ᄅ)'),
+    (0x3204, '3', u'(ᄆ)'),
+    (0x3205, '3', u'(ᄇ)'),
+    (0x3206, '3', u'(ᄉ)'),
+    (0x3207, '3', u'(ᄋ)'),
+    (0x3208, '3', u'(ᄌ)'),
+    (0x3209, '3', u'(ᄎ)'),
+    (0x320A, '3', u'(ᄏ)'),
+    (0x320B, '3', u'(ᄐ)'),
+    (0x320C, '3', u'(ᄑ)'),
+    (0x320D, '3', u'(ᄒ)'),
+    (0x320E, '3', u'(가)'),
+    (0x320F, '3', u'(나)'),
+    (0x3210, '3', u'(다)'),
+    (0x3211, '3', u'(라)'),
+    (0x3212, '3', u'(마)'),
+    (0x3213, '3', u'(바)'),
+    (0x3214, '3', u'(사)'),
+    (0x3215, '3', u'(아)'),
+    (0x3216, '3', u'(자)'),
+    (0x3217, '3', u'(차)'),
+    (0x3218, '3', u'(카)'),
+    (0x3219, '3', u'(타)'),
+    (0x321A, '3', u'(파)'),
+    (0x321B, '3', u'(하)'),
+    (0x321C, '3', u'(주)'),
+    (0x321D, '3', u'(오전)'),
+    (0x321E, '3', u'(오후)'),
+    (0x321F, 'X'),
+    (0x3220, '3', u'(一)'),
+    (0x3221, '3', u'(二)'),
+    (0x3222, '3', u'(三)'),
+    (0x3223, '3', u'(四)'),
+    (0x3224, '3', u'(五)'),
+    (0x3225, '3', u'(六)'),
+    (0x3226, '3', u'(七)'),
+    (0x3227, '3', u'(八)'),
+    (0x3228, '3', u'(九)'),
+    (0x3229, '3', u'(十)'),
+    (0x322A, '3', u'(月)'),
+    (0x322B, '3', u'(火)'),
+    (0x322C, '3', u'(水)'),
+    (0x322D, '3', u'(木)'),
+    (0x322E, '3', u'(金)'),
+    (0x322F, '3', u'(土)'),
+    (0x3230, '3', u'(日)'),
+    (0x3231, '3', u'(株)'),
+    (0x3232, '3', u'(有)'),
+    (0x3233, '3', u'(社)'),
+    (0x3234, '3', u'(名)'),
+    (0x3235, '3', u'(特)'),
+    (0x3236, '3', u'(財)'),
+    (0x3237, '3', u'(祝)'),
+    (0x3238, '3', u'(労)'),
+    (0x3239, '3', u'(代)'),
+    (0x323A, '3', u'(呼)'),
+    (0x323B, '3', u'(学)'),
+    (0x323C, '3', u'(監)'),
+    (0x323D, '3', u'(企)'),
+    (0x323E, '3', u'(資)'),
+    (0x323F, '3', u'(協)'),
+    (0x3240, '3', u'(祭)'),
+    (0x3241, '3', u'(休)'),
+    (0x3242, '3', u'(自)'),
+    (0x3243, '3', u'(至)'),
+    (0x3244, 'M', u'問'),
+    (0x3245, 'M', u'幼'),
+    (0x3246, 'M', u'文'),
+    (0x3247, 'M', u'箏'),
+    (0x3248, 'V'),
+    (0x3250, 'M', u'pte'),
+    (0x3251, 'M', u'21'),
+    (0x3252, 'M', u'22'),
+    (0x3253, 'M', u'23'),
+    (0x3254, 'M', u'24'),
+    (0x3255, 'M', u'25'),
+    (0x3256, 'M', u'26'),
+    (0x3257, 'M', u'27'),
+    (0x3258, 'M', u'28'),
+    (0x3259, 'M', u'29'),
+    (0x325A, 'M', u'30'),
+    (0x325B, 'M', u'31'),
+    (0x325C, 'M', u'32'),
+    (0x325D, 'M', u'33'),
+    (0x325E, 'M', u'34'),
+    (0x325F, 'M', u'35'),
+    (0x3260, 'M', u'ᄀ'),
+    (0x3261, 'M', u'ᄂ'),
+    (0x3262, 'M', u'ᄃ'),
+    (0x3263, 'M', u'ᄅ'),
+    ]
+
+def _seg_31():
+    return [
+    (0x3264, 'M', u'ᄆ'),
+    (0x3265, 'M', u'ᄇ'),
+    (0x3266, 'M', u'ᄉ'),
+    (0x3267, 'M', u'ᄋ'),
+    (0x3268, 'M', u'ᄌ'),
+    (0x3269, 'M', u'ᄎ'),
+    (0x326A, 'M', u'ᄏ'),
+    (0x326B, 'M', u'ᄐ'),
+    (0x326C, 'M', u'ᄑ'),
+    (0x326D, 'M', u'ᄒ'),
+    (0x326E, 'M', u'가'),
+    (0x326F, 'M', u'나'),
+    (0x3270, 'M', u'다'),
+    (0x3271, 'M', u'라'),
+    (0x3272, 'M', u'마'),
+    (0x3273, 'M', u'바'),
+    (0x3274, 'M', u'사'),
+    (0x3275, 'M', u'아'),
+    (0x3276, 'M', u'자'),
+    (0x3277, 'M', u'차'),
+    (0x3278, 'M', u'카'),
+    (0x3279, 'M', u'타'),
+    (0x327A, 'M', u'파'),
+    (0x327B, 'M', u'하'),
+    (0x327C, 'M', u'참고'),
+    (0x327D, 'M', u'주의'),
+    (0x327E, 'M', u'우'),
+    (0x327F, 'V'),
+    (0x3280, 'M', u'一'),
+    (0x3281, 'M', u'二'),
+    (0x3282, 'M', u'三'),
+    (0x3283, 'M', u'四'),
+    (0x3284, 'M', u'五'),
+    (0x3285, 'M', u'六'),
+    (0x3286, 'M', u'七'),
+    (0x3287, 'M', u'八'),
+    (0x3288, 'M', u'九'),
+    (0x3289, 'M', u'十'),
+    (0x328A, 'M', u'月'),
+    (0x328B, 'M', u'火'),
+    (0x328C, 'M', u'水'),
+    (0x328D, 'M', u'木'),
+    (0x328E, 'M', u'金'),
+    (0x328F, 'M', u'土'),
+    (0x3290, 'M', u'日'),
+    (0x3291, 'M', u'株'),
+    (0x3292, 'M', u'有'),
+    (0x3293, 'M', u'社'),
+    (0x3294, 'M', u'名'),
+    (0x3295, 'M', u'特'),
+    (0x3296, 'M', u'財'),
+    (0x3297, 'M', u'祝'),
+    (0x3298, 'M', u'労'),
+    (0x3299, 'M', u'秘'),
+    (0x329A, 'M', u'男'),
+    (0x329B, 'M', u'女'),
+    (0x329C, 'M', u'適'),
+    (0x329D, 'M', u'優'),
+    (0x329E, 'M', u'印'),
+    (0x329F, 'M', u'注'),
+    (0x32A0, 'M', u'項'),
+    (0x32A1, 'M', u'休'),
+    (0x32A2, 'M', u'写'),
+    (0x32A3, 'M', u'正'),
+    (0x32A4, 'M', u'上'),
+    (0x32A5, 'M', u'中'),
+    (0x32A6, 'M', u'下'),
+    (0x32A7, 'M', u'左'),
+    (0x32A8, 'M', u'右'),
+    (0x32A9, 'M', u'医'),
+    (0x32AA, 'M', u'宗'),
+    (0x32AB, 'M', u'学'),
+    (0x32AC, 'M', u'監'),
+    (0x32AD, 'M', u'企'),
+    (0x32AE, 'M', u'資'),
+    (0x32AF, 'M', u'協'),
+    (0x32B0, 'M', u'夜'),
+    (0x32B1, 'M', u'36'),
+    (0x32B2, 'M', u'37'),
+    (0x32B3, 'M', u'38'),
+    (0x32B4, 'M', u'39'),
+    (0x32B5, 'M', u'40'),
+    (0x32B6, 'M', u'41'),
+    (0x32B7, 'M', u'42'),
+    (0x32B8, 'M', u'43'),
+    (0x32B9, 'M', u'44'),
+    (0x32BA, 'M', u'45'),
+    (0x32BB, 'M', u'46'),
+    (0x32BC, 'M', u'47'),
+    (0x32BD, 'M', u'48'),
+    (0x32BE, 'M', u'49'),
+    (0x32BF, 'M', u'50'),
+    (0x32C0, 'M', u'1月'),
+    (0x32C1, 'M', u'2月'),
+    (0x32C2, 'M', u'3月'),
+    (0x32C3, 'M', u'4月'),
+    (0x32C4, 'M', u'5月'),
+    (0x32C5, 'M', u'6月'),
+    (0x32C6, 'M', u'7月'),
+    (0x32C7, 'M', u'8月'),
+    ]
+
+def _seg_32():
+    return [
+    (0x32C8, 'M', u'9月'),
+    (0x32C9, 'M', u'10月'),
+    (0x32CA, 'M', u'11月'),
+    (0x32CB, 'M', u'12月'),
+    (0x32CC, 'M', u'hg'),
+    (0x32CD, 'M', u'erg'),
+    (0x32CE, 'M', u'ev'),
+    (0x32CF, 'M', u'ltd'),
+    (0x32D0, 'M', u'ア'),
+    (0x32D1, 'M', u'イ'),
+    (0x32D2, 'M', u'ウ'),
+    (0x32D3, 'M', u'エ'),
+    (0x32D4, 'M', u'オ'),
+    (0x32D5, 'M', u'カ'),
+    (0x32D6, 'M', u'キ'),
+    (0x32D7, 'M', u'ク'),
+    (0x32D8, 'M', u'ケ'),
+    (0x32D9, 'M', u'コ'),
+    (0x32DA, 'M', u'サ'),
+    (0x32DB, 'M', u'シ'),
+    (0x32DC, 'M', u'ス'),
+    (0x32DD, 'M', u'セ'),
+    (0x32DE, 'M', u'ソ'),
+    (0x32DF, 'M', u'タ'),
+    (0x32E0, 'M', u'チ'),
+    (0x32E1, 'M', u'ツ'),
+    (0x32E2, 'M', u'テ'),
+    (0x32E3, 'M', u'ト'),
+    (0x32E4, 'M', u'ナ'),
+    (0x32E5, 'M', u'ニ'),
+    (0x32E6, 'M', u'ヌ'),
+    (0x32E7, 'M', u'ネ'),
+    (0x32E8, 'M', u'ノ'),
+    (0x32E9, 'M', u'ハ'),
+    (0x32EA, 'M', u'ヒ'),
+    (0x32EB, 'M', u'フ'),
+    (0x32EC, 'M', u'ヘ'),
+    (0x32ED, 'M', u'ホ'),
+    (0x32EE, 'M', u'マ'),
+    (0x32EF, 'M', u'ミ'),
+    (0x32F0, 'M', u'ム'),
+    (0x32F1, 'M', u'メ'),
+    (0x32F2, 'M', u'モ'),
+    (0x32F3, 'M', u'ヤ'),
+    (0x32F4, 'M', u'ユ'),
+    (0x32F5, 'M', u'ヨ'),
+    (0x32F6, 'M', u'ラ'),
+    (0x32F7, 'M', u'リ'),
+    (0x32F8, 'M', u'ル'),
+    (0x32F9, 'M', u'レ'),
+    (0x32FA, 'M', u'ロ'),
+    (0x32FB, 'M', u'ワ'),
+    (0x32FC, 'M', u'ヰ'),
+    (0x32FD, 'M', u'ヱ'),
+    (0x32FE, 'M', u'ヲ'),
+    (0x32FF, 'X'),
+    (0x3300, 'M', u'アパート'),
+    (0x3301, 'M', u'アルファ'),
+    (0x3302, 'M', u'アンペア'),
+    (0x3303, 'M', u'アール'),
+    (0x3304, 'M', u'イニング'),
+    (0x3305, 'M', u'インチ'),
+    (0x3306, 'M', u'ウォン'),
+    (0x3307, 'M', u'エスクード'),
+    (0x3308, 'M', u'エーカー'),
+    (0x3309, 'M', u'オンス'),
+    (0x330A, 'M', u'オーム'),
+    (0x330B, 'M', u'カイリ'),
+    (0x330C, 'M', u'カラット'),
+    (0x330D, 'M', u'カロリー'),
+    (0x330E, 'M', u'ガロン'),
+    (0x330F, 'M', u'ガンマ'),
+    (0x3310, 'M', u'ギガ'),
+    (0x3311, 'M', u'ギニー'),
+    (0x3312, 'M', u'キュリー'),
+    (0x3313, 'M', u'ギルダー'),
+    (0x3314, 'M', u'キロ'),
+    (0x3315, 'M', u'キログラム'),
+    (0x3316, 'M', u'キロメートル'),
+    (0x3317, 'M', u'キロワット'),
+    (0x3318, 'M', u'グラム'),
+    (0x3319, 'M', u'グラムトン'),
+    (0x331A, 'M', u'クルゼイロ'),
+    (0x331B, 'M', u'クローネ'),
+    (0x331C, 'M', u'ケース'),
+    (0x331D, 'M', u'コルナ'),
+    (0x331E, 'M', u'コーポ'),
+    (0x331F, 'M', u'サイクル'),
+    (0x3320, 'M', u'サンチーム'),
+    (0x3321, 'M', u'シリング'),
+    (0x3322, 'M', u'センチ'),
+    (0x3323, 'M', u'セント'),
+    (0x3324, 'M', u'ダース'),
+    (0x3325, 'M', u'デシ'),
+    (0x3326, 'M', u'ドル'),
+    (0x3327, 'M', u'トン'),
+    (0x3328, 'M', u'ナノ'),
+    (0x3329, 'M', u'ノット'),
+    (0x332A, 'M', u'ハイツ'),
+    (0x332B, 'M', u'パーセント'),
+    ]
+
+def _seg_33():
+    return [
+    (0x332C, 'M', u'パーツ'),
+    (0x332D, 'M', u'バーレル'),
+    (0x332E, 'M', u'ピアストル'),
+    (0x332F, 'M', u'ピクル'),
+    (0x3330, 'M', u'ピコ'),
+    (0x3331, 'M', u'ビル'),
+    (0x3332, 'M', u'ファラッド'),
+    (0x3333, 'M', u'フィート'),
+    (0x3334, 'M', u'ブッシェル'),
+    (0x3335, 'M', u'フラン'),
+    (0x3336, 'M', u'ヘクタール'),
+    (0x3337, 'M', u'ペソ'),
+    (0x3338, 'M', u'ペニヒ'),
+    (0x3339, 'M', u'ヘルツ'),
+    (0x333A, 'M', u'ペンス'),
+    (0x333B, 'M', u'ページ'),
+    (0x333C, 'M', u'ベータ'),
+    (0x333D, 'M', u'ポイント'),
+    (0x333E, 'M', u'ボルト'),
+    (0x333F, 'M', u'ホン'),
+    (0x3340, 'M', u'ポンド'),
+    (0x3341, 'M', u'ホール'),
+    (0x3342, 'M', u'ホーン'),
+    (0x3343, 'M', u'マイクロ'),
+    (0x3344, 'M', u'マイル'),
+    (0x3345, 'M', u'マッハ'),
+    (0x3346, 'M', u'マルク'),
+    (0x3347, 'M', u'マンション'),
+    (0x3348, 'M', u'ミクロン'),
+    (0x3349, 'M', u'ミリ'),
+    (0x334A, 'M', u'ミリバール'),
+    (0x334B, 'M', u'メガ'),
+    (0x334C, 'M', u'メガトン'),
+    (0x334D, 'M', u'メートル'),
+    (0x334E, 'M', u'ヤード'),
+    (0x334F, 'M', u'ヤール'),
+    (0x3350, 'M', u'ユアン'),
+    (0x3351, 'M', u'リットル'),
+    (0x3352, 'M', u'リラ'),
+    (0x3353, 'M', u'ルピー'),
+    (0x3354, 'M', u'ルーブル'),
+    (0x3355, 'M', u'レム'),
+    (0x3356, 'M', u'レントゲン'),
+    (0x3357, 'M', u'ワット'),
+    (0x3358, 'M', u'0点'),
+    (0x3359, 'M', u'1点'),
+    (0x335A, 'M', u'2点'),
+    (0x335B, 'M', u'3点'),
+    (0x335C, 'M', u'4点'),
+    (0x335D, 'M', u'5点'),
+    (0x335E, 'M', u'6点'),
+    (0x335F, 'M', u'7点'),
+    (0x3360, 'M', u'8点'),
+    (0x3361, 'M', u'9点'),
+    (0x3362, 'M', u'10点'),
+    (0x3363, 'M', u'11点'),
+    (0x3364, 'M', u'12点'),
+    (0x3365, 'M', u'13点'),
+    (0x3366, 'M', u'14点'),
+    (0x3367, 'M', u'15点'),
+    (0x3368, 'M', u'16点'),
+    (0x3369, 'M', u'17点'),
+    (0x336A, 'M', u'18点'),
+    (0x336B, 'M', u'19点'),
+    (0x336C, 'M', u'20点'),
+    (0x336D, 'M', u'21点'),
+    (0x336E, 'M', u'22点'),
+    (0x336F, 'M', u'23点'),
+    (0x3370, 'M', u'24点'),
+    (0x3371, 'M', u'hpa'),
+    (0x3372, 'M', u'da'),
+    (0x3373, 'M', u'au'),
+    (0x3374, 'M', u'bar'),
+    (0x3375, 'M', u'ov'),
+    (0x3376, 'M', u'pc'),
+    (0x3377, 'M', u'dm'),
+    (0x3378, 'M', u'dm2'),
+    (0x3379, 'M', u'dm3'),
+    (0x337A, 'M', u'iu'),
+    (0x337B, 'M', u'平成'),
+    (0x337C, 'M', u'昭和'),
+    (0x337D, 'M', u'大正'),
+    (0x337E, 'M', u'明治'),
+    (0x337F, 'M', u'株式会社'),
+    (0x3380, 'M', u'pa'),
+    (0x3381, 'M', u'na'),
+    (0x3382, 'M', u'μa'),
+    (0x3383, 'M', u'ma'),
+    (0x3384, 'M', u'ka'),
+    (0x3385, 'M', u'kb'),
+    (0x3386, 'M', u'mb'),
+    (0x3387, 'M', u'gb'),
+    (0x3388, 'M', u'cal'),
+    (0x3389, 'M', u'kcal'),
+    (0x338A, 'M', u'pf'),
+    (0x338B, 'M', u'nf'),
+    (0x338C, 'M', u'μf'),
+    (0x338D, 'M', u'μg'),
+    (0x338E, 'M', u'mg'),
+    (0x338F, 'M', u'kg'),
+    ]
+
+def _seg_34():
+    return [
+    (0x3390, 'M', u'hz'),
+    (0x3391, 'M', u'khz'),
+    (0x3392, 'M', u'mhz'),
+    (0x3393, 'M', u'ghz'),
+    (0x3394, 'M', u'thz'),
+    (0x3395, 'M', u'μl'),
+    (0x3396, 'M', u'ml'),
+    (0x3397, 'M', u'dl'),
+    (0x3398, 'M', u'kl'),
+    (0x3399, 'M', u'fm'),
+    (0x339A, 'M', u'nm'),
+    (0x339B, 'M', u'μm'),
+    (0x339C, 'M', u'mm'),
+    (0x339D, 'M', u'cm'),
+    (0x339E, 'M', u'km'),
+    (0x339F, 'M', u'mm2'),
+    (0x33A0, 'M', u'cm2'),
+    (0x33A1, 'M', u'm2'),
+    (0x33A2, 'M', u'km2'),
+    (0x33A3, 'M', u'mm3'),
+    (0x33A4, 'M', u'cm3'),
+    (0x33A5, 'M', u'm3'),
+    (0x33A6, 'M', u'km3'),
+    (0x33A7, 'M', u'm∕s'),
+    (0x33A8, 'M', u'm∕s2'),
+    (0x33A9, 'M', u'pa'),
+    (0x33AA, 'M', u'kpa'),
+    (0x33AB, 'M', u'mpa'),
+    (0x33AC, 'M', u'gpa'),
+    (0x33AD, 'M', u'rad'),
+    (0x33AE, 'M', u'rad∕s'),
+    (0x33AF, 'M', u'rad∕s2'),
+    (0x33B0, 'M', u'ps'),
+    (0x33B1, 'M', u'ns'),
+    (0x33B2, 'M', u'μs'),
+    (0x33B3, 'M', u'ms'),
+    (0x33B4, 'M', u'pv'),
+    (0x33B5, 'M', u'nv'),
+    (0x33B6, 'M', u'μv'),
+    (0x33B7, 'M', u'mv'),
+    (0x33B8, 'M', u'kv'),
+    (0x33B9, 'M', u'mv'),
+    (0x33BA, 'M', u'pw'),
+    (0x33BB, 'M', u'nw'),
+    (0x33BC, 'M', u'μw'),
+    (0x33BD, 'M', u'mw'),
+    (0x33BE, 'M', u'kw'),
+    (0x33BF, 'M', u'mw'),
+    (0x33C0, 'M', u'kω'),
+    (0x33C1, 'M', u'mω'),
+    (0x33C2, 'X'),
+    (0x33C3, 'M', u'bq'),
+    (0x33C4, 'M', u'cc'),
+    (0x33C5, 'M', u'cd'),
+    (0x33C6, 'M', u'c∕kg'),
+    (0x33C7, 'X'),
+    (0x33C8, 'M', u'db'),
+    (0x33C9, 'M', u'gy'),
+    (0x33CA, 'M', u'ha'),
+    (0x33CB, 'M', u'hp'),
+    (0x33CC, 'M', u'in'),
+    (0x33CD, 'M', u'kk'),
+    (0x33CE, 'M', u'km'),
+    (0x33CF, 'M', u'kt'),
+    (0x33D0, 'M', u'lm'),
+    (0x33D1, 'M', u'ln'),
+    (0x33D2, 'M', u'log'),
+    (0x33D3, 'M', u'lx'),
+    (0x33D4, 'M', u'mb'),
+    (0x33D5, 'M', u'mil'),
+    (0x33D6, 'M', u'mol'),
+    (0x33D7, 'M', u'ph'),
+    (0x33D8, 'X'),
+    (0x33D9, 'M', u'ppm'),
+    (0x33DA, 'M', u'pr'),
+    (0x33DB, 'M', u'sr'),
+    (0x33DC, 'M', u'sv'),
+    (0x33DD, 'M', u'wb'),
+    (0x33DE, 'M', u'v∕m'),
+    (0x33DF, 'M', u'a∕m'),
+    (0x33E0, 'M', u'1日'),
+    (0x33E1, 'M', u'2日'),
+    (0x33E2, 'M', u'3日'),
+    (0x33E3, 'M', u'4日'),
+    (0x33E4, 'M', u'5日'),
+    (0x33E5, 'M', u'6日'),
+    (0x33E6, 'M', u'7日'),
+    (0x33E7, 'M', u'8日'),
+    (0x33E8, 'M', u'9日'),
+    (0x33E9, 'M', u'10日'),
+    (0x33EA, 'M', u'11日'),
+    (0x33EB, 'M', u'12日'),
+    (0x33EC, 'M', u'13日'),
+    (0x33ED, 'M', u'14日'),
+    (0x33EE, 'M', u'15日'),
+    (0x33EF, 'M', u'16日'),
+    (0x33F0, 'M', u'17日'),
+    (0x33F1, 'M', u'18日'),
+    (0x33F2, 'M', u'19日'),
+    (0x33F3, 'M', u'20日'),
+    ]
+
+def _seg_35():
+    return [
+    (0x33F4, 'M', u'21日'),
+    (0x33F5, 'M', u'22日'),
+    (0x33F6, 'M', u'23日'),
+    (0x33F7, 'M', u'24日'),
+    (0x33F8, 'M', u'25日'),
+    (0x33F9, 'M', u'26日'),
+    (0x33FA, 'M', u'27日'),
+    (0x33FB, 'M', u'28日'),
+    (0x33FC, 'M', u'29日'),
+    (0x33FD, 'M', u'30日'),
+    (0x33FE, 'M', u'31日'),
+    (0x33FF, 'M', u'gal'),
+    (0x3400, 'V'),
+    (0x4DB6, 'X'),
+    (0x4DC0, 'V'),
+    (0x9FF0, 'X'),
+    (0xA000, 'V'),
+    (0xA48D, 'X'),
+    (0xA490, 'V'),
+    (0xA4C7, 'X'),
+    (0xA4D0, 'V'),
+    (0xA62C, 'X'),
+    (0xA640, 'M', u'ꙁ'),
+    (0xA641, 'V'),
+    (0xA642, 'M', u'ꙃ'),
+    (0xA643, 'V'),
+    (0xA644, 'M', u'ꙅ'),
+    (0xA645, 'V'),
+    (0xA646, 'M', u'ꙇ'),
+    (0xA647, 'V'),
+    (0xA648, 'M', u'ꙉ'),
+    (0xA649, 'V'),
+    (0xA64A, 'M', u'ꙋ'),
+    (0xA64B, 'V'),
+    (0xA64C, 'M', u'ꙍ'),
+    (0xA64D, 'V'),
+    (0xA64E, 'M', u'ꙏ'),
+    (0xA64F, 'V'),
+    (0xA650, 'M', u'ꙑ'),
+    (0xA651, 'V'),
+    (0xA652, 'M', u'ꙓ'),
+    (0xA653, 'V'),
+    (0xA654, 'M', u'ꙕ'),
+    (0xA655, 'V'),
+    (0xA656, 'M', u'ꙗ'),
+    (0xA657, 'V'),
+    (0xA658, 'M', u'ꙙ'),
+    (0xA659, 'V'),
+    (0xA65A, 'M', u'ꙛ'),
+    (0xA65B, 'V'),
+    (0xA65C, 'M', u'ꙝ'),
+    (0xA65D, 'V'),
+    (0xA65E, 'M', u'ꙟ'),
+    (0xA65F, 'V'),
+    (0xA660, 'M', u'ꙡ'),
+    (0xA661, 'V'),
+    (0xA662, 'M', u'ꙣ'),
+    (0xA663, 'V'),
+    (0xA664, 'M', u'ꙥ'),
+    (0xA665, 'V'),
+    (0xA666, 'M', u'ꙧ'),
+    (0xA667, 'V'),
+    (0xA668, 'M', u'ꙩ'),
+    (0xA669, 'V'),
+    (0xA66A, 'M', u'ꙫ'),
+    (0xA66B, 'V'),
+    (0xA66C, 'M', u'ꙭ'),
+    (0xA66D, 'V'),
+    (0xA680, 'M', u'ꚁ'),
+    (0xA681, 'V'),
+    (0xA682, 'M', u'ꚃ'),
+    (0xA683, 'V'),
+    (0xA684, 'M', u'ꚅ'),
+    (0xA685, 'V'),
+    (0xA686, 'M', u'ꚇ'),
+    (0xA687, 'V'),
+    (0xA688, 'M', u'ꚉ'),
+    (0xA689, 'V'),
+    (0xA68A, 'M', u'ꚋ'),
+    (0xA68B, 'V'),
+    (0xA68C, 'M', u'ꚍ'),
+    (0xA68D, 'V'),
+    (0xA68E, 'M', u'ꚏ'),
+    (0xA68F, 'V'),
+    (0xA690, 'M', u'ꚑ'),
+    (0xA691, 'V'),
+    (0xA692, 'M', u'ꚓ'),
+    (0xA693, 'V'),
+    (0xA694, 'M', u'ꚕ'),
+    (0xA695, 'V'),
+    (0xA696, 'M', u'ꚗ'),
+    (0xA697, 'V'),
+    (0xA698, 'M', u'ꚙ'),
+    (0xA699, 'V'),
+    (0xA69A, 'M', u'ꚛ'),
+    (0xA69B, 'V'),
+    (0xA69C, 'M', u'ъ'),
+    (0xA69D, 'M', u'ь'),
+    (0xA69E, 'V'),
+    (0xA6F8, 'X'),
+    ]
+
+def _seg_36():
+    return [
+    (0xA700, 'V'),
+    (0xA722, 'M', u'ꜣ'),
+    (0xA723, 'V'),
+    (0xA724, 'M', u'ꜥ'),
+    (0xA725, 'V'),
+    (0xA726, 'M', u'ꜧ'),
+    (0xA727, 'V'),
+    (0xA728, 'M', u'ꜩ'),
+    (0xA729, 'V'),
+    (0xA72A, 'M', u'ꜫ'),
+    (0xA72B, 'V'),
+    (0xA72C, 'M', u'ꜭ'),
+    (0xA72D, 'V'),
+    (0xA72E, 'M', u'ꜯ'),
+    (0xA72F, 'V'),
+    (0xA732, 'M', u'ꜳ'),
+    (0xA733, 'V'),
+    (0xA734, 'M', u'ꜵ'),
+    (0xA735, 'V'),
+    (0xA736, 'M', u'ꜷ'),
+    (0xA737, 'V'),
+    (0xA738, 'M', u'ꜹ'),
+    (0xA739, 'V'),
+    (0xA73A, 'M', u'ꜻ'),
+    (0xA73B, 'V'),
+    (0xA73C, 'M', u'ꜽ'),
+    (0xA73D, 'V'),
+    (0xA73E, 'M', u'ꜿ'),
+    (0xA73F, 'V'),
+    (0xA740, 'M', u'ꝁ'),
+    (0xA741, 'V'),
+    (0xA742, 'M', u'ꝃ'),
+    (0xA743, 'V'),
+    (0xA744, 'M', u'ꝅ'),
+    (0xA745, 'V'),
+    (0xA746, 'M', u'ꝇ'),
+    (0xA747, 'V'),
+    (0xA748, 'M', u'ꝉ'),
+    (0xA749, 'V'),
+    (0xA74A, 'M', u'ꝋ'),
+    (0xA74B, 'V'),
+    (0xA74C, 'M', u'ꝍ'),
+    (0xA74D, 'V'),
+    (0xA74E, 'M', u'ꝏ'),
+    (0xA74F, 'V'),
+    (0xA750, 'M', u'ꝑ'),
+    (0xA751, 'V'),
+    (0xA752, 'M', u'ꝓ'),
+    (0xA753, 'V'),
+    (0xA754, 'M', u'ꝕ'),
+    (0xA755, 'V'),
+    (0xA756, 'M', u'ꝗ'),
+    (0xA757, 'V'),
+    (0xA758, 'M', u'ꝙ'),
+    (0xA759, 'V'),
+    (0xA75A, 'M', u'ꝛ'),
+    (0xA75B, 'V'),
+    (0xA75C, 'M', u'ꝝ'),
+    (0xA75D, 'V'),
+    (0xA75E, 'M', u'ꝟ'),
+    (0xA75F, 'V'),
+    (0xA760, 'M', u'ꝡ'),
+    (0xA761, 'V'),
+    (0xA762, 'M', u'ꝣ'),
+    (0xA763, 'V'),
+    (0xA764, 'M', u'ꝥ'),
+    (0xA765, 'V'),
+    (0xA766, 'M', u'ꝧ'),
+    (0xA767, 'V'),
+    (0xA768, 'M', u'ꝩ'),
+    (0xA769, 'V'),
+    (0xA76A, 'M', u'ꝫ'),
+    (0xA76B, 'V'),
+    (0xA76C, 'M', u'ꝭ'),
+    (0xA76D, 'V'),
+    (0xA76E, 'M', u'ꝯ'),
+    (0xA76F, 'V'),
+    (0xA770, 'M', u'ꝯ'),
+    (0xA771, 'V'),
+    (0xA779, 'M', u'ꝺ'),
+    (0xA77A, 'V'),
+    (0xA77B, 'M', u'ꝼ'),
+    (0xA77C, 'V'),
+    (0xA77D, 'M', u'ᵹ'),
+    (0xA77E, 'M', u'ꝿ'),
+    (0xA77F, 'V'),
+    (0xA780, 'M', u'ꞁ'),
+    (0xA781, 'V'),
+    (0xA782, 'M', u'ꞃ'),
+    (0xA783, 'V'),
+    (0xA784, 'M', u'ꞅ'),
+    (0xA785, 'V'),
+    (0xA786, 'M', u'ꞇ'),
+    (0xA787, 'V'),
+    (0xA78B, 'M', u'ꞌ'),
+    (0xA78C, 'V'),
+    (0xA78D, 'M', u'ɥ'),
+    (0xA78E, 'V'),
+    (0xA790, 'M', u'ꞑ'),
+    (0xA791, 'V'),
+    ]
+
+def _seg_37():
+    return [
+    (0xA792, 'M', u'ꞓ'),
+    (0xA793, 'V'),
+    (0xA796, 'M', u'ꞗ'),
+    (0xA797, 'V'),
+    (0xA798, 'M', u'ꞙ'),
+    (0xA799, 'V'),
+    (0xA79A, 'M', u'ꞛ'),
+    (0xA79B, 'V'),
+    (0xA79C, 'M', u'ꞝ'),
+    (0xA79D, 'V'),
+    (0xA79E, 'M', u'ꞟ'),
+    (0xA79F, 'V'),
+    (0xA7A0, 'M', u'ꞡ'),
+    (0xA7A1, 'V'),
+    (0xA7A2, 'M', u'ꞣ'),
+    (0xA7A3, 'V'),
+    (0xA7A4, 'M', u'ꞥ'),
+    (0xA7A5, 'V'),
+    (0xA7A6, 'M', u'ꞧ'),
+    (0xA7A7, 'V'),
+    (0xA7A8, 'M', u'ꞩ'),
+    (0xA7A9, 'V'),
+    (0xA7AA, 'M', u'ɦ'),
+    (0xA7AB, 'M', u'ɜ'),
+    (0xA7AC, 'M', u'ɡ'),
+    (0xA7AD, 'M', u'ɬ'),
+    (0xA7AE, 'M', u'ɪ'),
+    (0xA7AF, 'V'),
+    (0xA7B0, 'M', u'ʞ'),
+    (0xA7B1, 'M', u'ʇ'),
+    (0xA7B2, 'M', u'ʝ'),
+    (0xA7B3, 'M', u'ꭓ'),
+    (0xA7B4, 'M', u'ꞵ'),
+    (0xA7B5, 'V'),
+    (0xA7B6, 'M', u'ꞷ'),
+    (0xA7B7, 'V'),
+    (0xA7B8, 'X'),
+    (0xA7B9, 'V'),
+    (0xA7BA, 'X'),
+    (0xA7F7, 'V'),
+    (0xA7F8, 'M', u'ħ'),
+    (0xA7F9, 'M', u'œ'),
+    (0xA7FA, 'V'),
+    (0xA82C, 'X'),
+    (0xA830, 'V'),
+    (0xA83A, 'X'),
+    (0xA840, 'V'),
+    (0xA878, 'X'),
+    (0xA880, 'V'),
+    (0xA8C6, 'X'),
+    (0xA8CE, 'V'),
+    (0xA8DA, 'X'),
+    (0xA8E0, 'V'),
+    (0xA954, 'X'),
+    (0xA95F, 'V'),
+    (0xA97D, 'X'),
+    (0xA980, 'V'),
+    (0xA9CE, 'X'),
+    (0xA9CF, 'V'),
+    (0xA9DA, 'X'),
+    (0xA9DE, 'V'),
+    (0xA9FF, 'X'),
+    (0xAA00, 'V'),
+    (0xAA37, 'X'),
+    (0xAA40, 'V'),
+    (0xAA4E, 'X'),
+    (0xAA50, 'V'),
+    (0xAA5A, 'X'),
+    (0xAA5C, 'V'),
+    (0xAAC3, 'X'),
+    (0xAADB, 'V'),
+    (0xAAF7, 'X'),
+    (0xAB01, 'V'),
+    (0xAB07, 'X'),
+    (0xAB09, 'V'),
+    (0xAB0F, 'X'),
+    (0xAB11, 'V'),
+    (0xAB17, 'X'),
+    (0xAB20, 'V'),
+    (0xAB27, 'X'),
+    (0xAB28, 'V'),
+    (0xAB2F, 'X'),
+    (0xAB30, 'V'),
+    (0xAB5C, 'M', u'ꜧ'),
+    (0xAB5D, 'M', u'ꬷ'),
+    (0xAB5E, 'M', u'ɫ'),
+    (0xAB5F, 'M', u'ꭒ'),
+    (0xAB60, 'V'),
+    (0xAB66, 'X'),
+    (0xAB70, 'M', u'Ꭰ'),
+    (0xAB71, 'M', u'Ꭱ'),
+    (0xAB72, 'M', u'Ꭲ'),
+    (0xAB73, 'M', u'Ꭳ'),
+    (0xAB74, 'M', u'Ꭴ'),
+    (0xAB75, 'M', u'Ꭵ'),
+    (0xAB76, 'M', u'Ꭶ'),
+    (0xAB77, 'M', u'Ꭷ'),
+    (0xAB78, 'M', u'Ꭸ'),
+    (0xAB79, 'M', u'Ꭹ'),
+    (0xAB7A, 'M', u'Ꭺ'),
+    ]
+
+def _seg_38():
+    return [
+    (0xAB7B, 'M', u'Ꭻ'),
+    (0xAB7C, 'M', u'Ꭼ'),
+    (0xAB7D, 'M', u'Ꭽ'),
+    (0xAB7E, 'M', u'Ꭾ'),
+    (0xAB7F, 'M', u'Ꭿ'),
+    (0xAB80, 'M', u'Ꮀ'),
+    (0xAB81, 'M', u'Ꮁ'),
+    (0xAB82, 'M', u'Ꮂ'),
+    (0xAB83, 'M', u'Ꮃ'),
+    (0xAB84, 'M', u'Ꮄ'),
+    (0xAB85, 'M', u'Ꮅ'),
+    (0xAB86, 'M', u'Ꮆ'),
+    (0xAB87, 'M', u'Ꮇ'),
+    (0xAB88, 'M', u'Ꮈ'),
+    (0xAB89, 'M', u'Ꮉ'),
+    (0xAB8A, 'M', u'Ꮊ'),
+    (0xAB8B, 'M', u'Ꮋ'),
+    (0xAB8C, 'M', u'Ꮌ'),
+    (0xAB8D, 'M', u'Ꮍ'),
+    (0xAB8E, 'M', u'Ꮎ'),
+    (0xAB8F, 'M', u'Ꮏ'),
+    (0xAB90, 'M', u'Ꮐ'),
+    (0xAB91, 'M', u'Ꮑ'),
+    (0xAB92, 'M', u'Ꮒ'),
+    (0xAB93, 'M', u'Ꮓ'),
+    (0xAB94, 'M', u'Ꮔ'),
+    (0xAB95, 'M', u'Ꮕ'),
+    (0xAB96, 'M', u'Ꮖ'),
+    (0xAB97, 'M', u'Ꮗ'),
+    (0xAB98, 'M', u'Ꮘ'),
+    (0xAB99, 'M', u'Ꮙ'),
+    (0xAB9A, 'M', u'Ꮚ'),
+    (0xAB9B, 'M', u'Ꮛ'),
+    (0xAB9C, 'M', u'Ꮜ'),
+    (0xAB9D, 'M', u'Ꮝ'),
+    (0xAB9E, 'M', u'Ꮞ'),
+    (0xAB9F, 'M', u'Ꮟ'),
+    (0xABA0, 'M', u'Ꮠ'),
+    (0xABA1, 'M', u'Ꮡ'),
+    (0xABA2, 'M', u'Ꮢ'),
+    (0xABA3, 'M', u'Ꮣ'),
+    (0xABA4, 'M', u'Ꮤ'),
+    (0xABA5, 'M', u'Ꮥ'),
+    (0xABA6, 'M', u'Ꮦ'),
+    (0xABA7, 'M', u'Ꮧ'),
+    (0xABA8, 'M', u'Ꮨ'),
+    (0xABA9, 'M', u'Ꮩ'),
+    (0xABAA, 'M', u'Ꮪ'),
+    (0xABAB, 'M', u'Ꮫ'),
+    (0xABAC, 'M', u'Ꮬ'),
+    (0xABAD, 'M', u'Ꮭ'),
+    (0xABAE, 'M', u'Ꮮ'),
+    (0xABAF, 'M', u'Ꮯ'),
+    (0xABB0, 'M', u'Ꮰ'),
+    (0xABB1, 'M', u'Ꮱ'),
+    (0xABB2, 'M', u'Ꮲ'),
+    (0xABB3, 'M', u'Ꮳ'),
+    (0xABB4, 'M', u'Ꮴ'),
+    (0xABB5, 'M', u'Ꮵ'),
+    (0xABB6, 'M', u'Ꮶ'),
+    (0xABB7, 'M', u'Ꮷ'),
+    (0xABB8, 'M', u'Ꮸ'),
+    (0xABB9, 'M', u'Ꮹ'),
+    (0xABBA, 'M', u'Ꮺ'),
+    (0xABBB, 'M', u'Ꮻ'),
+    (0xABBC, 'M', u'Ꮼ'),
+    (0xABBD, 'M', u'Ꮽ'),
+    (0xABBE, 'M', u'Ꮾ'),
+    (0xABBF, 'M', u'Ꮿ'),
+    (0xABC0, 'V'),
+    (0xABEE, 'X'),
+    (0xABF0, 'V'),
+    (0xABFA, 'X'),
+    (0xAC00, 'V'),
+    (0xD7A4, 'X'),
+    (0xD7B0, 'V'),
+    (0xD7C7, 'X'),
+    (0xD7CB, 'V'),
+    (0xD7FC, 'X'),
+    (0xF900, 'M', u'豈'),
+    (0xF901, 'M', u'更'),
+    (0xF902, 'M', u'車'),
+    (0xF903, 'M', u'賈'),
+    (0xF904, 'M', u'滑'),
+    (0xF905, 'M', u'串'),
+    (0xF906, 'M', u'句'),
+    (0xF907, 'M', u'龜'),
+    (0xF909, 'M', u'契'),
+    (0xF90A, 'M', u'金'),
+    (0xF90B, 'M', u'喇'),
+    (0xF90C, 'M', u'奈'),
+    (0xF90D, 'M', u'懶'),
+    (0xF90E, 'M', u'癩'),
+    (0xF90F, 'M', u'羅'),
+    (0xF910, 'M', u'蘿'),
+    (0xF911, 'M', u'螺'),
+    (0xF912, 'M', u'裸'),
+    (0xF913, 'M', u'邏'),
+    (0xF914, 'M', u'樂'),
+    (0xF915, 'M', u'洛'),
+    ]
+
+def _seg_39():
+    return [
+    (0xF916, 'M', u'烙'),
+    (0xF917, 'M', u'珞'),
+    (0xF918, 'M', u'落'),
+    (0xF919, 'M', u'酪'),
+    (0xF91A, 'M', u'駱'),
+    (0xF91B, 'M', u'亂'),
+    (0xF91C, 'M', u'卵'),
+    (0xF91D, 'M', u'欄'),
+    (0xF91E, 'M', u'爛'),
+    (0xF91F, 'M', u'蘭'),
+    (0xF920, 'M', u'鸞'),
+    (0xF921, 'M', u'嵐'),
+    (0xF922, 'M', u'濫'),
+    (0xF923, 'M', u'藍'),
+    (0xF924, 'M', u'襤'),
+    (0xF925, 'M', u'拉'),
+    (0xF926, 'M', u'臘'),
+    (0xF927, 'M', u'蠟'),
+    (0xF928, 'M', u'廊'),
+    (0xF929, 'M', u'朗'),
+    (0xF92A, 'M', u'浪'),
+    (0xF92B, 'M', u'狼'),
+    (0xF92C, 'M', u'郎'),
+    (0xF92D, 'M', u'來'),
+    (0xF92E, 'M', u'冷'),
+    (0xF92F, 'M', u'勞'),
+    (0xF930, 'M', u'擄'),
+    (0xF931, 'M', u'櫓'),
+    (0xF932, 'M', u'爐'),
+    (0xF933, 'M', u'盧'),
+    (0xF934, 'M', u'老'),
+    (0xF935, 'M', u'蘆'),
+    (0xF936, 'M', u'虜'),
+    (0xF937, 'M', u'路'),
+    (0xF938, 'M', u'露'),
+    (0xF939, 'M', u'魯'),
+    (0xF93A, 'M', u'鷺'),
+    (0xF93B, 'M', u'碌'),
+    (0xF93C, 'M', u'祿'),
+    (0xF93D, 'M', u'綠'),
+    (0xF93E, 'M', u'菉'),
+    (0xF93F, 'M', u'錄'),
+    (0xF940, 'M', u'鹿'),
+    (0xF941, 'M', u'論'),
+    (0xF942, 'M', u'壟'),
+    (0xF943, 'M', u'弄'),
+    (0xF944, 'M', u'籠'),
+    (0xF945, 'M', u'聾'),
+    (0xF946, 'M', u'牢'),
+    (0xF947, 'M', u'磊'),
+    (0xF948, 'M', u'賂'),
+    (0xF949, 'M', u'雷'),
+    (0xF94A, 'M', u'壘'),
+    (0xF94B, 'M', u'屢'),
+    (0xF94C, 'M', u'樓'),
+    (0xF94D, 'M', u'淚'),
+    (0xF94E, 'M', u'漏'),
+    (0xF94F, 'M', u'累'),
+    (0xF950, 'M', u'縷'),
+    (0xF951, 'M', u'陋'),
+    (0xF952, 'M', u'勒'),
+    (0xF953, 'M', u'肋'),
+    (0xF954, 'M', u'凜'),
+    (0xF955, 'M', u'凌'),
+    (0xF956, 'M', u'稜'),
+    (0xF957, 'M', u'綾'),
+    (0xF958, 'M', u'菱'),
+    (0xF959, 'M', u'陵'),
+    (0xF95A, 'M', u'讀'),
+    (0xF95B, 'M', u'拏'),
+    (0xF95C, 'M', u'樂'),
+    (0xF95D, 'M', u'諾'),
+    (0xF95E, 'M', u'丹'),
+    (0xF95F, 'M', u'寧'),
+    (0xF960, 'M', u'怒'),
+    (0xF961, 'M', u'率'),
+    (0xF962, 'M', u'異'),
+    (0xF963, 'M', u'北'),
+    (0xF964, 'M', u'磻'),
+    (0xF965, 'M', u'便'),
+    (0xF966, 'M', u'復'),
+    (0xF967, 'M', u'不'),
+    (0xF968, 'M', u'泌'),
+    (0xF969, 'M', u'數'),
+    (0xF96A, 'M', u'索'),
+    (0xF96B, 'M', u'參'),
+    (0xF96C, 'M', u'塞'),
+    (0xF96D, 'M', u'省'),
+    (0xF96E, 'M', u'葉'),
+    (0xF96F, 'M', u'說'),
+    (0xF970, 'M', u'殺'),
+    (0xF971, 'M', u'辰'),
+    (0xF972, 'M', u'沈'),
+    (0xF973, 'M', u'拾'),
+    (0xF974, 'M', u'若'),
+    (0xF975, 'M', u'掠'),
+    (0xF976, 'M', u'略'),
+    (0xF977, 'M', u'亮'),
+    (0xF978, 'M', u'兩'),
+    (0xF979, 'M', u'凉'),
+    ]
+
+def _seg_40():
+    return [
+    (0xF97A, 'M', u'梁'),
+    (0xF97B, 'M', u'糧'),
+    (0xF97C, 'M', u'良'),
+    (0xF97D, 'M', u'諒'),
+    (0xF97E, 'M', u'量'),
+    (0xF97F, 'M', u'勵'),
+    (0xF980, 'M', u'呂'),
+    (0xF981, 'M', u'女'),
+    (0xF982, 'M', u'廬'),
+    (0xF983, 'M', u'旅'),
+    (0xF984, 'M', u'濾'),
+    (0xF985, 'M', u'礪'),
+    (0xF986, 'M', u'閭'),
+    (0xF987, 'M', u'驪'),
+    (0xF988, 'M', u'麗'),
+    (0xF989, 'M', u'黎'),
+    (0xF98A, 'M', u'力'),
+    (0xF98B, 'M', u'曆'),
+    (0xF98C, 'M', u'歷'),
+    (0xF98D, 'M', u'轢'),
+    (0xF98E, 'M', u'年'),
+    (0xF98F, 'M', u'憐'),
+    (0xF990, 'M', u'戀'),
+    (0xF991, 'M', u'撚'),
+    (0xF992, 'M', u'漣'),
+    (0xF993, 'M', u'煉'),
+    (0xF994, 'M', u'璉'),
+    (0xF995, 'M', u'秊'),
+    (0xF996, 'M', u'練'),
+    (0xF997, 'M', u'聯'),
+    (0xF998, 'M', u'輦'),
+    (0xF999, 'M', u'蓮'),
+    (0xF99A, 'M', u'連'),
+    (0xF99B, 'M', u'鍊'),
+    (0xF99C, 'M', u'列'),
+    (0xF99D, 'M', u'劣'),
+    (0xF99E, 'M', u'咽'),
+    (0xF99F, 'M', u'烈'),
+    (0xF9A0, 'M', u'裂'),
+    (0xF9A1, 'M', u'說'),
+    (0xF9A2, 'M', u'廉'),
+    (0xF9A3, 'M', u'念'),
+    (0xF9A4, 'M', u'捻'),
+    (0xF9A5, 'M', u'殮'),
+    (0xF9A6, 'M', u'簾'),
+    (0xF9A7, 'M', u'獵'),
+    (0xF9A8, 'M', u'令'),
+    (0xF9A9, 'M', u'囹'),
+    (0xF9AA, 'M', u'寧'),
+    (0xF9AB, 'M', u'嶺'),
+    (0xF9AC, 'M', u'怜'),
+    (0xF9AD, 'M', u'玲'),
+    (0xF9AE, 'M', u'瑩'),
+    (0xF9AF, 'M', u'羚'),
+    (0xF9B0, 'M', u'聆'),
+    (0xF9B1, 'M', u'鈴'),
+    (0xF9B2, 'M', u'零'),
+    (0xF9B3, 'M', u'靈'),
+    (0xF9B4, 'M', u'領'),
+    (0xF9B5, 'M', u'例'),
+    (0xF9B6, 'M', u'禮'),
+    (0xF9B7, 'M', u'醴'),
+    (0xF9B8, 'M', u'隸'),
+    (0xF9B9, 'M', u'惡'),
+    (0xF9BA, 'M', u'了'),
+    (0xF9BB, 'M', u'僚'),
+    (0xF9BC, 'M', u'寮'),
+    (0xF9BD, 'M', u'尿'),
+    (0xF9BE, 'M', u'料'),
+    (0xF9BF, 'M', u'樂'),
+    (0xF9C0, 'M', u'燎'),
+    (0xF9C1, 'M', u'療'),
+    (0xF9C2, 'M', u'蓼'),
+    (0xF9C3, 'M', u'遼'),
+    (0xF9C4, 'M', u'龍'),
+    (0xF9C5, 'M', u'暈'),
+    (0xF9C6, 'M', u'阮'),
+    (0xF9C7, 'M', u'劉'),
+    (0xF9C8, 'M', u'杻'),
+    (0xF9C9, 'M', u'柳'),
+    (0xF9CA, 'M', u'流'),
+    (0xF9CB, 'M', u'溜'),
+    (0xF9CC, 'M', u'琉'),
+    (0xF9CD, 'M', u'留'),
+    (0xF9CE, 'M', u'硫'),
+    (0xF9CF, 'M', u'紐'),
+    (0xF9D0, 'M', u'類'),
+    (0xF9D1, 'M', u'六'),
+    (0xF9D2, 'M', u'戮'),
+    (0xF9D3, 'M', u'陸'),
+    (0xF9D4, 'M', u'倫'),
+    (0xF9D5, 'M', u'崙'),
+    (0xF9D6, 'M', u'淪'),
+    (0xF9D7, 'M', u'輪'),
+    (0xF9D8, 'M', u'律'),
+    (0xF9D9, 'M', u'慄'),
+    (0xF9DA, 'M', u'栗'),
+    (0xF9DB, 'M', u'率'),
+    (0xF9DC, 'M', u'隆'),
+    (0xF9DD, 'M', u'利'),
+    ]
+
+def _seg_41():
+    return [
+    (0xF9DE, 'M', u'吏'),
+    (0xF9DF, 'M', u'履'),
+    (0xF9E0, 'M', u'易'),
+    (0xF9E1, 'M', u'李'),
+    (0xF9E2, 'M', u'梨'),
+    (0xF9E3, 'M', u'泥'),
+    (0xF9E4, 'M', u'理'),
+    (0xF9E5, 'M', u'痢'),
+    (0xF9E6, 'M', u'罹'),
+    (0xF9E7, 'M', u'裏'),
+    (0xF9E8, 'M', u'裡'),
+    (0xF9E9, 'M', u'里'),
+    (0xF9EA, 'M', u'離'),
+    (0xF9EB, 'M', u'匿'),
+    (0xF9EC, 'M', u'溺'),
+    (0xF9ED, 'M', u'吝'),
+    (0xF9EE, 'M', u'燐'),
+    (0xF9EF, 'M', u'璘'),
+    (0xF9F0, 'M', u'藺'),
+    (0xF9F1, 'M', u'隣'),
+    (0xF9F2, 'M', u'鱗'),
+    (0xF9F3, 'M', u'麟'),
+    (0xF9F4, 'M', u'林'),
+    (0xF9F5, 'M', u'淋'),
+    (0xF9F6, 'M', u'臨'),
+    (0xF9F7, 'M', u'立'),
+    (0xF9F8, 'M', u'笠'),
+    (0xF9F9, 'M', u'粒'),
+    (0xF9FA, 'M', u'狀'),
+    (0xF9FB, 'M', u'炙'),
+    (0xF9FC, 'M', u'識'),
+    (0xF9FD, 'M', u'什'),
+    (0xF9FE, 'M', u'茶'),
+    (0xF9FF, 'M', u'刺'),
+    (0xFA00, 'M', u'切'),
+    (0xFA01, 'M', u'度'),
+    (0xFA02, 'M', u'拓'),
+    (0xFA03, 'M', u'糖'),
+    (0xFA04, 'M', u'宅'),
+    (0xFA05, 'M', u'洞'),
+    (0xFA06, 'M', u'暴'),
+    (0xFA07, 'M', u'輻'),
+    (0xFA08, 'M', u'行'),
+    (0xFA09, 'M', u'降'),
+    (0xFA0A, 'M', u'見'),
+    (0xFA0B, 'M', u'廓'),
+    (0xFA0C, 'M', u'兀'),
+    (0xFA0D, 'M', u'嗀'),
+    (0xFA0E, 'V'),
+    (0xFA10, 'M', u'塚'),
+    (0xFA11, 'V'),
+    (0xFA12, 'M', u'晴'),
+    (0xFA13, 'V'),
+    (0xFA15, 'M', u'凞'),
+    (0xFA16, 'M', u'猪'),
+    (0xFA17, 'M', u'益'),
+    (0xFA18, 'M', u'礼'),
+    (0xFA19, 'M', u'神'),
+    (0xFA1A, 'M', u'祥'),
+    (0xFA1B, 'M', u'福'),
+    (0xFA1C, 'M', u'靖'),
+    (0xFA1D, 'M', u'精'),
+    (0xFA1E, 'M', u'羽'),
+    (0xFA1F, 'V'),
+    (0xFA20, 'M', u'蘒'),
+    (0xFA21, 'V'),
+    (0xFA22, 'M', u'諸'),
+    (0xFA23, 'V'),
+    (0xFA25, 'M', u'逸'),
+    (0xFA26, 'M', u'都'),
+    (0xFA27, 'V'),
+    (0xFA2A, 'M', u'飯'),
+    (0xFA2B, 'M', u'飼'),
+    (0xFA2C, 'M', u'館'),
+    (0xFA2D, 'M', u'鶴'),
+    (0xFA2E, 'M', u'郞'),
+    (0xFA2F, 'M', u'隷'),
+    (0xFA30, 'M', u'侮'),
+    (0xFA31, 'M', u'僧'),
+    (0xFA32, 'M', u'免'),
+    (0xFA33, 'M', u'勉'),
+    (0xFA34, 'M', u'勤'),
+    (0xFA35, 'M', u'卑'),
+    (0xFA36, 'M', u'喝'),
+    (0xFA37, 'M', u'嘆'),
+    (0xFA38, 'M', u'器'),
+    (0xFA39, 'M', u'塀'),
+    (0xFA3A, 'M', u'墨'),
+    (0xFA3B, 'M', u'層'),
+    (0xFA3C, 'M', u'屮'),
+    (0xFA3D, 'M', u'悔'),
+    (0xFA3E, 'M', u'慨'),
+    (0xFA3F, 'M', u'憎'),
+    (0xFA40, 'M', u'懲'),
+    (0xFA41, 'M', u'敏'),
+    (0xFA42, 'M', u'既'),
+    (0xFA43, 'M', u'暑'),
+    (0xFA44, 'M', u'梅'),
+    (0xFA45, 'M', u'海'),
+    (0xFA46, 'M', u'渚'),
+    ]
+
+def _seg_42():
+    return [
+    (0xFA47, 'M', u'漢'),
+    (0xFA48, 'M', u'煮'),
+    (0xFA49, 'M', u'爫'),
+    (0xFA4A, 'M', u'琢'),
+    (0xFA4B, 'M', u'碑'),
+    (0xFA4C, 'M', u'社'),
+    (0xFA4D, 'M', u'祉'),
+    (0xFA4E, 'M', u'祈'),
+    (0xFA4F, 'M', u'祐'),
+    (0xFA50, 'M', u'祖'),
+    (0xFA51, 'M', u'祝'),
+    (0xFA52, 'M', u'禍'),
+    (0xFA53, 'M', u'禎'),
+    (0xFA54, 'M', u'穀'),
+    (0xFA55, 'M', u'突'),
+    (0xFA56, 'M', u'節'),
+    (0xFA57, 'M', u'練'),
+    (0xFA58, 'M', u'縉'),
+    (0xFA59, 'M', u'繁'),
+    (0xFA5A, 'M', u'署'),
+    (0xFA5B, 'M', u'者'),
+    (0xFA5C, 'M', u'臭'),
+    (0xFA5D, 'M', u'艹'),
+    (0xFA5F, 'M', u'著'),
+    (0xFA60, 'M', u'褐'),
+    (0xFA61, 'M', u'視'),
+    (0xFA62, 'M', u'謁'),
+    (0xFA63, 'M', u'謹'),
+    (0xFA64, 'M', u'賓'),
+    (0xFA65, 'M', u'贈'),
+    (0xFA66, 'M', u'辶'),
+    (0xFA67, 'M', u'逸'),
+    (0xFA68, 'M', u'難'),
+    (0xFA69, 'M', u'響'),
+    (0xFA6A, 'M', u'頻'),
+    (0xFA6B, 'M', u'恵'),
+    (0xFA6C, 'M', u'𤋮'),
+    (0xFA6D, 'M', u'舘'),
+    (0xFA6E, 'X'),
+    (0xFA70, 'M', u'並'),
+    (0xFA71, 'M', u'况'),
+    (0xFA72, 'M', u'全'),
+    (0xFA73, 'M', u'侀'),
+    (0xFA74, 'M', u'充'),
+    (0xFA75, 'M', u'冀'),
+    (0xFA76, 'M', u'勇'),
+    (0xFA77, 'M', u'勺'),
+    (0xFA78, 'M', u'喝'),
+    (0xFA79, 'M', u'啕'),
+    (0xFA7A, 'M', u'喙'),
+    (0xFA7B, 'M', u'嗢'),
+    (0xFA7C, 'M', u'塚'),
+    (0xFA7D, 'M', u'墳'),
+    (0xFA7E, 'M', u'奄'),
+    (0xFA7F, 'M', u'奔'),
+    (0xFA80, 'M', u'婢'),
+    (0xFA81, 'M', u'嬨'),
+    (0xFA82, 'M', u'廒'),
+    (0xFA83, 'M', u'廙'),
+    (0xFA84, 'M', u'彩'),
+    (0xFA85, 'M', u'徭'),
+    (0xFA86, 'M', u'惘'),
+    (0xFA87, 'M', u'慎'),
+    (0xFA88, 'M', u'愈'),
+    (0xFA89, 'M', u'憎'),
+    (0xFA8A, 'M', u'慠'),
+    (0xFA8B, 'M', u'懲'),
+    (0xFA8C, 'M', u'戴'),
+    (0xFA8D, 'M', u'揄'),
+    (0xFA8E, 'M', u'搜'),
+    (0xFA8F, 'M', u'摒'),
+    (0xFA90, 'M', u'敖'),
+    (0xFA91, 'M', u'晴'),
+    (0xFA92, 'M', u'朗'),
+    (0xFA93, 'M', u'望'),
+    (0xFA94, 'M', u'杖'),
+    (0xFA95, 'M', u'歹'),
+    (0xFA96, 'M', u'殺'),
+    (0xFA97, 'M', u'流'),
+    (0xFA98, 'M', u'滛'),
+    (0xFA99, 'M', u'滋'),
+    (0xFA9A, 'M', u'漢'),
+    (0xFA9B, 'M', u'瀞'),
+    (0xFA9C, 'M', u'煮'),
+    (0xFA9D, 'M', u'瞧'),
+    (0xFA9E, 'M', u'爵'),
+    (0xFA9F, 'M', u'犯'),
+    (0xFAA0, 'M', u'猪'),
+    (0xFAA1, 'M', u'瑱'),
+    (0xFAA2, 'M', u'甆'),
+    (0xFAA3, 'M', u'画'),
+    (0xFAA4, 'M', u'瘝'),
+    (0xFAA5, 'M', u'瘟'),
+    (0xFAA6, 'M', u'益'),
+    (0xFAA7, 'M', u'盛'),
+    (0xFAA8, 'M', u'直'),
+    (0xFAA9, 'M', u'睊'),
+    (0xFAAA, 'M', u'着'),
+    (0xFAAB, 'M', u'磌'),
+    (0xFAAC, 'M', u'窱'),
+    ]
+
+def _seg_43():
+    return [
+    (0xFAAD, 'M', u'節'),
+    (0xFAAE, 'M', u'类'),
+    (0xFAAF, 'M', u'絛'),
+    (0xFAB0, 'M', u'練'),
+    (0xFAB1, 'M', u'缾'),
+    (0xFAB2, 'M', u'者'),
+    (0xFAB3, 'M', u'荒'),
+    (0xFAB4, 'M', u'華'),
+    (0xFAB5, 'M', u'蝹'),
+    (0xFAB6, 'M', u'襁'),
+    (0xFAB7, 'M', u'覆'),
+    (0xFAB8, 'M', u'視'),
+    (0xFAB9, 'M', u'調'),
+    (0xFABA, 'M', u'諸'),
+    (0xFABB, 'M', u'請'),
+    (0xFABC, 'M', u'謁'),
+    (0xFABD, 'M', u'諾'),
+    (0xFABE, 'M', u'諭'),
+    (0xFABF, 'M', u'謹'),
+    (0xFAC0, 'M', u'變'),
+    (0xFAC1, 'M', u'贈'),
+    (0xFAC2, 'M', u'輸'),
+    (0xFAC3, 'M', u'遲'),
+    (0xFAC4, 'M', u'醙'),
+    (0xFAC5, 'M', u'鉶'),
+    (0xFAC6, 'M', u'陼'),
+    (0xFAC7, 'M', u'難'),
+    (0xFAC8, 'M', u'靖'),
+    (0xFAC9, 'M', u'韛'),
+    (0xFACA, 'M', u'響'),
+    (0xFACB, 'M', u'頋'),
+    (0xFACC, 'M', u'頻'),
+    (0xFACD, 'M', u'鬒'),
+    (0xFACE, 'M', u'龜'),
+    (0xFACF, 'M', u'𢡊'),
+    (0xFAD0, 'M', u'𢡄'),
+    (0xFAD1, 'M', u'𣏕'),
+    (0xFAD2, 'M', u'㮝'),
+    (0xFAD3, 'M', u'䀘'),
+    (0xFAD4, 'M', u'䀹'),
+    (0xFAD5, 'M', u'𥉉'),
+    (0xFAD6, 'M', u'𥳐'),
+    (0xFAD7, 'M', u'𧻓'),
+    (0xFAD8, 'M', u'齃'),
+    (0xFAD9, 'M', u'龎'),
+    (0xFADA, 'X'),
+    (0xFB00, 'M', u'ff'),
+    (0xFB01, 'M', u'fi'),
+    (0xFB02, 'M', u'fl'),
+    (0xFB03, 'M', u'ffi'),
+    (0xFB04, 'M', u'ffl'),
+    (0xFB05, 'M', u'st'),
+    (0xFB07, 'X'),
+    (0xFB13, 'M', u'մն'),
+    (0xFB14, 'M', u'մե'),
+    (0xFB15, 'M', u'մի'),
+    (0xFB16, 'M', u'վն'),
+    (0xFB17, 'M', u'մխ'),
+    (0xFB18, 'X'),
+    (0xFB1D, 'M', u'יִ'),
+    (0xFB1E, 'V'),
+    (0xFB1F, 'M', u'ײַ'),
+    (0xFB20, 'M', u'ע'),
+    (0xFB21, 'M', u'א'),
+    (0xFB22, 'M', u'ד'),
+    (0xFB23, 'M', u'ה'),
+    (0xFB24, 'M', u'כ'),
+    (0xFB25, 'M', u'ל'),
+    (0xFB26, 'M', u'ם'),
+    (0xFB27, 'M', u'ר'),
+    (0xFB28, 'M', u'ת'),
+    (0xFB29, '3', u'+'),
+    (0xFB2A, 'M', u'שׁ'),
+    (0xFB2B, 'M', u'שׂ'),
+    (0xFB2C, 'M', u'שּׁ'),
+    (0xFB2D, 'M', u'שּׂ'),
+    (0xFB2E, 'M', u'אַ'),
+    (0xFB2F, 'M', u'אָ'),
+    (0xFB30, 'M', u'אּ'),
+    (0xFB31, 'M', u'בּ'),
+    (0xFB32, 'M', u'גּ'),
+    (0xFB33, 'M', u'דּ'),
+    (0xFB34, 'M', u'הּ'),
+    (0xFB35, 'M', u'וּ'),
+    (0xFB36, 'M', u'זּ'),
+    (0xFB37, 'X'),
+    (0xFB38, 'M', u'טּ'),
+    (0xFB39, 'M', u'יּ'),
+    (0xFB3A, 'M', u'ךּ'),
+    (0xFB3B, 'M', u'כּ'),
+    (0xFB3C, 'M', u'לּ'),
+    (0xFB3D, 'X'),
+    (0xFB3E, 'M', u'מּ'),
+    (0xFB3F, 'X'),
+    (0xFB40, 'M', u'נּ'),
+    (0xFB41, 'M', u'סּ'),
+    (0xFB42, 'X'),
+    (0xFB43, 'M', u'ףּ'),
+    (0xFB44, 'M', u'פּ'),
+    (0xFB45, 'X'),
+    ]
+
+def _seg_44():
+    return [
+    (0xFB46, 'M', u'צּ'),
+    (0xFB47, 'M', u'קּ'),
+    (0xFB48, 'M', u'רּ'),
+    (0xFB49, 'M', u'שּ'),
+    (0xFB4A, 'M', u'תּ'),
+    (0xFB4B, 'M', u'וֹ'),
+    (0xFB4C, 'M', u'בֿ'),
+    (0xFB4D, 'M', u'כֿ'),
+    (0xFB4E, 'M', u'פֿ'),
+    (0xFB4F, 'M', u'אל'),
+    (0xFB50, 'M', u'ٱ'),
+    (0xFB52, 'M', u'ٻ'),
+    (0xFB56, 'M', u'پ'),
+    (0xFB5A, 'M', u'ڀ'),
+    (0xFB5E, 'M', u'ٺ'),
+    (0xFB62, 'M', u'ٿ'),
+    (0xFB66, 'M', u'ٹ'),
+    (0xFB6A, 'M', u'ڤ'),
+    (0xFB6E, 'M', u'ڦ'),
+    (0xFB72, 'M', u'ڄ'),
+    (0xFB76, 'M', u'ڃ'),
+    (0xFB7A, 'M', u'چ'),
+    (0xFB7E, 'M', u'ڇ'),
+    (0xFB82, 'M', u'ڍ'),
+    (0xFB84, 'M', u'ڌ'),
+    (0xFB86, 'M', u'ڎ'),
+    (0xFB88, 'M', u'ڈ'),
+    (0xFB8A, 'M', u'ژ'),
+    (0xFB8C, 'M', u'ڑ'),
+    (0xFB8E, 'M', u'ک'),
+    (0xFB92, 'M', u'گ'),
+    (0xFB96, 'M', u'ڳ'),
+    (0xFB9A, 'M', u'ڱ'),
+    (0xFB9E, 'M', u'ں'),
+    (0xFBA0, 'M', u'ڻ'),
+    (0xFBA4, 'M', u'ۀ'),
+    (0xFBA6, 'M', u'ہ'),
+    (0xFBAA, 'M', u'ھ'),
+    (0xFBAE, 'M', u'ے'),
+    (0xFBB0, 'M', u'ۓ'),
+    (0xFBB2, 'V'),
+    (0xFBC2, 'X'),
+    (0xFBD3, 'M', u'ڭ'),
+    (0xFBD7, 'M', u'ۇ'),
+    (0xFBD9, 'M', u'ۆ'),
+    (0xFBDB, 'M', u'ۈ'),
+    (0xFBDD, 'M', u'ۇٴ'),
+    (0xFBDE, 'M', u'ۋ'),
+    (0xFBE0, 'M', u'ۅ'),
+    (0xFBE2, 'M', u'ۉ'),
+    (0xFBE4, 'M', u'ې'),
+    (0xFBE8, 'M', u'ى'),
+    (0xFBEA, 'M', u'ئا'),
+    (0xFBEC, 'M', u'ئە'),
+    (0xFBEE, 'M', u'ئو'),
+    (0xFBF0, 'M', u'ئۇ'),
+    (0xFBF2, 'M', u'ئۆ'),
+    (0xFBF4, 'M', u'ئۈ'),
+    (0xFBF6, 'M', u'ئې'),
+    (0xFBF9, 'M', u'ئى'),
+    (0xFBFC, 'M', u'ی'),
+    (0xFC00, 'M', u'ئج'),
+    (0xFC01, 'M', u'ئح'),
+    (0xFC02, 'M', u'ئم'),
+    (0xFC03, 'M', u'ئى'),
+    (0xFC04, 'M', u'ئي'),
+    (0xFC05, 'M', u'بج'),
+    (0xFC06, 'M', u'بح'),
+    (0xFC07, 'M', u'بخ'),
+    (0xFC08, 'M', u'بم'),
+    (0xFC09, 'M', u'بى'),
+    (0xFC0A, 'M', u'بي'),
+    (0xFC0B, 'M', u'تج'),
+    (0xFC0C, 'M', u'تح'),
+    (0xFC0D, 'M', u'تخ'),
+    (0xFC0E, 'M', u'تم'),
+    (0xFC0F, 'M', u'تى'),
+    (0xFC10, 'M', u'تي'),
+    (0xFC11, 'M', u'ثج'),
+    (0xFC12, 'M', u'ثم'),
+    (0xFC13, 'M', u'ثى'),
+    (0xFC14, 'M', u'ثي'),
+    (0xFC15, 'M', u'جح'),
+    (0xFC16, 'M', u'جم'),
+    (0xFC17, 'M', u'حج'),
+    (0xFC18, 'M', u'حم'),
+    (0xFC19, 'M', u'خج'),
+    (0xFC1A, 'M', u'خح'),
+    (0xFC1B, 'M', u'خم'),
+    (0xFC1C, 'M', u'سج'),
+    (0xFC1D, 'M', u'سح'),
+    (0xFC1E, 'M', u'سخ'),
+    (0xFC1F, 'M', u'سم'),
+    (0xFC20, 'M', u'صح'),
+    (0xFC21, 'M', u'صم'),
+    (0xFC22, 'M', u'ضج'),
+    (0xFC23, 'M', u'ضح'),
+    (0xFC24, 'M', u'ضخ'),
+    (0xFC25, 'M', u'ضم'),
+    (0xFC26, 'M', u'طح'),
+    ]
+
+def _seg_45():
+    return [
+    (0xFC27, 'M', u'طم'),
+    (0xFC28, 'M', u'ظم'),
+    (0xFC29, 'M', u'عج'),
+    (0xFC2A, 'M', u'عم'),
+    (0xFC2B, 'M', u'غج'),
+    (0xFC2C, 'M', u'غم'),
+    (0xFC2D, 'M', u'فج'),
+    (0xFC2E, 'M', u'فح'),
+    (0xFC2F, 'M', u'فخ'),
+    (0xFC30, 'M', u'فم'),
+    (0xFC31, 'M', u'فى'),
+    (0xFC32, 'M', u'في'),
+    (0xFC33, 'M', u'قح'),
+    (0xFC34, 'M', u'قم'),
+    (0xFC35, 'M', u'قى'),
+    (0xFC36, 'M', u'قي'),
+    (0xFC37, 'M', u'كا'),
+    (0xFC38, 'M', u'كج'),
+    (0xFC39, 'M', u'كح'),
+    (0xFC3A, 'M', u'كخ'),
+    (0xFC3B, 'M', u'كل'),
+    (0xFC3C, 'M', u'كم'),
+    (0xFC3D, 'M', u'كى'),
+    (0xFC3E, 'M', u'كي'),
+    (0xFC3F, 'M', u'لج'),
+    (0xFC40, 'M', u'لح'),
+    (0xFC41, 'M', u'لخ'),
+    (0xFC42, 'M', u'لم'),
+    (0xFC43, 'M', u'لى'),
+    (0xFC44, 'M', u'لي'),
+    (0xFC45, 'M', u'مج'),
+    (0xFC46, 'M', u'مح'),
+    (0xFC47, 'M', u'مخ'),
+    (0xFC48, 'M', u'مم'),
+    (0xFC49, 'M', u'مى'),
+    (0xFC4A, 'M', u'مي'),
+    (0xFC4B, 'M', u'نج'),
+    (0xFC4C, 'M', u'نح'),
+    (0xFC4D, 'M', u'نخ'),
+    (0xFC4E, 'M', u'نم'),
+    (0xFC4F, 'M', u'نى'),
+    (0xFC50, 'M', u'ني'),
+    (0xFC51, 'M', u'هج'),
+    (0xFC52, 'M', u'هم'),
+    (0xFC53, 'M', u'هى'),
+    (0xFC54, 'M', u'هي'),
+    (0xFC55, 'M', u'يج'),
+    (0xFC56, 'M', u'يح'),
+    (0xFC57, 'M', u'يخ'),
+    (0xFC58, 'M', u'يم'),
+    (0xFC59, 'M', u'يى'),
+    (0xFC5A, 'M', u'يي'),
+    (0xFC5B, 'M', u'ذٰ'),
+    (0xFC5C, 'M', u'رٰ'),
+    (0xFC5D, 'M', u'ىٰ'),
+    (0xFC5E, '3', u' ٌّ'),
+    (0xFC5F, '3', u' ٍّ'),
+    (0xFC60, '3', u' َّ'),
+    (0xFC61, '3', u' ُّ'),
+    (0xFC62, '3', u' ِّ'),
+    (0xFC63, '3', u' ّٰ'),
+    (0xFC64, 'M', u'ئر'),
+    (0xFC65, 'M', u'ئز'),
+    (0xFC66, 'M', u'ئم'),
+    (0xFC67, 'M', u'ئن'),
+    (0xFC68, 'M', u'ئى'),
+    (0xFC69, 'M', u'ئي'),
+    (0xFC6A, 'M', u'بر'),
+    (0xFC6B, 'M', u'بز'),
+    (0xFC6C, 'M', u'بم'),
+    (0xFC6D, 'M', u'بن'),
+    (0xFC6E, 'M', u'بى'),
+    (0xFC6F, 'M', u'بي'),
+    (0xFC70, 'M', u'تر'),
+    (0xFC71, 'M', u'تز'),
+    (0xFC72, 'M', u'تم'),
+    (0xFC73, 'M', u'تن'),
+    (0xFC74, 'M', u'تى'),
+    (0xFC75, 'M', u'تي'),
+    (0xFC76, 'M', u'ثر'),
+    (0xFC77, 'M', u'ثز'),
+    (0xFC78, 'M', u'ثم'),
+    (0xFC79, 'M', u'ثن'),
+    (0xFC7A, 'M', u'ثى'),
+    (0xFC7B, 'M', u'ثي'),
+    (0xFC7C, 'M', u'فى'),
+    (0xFC7D, 'M', u'في'),
+    (0xFC7E, 'M', u'قى'),
+    (0xFC7F, 'M', u'قي'),
+    (0xFC80, 'M', u'كا'),
+    (0xFC81, 'M', u'كل'),
+    (0xFC82, 'M', u'كم'),
+    (0xFC83, 'M', u'كى'),
+    (0xFC84, 'M', u'كي'),
+    (0xFC85, 'M', u'لم'),
+    (0xFC86, 'M', u'لى'),
+    (0xFC87, 'M', u'لي'),
+    (0xFC88, 'M', u'ما'),
+    (0xFC89, 'M', u'مم'),
+    (0xFC8A, 'M', u'نر'),
+    ]
+
+def _seg_46():
+    return [
+    (0xFC8B, 'M', u'نز'),
+    (0xFC8C, 'M', u'نم'),
+    (0xFC8D, 'M', u'نن'),
+    (0xFC8E, 'M', u'نى'),
+    (0xFC8F, 'M', u'ني'),
+    (0xFC90, 'M', u'ىٰ'),
+    (0xFC91, 'M', u'ير'),
+    (0xFC92, 'M', u'يز'),
+    (0xFC93, 'M', u'يم'),
+    (0xFC94, 'M', u'ين'),
+    (0xFC95, 'M', u'يى'),
+    (0xFC96, 'M', u'يي'),
+    (0xFC97, 'M', u'ئج'),
+    (0xFC98, 'M', u'ئح'),
+    (0xFC99, 'M', u'ئخ'),
+    (0xFC9A, 'M', u'ئم'),
+    (0xFC9B, 'M', u'ئه'),
+    (0xFC9C, 'M', u'بج'),
+    (0xFC9D, 'M', u'بح'),
+    (0xFC9E, 'M', u'بخ'),
+    (0xFC9F, 'M', u'بم'),
+    (0xFCA0, 'M', u'به'),
+    (0xFCA1, 'M', u'تج'),
+    (0xFCA2, 'M', u'تح'),
+    (0xFCA3, 'M', u'تخ'),
+    (0xFCA4, 'M', u'تم'),
+    (0xFCA5, 'M', u'ته'),
+    (0xFCA6, 'M', u'ثم'),
+    (0xFCA7, 'M', u'جح'),
+    (0xFCA8, 'M', u'جم'),
+    (0xFCA9, 'M', u'حج'),
+    (0xFCAA, 'M', u'حم'),
+    (0xFCAB, 'M', u'خج'),
+    (0xFCAC, 'M', u'خم'),
+    (0xFCAD, 'M', u'سج'),
+    (0xFCAE, 'M', u'سح'),
+    (0xFCAF, 'M', u'سخ'),
+    (0xFCB0, 'M', u'سم'),
+    (0xFCB1, 'M', u'صح'),
+    (0xFCB2, 'M', u'صخ'),
+    (0xFCB3, 'M', u'صم'),
+    (0xFCB4, 'M', u'ضج'),
+    (0xFCB5, 'M', u'ضح'),
+    (0xFCB6, 'M', u'ضخ'),
+    (0xFCB7, 'M', u'ضم'),
+    (0xFCB8, 'M', u'طح'),
+    (0xFCB9, 'M', u'ظم'),
+    (0xFCBA, 'M', u'عج'),
+    (0xFCBB, 'M', u'عم'),
+    (0xFCBC, 'M', u'غج'),
+    (0xFCBD, 'M', u'غم'),
+    (0xFCBE, 'M', u'فج'),
+    (0xFCBF, 'M', u'فح'),
+    (0xFCC0, 'M', u'فخ'),
+    (0xFCC1, 'M', u'فم'),
+    (0xFCC2, 'M', u'قح'),
+    (0xFCC3, 'M', u'قم'),
+    (0xFCC4, 'M', u'كج'),
+    (0xFCC5, 'M', u'كح'),
+    (0xFCC6, 'M', u'كخ'),
+    (0xFCC7, 'M', u'كل'),
+    (0xFCC8, 'M', u'كم'),
+    (0xFCC9, 'M', u'لج'),
+    (0xFCCA, 'M', u'لح'),
+    (0xFCCB, 'M', u'لخ'),
+    (0xFCCC, 'M', u'لم'),
+    (0xFCCD, 'M', u'له'),
+    (0xFCCE, 'M', u'مج'),
+    (0xFCCF, 'M', u'مح'),
+    (0xFCD0, 'M', u'مخ'),
+    (0xFCD1, 'M', u'مم'),
+    (0xFCD2, 'M', u'نج'),
+    (0xFCD3, 'M', u'نح'),
+    (0xFCD4, 'M', u'نخ'),
+    (0xFCD5, 'M', u'نم'),
+    (0xFCD6, 'M', u'نه'),
+    (0xFCD7, 'M', u'هج'),
+    (0xFCD8, 'M', u'هم'),
+    (0xFCD9, 'M', u'هٰ'),
+    (0xFCDA, 'M', u'يج'),
+    (0xFCDB, 'M', u'يح'),
+    (0xFCDC, 'M', u'يخ'),
+    (0xFCDD, 'M', u'يم'),
+    (0xFCDE, 'M', u'يه'),
+    (0xFCDF, 'M', u'ئم'),
+    (0xFCE0, 'M', u'ئه'),
+    (0xFCE1, 'M', u'بم'),
+    (0xFCE2, 'M', u'به'),
+    (0xFCE3, 'M', u'تم'),
+    (0xFCE4, 'M', u'ته'),
+    (0xFCE5, 'M', u'ثم'),
+    (0xFCE6, 'M', u'ثه'),
+    (0xFCE7, 'M', u'سم'),
+    (0xFCE8, 'M', u'سه'),
+    (0xFCE9, 'M', u'شم'),
+    (0xFCEA, 'M', u'شه'),
+    (0xFCEB, 'M', u'كل'),
+    (0xFCEC, 'M', u'كم'),
+    (0xFCED, 'M', u'لم'),
+    (0xFCEE, 'M', u'نم'),
+    ]
+
+def _seg_47():
+    return [
+    (0xFCEF, 'M', u'نه'),
+    (0xFCF0, 'M', u'يم'),
+    (0xFCF1, 'M', u'يه'),
+    (0xFCF2, 'M', u'ـَّ'),
+    (0xFCF3, 'M', u'ـُّ'),
+    (0xFCF4, 'M', u'ـِّ'),
+    (0xFCF5, 'M', u'طى'),
+    (0xFCF6, 'M', u'طي'),
+    (0xFCF7, 'M', u'عى'),
+    (0xFCF8, 'M', u'عي'),
+    (0xFCF9, 'M', u'غى'),
+    (0xFCFA, 'M', u'غي'),
+    (0xFCFB, 'M', u'سى'),
+    (0xFCFC, 'M', u'سي'),
+    (0xFCFD, 'M', u'شى'),
+    (0xFCFE, 'M', u'شي'),
+    (0xFCFF, 'M', u'حى'),
+    (0xFD00, 'M', u'حي'),
+    (0xFD01, 'M', u'جى'),
+    (0xFD02, 'M', u'جي'),
+    (0xFD03, 'M', u'خى'),
+    (0xFD04, 'M', u'خي'),
+    (0xFD05, 'M', u'صى'),
+    (0xFD06, 'M', u'صي'),
+    (0xFD07, 'M', u'ضى'),
+    (0xFD08, 'M', u'ضي'),
+    (0xFD09, 'M', u'شج'),
+    (0xFD0A, 'M', u'شح'),
+    (0xFD0B, 'M', u'شخ'),
+    (0xFD0C, 'M', u'شم'),
+    (0xFD0D, 'M', u'شر'),
+    (0xFD0E, 'M', u'سر'),
+    (0xFD0F, 'M', u'صر'),
+    (0xFD10, 'M', u'ضر'),
+    (0xFD11, 'M', u'طى'),
+    (0xFD12, 'M', u'طي'),
+    (0xFD13, 'M', u'عى'),
+    (0xFD14, 'M', u'عي'),
+    (0xFD15, 'M', u'غى'),
+    (0xFD16, 'M', u'غي'),
+    (0xFD17, 'M', u'سى'),
+    (0xFD18, 'M', u'سي'),
+    (0xFD19, 'M', u'شى'),
+    (0xFD1A, 'M', u'شي'),
+    (0xFD1B, 'M', u'حى'),
+    (0xFD1C, 'M', u'حي'),
+    (0xFD1D, 'M', u'جى'),
+    (0xFD1E, 'M', u'جي'),
+    (0xFD1F, 'M', u'خى'),
+    (0xFD20, 'M', u'خي'),
+    (0xFD21, 'M', u'صى'),
+    (0xFD22, 'M', u'صي'),
+    (0xFD23, 'M', u'ضى'),
+    (0xFD24, 'M', u'ضي'),
+    (0xFD25, 'M', u'شج'),
+    (0xFD26, 'M', u'شح'),
+    (0xFD27, 'M', u'شخ'),
+    (0xFD28, 'M', u'شم'),
+    (0xFD29, 'M', u'شر'),
+    (0xFD2A, 'M', u'سر'),
+    (0xFD2B, 'M', u'صر'),
+    (0xFD2C, 'M', u'ضر'),
+    (0xFD2D, 'M', u'شج'),
+    (0xFD2E, 'M', u'شح'),
+    (0xFD2F, 'M', u'شخ'),
+    (0xFD30, 'M', u'شم'),
+    (0xFD31, 'M', u'سه'),
+    (0xFD32, 'M', u'شه'),
+    (0xFD33, 'M', u'طم'),
+    (0xFD34, 'M', u'سج'),
+    (0xFD35, 'M', u'سح'),
+    (0xFD36, 'M', u'سخ'),
+    (0xFD37, 'M', u'شج'),
+    (0xFD38, 'M', u'شح'),
+    (0xFD39, 'M', u'شخ'),
+    (0xFD3A, 'M', u'طم'),
+    (0xFD3B, 'M', u'ظم'),
+    (0xFD3C, 'M', u'اً'),
+    (0xFD3E, 'V'),
+    (0xFD40, 'X'),
+    (0xFD50, 'M', u'تجم'),
+    (0xFD51, 'M', u'تحج'),
+    (0xFD53, 'M', u'تحم'),
+    (0xFD54, 'M', u'تخم'),
+    (0xFD55, 'M', u'تمج'),
+    (0xFD56, 'M', u'تمح'),
+    (0xFD57, 'M', u'تمخ'),
+    (0xFD58, 'M', u'جمح'),
+    (0xFD5A, 'M', u'حمي'),
+    (0xFD5B, 'M', u'حمى'),
+    (0xFD5C, 'M', u'سحج'),
+    (0xFD5D, 'M', u'سجح'),
+    (0xFD5E, 'M', u'سجى'),
+    (0xFD5F, 'M', u'سمح'),
+    (0xFD61, 'M', u'سمج'),
+    (0xFD62, 'M', u'سمم'),
+    (0xFD64, 'M', u'صحح'),
+    (0xFD66, 'M', u'صمم'),
+    (0xFD67, 'M', u'شحم'),
+    (0xFD69, 'M', u'شجي'),
+    ]
+
+def _seg_48():
+    return [
+    (0xFD6A, 'M', u'شمخ'),
+    (0xFD6C, 'M', u'شمم'),
+    (0xFD6E, 'M', u'ضحى'),
+    (0xFD6F, 'M', u'ضخم'),
+    (0xFD71, 'M', u'طمح'),
+    (0xFD73, 'M', u'طمم'),
+    (0xFD74, 'M', u'طمي'),
+    (0xFD75, 'M', u'عجم'),
+    (0xFD76, 'M', u'عمم'),
+    (0xFD78, 'M', u'عمى'),
+    (0xFD79, 'M', u'غمم'),
+    (0xFD7A, 'M', u'غمي'),
+    (0xFD7B, 'M', u'غمى'),
+    (0xFD7C, 'M', u'فخم'),
+    (0xFD7E, 'M', u'قمح'),
+    (0xFD7F, 'M', u'قمم'),
+    (0xFD80, 'M', u'لحم'),
+    (0xFD81, 'M', u'لحي'),
+    (0xFD82, 'M', u'لحى'),
+    (0xFD83, 'M', u'لجج'),
+    (0xFD85, 'M', u'لخم'),
+    (0xFD87, 'M', u'لمح'),
+    (0xFD89, 'M', u'محج'),
+    (0xFD8A, 'M', u'محم'),
+    (0xFD8B, 'M', u'محي'),
+    (0xFD8C, 'M', u'مجح'),
+    (0xFD8D, 'M', u'مجم'),
+    (0xFD8E, 'M', u'مخج'),
+    (0xFD8F, 'M', u'مخم'),
+    (0xFD90, 'X'),
+    (0xFD92, 'M', u'مجخ'),
+    (0xFD93, 'M', u'همج'),
+    (0xFD94, 'M', u'همم'),
+    (0xFD95, 'M', u'نحم'),
+    (0xFD96, 'M', u'نحى'),
+    (0xFD97, 'M', u'نجم'),
+    (0xFD99, 'M', u'نجى'),
+    (0xFD9A, 'M', u'نمي'),
+    (0xFD9B, 'M', u'نمى'),
+    (0xFD9C, 'M', u'يمم'),
+    (0xFD9E, 'M', u'بخي'),
+    (0xFD9F, 'M', u'تجي'),
+    (0xFDA0, 'M', u'تجى'),
+    (0xFDA1, 'M', u'تخي'),
+    (0xFDA2, 'M', u'تخى'),
+    (0xFDA3, 'M', u'تمي'),
+    (0xFDA4, 'M', u'تمى'),
+    (0xFDA5, 'M', u'جمي'),
+    (0xFDA6, 'M', u'جحى'),
+    (0xFDA7, 'M', u'جمى'),
+    (0xFDA8, 'M', u'سخى'),
+    (0xFDA9, 'M', u'صحي'),
+    (0xFDAA, 'M', u'شحي'),
+    (0xFDAB, 'M', u'ضحي'),
+    (0xFDAC, 'M', u'لجي'),
+    (0xFDAD, 'M', u'لمي'),
+    (0xFDAE, 'M', u'يحي'),
+    (0xFDAF, 'M', u'يجي'),
+    (0xFDB0, 'M', u'يمي'),
+    (0xFDB1, 'M', u'ممي'),
+    (0xFDB2, 'M', u'قمي'),
+    (0xFDB3, 'M', u'نحي'),
+    (0xFDB4, 'M', u'قمح'),
+    (0xFDB5, 'M', u'لحم'),
+    (0xFDB6, 'M', u'عمي'),
+    (0xFDB7, 'M', u'كمي'),
+    (0xFDB8, 'M', u'نجح'),
+    (0xFDB9, 'M', u'مخي'),
+    (0xFDBA, 'M', u'لجم'),
+    (0xFDBB, 'M', u'كمم'),
+    (0xFDBC, 'M', u'لجم'),
+    (0xFDBD, 'M', u'نجح'),
+    (0xFDBE, 'M', u'جحي'),
+    (0xFDBF, 'M', u'حجي'),
+    (0xFDC0, 'M', u'مجي'),
+    (0xFDC1, 'M', u'فمي'),
+    (0xFDC2, 'M', u'بحي'),
+    (0xFDC3, 'M', u'كمم'),
+    (0xFDC4, 'M', u'عجم'),
+    (0xFDC5, 'M', u'صمم'),
+    (0xFDC6, 'M', u'سخي'),
+    (0xFDC7, 'M', u'نجي'),
+    (0xFDC8, 'X'),
+    (0xFDF0, 'M', u'صلے'),
+    (0xFDF1, 'M', u'قلے'),
+    (0xFDF2, 'M', u'الله'),
+    (0xFDF3, 'M', u'اكبر'),
+    (0xFDF4, 'M', u'محمد'),
+    (0xFDF5, 'M', u'صلعم'),
+    (0xFDF6, 'M', u'رسول'),
+    (0xFDF7, 'M', u'عليه'),
+    (0xFDF8, 'M', u'وسلم'),
+    (0xFDF9, 'M', u'صلى'),
+    (0xFDFA, '3', u'صلى الله عليه وسلم'),
+    (0xFDFB, '3', u'جل جلاله'),
+    (0xFDFC, 'M', u'ریال'),
+    (0xFDFD, 'V'),
+    (0xFDFE, 'X'),
+    (0xFE00, 'I'),
+    (0xFE10, '3', u','),
+    ]
+
+def _seg_49():
+    return [
+    (0xFE11, 'M', u'、'),
+    (0xFE12, 'X'),
+    (0xFE13, '3', u':'),
+    (0xFE14, '3', u';'),
+    (0xFE15, '3', u'!'),
+    (0xFE16, '3', u'?'),
+    (0xFE17, 'M', u'〖'),
+    (0xFE18, 'M', u'〗'),
+    (0xFE19, 'X'),
+    (0xFE20, 'V'),
+    (0xFE30, 'X'),
+    (0xFE31, 'M', u'—'),
+    (0xFE32, 'M', u'–'),
+    (0xFE33, '3', u'_'),
+    (0xFE35, '3', u'('),
+    (0xFE36, '3', u')'),
+    (0xFE37, '3', u'{'),
+    (0xFE38, '3', u'}'),
+    (0xFE39, 'M', u'〔'),
+    (0xFE3A, 'M', u'〕'),
+    (0xFE3B, 'M', u'【'),
+    (0xFE3C, 'M', u'】'),
+    (0xFE3D, 'M', u'《'),
+    (0xFE3E, 'M', u'》'),
+    (0xFE3F, 'M', u'〈'),
+    (0xFE40, 'M', u'〉'),
+    (0xFE41, 'M', u'「'),
+    (0xFE42, 'M', u'」'),
+    (0xFE43, 'M', u'『'),
+    (0xFE44, 'M', u'』'),
+    (0xFE45, 'V'),
+    (0xFE47, '3', u'['),
+    (0xFE48, '3', u']'),
+    (0xFE49, '3', u' ̅'),
+    (0xFE4D, '3', u'_'),
+    (0xFE50, '3', u','),
+    (0xFE51, 'M', u'、'),
+    (0xFE52, 'X'),
+    (0xFE54, '3', u';'),
+    (0xFE55, '3', u':'),
+    (0xFE56, '3', u'?'),
+    (0xFE57, '3', u'!'),
+    (0xFE58, 'M', u'—'),
+    (0xFE59, '3', u'('),
+    (0xFE5A, '3', u')'),
+    (0xFE5B, '3', u'{'),
+    (0xFE5C, '3', u'}'),
+    (0xFE5D, 'M', u'〔'),
+    (0xFE5E, 'M', u'〕'),
+    (0xFE5F, '3', u'#'),
+    (0xFE60, '3', u'&'),
+    (0xFE61, '3', u'*'),
+    (0xFE62, '3', u'+'),
+    (0xFE63, 'M', u'-'),
+    (0xFE64, '3', u'<'),
+    (0xFE65, '3', u'>'),
+    (0xFE66, '3', u'='),
+    (0xFE67, 'X'),
+    (0xFE68, '3', u'\\'),
+    (0xFE69, '3', u'$'),
+    (0xFE6A, '3', u'%'),
+    (0xFE6B, '3', u'@'),
+    (0xFE6C, 'X'),
+    (0xFE70, '3', u' ً'),
+    (0xFE71, 'M', u'ـً'),
+    (0xFE72, '3', u' ٌ'),
+    (0xFE73, 'V'),
+    (0xFE74, '3', u' ٍ'),
+    (0xFE75, 'X'),
+    (0xFE76, '3', u' َ'),
+    (0xFE77, 'M', u'ـَ'),
+    (0xFE78, '3', u' ُ'),
+    (0xFE79, 'M', u'ـُ'),
+    (0xFE7A, '3', u' ِ'),
+    (0xFE7B, 'M', u'ـِ'),
+    (0xFE7C, '3', u' ّ'),
+    (0xFE7D, 'M', u'ـّ'),
+    (0xFE7E, '3', u' ْ'),
+    (0xFE7F, 'M', u'ـْ'),
+    (0xFE80, 'M', u'ء'),
+    (0xFE81, 'M', u'آ'),
+    (0xFE83, 'M', u'أ'),
+    (0xFE85, 'M', u'ؤ'),
+    (0xFE87, 'M', u'إ'),
+    (0xFE89, 'M', u'ئ'),
+    (0xFE8D, 'M', u'ا'),
+    (0xFE8F, 'M', u'ب'),
+    (0xFE93, 'M', u'ة'),
+    (0xFE95, 'M', u'ت'),
+    (0xFE99, 'M', u'ث'),
+    (0xFE9D, 'M', u'ج'),
+    (0xFEA1, 'M', u'ح'),
+    (0xFEA5, 'M', u'خ'),
+    (0xFEA9, 'M', u'د'),
+    (0xFEAB, 'M', u'ذ'),
+    (0xFEAD, 'M', u'ر'),
+    (0xFEAF, 'M', u'ز'),
+    (0xFEB1, 'M', u'س'),
+    (0xFEB5, 'M', u'ش'),
+    (0xFEB9, 'M', u'ص'),
+    ]
+
+def _seg_50():
+    return [
+    (0xFEBD, 'M', u'ض'),
+    (0xFEC1, 'M', u'ط'),
+    (0xFEC5, 'M', u'ظ'),
+    (0xFEC9, 'M', u'ع'),
+    (0xFECD, 'M', u'غ'),
+    (0xFED1, 'M', u'ف'),
+    (0xFED5, 'M', u'ق'),
+    (0xFED9, 'M', u'ك'),
+    (0xFEDD, 'M', u'ل'),
+    (0xFEE1, 'M', u'م'),
+    (0xFEE5, 'M', u'ن'),
+    (0xFEE9, 'M', u'ه'),
+    (0xFEED, 'M', u'و'),
+    (0xFEEF, 'M', u'ى'),
+    (0xFEF1, 'M', u'ي'),
+    (0xFEF5, 'M', u'لآ'),
+    (0xFEF7, 'M', u'لأ'),
+    (0xFEF9, 'M', u'لإ'),
+    (0xFEFB, 'M', u'لا'),
+    (0xFEFD, 'X'),
+    (0xFEFF, 'I'),
+    (0xFF00, 'X'),
+    (0xFF01, '3', u'!'),
+    (0xFF02, '3', u'"'),
+    (0xFF03, '3', u'#'),
+    (0xFF04, '3', u'$'),
+    (0xFF05, '3', u'%'),
+    (0xFF06, '3', u'&'),
+    (0xFF07, '3', u'\''),
+    (0xFF08, '3', u'('),
+    (0xFF09, '3', u')'),
+    (0xFF0A, '3', u'*'),
+    (0xFF0B, '3', u'+'),
+    (0xFF0C, '3', u','),
+    (0xFF0D, 'M', u'-'),
+    (0xFF0E, 'M', u'.'),
+    (0xFF0F, '3', u'/'),
+    (0xFF10, 'M', u'0'),
+    (0xFF11, 'M', u'1'),
+    (0xFF12, 'M', u'2'),
+    (0xFF13, 'M', u'3'),
+    (0xFF14, 'M', u'4'),
+    (0xFF15, 'M', u'5'),
+    (0xFF16, 'M', u'6'),
+    (0xFF17, 'M', u'7'),
+    (0xFF18, 'M', u'8'),
+    (0xFF19, 'M', u'9'),
+    (0xFF1A, '3', u':'),
+    (0xFF1B, '3', u';'),
+    (0xFF1C, '3', u'<'),
+    (0xFF1D, '3', u'='),
+    (0xFF1E, '3', u'>'),
+    (0xFF1F, '3', u'?'),
+    (0xFF20, '3', u'@'),
+    (0xFF21, 'M', u'a'),
+    (0xFF22, 'M', u'b'),
+    (0xFF23, 'M', u'c'),
+    (0xFF24, 'M', u'd'),
+    (0xFF25, 'M', u'e'),
+    (0xFF26, 'M', u'f'),
+    (0xFF27, 'M', u'g'),
+    (0xFF28, 'M', u'h'),
+    (0xFF29, 'M', u'i'),
+    (0xFF2A, 'M', u'j'),
+    (0xFF2B, 'M', u'k'),
+    (0xFF2C, 'M', u'l'),
+    (0xFF2D, 'M', u'm'),
+    (0xFF2E, 'M', u'n'),
+    (0xFF2F, 'M', u'o'),
+    (0xFF30, 'M', u'p'),
+    (0xFF31, 'M', u'q'),
+    (0xFF32, 'M', u'r'),
+    (0xFF33, 'M', u's'),
+    (0xFF34, 'M', u't'),
+    (0xFF35, 'M', u'u'),
+    (0xFF36, 'M', u'v'),
+    (0xFF37, 'M', u'w'),
+    (0xFF38, 'M', u'x'),
+    (0xFF39, 'M', u'y'),
+    (0xFF3A, 'M', u'z'),
+    (0xFF3B, '3', u'['),
+    (0xFF3C, '3', u'\\'),
+    (0xFF3D, '3', u']'),
+    (0xFF3E, '3', u'^'),
+    (0xFF3F, '3', u'_'),
+    (0xFF40, '3', u'`'),
+    (0xFF41, 'M', u'a'),
+    (0xFF42, 'M', u'b'),
+    (0xFF43, 'M', u'c'),
+    (0xFF44, 'M', u'd'),
+    (0xFF45, 'M', u'e'),
+    (0xFF46, 'M', u'f'),
+    (0xFF47, 'M', u'g'),
+    (0xFF48, 'M', u'h'),
+    (0xFF49, 'M', u'i'),
+    (0xFF4A, 'M', u'j'),
+    (0xFF4B, 'M', u'k'),
+    (0xFF4C, 'M', u'l'),
+    (0xFF4D, 'M', u'm'),
+    (0xFF4E, 'M', u'n'),
+    ]
+
+def _seg_51():
+    return [
+    (0xFF4F, 'M', u'o'),
+    (0xFF50, 'M', u'p'),
+    (0xFF51, 'M', u'q'),
+    (0xFF52, 'M', u'r'),
+    (0xFF53, 'M', u's'),
+    (0xFF54, 'M', u't'),
+    (0xFF55, 'M', u'u'),
+    (0xFF56, 'M', u'v'),
+    (0xFF57, 'M', u'w'),
+    (0xFF58, 'M', u'x'),
+    (0xFF59, 'M', u'y'),
+    (0xFF5A, 'M', u'z'),
+    (0xFF5B, '3', u'{'),
+    (0xFF5C, '3', u'|'),
+    (0xFF5D, '3', u'}'),
+    (0xFF5E, '3', u'~'),
+    (0xFF5F, 'M', u'⦅'),
+    (0xFF60, 'M', u'⦆'),
+    (0xFF61, 'M', u'.'),
+    (0xFF62, 'M', u'「'),
+    (0xFF63, 'M', u'」'),
+    (0xFF64, 'M', u'、'),
+    (0xFF65, 'M', u'・'),
+    (0xFF66, 'M', u'ヲ'),
+    (0xFF67, 'M', u'ァ'),
+    (0xFF68, 'M', u'ィ'),
+    (0xFF69, 'M', u'ゥ'),
+    (0xFF6A, 'M', u'ェ'),
+    (0xFF6B, 'M', u'ォ'),
+    (0xFF6C, 'M', u'ャ'),
+    (0xFF6D, 'M', u'ュ'),
+    (0xFF6E, 'M', u'ョ'),
+    (0xFF6F, 'M', u'ッ'),
+    (0xFF70, 'M', u'ー'),
+    (0xFF71, 'M', u'ア'),
+    (0xFF72, 'M', u'イ'),
+    (0xFF73, 'M', u'ウ'),
+    (0xFF74, 'M', u'エ'),
+    (0xFF75, 'M', u'オ'),
+    (0xFF76, 'M', u'カ'),
+    (0xFF77, 'M', u'キ'),
+    (0xFF78, 'M', u'ク'),
+    (0xFF79, 'M', u'ケ'),
+    (0xFF7A, 'M', u'コ'),
+    (0xFF7B, 'M', u'サ'),
+    (0xFF7C, 'M', u'シ'),
+    (0xFF7D, 'M', u'ス'),
+    (0xFF7E, 'M', u'セ'),
+    (0xFF7F, 'M', u'ソ'),
+    (0xFF80, 'M', u'タ'),
+    (0xFF81, 'M', u'チ'),
+    (0xFF82, 'M', u'ツ'),
+    (0xFF83, 'M', u'テ'),
+    (0xFF84, 'M', u'ト'),
+    (0xFF85, 'M', u'ナ'),
+    (0xFF86, 'M', u'ニ'),
+    (0xFF87, 'M', u'ヌ'),
+    (0xFF88, 'M', u'ネ'),
+    (0xFF89, 'M', u'ノ'),
+    (0xFF8A, 'M', u'ハ'),
+    (0xFF8B, 'M', u'ヒ'),
+    (0xFF8C, 'M', u'フ'),
+    (0xFF8D, 'M', u'ヘ'),
+    (0xFF8E, 'M', u'ホ'),
+    (0xFF8F, 'M', u'マ'),
+    (0xFF90, 'M', u'ミ'),
+    (0xFF91, 'M', u'ム'),
+    (0xFF92, 'M', u'メ'),
+    (0xFF93, 'M', u'モ'),
+    (0xFF94, 'M', u'ヤ'),
+    (0xFF95, 'M', u'ユ'),
+    (0xFF96, 'M', u'ヨ'),
+    (0xFF97, 'M', u'ラ'),
+    (0xFF98, 'M', u'リ'),
+    (0xFF99, 'M', u'ル'),
+    (0xFF9A, 'M', u'レ'),
+    (0xFF9B, 'M', u'ロ'),
+    (0xFF9C, 'M', u'ワ'),
+    (0xFF9D, 'M', u'ン'),
+    (0xFF9E, 'M', u'゙'),
+    (0xFF9F, 'M', u'゚'),
+    (0xFFA0, 'X'),
+    (0xFFA1, 'M', u'ᄀ'),
+    (0xFFA2, 'M', u'ᄁ'),
+    (0xFFA3, 'M', u'ᆪ'),
+    (0xFFA4, 'M', u'ᄂ'),
+    (0xFFA5, 'M', u'ᆬ'),
+    (0xFFA6, 'M', u'ᆭ'),
+    (0xFFA7, 'M', u'ᄃ'),
+    (0xFFA8, 'M', u'ᄄ'),
+    (0xFFA9, 'M', u'ᄅ'),
+    (0xFFAA, 'M', u'ᆰ'),
+    (0xFFAB, 'M', u'ᆱ'),
+    (0xFFAC, 'M', u'ᆲ'),
+    (0xFFAD, 'M', u'ᆳ'),
+    (0xFFAE, 'M', u'ᆴ'),
+    (0xFFAF, 'M', u'ᆵ'),
+    (0xFFB0, 'M', u'ᄚ'),
+    (0xFFB1, 'M', u'ᄆ'),
+    (0xFFB2, 'M', u'ᄇ'),
+    ]
+
+def _seg_52():
+    return [
+    (0xFFB3, 'M', u'ᄈ'),
+    (0xFFB4, 'M', u'ᄡ'),
+    (0xFFB5, 'M', u'ᄉ'),
+    (0xFFB6, 'M', u'ᄊ'),
+    (0xFFB7, 'M', u'ᄋ'),
+    (0xFFB8, 'M', u'ᄌ'),
+    (0xFFB9, 'M', u'ᄍ'),
+    (0xFFBA, 'M', u'ᄎ'),
+    (0xFFBB, 'M', u'ᄏ'),
+    (0xFFBC, 'M', u'ᄐ'),
+    (0xFFBD, 'M', u'ᄑ'),
+    (0xFFBE, 'M', u'ᄒ'),
+    (0xFFBF, 'X'),
+    (0xFFC2, 'M', u'ᅡ'),
+    (0xFFC3, 'M', u'ᅢ'),
+    (0xFFC4, 'M', u'ᅣ'),
+    (0xFFC5, 'M', u'ᅤ'),
+    (0xFFC6, 'M', u'ᅥ'),
+    (0xFFC7, 'M', u'ᅦ'),
+    (0xFFC8, 'X'),
+    (0xFFCA, 'M', u'ᅧ'),
+    (0xFFCB, 'M', u'ᅨ'),
+    (0xFFCC, 'M', u'ᅩ'),
+    (0xFFCD, 'M', u'ᅪ'),
+    (0xFFCE, 'M', u'ᅫ'),
+    (0xFFCF, 'M', u'ᅬ'),
+    (0xFFD0, 'X'),
+    (0xFFD2, 'M', u'ᅭ'),
+    (0xFFD3, 'M', u'ᅮ'),
+    (0xFFD4, 'M', u'ᅯ'),
+    (0xFFD5, 'M', u'ᅰ'),
+    (0xFFD6, 'M', u'ᅱ'),
+    (0xFFD7, 'M', u'ᅲ'),
+    (0xFFD8, 'X'),
+    (0xFFDA, 'M', u'ᅳ'),
+    (0xFFDB, 'M', u'ᅴ'),
+    (0xFFDC, 'M', u'ᅵ'),
+    (0xFFDD, 'X'),
+    (0xFFE0, 'M', u'¢'),
+    (0xFFE1, 'M', u'£'),
+    (0xFFE2, 'M', u'¬'),
+    (0xFFE3, '3', u' ̄'),
+    (0xFFE4, 'M', u'¦'),
+    (0xFFE5, 'M', u'¥'),
+    (0xFFE6, 'M', u'₩'),
+    (0xFFE7, 'X'),
+    (0xFFE8, 'M', u'│'),
+    (0xFFE9, 'M', u'←'),
+    (0xFFEA, 'M', u'↑'),
+    (0xFFEB, 'M', u'→'),
+    (0xFFEC, 'M', u'↓'),
+    (0xFFED, 'M', u'■'),
+    (0xFFEE, 'M', u'○'),
+    (0xFFEF, 'X'),
+    (0x10000, 'V'),
+    (0x1000C, 'X'),
+    (0x1000D, 'V'),
+    (0x10027, 'X'),
+    (0x10028, 'V'),
+    (0x1003B, 'X'),
+    (0x1003C, 'V'),
+    (0x1003E, 'X'),
+    (0x1003F, 'V'),
+    (0x1004E, 'X'),
+    (0x10050, 'V'),
+    (0x1005E, 'X'),
+    (0x10080, 'V'),
+    (0x100FB, 'X'),
+    (0x10100, 'V'),
+    (0x10103, 'X'),
+    (0x10107, 'V'),
+    (0x10134, 'X'),
+    (0x10137, 'V'),
+    (0x1018F, 'X'),
+    (0x10190, 'V'),
+    (0x1019C, 'X'),
+    (0x101A0, 'V'),
+    (0x101A1, 'X'),
+    (0x101D0, 'V'),
+    (0x101FE, 'X'),
+    (0x10280, 'V'),
+    (0x1029D, 'X'),
+    (0x102A0, 'V'),
+    (0x102D1, 'X'),
+    (0x102E0, 'V'),
+    (0x102FC, 'X'),
+    (0x10300, 'V'),
+    (0x10324, 'X'),
+    (0x1032D, 'V'),
+    (0x1034B, 'X'),
+    (0x10350, 'V'),
+    (0x1037B, 'X'),
+    (0x10380, 'V'),
+    (0x1039E, 'X'),
+    (0x1039F, 'V'),
+    (0x103C4, 'X'),
+    (0x103C8, 'V'),
+    (0x103D6, 'X'),
+    (0x10400, 'M', u'𐐨'),
+    (0x10401, 'M', u'𐐩'),
+    ]
+
+def _seg_53():
+    return [
+    (0x10402, 'M', u'𐐪'),
+    (0x10403, 'M', u'𐐫'),
+    (0x10404, 'M', u'𐐬'),
+    (0x10405, 'M', u'𐐭'),
+    (0x10406, 'M', u'𐐮'),
+    (0x10407, 'M', u'𐐯'),
+    (0x10408, 'M', u'𐐰'),
+    (0x10409, 'M', u'𐐱'),
+    (0x1040A, 'M', u'𐐲'),
+    (0x1040B, 'M', u'𐐳'),
+    (0x1040C, 'M', u'𐐴'),
+    (0x1040D, 'M', u'𐐵'),
+    (0x1040E, 'M', u'𐐶'),
+    (0x1040F, 'M', u'𐐷'),
+    (0x10410, 'M', u'𐐸'),
+    (0x10411, 'M', u'𐐹'),
+    (0x10412, 'M', u'𐐺'),
+    (0x10413, 'M', u'𐐻'),
+    (0x10414, 'M', u'𐐼'),
+    (0x10415, 'M', u'𐐽'),
+    (0x10416, 'M', u'𐐾'),
+    (0x10417, 'M', u'𐐿'),
+    (0x10418, 'M', u'𐑀'),
+    (0x10419, 'M', u'𐑁'),
+    (0x1041A, 'M', u'𐑂'),
+    (0x1041B, 'M', u'𐑃'),
+    (0x1041C, 'M', u'𐑄'),
+    (0x1041D, 'M', u'𐑅'),
+    (0x1041E, 'M', u'𐑆'),
+    (0x1041F, 'M', u'𐑇'),
+    (0x10420, 'M', u'𐑈'),
+    (0x10421, 'M', u'𐑉'),
+    (0x10422, 'M', u'𐑊'),
+    (0x10423, 'M', u'𐑋'),
+    (0x10424, 'M', u'𐑌'),
+    (0x10425, 'M', u'𐑍'),
+    (0x10426, 'M', u'𐑎'),
+    (0x10427, 'M', u'𐑏'),
+    (0x10428, 'V'),
+    (0x1049E, 'X'),
+    (0x104A0, 'V'),
+    (0x104AA, 'X'),
+    (0x104B0, 'M', u'𐓘'),
+    (0x104B1, 'M', u'𐓙'),
+    (0x104B2, 'M', u'𐓚'),
+    (0x104B3, 'M', u'𐓛'),
+    (0x104B4, 'M', u'𐓜'),
+    (0x104B5, 'M', u'𐓝'),
+    (0x104B6, 'M', u'𐓞'),
+    (0x104B7, 'M', u'𐓟'),
+    (0x104B8, 'M', u'𐓠'),
+    (0x104B9, 'M', u'𐓡'),
+    (0x104BA, 'M', u'𐓢'),
+    (0x104BB, 'M', u'𐓣'),
+    (0x104BC, 'M', u'𐓤'),
+    (0x104BD, 'M', u'𐓥'),
+    (0x104BE, 'M', u'𐓦'),
+    (0x104BF, 'M', u'𐓧'),
+    (0x104C0, 'M', u'𐓨'),
+    (0x104C1, 'M', u'𐓩'),
+    (0x104C2, 'M', u'𐓪'),
+    (0x104C3, 'M', u'𐓫'),
+    (0x104C4, 'M', u'𐓬'),
+    (0x104C5, 'M', u'𐓭'),
+    (0x104C6, 'M', u'𐓮'),
+    (0x104C7, 'M', u'𐓯'),
+    (0x104C8, 'M', u'𐓰'),
+    (0x104C9, 'M', u'𐓱'),
+    (0x104CA, 'M', u'𐓲'),
+    (0x104CB, 'M', u'𐓳'),
+    (0x104CC, 'M', u'𐓴'),
+    (0x104CD, 'M', u'𐓵'),
+    (0x104CE, 'M', u'𐓶'),
+    (0x104CF, 'M', u'𐓷'),
+    (0x104D0, 'M', u'𐓸'),
+    (0x104D1, 'M', u'𐓹'),
+    (0x104D2, 'M', u'𐓺'),
+    (0x104D3, 'M', u'𐓻'),
+    (0x104D4, 'X'),
+    (0x104D8, 'V'),
+    (0x104FC, 'X'),
+    (0x10500, 'V'),
+    (0x10528, 'X'),
+    (0x10530, 'V'),
+    (0x10564, 'X'),
+    (0x1056F, 'V'),
+    (0x10570, 'X'),
+    (0x10600, 'V'),
+    (0x10737, 'X'),
+    (0x10740, 'V'),
+    (0x10756, 'X'),
+    (0x10760, 'V'),
+    (0x10768, 'X'),
+    (0x10800, 'V'),
+    (0x10806, 'X'),
+    (0x10808, 'V'),
+    (0x10809, 'X'),
+    (0x1080A, 'V'),
+    (0x10836, 'X'),
+    (0x10837, 'V'),
+    ]
+
+def _seg_54():
+    return [
+    (0x10839, 'X'),
+    (0x1083C, 'V'),
+    (0x1083D, 'X'),
+    (0x1083F, 'V'),
+    (0x10856, 'X'),
+    (0x10857, 'V'),
+    (0x1089F, 'X'),
+    (0x108A7, 'V'),
+    (0x108B0, 'X'),
+    (0x108E0, 'V'),
+    (0x108F3, 'X'),
+    (0x108F4, 'V'),
+    (0x108F6, 'X'),
+    (0x108FB, 'V'),
+    (0x1091C, 'X'),
+    (0x1091F, 'V'),
+    (0x1093A, 'X'),
+    (0x1093F, 'V'),
+    (0x10940, 'X'),
+    (0x10980, 'V'),
+    (0x109B8, 'X'),
+    (0x109BC, 'V'),
+    (0x109D0, 'X'),
+    (0x109D2, 'V'),
+    (0x10A04, 'X'),
+    (0x10A05, 'V'),
+    (0x10A07, 'X'),
+    (0x10A0C, 'V'),
+    (0x10A14, 'X'),
+    (0x10A15, 'V'),
+    (0x10A18, 'X'),
+    (0x10A19, 'V'),
+    (0x10A36, 'X'),
+    (0x10A38, 'V'),
+    (0x10A3B, 'X'),
+    (0x10A3F, 'V'),
+    (0x10A49, 'X'),
+    (0x10A50, 'V'),
+    (0x10A59, 'X'),
+    (0x10A60, 'V'),
+    (0x10AA0, 'X'),
+    (0x10AC0, 'V'),
+    (0x10AE7, 'X'),
+    (0x10AEB, 'V'),
+    (0x10AF7, 'X'),
+    (0x10B00, 'V'),
+    (0x10B36, 'X'),
+    (0x10B39, 'V'),
+    (0x10B56, 'X'),
+    (0x10B58, 'V'),
+    (0x10B73, 'X'),
+    (0x10B78, 'V'),
+    (0x10B92, 'X'),
+    (0x10B99, 'V'),
+    (0x10B9D, 'X'),
+    (0x10BA9, 'V'),
+    (0x10BB0, 'X'),
+    (0x10C00, 'V'),
+    (0x10C49, 'X'),
+    (0x10C80, 'M', u'𐳀'),
+    (0x10C81, 'M', u'𐳁'),
+    (0x10C82, 'M', u'𐳂'),
+    (0x10C83, 'M', u'𐳃'),
+    (0x10C84, 'M', u'𐳄'),
+    (0x10C85, 'M', u'𐳅'),
+    (0x10C86, 'M', u'𐳆'),
+    (0x10C87, 'M', u'𐳇'),
+    (0x10C88, 'M', u'𐳈'),
+    (0x10C89, 'M', u'𐳉'),
+    (0x10C8A, 'M', u'𐳊'),
+    (0x10C8B, 'M', u'𐳋'),
+    (0x10C8C, 'M', u'𐳌'),
+    (0x10C8D, 'M', u'𐳍'),
+    (0x10C8E, 'M', u'𐳎'),
+    (0x10C8F, 'M', u'𐳏'),
+    (0x10C90, 'M', u'𐳐'),
+    (0x10C91, 'M', u'𐳑'),
+    (0x10C92, 'M', u'𐳒'),
+    (0x10C93, 'M', u'𐳓'),
+    (0x10C94, 'M', u'𐳔'),
+    (0x10C95, 'M', u'𐳕'),
+    (0x10C96, 'M', u'𐳖'),
+    (0x10C97, 'M', u'𐳗'),
+    (0x10C98, 'M', u'𐳘'),
+    (0x10C99, 'M', u'𐳙'),
+    (0x10C9A, 'M', u'𐳚'),
+    (0x10C9B, 'M', u'𐳛'),
+    (0x10C9C, 'M', u'𐳜'),
+    (0x10C9D, 'M', u'𐳝'),
+    (0x10C9E, 'M', u'𐳞'),
+    (0x10C9F, 'M', u'𐳟'),
+    (0x10CA0, 'M', u'𐳠'),
+    (0x10CA1, 'M', u'𐳡'),
+    (0x10CA2, 'M', u'𐳢'),
+    (0x10CA3, 'M', u'𐳣'),
+    (0x10CA4, 'M', u'𐳤'),
+    (0x10CA5, 'M', u'𐳥'),
+    (0x10CA6, 'M', u'𐳦'),
+    (0x10CA7, 'M', u'𐳧'),
+    (0x10CA8, 'M', u'𐳨'),
+    ]
+
+def _seg_55():
+    return [
+    (0x10CA9, 'M', u'𐳩'),
+    (0x10CAA, 'M', u'𐳪'),
+    (0x10CAB, 'M', u'𐳫'),
+    (0x10CAC, 'M', u'𐳬'),
+    (0x10CAD, 'M', u'𐳭'),
+    (0x10CAE, 'M', u'𐳮'),
+    (0x10CAF, 'M', u'𐳯'),
+    (0x10CB0, 'M', u'𐳰'),
+    (0x10CB1, 'M', u'𐳱'),
+    (0x10CB2, 'M', u'𐳲'),
+    (0x10CB3, 'X'),
+    (0x10CC0, 'V'),
+    (0x10CF3, 'X'),
+    (0x10CFA, 'V'),
+    (0x10D28, 'X'),
+    (0x10D30, 'V'),
+    (0x10D3A, 'X'),
+    (0x10E60, 'V'),
+    (0x10E7F, 'X'),
+    (0x10F00, 'V'),
+    (0x10F28, 'X'),
+    (0x10F30, 'V'),
+    (0x10F5A, 'X'),
+    (0x11000, 'V'),
+    (0x1104E, 'X'),
+    (0x11052, 'V'),
+    (0x11070, 'X'),
+    (0x1107F, 'V'),
+    (0x110BD, 'X'),
+    (0x110BE, 'V'),
+    (0x110C2, 'X'),
+    (0x110D0, 'V'),
+    (0x110E9, 'X'),
+    (0x110F0, 'V'),
+    (0x110FA, 'X'),
+    (0x11100, 'V'),
+    (0x11135, 'X'),
+    (0x11136, 'V'),
+    (0x11147, 'X'),
+    (0x11150, 'V'),
+    (0x11177, 'X'),
+    (0x11180, 'V'),
+    (0x111CE, 'X'),
+    (0x111D0, 'V'),
+    (0x111E0, 'X'),
+    (0x111E1, 'V'),
+    (0x111F5, 'X'),
+    (0x11200, 'V'),
+    (0x11212, 'X'),
+    (0x11213, 'V'),
+    (0x1123F, 'X'),
+    (0x11280, 'V'),
+    (0x11287, 'X'),
+    (0x11288, 'V'),
+    (0x11289, 'X'),
+    (0x1128A, 'V'),
+    (0x1128E, 'X'),
+    (0x1128F, 'V'),
+    (0x1129E, 'X'),
+    (0x1129F, 'V'),
+    (0x112AA, 'X'),
+    (0x112B0, 'V'),
+    (0x112EB, 'X'),
+    (0x112F0, 'V'),
+    (0x112FA, 'X'),
+    (0x11300, 'V'),
+    (0x11304, 'X'),
+    (0x11305, 'V'),
+    (0x1130D, 'X'),
+    (0x1130F, 'V'),
+    (0x11311, 'X'),
+    (0x11313, 'V'),
+    (0x11329, 'X'),
+    (0x1132A, 'V'),
+    (0x11331, 'X'),
+    (0x11332, 'V'),
+    (0x11334, 'X'),
+    (0x11335, 'V'),
+    (0x1133A, 'X'),
+    (0x1133B, 'V'),
+    (0x11345, 'X'),
+    (0x11347, 'V'),
+    (0x11349, 'X'),
+    (0x1134B, 'V'),
+    (0x1134E, 'X'),
+    (0x11350, 'V'),
+    (0x11351, 'X'),
+    (0x11357, 'V'),
+    (0x11358, 'X'),
+    (0x1135D, 'V'),
+    (0x11364, 'X'),
+    (0x11366, 'V'),
+    (0x1136D, 'X'),
+    (0x11370, 'V'),
+    (0x11375, 'X'),
+    (0x11400, 'V'),
+    (0x1145A, 'X'),
+    (0x1145B, 'V'),
+    (0x1145C, 'X'),
+    (0x1145D, 'V'),
+    ]
+
+def _seg_56():
+    return [
+    (0x1145F, 'X'),
+    (0x11480, 'V'),
+    (0x114C8, 'X'),
+    (0x114D0, 'V'),
+    (0x114DA, 'X'),
+    (0x11580, 'V'),
+    (0x115B6, 'X'),
+    (0x115B8, 'V'),
+    (0x115DE, 'X'),
+    (0x11600, 'V'),
+    (0x11645, 'X'),
+    (0x11650, 'V'),
+    (0x1165A, 'X'),
+    (0x11660, 'V'),
+    (0x1166D, 'X'),
+    (0x11680, 'V'),
+    (0x116B8, 'X'),
+    (0x116C0, 'V'),
+    (0x116CA, 'X'),
+    (0x11700, 'V'),
+    (0x1171B, 'X'),
+    (0x1171D, 'V'),
+    (0x1172C, 'X'),
+    (0x11730, 'V'),
+    (0x11740, 'X'),
+    (0x11800, 'V'),
+    (0x1183C, 'X'),
+    (0x118A0, 'M', u'𑣀'),
+    (0x118A1, 'M', u'𑣁'),
+    (0x118A2, 'M', u'𑣂'),
+    (0x118A3, 'M', u'𑣃'),
+    (0x118A4, 'M', u'𑣄'),
+    (0x118A5, 'M', u'𑣅'),
+    (0x118A6, 'M', u'𑣆'),
+    (0x118A7, 'M', u'𑣇'),
+    (0x118A8, 'M', u'𑣈'),
+    (0x118A9, 'M', u'𑣉'),
+    (0x118AA, 'M', u'𑣊'),
+    (0x118AB, 'M', u'𑣋'),
+    (0x118AC, 'M', u'𑣌'),
+    (0x118AD, 'M', u'𑣍'),
+    (0x118AE, 'M', u'𑣎'),
+    (0x118AF, 'M', u'𑣏'),
+    (0x118B0, 'M', u'𑣐'),
+    (0x118B1, 'M', u'𑣑'),
+    (0x118B2, 'M', u'𑣒'),
+    (0x118B3, 'M', u'𑣓'),
+    (0x118B4, 'M', u'𑣔'),
+    (0x118B5, 'M', u'𑣕'),
+    (0x118B6, 'M', u'𑣖'),
+    (0x118B7, 'M', u'𑣗'),
+    (0x118B8, 'M', u'𑣘'),
+    (0x118B9, 'M', u'𑣙'),
+    (0x118BA, 'M', u'𑣚'),
+    (0x118BB, 'M', u'𑣛'),
+    (0x118BC, 'M', u'𑣜'),
+    (0x118BD, 'M', u'𑣝'),
+    (0x118BE, 'M', u'𑣞'),
+    (0x118BF, 'M', u'𑣟'),
+    (0x118C0, 'V'),
+    (0x118F3, 'X'),
+    (0x118FF, 'V'),
+    (0x11900, 'X'),
+    (0x11A00, 'V'),
+    (0x11A48, 'X'),
+    (0x11A50, 'V'),
+    (0x11A84, 'X'),
+    (0x11A86, 'V'),
+    (0x11AA3, 'X'),
+    (0x11AC0, 'V'),
+    (0x11AF9, 'X'),
+    (0x11C00, 'V'),
+    (0x11C09, 'X'),
+    (0x11C0A, 'V'),
+    (0x11C37, 'X'),
+    (0x11C38, 'V'),
+    (0x11C46, 'X'),
+    (0x11C50, 'V'),
+    (0x11C6D, 'X'),
+    (0x11C70, 'V'),
+    (0x11C90, 'X'),
+    (0x11C92, 'V'),
+    (0x11CA8, 'X'),
+    (0x11CA9, 'V'),
+    (0x11CB7, 'X'),
+    (0x11D00, 'V'),
+    (0x11D07, 'X'),
+    (0x11D08, 'V'),
+    (0x11D0A, 'X'),
+    (0x11D0B, 'V'),
+    (0x11D37, 'X'),
+    (0x11D3A, 'V'),
+    (0x11D3B, 'X'),
+    (0x11D3C, 'V'),
+    (0x11D3E, 'X'),
+    (0x11D3F, 'V'),
+    (0x11D48, 'X'),
+    (0x11D50, 'V'),
+    (0x11D5A, 'X'),
+    (0x11D60, 'V'),
+    ]
+
+def _seg_57():
+    return [
+    (0x11D66, 'X'),
+    (0x11D67, 'V'),
+    (0x11D69, 'X'),
+    (0x11D6A, 'V'),
+    (0x11D8F, 'X'),
+    (0x11D90, 'V'),
+    (0x11D92, 'X'),
+    (0x11D93, 'V'),
+    (0x11D99, 'X'),
+    (0x11DA0, 'V'),
+    (0x11DAA, 'X'),
+    (0x11EE0, 'V'),
+    (0x11EF9, 'X'),
+    (0x12000, 'V'),
+    (0x1239A, 'X'),
+    (0x12400, 'V'),
+    (0x1246F, 'X'),
+    (0x12470, 'V'),
+    (0x12475, 'X'),
+    (0x12480, 'V'),
+    (0x12544, 'X'),
+    (0x13000, 'V'),
+    (0x1342F, 'X'),
+    (0x14400, 'V'),
+    (0x14647, 'X'),
+    (0x16800, 'V'),
+    (0x16A39, 'X'),
+    (0x16A40, 'V'),
+    (0x16A5F, 'X'),
+    (0x16A60, 'V'),
+    (0x16A6A, 'X'),
+    (0x16A6E, 'V'),
+    (0x16A70, 'X'),
+    (0x16AD0, 'V'),
+    (0x16AEE, 'X'),
+    (0x16AF0, 'V'),
+    (0x16AF6, 'X'),
+    (0x16B00, 'V'),
+    (0x16B46, 'X'),
+    (0x16B50, 'V'),
+    (0x16B5A, 'X'),
+    (0x16B5B, 'V'),
+    (0x16B62, 'X'),
+    (0x16B63, 'V'),
+    (0x16B78, 'X'),
+    (0x16B7D, 'V'),
+    (0x16B90, 'X'),
+    (0x16E60, 'V'),
+    (0x16E9B, 'X'),
+    (0x16F00, 'V'),
+    (0x16F45, 'X'),
+    (0x16F50, 'V'),
+    (0x16F7F, 'X'),
+    (0x16F8F, 'V'),
+    (0x16FA0, 'X'),
+    (0x16FE0, 'V'),
+    (0x16FE2, 'X'),
+    (0x17000, 'V'),
+    (0x187F2, 'X'),
+    (0x18800, 'V'),
+    (0x18AF3, 'X'),
+    (0x1B000, 'V'),
+    (0x1B11F, 'X'),
+    (0x1B170, 'V'),
+    (0x1B2FC, 'X'),
+    (0x1BC00, 'V'),
+    (0x1BC6B, 'X'),
+    (0x1BC70, 'V'),
+    (0x1BC7D, 'X'),
+    (0x1BC80, 'V'),
+    (0x1BC89, 'X'),
+    (0x1BC90, 'V'),
+    (0x1BC9A, 'X'),
+    (0x1BC9C, 'V'),
+    (0x1BCA0, 'I'),
+    (0x1BCA4, 'X'),
+    (0x1D000, 'V'),
+    (0x1D0F6, 'X'),
+    (0x1D100, 'V'),
+    (0x1D127, 'X'),
+    (0x1D129, 'V'),
+    (0x1D15E, 'M', u'𝅗𝅥'),
+    (0x1D15F, 'M', u'𝅘𝅥'),
+    (0x1D160, 'M', u'𝅘𝅥𝅮'),
+    (0x1D161, 'M', u'𝅘𝅥𝅯'),
+    (0x1D162, 'M', u'𝅘𝅥𝅰'),
+    (0x1D163, 'M', u'𝅘𝅥𝅱'),
+    (0x1D164, 'M', u'𝅘𝅥𝅲'),
+    (0x1D165, 'V'),
+    (0x1D173, 'X'),
+    (0x1D17B, 'V'),
+    (0x1D1BB, 'M', u'𝆹𝅥'),
+    (0x1D1BC, 'M', u'𝆺𝅥'),
+    (0x1D1BD, 'M', u'𝆹𝅥𝅮'),
+    (0x1D1BE, 'M', u'𝆺𝅥𝅮'),
+    (0x1D1BF, 'M', u'𝆹𝅥𝅯'),
+    (0x1D1C0, 'M', u'𝆺𝅥𝅯'),
+    (0x1D1C1, 'V'),
+    (0x1D1E9, 'X'),
+    (0x1D200, 'V'),
+    ]
+
+def _seg_58():
+    return [
+    (0x1D246, 'X'),
+    (0x1D2E0, 'V'),
+    (0x1D2F4, 'X'),
+    (0x1D300, 'V'),
+    (0x1D357, 'X'),
+    (0x1D360, 'V'),
+    (0x1D379, 'X'),
+    (0x1D400, 'M', u'a'),
+    (0x1D401, 'M', u'b'),
+    (0x1D402, 'M', u'c'),
+    (0x1D403, 'M', u'd'),
+    (0x1D404, 'M', u'e'),
+    (0x1D405, 'M', u'f'),
+    (0x1D406, 'M', u'g'),
+    (0x1D407, 'M', u'h'),
+    (0x1D408, 'M', u'i'),
+    (0x1D409, 'M', u'j'),
+    (0x1D40A, 'M', u'k'),
+    (0x1D40B, 'M', u'l'),
+    (0x1D40C, 'M', u'm'),
+    (0x1D40D, 'M', u'n'),
+    (0x1D40E, 'M', u'o'),
+    (0x1D40F, 'M', u'p'),
+    (0x1D410, 'M', u'q'),
+    (0x1D411, 'M', u'r'),
+    (0x1D412, 'M', u's'),
+    (0x1D413, 'M', u't'),
+    (0x1D414, 'M', u'u'),
+    (0x1D415, 'M', u'v'),
+    (0x1D416, 'M', u'w'),
+    (0x1D417, 'M', u'x'),
+    (0x1D418, 'M', u'y'),
+    (0x1D419, 'M', u'z'),
+    (0x1D41A, 'M', u'a'),
+    (0x1D41B, 'M', u'b'),
+    (0x1D41C, 'M', u'c'),
+    (0x1D41D, 'M', u'd'),
+    (0x1D41E, 'M', u'e'),
+    (0x1D41F, 'M', u'f'),
+    (0x1D420, 'M', u'g'),
+    (0x1D421, 'M', u'h'),
+    (0x1D422, 'M', u'i'),
+    (0x1D423, 'M', u'j'),
+    (0x1D424, 'M', u'k'),
+    (0x1D425, 'M', u'l'),
+    (0x1D426, 'M', u'm'),
+    (0x1D427, 'M', u'n'),
+    (0x1D428, 'M', u'o'),
+    (0x1D429, 'M', u'p'),
+    (0x1D42A, 'M', u'q'),
+    (0x1D42B, 'M', u'r'),
+    (0x1D42C, 'M', u's'),
+    (0x1D42D, 'M', u't'),
+    (0x1D42E, 'M', u'u'),
+    (0x1D42F, 'M', u'v'),
+    (0x1D430, 'M', u'w'),
+    (0x1D431, 'M', u'x'),
+    (0x1D432, 'M', u'y'),
+    (0x1D433, 'M', u'z'),
+    (0x1D434, 'M', u'a'),
+    (0x1D435, 'M', u'b'),
+    (0x1D436, 'M', u'c'),
+    (0x1D437, 'M', u'd'),
+    (0x1D438, 'M', u'e'),
+    (0x1D439, 'M', u'f'),
+    (0x1D43A, 'M', u'g'),
+    (0x1D43B, 'M', u'h'),
+    (0x1D43C, 'M', u'i'),
+    (0x1D43D, 'M', u'j'),
+    (0x1D43E, 'M', u'k'),
+    (0x1D43F, 'M', u'l'),
+    (0x1D440, 'M', u'm'),
+    (0x1D441, 'M', u'n'),
+    (0x1D442, 'M', u'o'),
+    (0x1D443, 'M', u'p'),
+    (0x1D444, 'M', u'q'),
+    (0x1D445, 'M', u'r'),
+    (0x1D446, 'M', u's'),
+    (0x1D447, 'M', u't'),
+    (0x1D448, 'M', u'u'),
+    (0x1D449, 'M', u'v'),
+    (0x1D44A, 'M', u'w'),
+    (0x1D44B, 'M', u'x'),
+    (0x1D44C, 'M', u'y'),
+    (0x1D44D, 'M', u'z'),
+    (0x1D44E, 'M', u'a'),
+    (0x1D44F, 'M', u'b'),
+    (0x1D450, 'M', u'c'),
+    (0x1D451, 'M', u'd'),
+    (0x1D452, 'M', u'e'),
+    (0x1D453, 'M', u'f'),
+    (0x1D454, 'M', u'g'),
+    (0x1D455, 'X'),
+    (0x1D456, 'M', u'i'),
+    (0x1D457, 'M', u'j'),
+    (0x1D458, 'M', u'k'),
+    (0x1D459, 'M', u'l'),
+    (0x1D45A, 'M', u'm'),
+    (0x1D45B, 'M', u'n'),
+    (0x1D45C, 'M', u'o'),
+    ]
+
+def _seg_59():
+    return [
+    (0x1D45D, 'M', u'p'),
+    (0x1D45E, 'M', u'q'),
+    (0x1D45F, 'M', u'r'),
+    (0x1D460, 'M', u's'),
+    (0x1D461, 'M', u't'),
+    (0x1D462, 'M', u'u'),
+    (0x1D463, 'M', u'v'),
+    (0x1D464, 'M', u'w'),
+    (0x1D465, 'M', u'x'),
+    (0x1D466, 'M', u'y'),
+    (0x1D467, 'M', u'z'),
+    (0x1D468, 'M', u'a'),
+    (0x1D469, 'M', u'b'),
+    (0x1D46A, 'M', u'c'),
+    (0x1D46B, 'M', u'd'),
+    (0x1D46C, 'M', u'e'),
+    (0x1D46D, 'M', u'f'),
+    (0x1D46E, 'M', u'g'),
+    (0x1D46F, 'M', u'h'),
+    (0x1D470, 'M', u'i'),
+    (0x1D471, 'M', u'j'),
+    (0x1D472, 'M', u'k'),
+    (0x1D473, 'M', u'l'),
+    (0x1D474, 'M', u'm'),
+    (0x1D475, 'M', u'n'),
+    (0x1D476, 'M', u'o'),
+    (0x1D477, 'M', u'p'),
+    (0x1D478, 'M', u'q'),
+    (0x1D479, 'M', u'r'),
+    (0x1D47A, 'M', u's'),
+    (0x1D47B, 'M', u't'),
+    (0x1D47C, 'M', u'u'),
+    (0x1D47D, 'M', u'v'),
+    (0x1D47E, 'M', u'w'),
+    (0x1D47F, 'M', u'x'),
+    (0x1D480, 'M', u'y'),
+    (0x1D481, 'M', u'z'),
+    (0x1D482, 'M', u'a'),
+    (0x1D483, 'M', u'b'),
+    (0x1D484, 'M', u'c'),
+    (0x1D485, 'M', u'd'),
+    (0x1D486, 'M', u'e'),
+    (0x1D487, 'M', u'f'),
+    (0x1D488, 'M', u'g'),
+    (0x1D489, 'M', u'h'),
+    (0x1D48A, 'M', u'i'),
+    (0x1D48B, 'M', u'j'),
+    (0x1D48C, 'M', u'k'),
+    (0x1D48D, 'M', u'l'),
+    (0x1D48E, 'M', u'm'),
+    (0x1D48F, 'M', u'n'),
+    (0x1D490, 'M', u'o'),
+    (0x1D491, 'M', u'p'),
+    (0x1D492, 'M', u'q'),
+    (0x1D493, 'M', u'r'),
+    (0x1D494, 'M', u's'),
+    (0x1D495, 'M', u't'),
+    (0x1D496, 'M', u'u'),
+    (0x1D497, 'M', u'v'),
+    (0x1D498, 'M', u'w'),
+    (0x1D499, 'M', u'x'),
+    (0x1D49A, 'M', u'y'),
+    (0x1D49B, 'M', u'z'),
+    (0x1D49C, 'M', u'a'),
+    (0x1D49D, 'X'),
+    (0x1D49E, 'M', u'c'),
+    (0x1D49F, 'M', u'd'),
+    (0x1D4A0, 'X'),
+    (0x1D4A2, 'M', u'g'),
+    (0x1D4A3, 'X'),
+    (0x1D4A5, 'M', u'j'),
+    (0x1D4A6, 'M', u'k'),
+    (0x1D4A7, 'X'),
+    (0x1D4A9, 'M', u'n'),
+    (0x1D4AA, 'M', u'o'),
+    (0x1D4AB, 'M', u'p'),
+    (0x1D4AC, 'M', u'q'),
+    (0x1D4AD, 'X'),
+    (0x1D4AE, 'M', u's'),
+    (0x1D4AF, 'M', u't'),
+    (0x1D4B0, 'M', u'u'),
+    (0x1D4B1, 'M', u'v'),
+    (0x1D4B2, 'M', u'w'),
+    (0x1D4B3, 'M', u'x'),
+    (0x1D4B4, 'M', u'y'),
+    (0x1D4B5, 'M', u'z'),
+    (0x1D4B6, 'M', u'a'),
+    (0x1D4B7, 'M', u'b'),
+    (0x1D4B8, 'M', u'c'),
+    (0x1D4B9, 'M', u'd'),
+    (0x1D4BA, 'X'),
+    (0x1D4BB, 'M', u'f'),
+    (0x1D4BC, 'X'),
+    (0x1D4BD, 'M', u'h'),
+    (0x1D4BE, 'M', u'i'),
+    (0x1D4BF, 'M', u'j'),
+    (0x1D4C0, 'M', u'k'),
+    (0x1D4C1, 'M', u'l'),
+    (0x1D4C2, 'M', u'm'),
+    (0x1D4C3, 'M', u'n'),
+    ]
+
+def _seg_60():
+    return [
+    (0x1D4C4, 'X'),
+    (0x1D4C5, 'M', u'p'),
+    (0x1D4C6, 'M', u'q'),
+    (0x1D4C7, 'M', u'r'),
+    (0x1D4C8, 'M', u's'),
+    (0x1D4C9, 'M', u't'),
+    (0x1D4CA, 'M', u'u'),
+    (0x1D4CB, 'M', u'v'),
+    (0x1D4CC, 'M', u'w'),
+    (0x1D4CD, 'M', u'x'),
+    (0x1D4CE, 'M', u'y'),
+    (0x1D4CF, 'M', u'z'),
+    (0x1D4D0, 'M', u'a'),
+    (0x1D4D1, 'M', u'b'),
+    (0x1D4D2, 'M', u'c'),
+    (0x1D4D3, 'M', u'd'),
+    (0x1D4D4, 'M', u'e'),
+    (0x1D4D5, 'M', u'f'),
+    (0x1D4D6, 'M', u'g'),
+    (0x1D4D7, 'M', u'h'),
+    (0x1D4D8, 'M', u'i'),
+    (0x1D4D9, 'M', u'j'),
+    (0x1D4DA, 'M', u'k'),
+    (0x1D4DB, 'M', u'l'),
+    (0x1D4DC, 'M', u'm'),
+    (0x1D4DD, 'M', u'n'),
+    (0x1D4DE, 'M', u'o'),
+    (0x1D4DF, 'M', u'p'),
+    (0x1D4E0, 'M', u'q'),
+    (0x1D4E1, 'M', u'r'),
+    (0x1D4E2, 'M', u's'),
+    (0x1D4E3, 'M', u't'),
+    (0x1D4E4, 'M', u'u'),
+    (0x1D4E5, 'M', u'v'),
+    (0x1D4E6, 'M', u'w'),
+    (0x1D4E7, 'M', u'x'),
+    (0x1D4E8, 'M', u'y'),
+    (0x1D4E9, 'M', u'z'),
+    (0x1D4EA, 'M', u'a'),
+    (0x1D4EB, 'M', u'b'),
+    (0x1D4EC, 'M', u'c'),
+    (0x1D4ED, 'M', u'd'),
+    (0x1D4EE, 'M', u'e'),
+    (0x1D4EF, 'M', u'f'),
+    (0x1D4F0, 'M', u'g'),
+    (0x1D4F1, 'M', u'h'),
+    (0x1D4F2, 'M', u'i'),
+    (0x1D4F3, 'M', u'j'),
+    (0x1D4F4, 'M', u'k'),
+    (0x1D4F5, 'M', u'l'),
+    (0x1D4F6, 'M', u'm'),
+    (0x1D4F7, 'M', u'n'),
+    (0x1D4F8, 'M', u'o'),
+    (0x1D4F9, 'M', u'p'),
+    (0x1D4FA, 'M', u'q'),
+    (0x1D4FB, 'M', u'r'),
+    (0x1D4FC, 'M', u's'),
+    (0x1D4FD, 'M', u't'),
+    (0x1D4FE, 'M', u'u'),
+    (0x1D4FF, 'M', u'v'),
+    (0x1D500, 'M', u'w'),
+    (0x1D501, 'M', u'x'),
+    (0x1D502, 'M', u'y'),
+    (0x1D503, 'M', u'z'),
+    (0x1D504, 'M', u'a'),
+    (0x1D505, 'M', u'b'),
+    (0x1D506, 'X'),
+    (0x1D507, 'M', u'd'),
+    (0x1D508, 'M', u'e'),
+    (0x1D509, 'M', u'f'),
+    (0x1D50A, 'M', u'g'),
+    (0x1D50B, 'X'),
+    (0x1D50D, 'M', u'j'),
+    (0x1D50E, 'M', u'k'),
+    (0x1D50F, 'M', u'l'),
+    (0x1D510, 'M', u'm'),
+    (0x1D511, 'M', u'n'),
+    (0x1D512, 'M', u'o'),
+    (0x1D513, 'M', u'p'),
+    (0x1D514, 'M', u'q'),
+    (0x1D515, 'X'),
+    (0x1D516, 'M', u's'),
+    (0x1D517, 'M', u't'),
+    (0x1D518, 'M', u'u'),
+    (0x1D519, 'M', u'v'),
+    (0x1D51A, 'M', u'w'),
+    (0x1D51B, 'M', u'x'),
+    (0x1D51C, 'M', u'y'),
+    (0x1D51D, 'X'),
+    (0x1D51E, 'M', u'a'),
+    (0x1D51F, 'M', u'b'),
+    (0x1D520, 'M', u'c'),
+    (0x1D521, 'M', u'd'),
+    (0x1D522, 'M', u'e'),
+    (0x1D523, 'M', u'f'),
+    (0x1D524, 'M', u'g'),
+    (0x1D525, 'M', u'h'),
+    (0x1D526, 'M', u'i'),
+    (0x1D527, 'M', u'j'),
+    (0x1D528, 'M', u'k'),
+    ]
+
+def _seg_61():
+    return [
+    (0x1D529, 'M', u'l'),
+    (0x1D52A, 'M', u'm'),
+    (0x1D52B, 'M', u'n'),
+    (0x1D52C, 'M', u'o'),
+    (0x1D52D, 'M', u'p'),
+    (0x1D52E, 'M', u'q'),
+    (0x1D52F, 'M', u'r'),
+    (0x1D530, 'M', u's'),
+    (0x1D531, 'M', u't'),
+    (0x1D532, 'M', u'u'),
+    (0x1D533, 'M', u'v'),
+    (0x1D534, 'M', u'w'),
+    (0x1D535, 'M', u'x'),
+    (0x1D536, 'M', u'y'),
+    (0x1D537, 'M', u'z'),
+    (0x1D538, 'M', u'a'),
+    (0x1D539, 'M', u'b'),
+    (0x1D53A, 'X'),
+    (0x1D53B, 'M', u'd'),
+    (0x1D53C, 'M', u'e'),
+    (0x1D53D, 'M', u'f'),
+    (0x1D53E, 'M', u'g'),
+    (0x1D53F, 'X'),
+    (0x1D540, 'M', u'i'),
+    (0x1D541, 'M', u'j'),
+    (0x1D542, 'M', u'k'),
+    (0x1D543, 'M', u'l'),
+    (0x1D544, 'M', u'm'),
+    (0x1D545, 'X'),
+    (0x1D546, 'M', u'o'),
+    (0x1D547, 'X'),
+    (0x1D54A, 'M', u's'),
+    (0x1D54B, 'M', u't'),
+    (0x1D54C, 'M', u'u'),
+    (0x1D54D, 'M', u'v'),
+    (0x1D54E, 'M', u'w'),
+    (0x1D54F, 'M', u'x'),
+    (0x1D550, 'M', u'y'),
+    (0x1D551, 'X'),
+    (0x1D552, 'M', u'a'),
+    (0x1D553, 'M', u'b'),
+    (0x1D554, 'M', u'c'),
+    (0x1D555, 'M', u'd'),
+    (0x1D556, 'M', u'e'),
+    (0x1D557, 'M', u'f'),
+    (0x1D558, 'M', u'g'),
+    (0x1D559, 'M', u'h'),
+    (0x1D55A, 'M', u'i'),
+    (0x1D55B, 'M', u'j'),
+    (0x1D55C, 'M', u'k'),
+    (0x1D55D, 'M', u'l'),
+    (0x1D55E, 'M', u'm'),
+    (0x1D55F, 'M', u'n'),
+    (0x1D560, 'M', u'o'),
+    (0x1D561, 'M', u'p'),
+    (0x1D562, 'M', u'q'),
+    (0x1D563, 'M', u'r'),
+    (0x1D564, 'M', u's'),
+    (0x1D565, 'M', u't'),
+    (0x1D566, 'M', u'u'),
+    (0x1D567, 'M', u'v'),
+    (0x1D568, 'M', u'w'),
+    (0x1D569, 'M', u'x'),
+    (0x1D56A, 'M', u'y'),
+    (0x1D56B, 'M', u'z'),
+    (0x1D56C, 'M', u'a'),
+    (0x1D56D, 'M', u'b'),
+    (0x1D56E, 'M', u'c'),
+    (0x1D56F, 'M', u'd'),
+    (0x1D570, 'M', u'e'),
+    (0x1D571, 'M', u'f'),
+    (0x1D572, 'M', u'g'),
+    (0x1D573, 'M', u'h'),
+    (0x1D574, 'M', u'i'),
+    (0x1D575, 'M', u'j'),
+    (0x1D576, 'M', u'k'),
+    (0x1D577, 'M', u'l'),
+    (0x1D578, 'M', u'm'),
+    (0x1D579, 'M', u'n'),
+    (0x1D57A, 'M', u'o'),
+    (0x1D57B, 'M', u'p'),
+    (0x1D57C, 'M', u'q'),
+    (0x1D57D, 'M', u'r'),
+    (0x1D57E, 'M', u's'),
+    (0x1D57F, 'M', u't'),
+    (0x1D580, 'M', u'u'),
+    (0x1D581, 'M', u'v'),
+    (0x1D582, 'M', u'w'),
+    (0x1D583, 'M', u'x'),
+    (0x1D584, 'M', u'y'),
+    (0x1D585, 'M', u'z'),
+    (0x1D586, 'M', u'a'),
+    (0x1D587, 'M', u'b'),
+    (0x1D588, 'M', u'c'),
+    (0x1D589, 'M', u'd'),
+    (0x1D58A, 'M', u'e'),
+    (0x1D58B, 'M', u'f'),
+    (0x1D58C, 'M', u'g'),
+    (0x1D58D, 'M', u'h'),
+    (0x1D58E, 'M', u'i'),
+    ]
+
+def _seg_62():
+    return [
+    (0x1D58F, 'M', u'j'),
+    (0x1D590, 'M', u'k'),
+    (0x1D591, 'M', u'l'),
+    (0x1D592, 'M', u'm'),
+    (0x1D593, 'M', u'n'),
+    (0x1D594, 'M', u'o'),
+    (0x1D595, 'M', u'p'),
+    (0x1D596, 'M', u'q'),
+    (0x1D597, 'M', u'r'),
+    (0x1D598, 'M', u's'),
+    (0x1D599, 'M', u't'),
+    (0x1D59A, 'M', u'u'),
+    (0x1D59B, 'M', u'v'),
+    (0x1D59C, 'M', u'w'),
+    (0x1D59D, 'M', u'x'),
+    (0x1D59E, 'M', u'y'),
+    (0x1D59F, 'M', u'z'),
+    (0x1D5A0, 'M', u'a'),
+    (0x1D5A1, 'M', u'b'),
+    (0x1D5A2, 'M', u'c'),
+    (0x1D5A3, 'M', u'd'),
+    (0x1D5A4, 'M', u'e'),
+    (0x1D5A5, 'M', u'f'),
+    (0x1D5A6, 'M', u'g'),
+    (0x1D5A7, 'M', u'h'),
+    (0x1D5A8, 'M', u'i'),
+    (0x1D5A9, 'M', u'j'),
+    (0x1D5AA, 'M', u'k'),
+    (0x1D5AB, 'M', u'l'),
+    (0x1D5AC, 'M', u'm'),
+    (0x1D5AD, 'M', u'n'),
+    (0x1D5AE, 'M', u'o'),
+    (0x1D5AF, 'M', u'p'),
+    (0x1D5B0, 'M', u'q'),
+    (0x1D5B1, 'M', u'r'),
+    (0x1D5B2, 'M', u's'),
+    (0x1D5B3, 'M', u't'),
+    (0x1D5B4, 'M', u'u'),
+    (0x1D5B5, 'M', u'v'),
+    (0x1D5B6, 'M', u'w'),
+    (0x1D5B7, 'M', u'x'),
+    (0x1D5B8, 'M', u'y'),
+    (0x1D5B9, 'M', u'z'),
+    (0x1D5BA, 'M', u'a'),
+    (0x1D5BB, 'M', u'b'),
+    (0x1D5BC, 'M', u'c'),
+    (0x1D5BD, 'M', u'd'),
+    (0x1D5BE, 'M', u'e'),
+    (0x1D5BF, 'M', u'f'),
+    (0x1D5C0, 'M', u'g'),
+    (0x1D5C1, 'M', u'h'),
+    (0x1D5C2, 'M', u'i'),
+    (0x1D5C3, 'M', u'j'),
+    (0x1D5C4, 'M', u'k'),
+    (0x1D5C5, 'M', u'l'),
+    (0x1D5C6, 'M', u'm'),
+    (0x1D5C7, 'M', u'n'),
+    (0x1D5C8, 'M', u'o'),
+    (0x1D5C9, 'M', u'p'),
+    (0x1D5CA, 'M', u'q'),
+    (0x1D5CB, 'M', u'r'),
+    (0x1D5CC, 'M', u's'),
+    (0x1D5CD, 'M', u't'),
+    (0x1D5CE, 'M', u'u'),
+    (0x1D5CF, 'M', u'v'),
+    (0x1D5D0, 'M', u'w'),
+    (0x1D5D1, 'M', u'x'),
+    (0x1D5D2, 'M', u'y'),
+    (0x1D5D3, 'M', u'z'),
+    (0x1D5D4, 'M', u'a'),
+    (0x1D5D5, 'M', u'b'),
+    (0x1D5D6, 'M', u'c'),
+    (0x1D5D7, 'M', u'd'),
+    (0x1D5D8, 'M', u'e'),
+    (0x1D5D9, 'M', u'f'),
+    (0x1D5DA, 'M', u'g'),
+    (0x1D5DB, 'M', u'h'),
+    (0x1D5DC, 'M', u'i'),
+    (0x1D5DD, 'M', u'j'),
+    (0x1D5DE, 'M', u'k'),
+    (0x1D5DF, 'M', u'l'),
+    (0x1D5E0, 'M', u'm'),
+    (0x1D5E1, 'M', u'n'),
+    (0x1D5E2, 'M', u'o'),
+    (0x1D5E3, 'M', u'p'),
+    (0x1D5E4, 'M', u'q'),
+    (0x1D5E5, 'M', u'r'),
+    (0x1D5E6, 'M', u's'),
+    (0x1D5E7, 'M', u't'),
+    (0x1D5E8, 'M', u'u'),
+    (0x1D5E9, 'M', u'v'),
+    (0x1D5EA, 'M', u'w'),
+    (0x1D5EB, 'M', u'x'),
+    (0x1D5EC, 'M', u'y'),
+    (0x1D5ED, 'M', u'z'),
+    (0x1D5EE, 'M', u'a'),
+    (0x1D5EF, 'M', u'b'),
+    (0x1D5F0, 'M', u'c'),
+    (0x1D5F1, 'M', u'd'),
+    (0x1D5F2, 'M', u'e'),
+    ]
+
+def _seg_63():
+    return [
+    (0x1D5F3, 'M', u'f'),
+    (0x1D5F4, 'M', u'g'),
+    (0x1D5F5, 'M', u'h'),
+    (0x1D5F6, 'M', u'i'),
+    (0x1D5F7, 'M', u'j'),
+    (0x1D5F8, 'M', u'k'),
+    (0x1D5F9, 'M', u'l'),
+    (0x1D5FA, 'M', u'm'),
+    (0x1D5FB, 'M', u'n'),
+    (0x1D5FC, 'M', u'o'),
+    (0x1D5FD, 'M', u'p'),
+    (0x1D5FE, 'M', u'q'),
+    (0x1D5FF, 'M', u'r'),
+    (0x1D600, 'M', u's'),
+    (0x1D601, 'M', u't'),
+    (0x1D602, 'M', u'u'),
+    (0x1D603, 'M', u'v'),
+    (0x1D604, 'M', u'w'),
+    (0x1D605, 'M', u'x'),
+    (0x1D606, 'M', u'y'),
+    (0x1D607, 'M', u'z'),
+    (0x1D608, 'M', u'a'),
+    (0x1D609, 'M', u'b'),
+    (0x1D60A, 'M', u'c'),
+    (0x1D60B, 'M', u'd'),
+    (0x1D60C, 'M', u'e'),
+    (0x1D60D, 'M', u'f'),
+    (0x1D60E, 'M', u'g'),
+    (0x1D60F, 'M', u'h'),
+    (0x1D610, 'M', u'i'),
+    (0x1D611, 'M', u'j'),
+    (0x1D612, 'M', u'k'),
+    (0x1D613, 'M', u'l'),
+    (0x1D614, 'M', u'm'),
+    (0x1D615, 'M', u'n'),
+    (0x1D616, 'M', u'o'),
+    (0x1D617, 'M', u'p'),
+    (0x1D618, 'M', u'q'),
+    (0x1D619, 'M', u'r'),
+    (0x1D61A, 'M', u's'),
+    (0x1D61B, 'M', u't'),
+    (0x1D61C, 'M', u'u'),
+    (0x1D61D, 'M', u'v'),
+    (0x1D61E, 'M', u'w'),
+    (0x1D61F, 'M', u'x'),
+    (0x1D620, 'M', u'y'),
+    (0x1D621, 'M', u'z'),
+    (0x1D622, 'M', u'a'),
+    (0x1D623, 'M', u'b'),
+    (0x1D624, 'M', u'c'),
+    (0x1D625, 'M', u'd'),
+    (0x1D626, 'M', u'e'),
+    (0x1D627, 'M', u'f'),
+    (0x1D628, 'M', u'g'),
+    (0x1D629, 'M', u'h'),
+    (0x1D62A, 'M', u'i'),
+    (0x1D62B, 'M', u'j'),
+    (0x1D62C, 'M', u'k'),
+    (0x1D62D, 'M', u'l'),
+    (0x1D62E, 'M', u'm'),
+    (0x1D62F, 'M', u'n'),
+    (0x1D630, 'M', u'o'),
+    (0x1D631, 'M', u'p'),
+    (0x1D632, 'M', u'q'),
+    (0x1D633, 'M', u'r'),
+    (0x1D634, 'M', u's'),
+    (0x1D635, 'M', u't'),
+    (0x1D636, 'M', u'u'),
+    (0x1D637, 'M', u'v'),
+    (0x1D638, 'M', u'w'),
+    (0x1D639, 'M', u'x'),
+    (0x1D63A, 'M', u'y'),
+    (0x1D63B, 'M', u'z'),
+    (0x1D63C, 'M', u'a'),
+    (0x1D63D, 'M', u'b'),
+    (0x1D63E, 'M', u'c'),
+    (0x1D63F, 'M', u'd'),
+    (0x1D640, 'M', u'e'),
+    (0x1D641, 'M', u'f'),
+    (0x1D642, 'M', u'g'),
+    (0x1D643, 'M', u'h'),
+    (0x1D644, 'M', u'i'),
+    (0x1D645, 'M', u'j'),
+    (0x1D646, 'M', u'k'),
+    (0x1D647, 'M', u'l'),
+    (0x1D648, 'M', u'm'),
+    (0x1D649, 'M', u'n'),
+    (0x1D64A, 'M', u'o'),
+    (0x1D64B, 'M', u'p'),
+    (0x1D64C, 'M', u'q'),
+    (0x1D64D, 'M', u'r'),
+    (0x1D64E, 'M', u's'),
+    (0x1D64F, 'M', u't'),
+    (0x1D650, 'M', u'u'),
+    (0x1D651, 'M', u'v'),
+    (0x1D652, 'M', u'w'),
+    (0x1D653, 'M', u'x'),
+    (0x1D654, 'M', u'y'),
+    (0x1D655, 'M', u'z'),
+    (0x1D656, 'M', u'a'),
+    ]
+
+def _seg_64():
+    return [
+    (0x1D657, 'M', u'b'),
+    (0x1D658, 'M', u'c'),
+    (0x1D659, 'M', u'd'),
+    (0x1D65A, 'M', u'e'),
+    (0x1D65B, 'M', u'f'),
+    (0x1D65C, 'M', u'g'),
+    (0x1D65D, 'M', u'h'),
+    (0x1D65E, 'M', u'i'),
+    (0x1D65F, 'M', u'j'),
+    (0x1D660, 'M', u'k'),
+    (0x1D661, 'M', u'l'),
+    (0x1D662, 'M', u'm'),
+    (0x1D663, 'M', u'n'),
+    (0x1D664, 'M', u'o'),
+    (0x1D665, 'M', u'p'),
+    (0x1D666, 'M', u'q'),
+    (0x1D667, 'M', u'r'),
+    (0x1D668, 'M', u's'),
+    (0x1D669, 'M', u't'),
+    (0x1D66A, 'M', u'u'),
+    (0x1D66B, 'M', u'v'),
+    (0x1D66C, 'M', u'w'),
+    (0x1D66D, 'M', u'x'),
+    (0x1D66E, 'M', u'y'),
+    (0x1D66F, 'M', u'z'),
+    (0x1D670, 'M', u'a'),
+    (0x1D671, 'M', u'b'),
+    (0x1D672, 'M', u'c'),
+    (0x1D673, 'M', u'd'),
+    (0x1D674, 'M', u'e'),
+    (0x1D675, 'M', u'f'),
+    (0x1D676, 'M', u'g'),
+    (0x1D677, 'M', u'h'),
+    (0x1D678, 'M', u'i'),
+    (0x1D679, 'M', u'j'),
+    (0x1D67A, 'M', u'k'),
+    (0x1D67B, 'M', u'l'),
+    (0x1D67C, 'M', u'm'),
+    (0x1D67D, 'M', u'n'),
+    (0x1D67E, 'M', u'o'),
+    (0x1D67F, 'M', u'p'),
+    (0x1D680, 'M', u'q'),
+    (0x1D681, 'M', u'r'),
+    (0x1D682, 'M', u's'),
+    (0x1D683, 'M', u't'),
+    (0x1D684, 'M', u'u'),
+    (0x1D685, 'M', u'v'),
+    (0x1D686, 'M', u'w'),
+    (0x1D687, 'M', u'x'),
+    (0x1D688, 'M', u'y'),
+    (0x1D689, 'M', u'z'),
+    (0x1D68A, 'M', u'a'),
+    (0x1D68B, 'M', u'b'),
+    (0x1D68C, 'M', u'c'),
+    (0x1D68D, 'M', u'd'),
+    (0x1D68E, 'M', u'e'),
+    (0x1D68F, 'M', u'f'),
+    (0x1D690, 'M', u'g'),
+    (0x1D691, 'M', u'h'),
+    (0x1D692, 'M', u'i'),
+    (0x1D693, 'M', u'j'),
+    (0x1D694, 'M', u'k'),
+    (0x1D695, 'M', u'l'),
+    (0x1D696, 'M', u'm'),
+    (0x1D697, 'M', u'n'),
+    (0x1D698, 'M', u'o'),
+    (0x1D699, 'M', u'p'),
+    (0x1D69A, 'M', u'q'),
+    (0x1D69B, 'M', u'r'),
+    (0x1D69C, 'M', u's'),
+    (0x1D69D, 'M', u't'),
+    (0x1D69E, 'M', u'u'),
+    (0x1D69F, 'M', u'v'),
+    (0x1D6A0, 'M', u'w'),
+    (0x1D6A1, 'M', u'x'),
+    (0x1D6A2, 'M', u'y'),
+    (0x1D6A3, 'M', u'z'),
+    (0x1D6A4, 'M', u'ı'),
+    (0x1D6A5, 'M', u'ȷ'),
+    (0x1D6A6, 'X'),
+    (0x1D6A8, 'M', u'α'),
+    (0x1D6A9, 'M', u'β'),
+    (0x1D6AA, 'M', u'γ'),
+    (0x1D6AB, 'M', u'δ'),
+    (0x1D6AC, 'M', u'ε'),
+    (0x1D6AD, 'M', u'ζ'),
+    (0x1D6AE, 'M', u'η'),
+    (0x1D6AF, 'M', u'θ'),
+    (0x1D6B0, 'M', u'ι'),
+    (0x1D6B1, 'M', u'κ'),
+    (0x1D6B2, 'M', u'λ'),
+    (0x1D6B3, 'M', u'μ'),
+    (0x1D6B4, 'M', u'ν'),
+    (0x1D6B5, 'M', u'ξ'),
+    (0x1D6B6, 'M', u'ο'),
+    (0x1D6B7, 'M', u'π'),
+    (0x1D6B8, 'M', u'ρ'),
+    (0x1D6B9, 'M', u'θ'),
+    (0x1D6BA, 'M', u'σ'),
+    (0x1D6BB, 'M', u'τ'),
+    ]
+
+def _seg_65():
+    return [
+    (0x1D6BC, 'M', u'υ'),
+    (0x1D6BD, 'M', u'φ'),
+    (0x1D6BE, 'M', u'χ'),
+    (0x1D6BF, 'M', u'ψ'),
+    (0x1D6C0, 'M', u'ω'),
+    (0x1D6C1, 'M', u'∇'),
+    (0x1D6C2, 'M', u'α'),
+    (0x1D6C3, 'M', u'β'),
+    (0x1D6C4, 'M', u'γ'),
+    (0x1D6C5, 'M', u'δ'),
+    (0x1D6C6, 'M', u'ε'),
+    (0x1D6C7, 'M', u'ζ'),
+    (0x1D6C8, 'M', u'η'),
+    (0x1D6C9, 'M', u'θ'),
+    (0x1D6CA, 'M', u'ι'),
+    (0x1D6CB, 'M', u'κ'),
+    (0x1D6CC, 'M', u'λ'),
+    (0x1D6CD, 'M', u'μ'),
+    (0x1D6CE, 'M', u'ν'),
+    (0x1D6CF, 'M', u'ξ'),
+    (0x1D6D0, 'M', u'ο'),
+    (0x1D6D1, 'M', u'π'),
+    (0x1D6D2, 'M', u'ρ'),
+    (0x1D6D3, 'M', u'σ'),
+    (0x1D6D5, 'M', u'τ'),
+    (0x1D6D6, 'M', u'υ'),
+    (0x1D6D7, 'M', u'φ'),
+    (0x1D6D8, 'M', u'χ'),
+    (0x1D6D9, 'M', u'ψ'),
+    (0x1D6DA, 'M', u'ω'),
+    (0x1D6DB, 'M', u'∂'),
+    (0x1D6DC, 'M', u'ε'),
+    (0x1D6DD, 'M', u'θ'),
+    (0x1D6DE, 'M', u'κ'),
+    (0x1D6DF, 'M', u'φ'),
+    (0x1D6E0, 'M', u'ρ'),
+    (0x1D6E1, 'M', u'π'),
+    (0x1D6E2, 'M', u'α'),
+    (0x1D6E3, 'M', u'β'),
+    (0x1D6E4, 'M', u'γ'),
+    (0x1D6E5, 'M', u'δ'),
+    (0x1D6E6, 'M', u'ε'),
+    (0x1D6E7, 'M', u'ζ'),
+    (0x1D6E8, 'M', u'η'),
+    (0x1D6E9, 'M', u'θ'),
+    (0x1D6EA, 'M', u'ι'),
+    (0x1D6EB, 'M', u'κ'),
+    (0x1D6EC, 'M', u'λ'),
+    (0x1D6ED, 'M', u'μ'),
+    (0x1D6EE, 'M', u'ν'),
+    (0x1D6EF, 'M', u'ξ'),
+    (0x1D6F0, 'M', u'ο'),
+    (0x1D6F1, 'M', u'π'),
+    (0x1D6F2, 'M', u'ρ'),
+    (0x1D6F3, 'M', u'θ'),
+    (0x1D6F4, 'M', u'σ'),
+    (0x1D6F5, 'M', u'τ'),
+    (0x1D6F6, 'M', u'υ'),
+    (0x1D6F7, 'M', u'φ'),
+    (0x1D6F8, 'M', u'χ'),
+    (0x1D6F9, 'M', u'ψ'),
+    (0x1D6FA, 'M', u'ω'),
+    (0x1D6FB, 'M', u'∇'),
+    (0x1D6FC, 'M', u'α'),
+    (0x1D6FD, 'M', u'β'),
+    (0x1D6FE, 'M', u'γ'),
+    (0x1D6FF, 'M', u'δ'),
+    (0x1D700, 'M', u'ε'),
+    (0x1D701, 'M', u'ζ'),
+    (0x1D702, 'M', u'η'),
+    (0x1D703, 'M', u'θ'),
+    (0x1D704, 'M', u'ι'),
+    (0x1D705, 'M', u'κ'),
+    (0x1D706, 'M', u'λ'),
+    (0x1D707, 'M', u'μ'),
+    (0x1D708, 'M', u'ν'),
+    (0x1D709, 'M', u'ξ'),
+    (0x1D70A, 'M', u'ο'),
+    (0x1D70B, 'M', u'π'),
+    (0x1D70C, 'M', u'ρ'),
+    (0x1D70D, 'M', u'σ'),
+    (0x1D70F, 'M', u'τ'),
+    (0x1D710, 'M', u'υ'),
+    (0x1D711, 'M', u'φ'),
+    (0x1D712, 'M', u'χ'),
+    (0x1D713, 'M', u'ψ'),
+    (0x1D714, 'M', u'ω'),
+    (0x1D715, 'M', u'∂'),
+    (0x1D716, 'M', u'ε'),
+    (0x1D717, 'M', u'θ'),
+    (0x1D718, 'M', u'κ'),
+    (0x1D719, 'M', u'φ'),
+    (0x1D71A, 'M', u'ρ'),
+    (0x1D71B, 'M', u'π'),
+    (0x1D71C, 'M', u'α'),
+    (0x1D71D, 'M', u'β'),
+    (0x1D71E, 'M', u'γ'),
+    (0x1D71F, 'M', u'δ'),
+    (0x1D720, 'M', u'ε'),
+    (0x1D721, 'M', u'ζ'),
+    ]
+
+def _seg_66():
+    return [
+    (0x1D722, 'M', u'η'),
+    (0x1D723, 'M', u'θ'),
+    (0x1D724, 'M', u'ι'),
+    (0x1D725, 'M', u'κ'),
+    (0x1D726, 'M', u'λ'),
+    (0x1D727, 'M', u'μ'),
+    (0x1D728, 'M', u'ν'),
+    (0x1D729, 'M', u'ξ'),
+    (0x1D72A, 'M', u'ο'),
+    (0x1D72B, 'M', u'π'),
+    (0x1D72C, 'M', u'ρ'),
+    (0x1D72D, 'M', u'θ'),
+    (0x1D72E, 'M', u'σ'),
+    (0x1D72F, 'M', u'τ'),
+    (0x1D730, 'M', u'υ'),
+    (0x1D731, 'M', u'φ'),
+    (0x1D732, 'M', u'χ'),
+    (0x1D733, 'M', u'ψ'),
+    (0x1D734, 'M', u'ω'),
+    (0x1D735, 'M', u'∇'),
+    (0x1D736, 'M', u'α'),
+    (0x1D737, 'M', u'β'),
+    (0x1D738, 'M', u'γ'),
+    (0x1D739, 'M', u'δ'),
+    (0x1D73A, 'M', u'ε'),
+    (0x1D73B, 'M', u'ζ'),
+    (0x1D73C, 'M', u'η'),
+    (0x1D73D, 'M', u'θ'),
+    (0x1D73E, 'M', u'ι'),
+    (0x1D73F, 'M', u'κ'),
+    (0x1D740, 'M', u'λ'),
+    (0x1D741, 'M', u'μ'),
+    (0x1D742, 'M', u'ν'),
+    (0x1D743, 'M', u'ξ'),
+    (0x1D744, 'M', u'ο'),
+    (0x1D745, 'M', u'π'),
+    (0x1D746, 'M', u'ρ'),
+    (0x1D747, 'M', u'σ'),
+    (0x1D749, 'M', u'τ'),
+    (0x1D74A, 'M', u'υ'),
+    (0x1D74B, 'M', u'φ'),
+    (0x1D74C, 'M', u'χ'),
+    (0x1D74D, 'M', u'ψ'),
+    (0x1D74E, 'M', u'ω'),
+    (0x1D74F, 'M', u'∂'),
+    (0x1D750, 'M', u'ε'),
+    (0x1D751, 'M', u'θ'),
+    (0x1D752, 'M', u'κ'),
+    (0x1D753, 'M', u'φ'),
+    (0x1D754, 'M', u'ρ'),
+    (0x1D755, 'M', u'π'),
+    (0x1D756, 'M', u'α'),
+    (0x1D757, 'M', u'β'),
+    (0x1D758, 'M', u'γ'),
+    (0x1D759, 'M', u'δ'),
+    (0x1D75A, 'M', u'ε'),
+    (0x1D75B, 'M', u'ζ'),
+    (0x1D75C, 'M', u'η'),
+    (0x1D75D, 'M', u'θ'),
+    (0x1D75E, 'M', u'ι'),
+    (0x1D75F, 'M', u'κ'),
+    (0x1D760, 'M', u'λ'),
+    (0x1D761, 'M', u'μ'),
+    (0x1D762, 'M', u'ν'),
+    (0x1D763, 'M', u'ξ'),
+    (0x1D764, 'M', u'ο'),
+    (0x1D765, 'M', u'π'),
+    (0x1D766, 'M', u'ρ'),
+    (0x1D767, 'M', u'θ'),
+    (0x1D768, 'M', u'σ'),
+    (0x1D769, 'M', u'τ'),
+    (0x1D76A, 'M', u'υ'),
+    (0x1D76B, 'M', u'φ'),
+    (0x1D76C, 'M', u'χ'),
+    (0x1D76D, 'M', u'ψ'),
+    (0x1D76E, 'M', u'ω'),
+    (0x1D76F, 'M', u'∇'),
+    (0x1D770, 'M', u'α'),
+    (0x1D771, 'M', u'β'),
+    (0x1D772, 'M', u'γ'),
+    (0x1D773, 'M', u'δ'),
+    (0x1D774, 'M', u'ε'),
+    (0x1D775, 'M', u'ζ'),
+    (0x1D776, 'M', u'η'),
+    (0x1D777, 'M', u'θ'),
+    (0x1D778, 'M', u'ι'),
+    (0x1D779, 'M', u'κ'),
+    (0x1D77A, 'M', u'λ'),
+    (0x1D77B, 'M', u'μ'),
+    (0x1D77C, 'M', u'ν'),
+    (0x1D77D, 'M', u'ξ'),
+    (0x1D77E, 'M', u'ο'),
+    (0x1D77F, 'M', u'π'),
+    (0x1D780, 'M', u'ρ'),
+    (0x1D781, 'M', u'σ'),
+    (0x1D783, 'M', u'τ'),
+    (0x1D784, 'M', u'υ'),
+    (0x1D785, 'M', u'φ'),
+    (0x1D786, 'M', u'χ'),
+    (0x1D787, 'M', u'ψ'),
+    ]
+
+def _seg_67():
+    return [
+    (0x1D788, 'M', u'ω'),
+    (0x1D789, 'M', u'∂'),
+    (0x1D78A, 'M', u'ε'),
+    (0x1D78B, 'M', u'θ'),
+    (0x1D78C, 'M', u'κ'),
+    (0x1D78D, 'M', u'φ'),
+    (0x1D78E, 'M', u'ρ'),
+    (0x1D78F, 'M', u'π'),
+    (0x1D790, 'M', u'α'),
+    (0x1D791, 'M', u'β'),
+    (0x1D792, 'M', u'γ'),
+    (0x1D793, 'M', u'δ'),
+    (0x1D794, 'M', u'ε'),
+    (0x1D795, 'M', u'ζ'),
+    (0x1D796, 'M', u'η'),
+    (0x1D797, 'M', u'θ'),
+    (0x1D798, 'M', u'ι'),
+    (0x1D799, 'M', u'κ'),
+    (0x1D79A, 'M', u'λ'),
+    (0x1D79B, 'M', u'μ'),
+    (0x1D79C, 'M', u'ν'),
+    (0x1D79D, 'M', u'ξ'),
+    (0x1D79E, 'M', u'ο'),
+    (0x1D79F, 'M', u'π'),
+    (0x1D7A0, 'M', u'ρ'),
+    (0x1D7A1, 'M', u'θ'),
+    (0x1D7A2, 'M', u'σ'),
+    (0x1D7A3, 'M', u'τ'),
+    (0x1D7A4, 'M', u'υ'),
+    (0x1D7A5, 'M', u'φ'),
+    (0x1D7A6, 'M', u'χ'),
+    (0x1D7A7, 'M', u'ψ'),
+    (0x1D7A8, 'M', u'ω'),
+    (0x1D7A9, 'M', u'∇'),
+    (0x1D7AA, 'M', u'α'),
+    (0x1D7AB, 'M', u'β'),
+    (0x1D7AC, 'M', u'γ'),
+    (0x1D7AD, 'M', u'δ'),
+    (0x1D7AE, 'M', u'ε'),
+    (0x1D7AF, 'M', u'ζ'),
+    (0x1D7B0, 'M', u'η'),
+    (0x1D7B1, 'M', u'θ'),
+    (0x1D7B2, 'M', u'ι'),
+    (0x1D7B3, 'M', u'κ'),
+    (0x1D7B4, 'M', u'λ'),
+    (0x1D7B5, 'M', u'μ'),
+    (0x1D7B6, 'M', u'ν'),
+    (0x1D7B7, 'M', u'ξ'),
+    (0x1D7B8, 'M', u'ο'),
+    (0x1D7B9, 'M', u'π'),
+    (0x1D7BA, 'M', u'ρ'),
+    (0x1D7BB, 'M', u'σ'),
+    (0x1D7BD, 'M', u'τ'),
+    (0x1D7BE, 'M', u'υ'),
+    (0x1D7BF, 'M', u'φ'),
+    (0x1D7C0, 'M', u'χ'),
+    (0x1D7C1, 'M', u'ψ'),
+    (0x1D7C2, 'M', u'ω'),
+    (0x1D7C3, 'M', u'∂'),
+    (0x1D7C4, 'M', u'ε'),
+    (0x1D7C5, 'M', u'θ'),
+    (0x1D7C6, 'M', u'κ'),
+    (0x1D7C7, 'M', u'φ'),
+    (0x1D7C8, 'M', u'ρ'),
+    (0x1D7C9, 'M', u'π'),
+    (0x1D7CA, 'M', u'ϝ'),
+    (0x1D7CC, 'X'),
+    (0x1D7CE, 'M', u'0'),
+    (0x1D7CF, 'M', u'1'),
+    (0x1D7D0, 'M', u'2'),
+    (0x1D7D1, 'M', u'3'),
+    (0x1D7D2, 'M', u'4'),
+    (0x1D7D3, 'M', u'5'),
+    (0x1D7D4, 'M', u'6'),
+    (0x1D7D5, 'M', u'7'),
+    (0x1D7D6, 'M', u'8'),
+    (0x1D7D7, 'M', u'9'),
+    (0x1D7D8, 'M', u'0'),
+    (0x1D7D9, 'M', u'1'),
+    (0x1D7DA, 'M', u'2'),
+    (0x1D7DB, 'M', u'3'),
+    (0x1D7DC, 'M', u'4'),
+    (0x1D7DD, 'M', u'5'),
+    (0x1D7DE, 'M', u'6'),
+    (0x1D7DF, 'M', u'7'),
+    (0x1D7E0, 'M', u'8'),
+    (0x1D7E1, 'M', u'9'),
+    (0x1D7E2, 'M', u'0'),
+    (0x1D7E3, 'M', u'1'),
+    (0x1D7E4, 'M', u'2'),
+    (0x1D7E5, 'M', u'3'),
+    (0x1D7E6, 'M', u'4'),
+    (0x1D7E7, 'M', u'5'),
+    (0x1D7E8, 'M', u'6'),
+    (0x1D7E9, 'M', u'7'),
+    (0x1D7EA, 'M', u'8'),
+    (0x1D7EB, 'M', u'9'),
+    (0x1D7EC, 'M', u'0'),
+    (0x1D7ED, 'M', u'1'),
+    (0x1D7EE, 'M', u'2'),
+    ]
+
+def _seg_68():
+    return [
+    (0x1D7EF, 'M', u'3'),
+    (0x1D7F0, 'M', u'4'),
+    (0x1D7F1, 'M', u'5'),
+    (0x1D7F2, 'M', u'6'),
+    (0x1D7F3, 'M', u'7'),
+    (0x1D7F4, 'M', u'8'),
+    (0x1D7F5, 'M', u'9'),
+    (0x1D7F6, 'M', u'0'),
+    (0x1D7F7, 'M', u'1'),
+    (0x1D7F8, 'M', u'2'),
+    (0x1D7F9, 'M', u'3'),
+    (0x1D7FA, 'M', u'4'),
+    (0x1D7FB, 'M', u'5'),
+    (0x1D7FC, 'M', u'6'),
+    (0x1D7FD, 'M', u'7'),
+    (0x1D7FE, 'M', u'8'),
+    (0x1D7FF, 'M', u'9'),
+    (0x1D800, 'V'),
+    (0x1DA8C, 'X'),
+    (0x1DA9B, 'V'),
+    (0x1DAA0, 'X'),
+    (0x1DAA1, 'V'),
+    (0x1DAB0, 'X'),
+    (0x1E000, 'V'),
+    (0x1E007, 'X'),
+    (0x1E008, 'V'),
+    (0x1E019, 'X'),
+    (0x1E01B, 'V'),
+    (0x1E022, 'X'),
+    (0x1E023, 'V'),
+    (0x1E025, 'X'),
+    (0x1E026, 'V'),
+    (0x1E02B, 'X'),
+    (0x1E800, 'V'),
+    (0x1E8C5, 'X'),
+    (0x1E8C7, 'V'),
+    (0x1E8D7, 'X'),
+    (0x1E900, 'M', u'𞤢'),
+    (0x1E901, 'M', u'𞤣'),
+    (0x1E902, 'M', u'𞤤'),
+    (0x1E903, 'M', u'𞤥'),
+    (0x1E904, 'M', u'𞤦'),
+    (0x1E905, 'M', u'𞤧'),
+    (0x1E906, 'M', u'𞤨'),
+    (0x1E907, 'M', u'𞤩'),
+    (0x1E908, 'M', u'𞤪'),
+    (0x1E909, 'M', u'𞤫'),
+    (0x1E90A, 'M', u'𞤬'),
+    (0x1E90B, 'M', u'𞤭'),
+    (0x1E90C, 'M', u'𞤮'),
+    (0x1E90D, 'M', u'𞤯'),
+    (0x1E90E, 'M', u'𞤰'),
+    (0x1E90F, 'M', u'𞤱'),
+    (0x1E910, 'M', u'𞤲'),
+    (0x1E911, 'M', u'𞤳'),
+    (0x1E912, 'M', u'𞤴'),
+    (0x1E913, 'M', u'𞤵'),
+    (0x1E914, 'M', u'𞤶'),
+    (0x1E915, 'M', u'𞤷'),
+    (0x1E916, 'M', u'𞤸'),
+    (0x1E917, 'M', u'𞤹'),
+    (0x1E918, 'M', u'𞤺'),
+    (0x1E919, 'M', u'𞤻'),
+    (0x1E91A, 'M', u'𞤼'),
+    (0x1E91B, 'M', u'𞤽'),
+    (0x1E91C, 'M', u'𞤾'),
+    (0x1E91D, 'M', u'𞤿'),
+    (0x1E91E, 'M', u'𞥀'),
+    (0x1E91F, 'M', u'𞥁'),
+    (0x1E920, 'M', u'𞥂'),
+    (0x1E921, 'M', u'𞥃'),
+    (0x1E922, 'V'),
+    (0x1E94B, 'X'),
+    (0x1E950, 'V'),
+    (0x1E95A, 'X'),
+    (0x1E95E, 'V'),
+    (0x1E960, 'X'),
+    (0x1EC71, 'V'),
+    (0x1ECB5, 'X'),
+    (0x1EE00, 'M', u'ا'),
+    (0x1EE01, 'M', u'ب'),
+    (0x1EE02, 'M', u'ج'),
+    (0x1EE03, 'M', u'د'),
+    (0x1EE04, 'X'),
+    (0x1EE05, 'M', u'و'),
+    (0x1EE06, 'M', u'ز'),
+    (0x1EE07, 'M', u'ح'),
+    (0x1EE08, 'M', u'ط'),
+    (0x1EE09, 'M', u'ي'),
+    (0x1EE0A, 'M', u'ك'),
+    (0x1EE0B, 'M', u'ل'),
+    (0x1EE0C, 'M', u'م'),
+    (0x1EE0D, 'M', u'ن'),
+    (0x1EE0E, 'M', u'س'),
+    (0x1EE0F, 'M', u'ع'),
+    (0x1EE10, 'M', u'ف'),
+    (0x1EE11, 'M', u'ص'),
+    (0x1EE12, 'M', u'ق'),
+    (0x1EE13, 'M', u'ر'),
+    (0x1EE14, 'M', u'ش'),
+    ]
+
+def _seg_69():
+    return [
+    (0x1EE15, 'M', u'ت'),
+    (0x1EE16, 'M', u'ث'),
+    (0x1EE17, 'M', u'خ'),
+    (0x1EE18, 'M', u'ذ'),
+    (0x1EE19, 'M', u'ض'),
+    (0x1EE1A, 'M', u'ظ'),
+    (0x1EE1B, 'M', u'غ'),
+    (0x1EE1C, 'M', u'ٮ'),
+    (0x1EE1D, 'M', u'ں'),
+    (0x1EE1E, 'M', u'ڡ'),
+    (0x1EE1F, 'M', u'ٯ'),
+    (0x1EE20, 'X'),
+    (0x1EE21, 'M', u'ب'),
+    (0x1EE22, 'M', u'ج'),
+    (0x1EE23, 'X'),
+    (0x1EE24, 'M', u'ه'),
+    (0x1EE25, 'X'),
+    (0x1EE27, 'M', u'ح'),
+    (0x1EE28, 'X'),
+    (0x1EE29, 'M', u'ي'),
+    (0x1EE2A, 'M', u'ك'),
+    (0x1EE2B, 'M', u'ل'),
+    (0x1EE2C, 'M', u'م'),
+    (0x1EE2D, 'M', u'ن'),
+    (0x1EE2E, 'M', u'س'),
+    (0x1EE2F, 'M', u'ع'),
+    (0x1EE30, 'M', u'ف'),
+    (0x1EE31, 'M', u'ص'),
+    (0x1EE32, 'M', u'ق'),
+    (0x1EE33, 'X'),
+    (0x1EE34, 'M', u'ش'),
+    (0x1EE35, 'M', u'ت'),
+    (0x1EE36, 'M', u'ث'),
+    (0x1EE37, 'M', u'خ'),
+    (0x1EE38, 'X'),
+    (0x1EE39, 'M', u'ض'),
+    (0x1EE3A, 'X'),
+    (0x1EE3B, 'M', u'غ'),
+    (0x1EE3C, 'X'),
+    (0x1EE42, 'M', u'ج'),
+    (0x1EE43, 'X'),
+    (0x1EE47, 'M', u'ح'),
+    (0x1EE48, 'X'),
+    (0x1EE49, 'M', u'ي'),
+    (0x1EE4A, 'X'),
+    (0x1EE4B, 'M', u'ل'),
+    (0x1EE4C, 'X'),
+    (0x1EE4D, 'M', u'ن'),
+    (0x1EE4E, 'M', u'س'),
+    (0x1EE4F, 'M', u'ع'),
+    (0x1EE50, 'X'),
+    (0x1EE51, 'M', u'ص'),
+    (0x1EE52, 'M', u'ق'),
+    (0x1EE53, 'X'),
+    (0x1EE54, 'M', u'ش'),
+    (0x1EE55, 'X'),
+    (0x1EE57, 'M', u'خ'),
+    (0x1EE58, 'X'),
+    (0x1EE59, 'M', u'ض'),
+    (0x1EE5A, 'X'),
+    (0x1EE5B, 'M', u'غ'),
+    (0x1EE5C, 'X'),
+    (0x1EE5D, 'M', u'ں'),
+    (0x1EE5E, 'X'),
+    (0x1EE5F, 'M', u'ٯ'),
+    (0x1EE60, 'X'),
+    (0x1EE61, 'M', u'ب'),
+    (0x1EE62, 'M', u'ج'),
+    (0x1EE63, 'X'),
+    (0x1EE64, 'M', u'ه'),
+    (0x1EE65, 'X'),
+    (0x1EE67, 'M', u'ح'),
+    (0x1EE68, 'M', u'ط'),
+    (0x1EE69, 'M', u'ي'),
+    (0x1EE6A, 'M', u'ك'),
+    (0x1EE6B, 'X'),
+    (0x1EE6C, 'M', u'م'),
+    (0x1EE6D, 'M', u'ن'),
+    (0x1EE6E, 'M', u'س'),
+    (0x1EE6F, 'M', u'ع'),
+    (0x1EE70, 'M', u'ف'),
+    (0x1EE71, 'M', u'ص'),
+    (0x1EE72, 'M', u'ق'),
+    (0x1EE73, 'X'),
+    (0x1EE74, 'M', u'ش'),
+    (0x1EE75, 'M', u'ت'),
+    (0x1EE76, 'M', u'ث'),
+    (0x1EE77, 'M', u'خ'),
+    (0x1EE78, 'X'),
+    (0x1EE79, 'M', u'ض'),
+    (0x1EE7A, 'M', u'ظ'),
+    (0x1EE7B, 'M', u'غ'),
+    (0x1EE7C, 'M', u'ٮ'),
+    (0x1EE7D, 'X'),
+    (0x1EE7E, 'M', u'ڡ'),
+    (0x1EE7F, 'X'),
+    (0x1EE80, 'M', u'ا'),
+    (0x1EE81, 'M', u'ب'),
+    (0x1EE82, 'M', u'ج'),
+    (0x1EE83, 'M', u'د'),
+    ]
+
+def _seg_70():
+    return [
+    (0x1EE84, 'M', u'ه'),
+    (0x1EE85, 'M', u'و'),
+    (0x1EE86, 'M', u'ز'),
+    (0x1EE87, 'M', u'ح'),
+    (0x1EE88, 'M', u'ط'),
+    (0x1EE89, 'M', u'ي'),
+    (0x1EE8A, 'X'),
+    (0x1EE8B, 'M', u'ل'),
+    (0x1EE8C, 'M', u'م'),
+    (0x1EE8D, 'M', u'ن'),
+    (0x1EE8E, 'M', u'س'),
+    (0x1EE8F, 'M', u'ع'),
+    (0x1EE90, 'M', u'ف'),
+    (0x1EE91, 'M', u'ص'),
+    (0x1EE92, 'M', u'ق'),
+    (0x1EE93, 'M', u'ر'),
+    (0x1EE94, 'M', u'ش'),
+    (0x1EE95, 'M', u'ت'),
+    (0x1EE96, 'M', u'ث'),
+    (0x1EE97, 'M', u'خ'),
+    (0x1EE98, 'M', u'ذ'),
+    (0x1EE99, 'M', u'ض'),
+    (0x1EE9A, 'M', u'ظ'),
+    (0x1EE9B, 'M', u'غ'),
+    (0x1EE9C, 'X'),
+    (0x1EEA1, 'M', u'ب'),
+    (0x1EEA2, 'M', u'ج'),
+    (0x1EEA3, 'M', u'د'),
+    (0x1EEA4, 'X'),
+    (0x1EEA5, 'M', u'و'),
+    (0x1EEA6, 'M', u'ز'),
+    (0x1EEA7, 'M', u'ح'),
+    (0x1EEA8, 'M', u'ط'),
+    (0x1EEA9, 'M', u'ي'),
+    (0x1EEAA, 'X'),
+    (0x1EEAB, 'M', u'ل'),
+    (0x1EEAC, 'M', u'م'),
+    (0x1EEAD, 'M', u'ن'),
+    (0x1EEAE, 'M', u'س'),
+    (0x1EEAF, 'M', u'ع'),
+    (0x1EEB0, 'M', u'ف'),
+    (0x1EEB1, 'M', u'ص'),
+    (0x1EEB2, 'M', u'ق'),
+    (0x1EEB3, 'M', u'ر'),
+    (0x1EEB4, 'M', u'ش'),
+    (0x1EEB5, 'M', u'ت'),
+    (0x1EEB6, 'M', u'ث'),
+    (0x1EEB7, 'M', u'خ'),
+    (0x1EEB8, 'M', u'ذ'),
+    (0x1EEB9, 'M', u'ض'),
+    (0x1EEBA, 'M', u'ظ'),
+    (0x1EEBB, 'M', u'غ'),
+    (0x1EEBC, 'X'),
+    (0x1EEF0, 'V'),
+    (0x1EEF2, 'X'),
+    (0x1F000, 'V'),
+    (0x1F02C, 'X'),
+    (0x1F030, 'V'),
+    (0x1F094, 'X'),
+    (0x1F0A0, 'V'),
+    (0x1F0AF, 'X'),
+    (0x1F0B1, 'V'),
+    (0x1F0C0, 'X'),
+    (0x1F0C1, 'V'),
+    (0x1F0D0, 'X'),
+    (0x1F0D1, 'V'),
+    (0x1F0F6, 'X'),
+    (0x1F101, '3', u'0,'),
+    (0x1F102, '3', u'1,'),
+    (0x1F103, '3', u'2,'),
+    (0x1F104, '3', u'3,'),
+    (0x1F105, '3', u'4,'),
+    (0x1F106, '3', u'5,'),
+    (0x1F107, '3', u'6,'),
+    (0x1F108, '3', u'7,'),
+    (0x1F109, '3', u'8,'),
+    (0x1F10A, '3', u'9,'),
+    (0x1F10B, 'V'),
+    (0x1F10D, 'X'),
+    (0x1F110, '3', u'(a)'),
+    (0x1F111, '3', u'(b)'),
+    (0x1F112, '3', u'(c)'),
+    (0x1F113, '3', u'(d)'),
+    (0x1F114, '3', u'(e)'),
+    (0x1F115, '3', u'(f)'),
+    (0x1F116, '3', u'(g)'),
+    (0x1F117, '3', u'(h)'),
+    (0x1F118, '3', u'(i)'),
+    (0x1F119, '3', u'(j)'),
+    (0x1F11A, '3', u'(k)'),
+    (0x1F11B, '3', u'(l)'),
+    (0x1F11C, '3', u'(m)'),
+    (0x1F11D, '3', u'(n)'),
+    (0x1F11E, '3', u'(o)'),
+    (0x1F11F, '3', u'(p)'),
+    (0x1F120, '3', u'(q)'),
+    (0x1F121, '3', u'(r)'),
+    (0x1F122, '3', u'(s)'),
+    (0x1F123, '3', u'(t)'),
+    (0x1F124, '3', u'(u)'),
+    ]
+
+def _seg_71():
+    return [
+    (0x1F125, '3', u'(v)'),
+    (0x1F126, '3', u'(w)'),
+    (0x1F127, '3', u'(x)'),
+    (0x1F128, '3', u'(y)'),
+    (0x1F129, '3', u'(z)'),
+    (0x1F12A, 'M', u'〔s〕'),
+    (0x1F12B, 'M', u'c'),
+    (0x1F12C, 'M', u'r'),
+    (0x1F12D, 'M', u'cd'),
+    (0x1F12E, 'M', u'wz'),
+    (0x1F12F, 'V'),
+    (0x1F130, 'M', u'a'),
+    (0x1F131, 'M', u'b'),
+    (0x1F132, 'M', u'c'),
+    (0x1F133, 'M', u'd'),
+    (0x1F134, 'M', u'e'),
+    (0x1F135, 'M', u'f'),
+    (0x1F136, 'M', u'g'),
+    (0x1F137, 'M', u'h'),
+    (0x1F138, 'M', u'i'),
+    (0x1F139, 'M', u'j'),
+    (0x1F13A, 'M', u'k'),
+    (0x1F13B, 'M', u'l'),
+    (0x1F13C, 'M', u'm'),
+    (0x1F13D, 'M', u'n'),
+    (0x1F13E, 'M', u'o'),
+    (0x1F13F, 'M', u'p'),
+    (0x1F140, 'M', u'q'),
+    (0x1F141, 'M', u'r'),
+    (0x1F142, 'M', u's'),
+    (0x1F143, 'M', u't'),
+    (0x1F144, 'M', u'u'),
+    (0x1F145, 'M', u'v'),
+    (0x1F146, 'M', u'w'),
+    (0x1F147, 'M', u'x'),
+    (0x1F148, 'M', u'y'),
+    (0x1F149, 'M', u'z'),
+    (0x1F14A, 'M', u'hv'),
+    (0x1F14B, 'M', u'mv'),
+    (0x1F14C, 'M', u'sd'),
+    (0x1F14D, 'M', u'ss'),
+    (0x1F14E, 'M', u'ppv'),
+    (0x1F14F, 'M', u'wc'),
+    (0x1F150, 'V'),
+    (0x1F16A, 'M', u'mc'),
+    (0x1F16B, 'M', u'md'),
+    (0x1F16C, 'X'),
+    (0x1F170, 'V'),
+    (0x1F190, 'M', u'dj'),
+    (0x1F191, 'V'),
+    (0x1F1AD, 'X'),
+    (0x1F1E6, 'V'),
+    (0x1F200, 'M', u'ほか'),
+    (0x1F201, 'M', u'ココ'),
+    (0x1F202, 'M', u'サ'),
+    (0x1F203, 'X'),
+    (0x1F210, 'M', u'手'),
+    (0x1F211, 'M', u'字'),
+    (0x1F212, 'M', u'双'),
+    (0x1F213, 'M', u'デ'),
+    (0x1F214, 'M', u'二'),
+    (0x1F215, 'M', u'多'),
+    (0x1F216, 'M', u'解'),
+    (0x1F217, 'M', u'天'),
+    (0x1F218, 'M', u'交'),
+    (0x1F219, 'M', u'映'),
+    (0x1F21A, 'M', u'無'),
+    (0x1F21B, 'M', u'料'),
+    (0x1F21C, 'M', u'前'),
+    (0x1F21D, 'M', u'後'),
+    (0x1F21E, 'M', u'再'),
+    (0x1F21F, 'M', u'新'),
+    (0x1F220, 'M', u'初'),
+    (0x1F221, 'M', u'終'),
+    (0x1F222, 'M', u'生'),
+    (0x1F223, 'M', u'販'),
+    (0x1F224, 'M', u'声'),
+    (0x1F225, 'M', u'吹'),
+    (0x1F226, 'M', u'演'),
+    (0x1F227, 'M', u'投'),
+    (0x1F228, 'M', u'捕'),
+    (0x1F229, 'M', u'一'),
+    (0x1F22A, 'M', u'三'),
+    (0x1F22B, 'M', u'遊'),
+    (0x1F22C, 'M', u'左'),
+    (0x1F22D, 'M', u'中'),
+    (0x1F22E, 'M', u'右'),
+    (0x1F22F, 'M', u'指'),
+    (0x1F230, 'M', u'走'),
+    (0x1F231, 'M', u'打'),
+    (0x1F232, 'M', u'禁'),
+    (0x1F233, 'M', u'空'),
+    (0x1F234, 'M', u'合'),
+    (0x1F235, 'M', u'満'),
+    (0x1F236, 'M', u'有'),
+    (0x1F237, 'M', u'月'),
+    (0x1F238, 'M', u'申'),
+    (0x1F239, 'M', u'割'),
+    (0x1F23A, 'M', u'営'),
+    (0x1F23B, 'M', u'配'),
+    ]
+
+def _seg_72():
+    return [
+    (0x1F23C, 'X'),
+    (0x1F240, 'M', u'〔本〕'),
+    (0x1F241, 'M', u'〔三〕'),
+    (0x1F242, 'M', u'〔二〕'),
+    (0x1F243, 'M', u'〔安〕'),
+    (0x1F244, 'M', u'〔点〕'),
+    (0x1F245, 'M', u'〔打〕'),
+    (0x1F246, 'M', u'〔盗〕'),
+    (0x1F247, 'M', u'〔勝〕'),
+    (0x1F248, 'M', u'〔敗〕'),
+    (0x1F249, 'X'),
+    (0x1F250, 'M', u'得'),
+    (0x1F251, 'M', u'可'),
+    (0x1F252, 'X'),
+    (0x1F260, 'V'),
+    (0x1F266, 'X'),
+    (0x1F300, 'V'),
+    (0x1F6D5, 'X'),
+    (0x1F6E0, 'V'),
+    (0x1F6ED, 'X'),
+    (0x1F6F0, 'V'),
+    (0x1F6FA, 'X'),
+    (0x1F700, 'V'),
+    (0x1F774, 'X'),
+    (0x1F780, 'V'),
+    (0x1F7D9, 'X'),
+    (0x1F800, 'V'),
+    (0x1F80C, 'X'),
+    (0x1F810, 'V'),
+    (0x1F848, 'X'),
+    (0x1F850, 'V'),
+    (0x1F85A, 'X'),
+    (0x1F860, 'V'),
+    (0x1F888, 'X'),
+    (0x1F890, 'V'),
+    (0x1F8AE, 'X'),
+    (0x1F900, 'V'),
+    (0x1F90C, 'X'),
+    (0x1F910, 'V'),
+    (0x1F93F, 'X'),
+    (0x1F940, 'V'),
+    (0x1F971, 'X'),
+    (0x1F973, 'V'),
+    (0x1F977, 'X'),
+    (0x1F97A, 'V'),
+    (0x1F97B, 'X'),
+    (0x1F97C, 'V'),
+    (0x1F9A3, 'X'),
+    (0x1F9B0, 'V'),
+    (0x1F9BA, 'X'),
+    (0x1F9C0, 'V'),
+    (0x1F9C3, 'X'),
+    (0x1F9D0, 'V'),
+    (0x1FA00, 'X'),
+    (0x1FA60, 'V'),
+    (0x1FA6E, 'X'),
+    (0x20000, 'V'),
+    (0x2A6D7, 'X'),
+    (0x2A700, 'V'),
+    (0x2B735, 'X'),
+    (0x2B740, 'V'),
+    (0x2B81E, 'X'),
+    (0x2B820, 'V'),
+    (0x2CEA2, 'X'),
+    (0x2CEB0, 'V'),
+    (0x2EBE1, 'X'),
+    (0x2F800, 'M', u'丽'),
+    (0x2F801, 'M', u'丸'),
+    (0x2F802, 'M', u'乁'),
+    (0x2F803, 'M', u'𠄢'),
+    (0x2F804, 'M', u'你'),
+    (0x2F805, 'M', u'侮'),
+    (0x2F806, 'M', u'侻'),
+    (0x2F807, 'M', u'倂'),
+    (0x2F808, 'M', u'偺'),
+    (0x2F809, 'M', u'備'),
+    (0x2F80A, 'M', u'僧'),
+    (0x2F80B, 'M', u'像'),
+    (0x2F80C, 'M', u'㒞'),
+    (0x2F80D, 'M', u'𠘺'),
+    (0x2F80E, 'M', u'免'),
+    (0x2F80F, 'M', u'兔'),
+    (0x2F810, 'M', u'兤'),
+    (0x2F811, 'M', u'具'),
+    (0x2F812, 'M', u'𠔜'),
+    (0x2F813, 'M', u'㒹'),
+    (0x2F814, 'M', u'內'),
+    (0x2F815, 'M', u'再'),
+    (0x2F816, 'M', u'𠕋'),
+    (0x2F817, 'M', u'冗'),
+    (0x2F818, 'M', u'冤'),
+    (0x2F819, 'M', u'仌'),
+    (0x2F81A, 'M', u'冬'),
+    (0x2F81B, 'M', u'况'),
+    (0x2F81C, 'M', u'𩇟'),
+    (0x2F81D, 'M', u'凵'),
+    (0x2F81E, 'M', u'刃'),
+    (0x2F81F, 'M', u'㓟'),
+    (0x2F820, 'M', u'刻'),
+    (0x2F821, 'M', u'剆'),
+    ]
+
+def _seg_73():
+    return [
+    (0x2F822, 'M', u'割'),
+    (0x2F823, 'M', u'剷'),
+    (0x2F824, 'M', u'㔕'),
+    (0x2F825, 'M', u'勇'),
+    (0x2F826, 'M', u'勉'),
+    (0x2F827, 'M', u'勤'),
+    (0x2F828, 'M', u'勺'),
+    (0x2F829, 'M', u'包'),
+    (0x2F82A, 'M', u'匆'),
+    (0x2F82B, 'M', u'北'),
+    (0x2F82C, 'M', u'卉'),
+    (0x2F82D, 'M', u'卑'),
+    (0x2F82E, 'M', u'博'),
+    (0x2F82F, 'M', u'即'),
+    (0x2F830, 'M', u'卽'),
+    (0x2F831, 'M', u'卿'),
+    (0x2F834, 'M', u'𠨬'),
+    (0x2F835, 'M', u'灰'),
+    (0x2F836, 'M', u'及'),
+    (0x2F837, 'M', u'叟'),
+    (0x2F838, 'M', u'𠭣'),
+    (0x2F839, 'M', u'叫'),
+    (0x2F83A, 'M', u'叱'),
+    (0x2F83B, 'M', u'吆'),
+    (0x2F83C, 'M', u'咞'),
+    (0x2F83D, 'M', u'吸'),
+    (0x2F83E, 'M', u'呈'),
+    (0x2F83F, 'M', u'周'),
+    (0x2F840, 'M', u'咢'),
+    (0x2F841, 'M', u'哶'),
+    (0x2F842, 'M', u'唐'),
+    (0x2F843, 'M', u'啓'),
+    (0x2F844, 'M', u'啣'),
+    (0x2F845, 'M', u'善'),
+    (0x2F847, 'M', u'喙'),
+    (0x2F848, 'M', u'喫'),
+    (0x2F849, 'M', u'喳'),
+    (0x2F84A, 'M', u'嗂'),
+    (0x2F84B, 'M', u'圖'),
+    (0x2F84C, 'M', u'嘆'),
+    (0x2F84D, 'M', u'圗'),
+    (0x2F84E, 'M', u'噑'),
+    (0x2F84F, 'M', u'噴'),
+    (0x2F850, 'M', u'切'),
+    (0x2F851, 'M', u'壮'),
+    (0x2F852, 'M', u'城'),
+    (0x2F853, 'M', u'埴'),
+    (0x2F854, 'M', u'堍'),
+    (0x2F855, 'M', u'型'),
+    (0x2F856, 'M', u'堲'),
+    (0x2F857, 'M', u'報'),
+    (0x2F858, 'M', u'墬'),
+    (0x2F859, 'M', u'𡓤'),
+    (0x2F85A, 'M', u'売'),
+    (0x2F85B, 'M', u'壷'),
+    (0x2F85C, 'M', u'夆'),
+    (0x2F85D, 'M', u'多'),
+    (0x2F85E, 'M', u'夢'),
+    (0x2F85F, 'M', u'奢'),
+    (0x2F860, 'M', u'𡚨'),
+    (0x2F861, 'M', u'𡛪'),
+    (0x2F862, 'M', u'姬'),
+    (0x2F863, 'M', u'娛'),
+    (0x2F864, 'M', u'娧'),
+    (0x2F865, 'M', u'姘'),
+    (0x2F866, 'M', u'婦'),
+    (0x2F867, 'M', u'㛮'),
+    (0x2F868, 'X'),
+    (0x2F869, 'M', u'嬈'),
+    (0x2F86A, 'M', u'嬾'),
+    (0x2F86C, 'M', u'𡧈'),
+    (0x2F86D, 'M', u'寃'),
+    (0x2F86E, 'M', u'寘'),
+    (0x2F86F, 'M', u'寧'),
+    (0x2F870, 'M', u'寳'),
+    (0x2F871, 'M', u'𡬘'),
+    (0x2F872, 'M', u'寿'),
+    (0x2F873, 'M', u'将'),
+    (0x2F874, 'X'),
+    (0x2F875, 'M', u'尢'),
+    (0x2F876, 'M', u'㞁'),
+    (0x2F877, 'M', u'屠'),
+    (0x2F878, 'M', u'屮'),
+    (0x2F879, 'M', u'峀'),
+    (0x2F87A, 'M', u'岍'),
+    (0x2F87B, 'M', u'𡷤'),
+    (0x2F87C, 'M', u'嵃'),
+    (0x2F87D, 'M', u'𡷦'),
+    (0x2F87E, 'M', u'嵮'),
+    (0x2F87F, 'M', u'嵫'),
+    (0x2F880, 'M', u'嵼'),
+    (0x2F881, 'M', u'巡'),
+    (0x2F882, 'M', u'巢'),
+    (0x2F883, 'M', u'㠯'),
+    (0x2F884, 'M', u'巽'),
+    (0x2F885, 'M', u'帨'),
+    (0x2F886, 'M', u'帽'),
+    (0x2F887, 'M', u'幩'),
+    (0x2F888, 'M', u'㡢'),
+    (0x2F889, 'M', u'𢆃'),
+    ]
+
+def _seg_74():
+    return [
+    (0x2F88A, 'M', u'㡼'),
+    (0x2F88B, 'M', u'庰'),
+    (0x2F88C, 'M', u'庳'),
+    (0x2F88D, 'M', u'庶'),
+    (0x2F88E, 'M', u'廊'),
+    (0x2F88F, 'M', u'𪎒'),
+    (0x2F890, 'M', u'廾'),
+    (0x2F891, 'M', u'𢌱'),
+    (0x2F893, 'M', u'舁'),
+    (0x2F894, 'M', u'弢'),
+    (0x2F896, 'M', u'㣇'),
+    (0x2F897, 'M', u'𣊸'),
+    (0x2F898, 'M', u'𦇚'),
+    (0x2F899, 'M', u'形'),
+    (0x2F89A, 'M', u'彫'),
+    (0x2F89B, 'M', u'㣣'),
+    (0x2F89C, 'M', u'徚'),
+    (0x2F89D, 'M', u'忍'),
+    (0x2F89E, 'M', u'志'),
+    (0x2F89F, 'M', u'忹'),
+    (0x2F8A0, 'M', u'悁'),
+    (0x2F8A1, 'M', u'㤺'),
+    (0x2F8A2, 'M', u'㤜'),
+    (0x2F8A3, 'M', u'悔'),
+    (0x2F8A4, 'M', u'𢛔'),
+    (0x2F8A5, 'M', u'惇'),
+    (0x2F8A6, 'M', u'慈'),
+    (0x2F8A7, 'M', u'慌'),
+    (0x2F8A8, 'M', u'慎'),
+    (0x2F8A9, 'M', u'慌'),
+    (0x2F8AA, 'M', u'慺'),
+    (0x2F8AB, 'M', u'憎'),
+    (0x2F8AC, 'M', u'憲'),
+    (0x2F8AD, 'M', u'憤'),
+    (0x2F8AE, 'M', u'憯'),
+    (0x2F8AF, 'M', u'懞'),
+    (0x2F8B0, 'M', u'懲'),
+    (0x2F8B1, 'M', u'懶'),
+    (0x2F8B2, 'M', u'成'),
+    (0x2F8B3, 'M', u'戛'),
+    (0x2F8B4, 'M', u'扝'),
+    (0x2F8B5, 'M', u'抱'),
+    (0x2F8B6, 'M', u'拔'),
+    (0x2F8B7, 'M', u'捐'),
+    (0x2F8B8, 'M', u'𢬌'),
+    (0x2F8B9, 'M', u'挽'),
+    (0x2F8BA, 'M', u'拼'),
+    (0x2F8BB, 'M', u'捨'),
+    (0x2F8BC, 'M', u'掃'),
+    (0x2F8BD, 'M', u'揤'),
+    (0x2F8BE, 'M', u'𢯱'),
+    (0x2F8BF, 'M', u'搢'),
+    (0x2F8C0, 'M', u'揅'),
+    (0x2F8C1, 'M', u'掩'),
+    (0x2F8C2, 'M', u'㨮'),
+    (0x2F8C3, 'M', u'摩'),
+    (0x2F8C4, 'M', u'摾'),
+    (0x2F8C5, 'M', u'撝'),
+    (0x2F8C6, 'M', u'摷'),
+    (0x2F8C7, 'M', u'㩬'),
+    (0x2F8C8, 'M', u'敏'),
+    (0x2F8C9, 'M', u'敬'),
+    (0x2F8CA, 'M', u'𣀊'),
+    (0x2F8CB, 'M', u'旣'),
+    (0x2F8CC, 'M', u'書'),
+    (0x2F8CD, 'M', u'晉'),
+    (0x2F8CE, 'M', u'㬙'),
+    (0x2F8CF, 'M', u'暑'),
+    (0x2F8D0, 'M', u'㬈'),
+    (0x2F8D1, 'M', u'㫤'),
+    (0x2F8D2, 'M', u'冒'),
+    (0x2F8D3, 'M', u'冕'),
+    (0x2F8D4, 'M', u'最'),
+    (0x2F8D5, 'M', u'暜'),
+    (0x2F8D6, 'M', u'肭'),
+    (0x2F8D7, 'M', u'䏙'),
+    (0x2F8D8, 'M', u'朗'),
+    (0x2F8D9, 'M', u'望'),
+    (0x2F8DA, 'M', u'朡'),
+    (0x2F8DB, 'M', u'杞'),
+    (0x2F8DC, 'M', u'杓'),
+    (0x2F8DD, 'M', u'𣏃'),
+    (0x2F8DE, 'M', u'㭉'),
+    (0x2F8DF, 'M', u'柺'),
+    (0x2F8E0, 'M', u'枅'),
+    (0x2F8E1, 'M', u'桒'),
+    (0x2F8E2, 'M', u'梅'),
+    (0x2F8E3, 'M', u'𣑭'),
+    (0x2F8E4, 'M', u'梎'),
+    (0x2F8E5, 'M', u'栟'),
+    (0x2F8E6, 'M', u'椔'),
+    (0x2F8E7, 'M', u'㮝'),
+    (0x2F8E8, 'M', u'楂'),
+    (0x2F8E9, 'M', u'榣'),
+    (0x2F8EA, 'M', u'槪'),
+    (0x2F8EB, 'M', u'檨'),
+    (0x2F8EC, 'M', u'𣚣'),
+    (0x2F8ED, 'M', u'櫛'),
+    (0x2F8EE, 'M', u'㰘'),
+    (0x2F8EF, 'M', u'次'),
+    ]
+
+def _seg_75():
+    return [
+    (0x2F8F0, 'M', u'𣢧'),
+    (0x2F8F1, 'M', u'歔'),
+    (0x2F8F2, 'M', u'㱎'),
+    (0x2F8F3, 'M', u'歲'),
+    (0x2F8F4, 'M', u'殟'),
+    (0x2F8F5, 'M', u'殺'),
+    (0x2F8F6, 'M', u'殻'),
+    (0x2F8F7, 'M', u'𣪍'),
+    (0x2F8F8, 'M', u'𡴋'),
+    (0x2F8F9, 'M', u'𣫺'),
+    (0x2F8FA, 'M', u'汎'),
+    (0x2F8FB, 'M', u'𣲼'),
+    (0x2F8FC, 'M', u'沿'),
+    (0x2F8FD, 'M', u'泍'),
+    (0x2F8FE, 'M', u'汧'),
+    (0x2F8FF, 'M', u'洖'),
+    (0x2F900, 'M', u'派'),
+    (0x2F901, 'M', u'海'),
+    (0x2F902, 'M', u'流'),
+    (0x2F903, 'M', u'浩'),
+    (0x2F904, 'M', u'浸'),
+    (0x2F905, 'M', u'涅'),
+    (0x2F906, 'M', u'𣴞'),
+    (0x2F907, 'M', u'洴'),
+    (0x2F908, 'M', u'港'),
+    (0x2F909, 'M', u'湮'),
+    (0x2F90A, 'M', u'㴳'),
+    (0x2F90B, 'M', u'滋'),
+    (0x2F90C, 'M', u'滇'),
+    (0x2F90D, 'M', u'𣻑'),
+    (0x2F90E, 'M', u'淹'),
+    (0x2F90F, 'M', u'潮'),
+    (0x2F910, 'M', u'𣽞'),
+    (0x2F911, 'M', u'𣾎'),
+    (0x2F912, 'M', u'濆'),
+    (0x2F913, 'M', u'瀹'),
+    (0x2F914, 'M', u'瀞'),
+    (0x2F915, 'M', u'瀛'),
+    (0x2F916, 'M', u'㶖'),
+    (0x2F917, 'M', u'灊'),
+    (0x2F918, 'M', u'災'),
+    (0x2F919, 'M', u'灷'),
+    (0x2F91A, 'M', u'炭'),
+    (0x2F91B, 'M', u'𠔥'),
+    (0x2F91C, 'M', u'煅'),
+    (0x2F91D, 'M', u'𤉣'),
+    (0x2F91E, 'M', u'熜'),
+    (0x2F91F, 'X'),
+    (0x2F920, 'M', u'爨'),
+    (0x2F921, 'M', u'爵'),
+    (0x2F922, 'M', u'牐'),
+    (0x2F923, 'M', u'𤘈'),
+    (0x2F924, 'M', u'犀'),
+    (0x2F925, 'M', u'犕'),
+    (0x2F926, 'M', u'𤜵'),
+    (0x2F927, 'M', u'𤠔'),
+    (0x2F928, 'M', u'獺'),
+    (0x2F929, 'M', u'王'),
+    (0x2F92A, 'M', u'㺬'),
+    (0x2F92B, 'M', u'玥'),
+    (0x2F92C, 'M', u'㺸'),
+    (0x2F92E, 'M', u'瑇'),
+    (0x2F92F, 'M', u'瑜'),
+    (0x2F930, 'M', u'瑱'),
+    (0x2F931, 'M', u'璅'),
+    (0x2F932, 'M', u'瓊'),
+    (0x2F933, 'M', u'㼛'),
+    (0x2F934, 'M', u'甤'),
+    (0x2F935, 'M', u'𤰶'),
+    (0x2F936, 'M', u'甾'),
+    (0x2F937, 'M', u'𤲒'),
+    (0x2F938, 'M', u'異'),
+    (0x2F939, 'M', u'𢆟'),
+    (0x2F93A, 'M', u'瘐'),
+    (0x2F93B, 'M', u'𤾡'),
+    (0x2F93C, 'M', u'𤾸'),
+    (0x2F93D, 'M', u'𥁄'),
+    (0x2F93E, 'M', u'㿼'),
+    (0x2F93F, 'M', u'䀈'),
+    (0x2F940, 'M', u'直'),
+    (0x2F941, 'M', u'𥃳'),
+    (0x2F942, 'M', u'𥃲'),
+    (0x2F943, 'M', u'𥄙'),
+    (0x2F944, 'M', u'𥄳'),
+    (0x2F945, 'M', u'眞'),
+    (0x2F946, 'M', u'真'),
+    (0x2F948, 'M', u'睊'),
+    (0x2F949, 'M', u'䀹'),
+    (0x2F94A, 'M', u'瞋'),
+    (0x2F94B, 'M', u'䁆'),
+    (0x2F94C, 'M', u'䂖'),
+    (0x2F94D, 'M', u'𥐝'),
+    (0x2F94E, 'M', u'硎'),
+    (0x2F94F, 'M', u'碌'),
+    (0x2F950, 'M', u'磌'),
+    (0x2F951, 'M', u'䃣'),
+    (0x2F952, 'M', u'𥘦'),
+    (0x2F953, 'M', u'祖'),
+    (0x2F954, 'M', u'𥚚'),
+    (0x2F955, 'M', u'𥛅'),
+    ]
+
+def _seg_76():
+    return [
+    (0x2F956, 'M', u'福'),
+    (0x2F957, 'M', u'秫'),
+    (0x2F958, 'M', u'䄯'),
+    (0x2F959, 'M', u'穀'),
+    (0x2F95A, 'M', u'穊'),
+    (0x2F95B, 'M', u'穏'),
+    (0x2F95C, 'M', u'𥥼'),
+    (0x2F95D, 'M', u'𥪧'),
+    (0x2F95F, 'X'),
+    (0x2F960, 'M', u'䈂'),
+    (0x2F961, 'M', u'𥮫'),
+    (0x2F962, 'M', u'篆'),
+    (0x2F963, 'M', u'築'),
+    (0x2F964, 'M', u'䈧'),
+    (0x2F965, 'M', u'𥲀'),
+    (0x2F966, 'M', u'糒'),
+    (0x2F967, 'M', u'䊠'),
+    (0x2F968, 'M', u'糨'),
+    (0x2F969, 'M', u'糣'),
+    (0x2F96A, 'M', u'紀'),
+    (0x2F96B, 'M', u'𥾆'),
+    (0x2F96C, 'M', u'絣'),
+    (0x2F96D, 'M', u'䌁'),
+    (0x2F96E, 'M', u'緇'),
+    (0x2F96F, 'M', u'縂'),
+    (0x2F970, 'M', u'繅'),
+    (0x2F971, 'M', u'䌴'),
+    (0x2F972, 'M', u'𦈨'),
+    (0x2F973, 'M', u'𦉇'),
+    (0x2F974, 'M', u'䍙'),
+    (0x2F975, 'M', u'𦋙'),
+    (0x2F976, 'M', u'罺'),
+    (0x2F977, 'M', u'𦌾'),
+    (0x2F978, 'M', u'羕'),
+    (0x2F979, 'M', u'翺'),
+    (0x2F97A, 'M', u'者'),
+    (0x2F97B, 'M', u'𦓚'),
+    (0x2F97C, 'M', u'𦔣'),
+    (0x2F97D, 'M', u'聠'),
+    (0x2F97E, 'M', u'𦖨'),
+    (0x2F97F, 'M', u'聰'),
+    (0x2F980, 'M', u'𣍟'),
+    (0x2F981, 'M', u'䏕'),
+    (0x2F982, 'M', u'育'),
+    (0x2F983, 'M', u'脃'),
+    (0x2F984, 'M', u'䐋'),
+    (0x2F985, 'M', u'脾'),
+    (0x2F986, 'M', u'媵'),
+    (0x2F987, 'M', u'𦞧'),
+    (0x2F988, 'M', u'𦞵'),
+    (0x2F989, 'M', u'𣎓'),
+    (0x2F98A, 'M', u'𣎜'),
+    (0x2F98B, 'M', u'舁'),
+    (0x2F98C, 'M', u'舄'),
+    (0x2F98D, 'M', u'辞'),
+    (0x2F98E, 'M', u'䑫'),
+    (0x2F98F, 'M', u'芑'),
+    (0x2F990, 'M', u'芋'),
+    (0x2F991, 'M', u'芝'),
+    (0x2F992, 'M', u'劳'),
+    (0x2F993, 'M', u'花'),
+    (0x2F994, 'M', u'芳'),
+    (0x2F995, 'M', u'芽'),
+    (0x2F996, 'M', u'苦'),
+    (0x2F997, 'M', u'𦬼'),
+    (0x2F998, 'M', u'若'),
+    (0x2F999, 'M', u'茝'),
+    (0x2F99A, 'M', u'荣'),
+    (0x2F99B, 'M', u'莭'),
+    (0x2F99C, 'M', u'茣'),
+    (0x2F99D, 'M', u'莽'),
+    (0x2F99E, 'M', u'菧'),
+    (0x2F99F, 'M', u'著'),
+    (0x2F9A0, 'M', u'荓'),
+    (0x2F9A1, 'M', u'菊'),
+    (0x2F9A2, 'M', u'菌'),
+    (0x2F9A3, 'M', u'菜'),
+    (0x2F9A4, 'M', u'𦰶'),
+    (0x2F9A5, 'M', u'𦵫'),
+    (0x2F9A6, 'M', u'𦳕'),
+    (0x2F9A7, 'M', u'䔫'),
+    (0x2F9A8, 'M', u'蓱'),
+    (0x2F9A9, 'M', u'蓳'),
+    (0x2F9AA, 'M', u'蔖'),
+    (0x2F9AB, 'M', u'𧏊'),
+    (0x2F9AC, 'M', u'蕤'),
+    (0x2F9AD, 'M', u'𦼬'),
+    (0x2F9AE, 'M', u'䕝'),
+    (0x2F9AF, 'M', u'䕡'),
+    (0x2F9B0, 'M', u'𦾱'),
+    (0x2F9B1, 'M', u'𧃒'),
+    (0x2F9B2, 'M', u'䕫'),
+    (0x2F9B3, 'M', u'虐'),
+    (0x2F9B4, 'M', u'虜'),
+    (0x2F9B5, 'M', u'虧'),
+    (0x2F9B6, 'M', u'虩'),
+    (0x2F9B7, 'M', u'蚩'),
+    (0x2F9B8, 'M', u'蚈'),
+    (0x2F9B9, 'M', u'蜎'),
+    (0x2F9BA, 'M', u'蛢'),
+    ]
+
+def _seg_77():
+    return [
+    (0x2F9BB, 'M', u'蝹'),
+    (0x2F9BC, 'M', u'蜨'),
+    (0x2F9BD, 'M', u'蝫'),
+    (0x2F9BE, 'M', u'螆'),
+    (0x2F9BF, 'X'),
+    (0x2F9C0, 'M', u'蟡'),
+    (0x2F9C1, 'M', u'蠁'),
+    (0x2F9C2, 'M', u'䗹'),
+    (0x2F9C3, 'M', u'衠'),
+    (0x2F9C4, 'M', u'衣'),
+    (0x2F9C5, 'M', u'𧙧'),
+    (0x2F9C6, 'M', u'裗'),
+    (0x2F9C7, 'M', u'裞'),
+    (0x2F9C8, 'M', u'䘵'),
+    (0x2F9C9, 'M', u'裺'),
+    (0x2F9CA, 'M', u'㒻'),
+    (0x2F9CB, 'M', u'𧢮'),
+    (0x2F9CC, 'M', u'𧥦'),
+    (0x2F9CD, 'M', u'䚾'),
+    (0x2F9CE, 'M', u'䛇'),
+    (0x2F9CF, 'M', u'誠'),
+    (0x2F9D0, 'M', u'諭'),
+    (0x2F9D1, 'M', u'變'),
+    (0x2F9D2, 'M', u'豕'),
+    (0x2F9D3, 'M', u'𧲨'),
+    (0x2F9D4, 'M', u'貫'),
+    (0x2F9D5, 'M', u'賁'),
+    (0x2F9D6, 'M', u'贛'),
+    (0x2F9D7, 'M', u'起'),
+    (0x2F9D8, 'M', u'𧼯'),
+    (0x2F9D9, 'M', u'𠠄'),
+    (0x2F9DA, 'M', u'跋'),
+    (0x2F9DB, 'M', u'趼'),
+    (0x2F9DC, 'M', u'跰'),
+    (0x2F9DD, 'M', u'𠣞'),
+    (0x2F9DE, 'M', u'軔'),
+    (0x2F9DF, 'M', u'輸'),
+    (0x2F9E0, 'M', u'𨗒'),
+    (0x2F9E1, 'M', u'𨗭'),
+    (0x2F9E2, 'M', u'邔'),
+    (0x2F9E3, 'M', u'郱'),
+    (0x2F9E4, 'M', u'鄑'),
+    (0x2F9E5, 'M', u'𨜮'),
+    (0x2F9E6, 'M', u'鄛'),
+    (0x2F9E7, 'M', u'鈸'),
+    (0x2F9E8, 'M', u'鋗'),
+    (0x2F9E9, 'M', u'鋘'),
+    (0x2F9EA, 'M', u'鉼'),
+    (0x2F9EB, 'M', u'鏹'),
+    (0x2F9EC, 'M', u'鐕'),
+    (0x2F9ED, 'M', u'𨯺'),
+    (0x2F9EE, 'M', u'開'),
+    (0x2F9EF, 'M', u'䦕'),
+    (0x2F9F0, 'M', u'閷'),
+    (0x2F9F1, 'M', u'𨵷'),
+    (0x2F9F2, 'M', u'䧦'),
+    (0x2F9F3, 'M', u'雃'),
+    (0x2F9F4, 'M', u'嶲'),
+    (0x2F9F5, 'M', u'霣'),
+    (0x2F9F6, 'M', u'𩅅'),
+    (0x2F9F7, 'M', u'𩈚'),
+    (0x2F9F8, 'M', u'䩮'),
+    (0x2F9F9, 'M', u'䩶'),
+    (0x2F9FA, 'M', u'韠'),
+    (0x2F9FB, 'M', u'𩐊'),
+    (0x2F9FC, 'M', u'䪲'),
+    (0x2F9FD, 'M', u'𩒖'),
+    (0x2F9FE, 'M', u'頋'),
+    (0x2FA00, 'M', u'頩'),
+    (0x2FA01, 'M', u'𩖶'),
+    (0x2FA02, 'M', u'飢'),
+    (0x2FA03, 'M', u'䬳'),
+    (0x2FA04, 'M', u'餩'),
+    (0x2FA05, 'M', u'馧'),
+    (0x2FA06, 'M', u'駂'),
+    (0x2FA07, 'M', u'駾'),
+    (0x2FA08, 'M', u'䯎'),
+    (0x2FA09, 'M', u'𩬰'),
+    (0x2FA0A, 'M', u'鬒'),
+    (0x2FA0B, 'M', u'鱀'),
+    (0x2FA0C, 'M', u'鳽'),
+    (0x2FA0D, 'M', u'䳎'),
+    (0x2FA0E, 'M', u'䳭'),
+    (0x2FA0F, 'M', u'鵧'),
+    (0x2FA10, 'M', u'𪃎'),
+    (0x2FA11, 'M', u'䳸'),
+    (0x2FA12, 'M', u'𪄅'),
+    (0x2FA13, 'M', u'𪈎'),
+    (0x2FA14, 'M', u'𪊑'),
+    (0x2FA15, 'M', u'麻'),
+    (0x2FA16, 'M', u'䵖'),
+    (0x2FA17, 'M', u'黹'),
+    (0x2FA18, 'M', u'黾'),
+    (0x2FA19, 'M', u'鼅'),
+    (0x2FA1A, 'M', u'鼏'),
+    (0x2FA1B, 'M', u'鼖'),
+    (0x2FA1C, 'M', u'鼻'),
+    (0x2FA1D, 'M', u'𪘀'),
+    (0x2FA1E, 'X'),
+    (0xE0100, 'I'),
+    ]
+
+def _seg_78():
+    return [
+    (0xE01F0, 'X'),
+    ]
+
+uts46data = tuple(
+    _seg_0()
+    + _seg_1()
+    + _seg_2()
+    + _seg_3()
+    + _seg_4()
+    + _seg_5()
+    + _seg_6()
+    + _seg_7()
+    + _seg_8()
+    + _seg_9()
+    + _seg_10()
+    + _seg_11()
+    + _seg_12()
+    + _seg_13()
+    + _seg_14()
+    + _seg_15()
+    + _seg_16()
+    + _seg_17()
+    + _seg_18()
+    + _seg_19()
+    + _seg_20()
+    + _seg_21()
+    + _seg_22()
+    + _seg_23()
+    + _seg_24()
+    + _seg_25()
+    + _seg_26()
+    + _seg_27()
+    + _seg_28()
+    + _seg_29()
+    + _seg_30()
+    + _seg_31()
+    + _seg_32()
+    + _seg_33()
+    + _seg_34()
+    + _seg_35()
+    + _seg_36()
+    + _seg_37()
+    + _seg_38()
+    + _seg_39()
+    + _seg_40()
+    + _seg_41()
+    + _seg_42()
+    + _seg_43()
+    + _seg_44()
+    + _seg_45()
+    + _seg_46()
+    + _seg_47()
+    + _seg_48()
+    + _seg_49()
+    + _seg_50()
+    + _seg_51()
+    + _seg_52()
+    + _seg_53()
+    + _seg_54()
+    + _seg_55()
+    + _seg_56()
+    + _seg_57()
+    + _seg_58()
+    + _seg_59()
+    + _seg_60()
+    + _seg_61()
+    + _seg_62()
+    + _seg_63()
+    + _seg_64()
+    + _seg_65()
+    + _seg_66()
+    + _seg_67()
+    + _seg_68()
+    + _seg_69()
+    + _seg_70()
+    + _seg_71()
+    + _seg_72()
+    + _seg_73()
+    + _seg_74()
+    + _seg_75()
+    + _seg_76()
+    + _seg_77()
+    + _seg_78()
+)
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/idna/uts46data.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/idna/uts46data.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..e7e7eac5d605cf384216982963833be37827ef0b
GIT binary patch
literal 296556
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%0A<
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%0AhhsZDs&S
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
JV#vzu4*-BKq@4f&

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/ipaddress.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/ipaddress.py
new file mode 100644
index 0000000..f2d0766
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/ipaddress.py
@@ -0,0 +1,2419 @@
+# Copyright 2007 Google Inc.
+#  Licensed to PSF under a Contributor Agreement.
+
+"""A fast, lightweight IPv4/IPv6 manipulation library in Python.
+
+This library is used to create/poke/manipulate IPv4 and IPv6 addresses
+and networks.
+
+"""
+
+from __future__ import unicode_literals
+
+
+import itertools
+import struct
+
+__version__ = '1.0.22'
+
+# Compatibility functions
+_compat_int_types = (int,)
+try:
+    _compat_int_types = (int, long)
+except NameError:
+    pass
+try:
+    _compat_str = unicode
+except NameError:
+    _compat_str = str
+    assert bytes != str
+if b'\0'[0] == 0:  # Python 3 semantics
+    def _compat_bytes_to_byte_vals(byt):
+        return byt
+else:
+    def _compat_bytes_to_byte_vals(byt):
+        return [struct.unpack(b'!B', b)[0] for b in byt]
+try:
+    _compat_int_from_byte_vals = int.from_bytes
+except AttributeError:
+    def _compat_int_from_byte_vals(bytvals, endianess):
+        assert endianess == 'big'
+        res = 0
+        for bv in bytvals:
+            assert isinstance(bv, _compat_int_types)
+            res = (res << 8) + bv
+        return res
+
+
+def _compat_to_bytes(intval, length, endianess):
+    assert isinstance(intval, _compat_int_types)
+    assert endianess == 'big'
+    if length == 4:
+        if intval < 0 or intval >= 2 ** 32:
+            raise struct.error("integer out of range for 'I' format code")
+        return struct.pack(b'!I', intval)
+    elif length == 16:
+        if intval < 0 or intval >= 2 ** 128:
+            raise struct.error("integer out of range for 'QQ' format code")
+        return struct.pack(b'!QQ', intval >> 64, intval & 0xffffffffffffffff)
+    else:
+        raise NotImplementedError()
+
+
+if hasattr(int, 'bit_length'):
+    # Not int.bit_length , since that won't work in 2.7 where long exists
+    def _compat_bit_length(i):
+        return i.bit_length()
+else:
+    def _compat_bit_length(i):
+        for res in itertools.count():
+            if i >> res == 0:
+                return res
+
+
+def _compat_range(start, end, step=1):
+    assert step > 0
+    i = start
+    while i < end:
+        yield i
+        i += step
+
+
+class _TotalOrderingMixin(object):
+    __slots__ = ()
+
+    # Helper that derives the other comparison operations from
+    # __lt__ and __eq__
+    # We avoid functools.total_ordering because it doesn't handle
+    # NotImplemented correctly yet (http://bugs.python.org/issue10042)
+    def __eq__(self, other):
+        raise NotImplementedError
+
+    def __ne__(self, other):
+        equal = self.__eq__(other)
+        if equal is NotImplemented:
+            return NotImplemented
+        return not equal
+
+    def __lt__(self, other):
+        raise NotImplementedError
+
+    def __le__(self, other):
+        less = self.__lt__(other)
+        if less is NotImplemented or not less:
+            return self.__eq__(other)
+        return less
+
+    def __gt__(self, other):
+        less = self.__lt__(other)
+        if less is NotImplemented:
+            return NotImplemented
+        equal = self.__eq__(other)
+        if equal is NotImplemented:
+            return NotImplemented
+        return not (less or equal)
+
+    def __ge__(self, other):
+        less = self.__lt__(other)
+        if less is NotImplemented:
+            return NotImplemented
+        return not less
+
+
+IPV4LENGTH = 32
+IPV6LENGTH = 128
+
+
+class AddressValueError(ValueError):
+    """A Value Error related to the address."""
+
+
+class NetmaskValueError(ValueError):
+    """A Value Error related to the netmask."""
+
+
+def ip_address(address):
+    """Take an IP string/int and return an object of the correct type.
+
+    Args:
+        address: A string or integer, the IP address.  Either IPv4 or
+          IPv6 addresses may be supplied; integers less than 2**32 will
+          be considered to be IPv4 by default.
+
+    Returns:
+        An IPv4Address or IPv6Address object.
+
+    Raises:
+        ValueError: if the *address* passed isn't either a v4 or a v6
+          address
+
+    """
+    try:
+        return IPv4Address(address)
+    except (AddressValueError, NetmaskValueError):
+        pass
+
+    try:
+        return IPv6Address(address)
+    except (AddressValueError, NetmaskValueError):
+        pass
+
+    if isinstance(address, bytes):
+        raise AddressValueError(
+            '%r does not appear to be an IPv4 or IPv6 address. '
+            'Did you pass in a bytes (str in Python 2) instead of'
+            ' a unicode object?' % address)
+
+    raise ValueError('%r does not appear to be an IPv4 or IPv6 address' %
+                     address)
+
+
+def ip_network(address, strict=True):
+    """Take an IP string/int and return an object of the correct type.
+
+    Args:
+        address: A string or integer, the IP network.  Either IPv4 or
+          IPv6 networks may be supplied; integers less than 2**32 will
+          be considered to be IPv4 by default.
+
+    Returns:
+        An IPv4Network or IPv6Network object.
+
+    Raises:
+        ValueError: if the string passed isn't either a v4 or a v6
+          address. Or if the network has host bits set.
+
+    """
+    try:
+        return IPv4Network(address, strict)
+    except (AddressValueError, NetmaskValueError):
+        pass
+
+    try:
+        return IPv6Network(address, strict)
+    except (AddressValueError, NetmaskValueError):
+        pass
+
+    if isinstance(address, bytes):
+        raise AddressValueError(
+            '%r does not appear to be an IPv4 or IPv6 network. '
+            'Did you pass in a bytes (str in Python 2) instead of'
+            ' a unicode object?' % address)
+
+    raise ValueError('%r does not appear to be an IPv4 or IPv6 network' %
+                     address)
+
+
+def ip_interface(address):
+    """Take an IP string/int and return an object of the correct type.
+
+    Args:
+        address: A string or integer, the IP address.  Either IPv4 or
+          IPv6 addresses may be supplied; integers less than 2**32 will
+          be considered to be IPv4 by default.
+
+    Returns:
+        An IPv4Interface or IPv6Interface object.
+
+    Raises:
+        ValueError: if the string passed isn't either a v4 or a v6
+          address.
+
+    Notes:
+        The IPv?Interface classes describe an Address on a particular
+        Network, so they're basically a combination of both the Address
+        and Network classes.
+
+    """
+    try:
+        return IPv4Interface(address)
+    except (AddressValueError, NetmaskValueError):
+        pass
+
+    try:
+        return IPv6Interface(address)
+    except (AddressValueError, NetmaskValueError):
+        pass
+
+    raise ValueError('%r does not appear to be an IPv4 or IPv6 interface' %
+                     address)
+
+
+def v4_int_to_packed(address):
+    """Represent an address as 4 packed bytes in network (big-endian) order.
+
+    Args:
+        address: An integer representation of an IPv4 IP address.
+
+    Returns:
+        The integer address packed as 4 bytes in network (big-endian) order.
+
+    Raises:
+        ValueError: If the integer is negative or too large to be an
+          IPv4 IP address.
+
+    """
+    try:
+        return _compat_to_bytes(address, 4, 'big')
+    except (struct.error, OverflowError):
+        raise ValueError("Address negative or too large for IPv4")
+
+
+def v6_int_to_packed(address):
+    """Represent an address as 16 packed bytes in network (big-endian) order.
+
+    Args:
+        address: An integer representation of an IPv6 IP address.
+
+    Returns:
+        The integer address packed as 16 bytes in network (big-endian) order.
+
+    """
+    try:
+        return _compat_to_bytes(address, 16, 'big')
+    except (struct.error, OverflowError):
+        raise ValueError("Address negative or too large for IPv6")
+
+
+def _split_optional_netmask(address):
+    """Helper to split the netmask and raise AddressValueError if needed"""
+    addr = _compat_str(address).split('/')
+    if len(addr) > 2:
+        raise AddressValueError("Only one '/' permitted in %r" % address)
+    return addr
+
+
+def _find_address_range(addresses):
+    """Find a sequence of sorted deduplicated IPv#Address.
+
+    Args:
+        addresses: a list of IPv#Address objects.
+
+    Yields:
+        A tuple containing the first and last IP addresses in the sequence.
+
+    """
+    it = iter(addresses)
+    first = last = next(it)
+    for ip in it:
+        if ip._ip != last._ip + 1:
+            yield first, last
+            first = ip
+        last = ip
+    yield first, last
+
+
+def _count_righthand_zero_bits(number, bits):
+    """Count the number of zero bits on the right hand side.
+
+    Args:
+        number: an integer.
+        bits: maximum number of bits to count.
+
+    Returns:
+        The number of zero bits on the right hand side of the number.
+
+    """
+    if number == 0:
+        return bits
+    return min(bits, _compat_bit_length(~number & (number - 1)))
+
+
+def summarize_address_range(first, last):
+    """Summarize a network range given the first and last IP addresses.
+
+    Example:
+        >>> list(summarize_address_range(IPv4Address('192.0.2.0'),
+        ...                              IPv4Address('192.0.2.130')))
+        ...                                #doctest: +NORMALIZE_WHITESPACE
+        [IPv4Network('192.0.2.0/25'), IPv4Network('192.0.2.128/31'),
+         IPv4Network('192.0.2.130/32')]
+
+    Args:
+        first: the first IPv4Address or IPv6Address in the range.
+        last: the last IPv4Address or IPv6Address in the range.
+
+    Returns:
+        An iterator of the summarized IPv(4|6) network objects.
+
+    Raise:
+        TypeError:
+            If the first and last objects are not IP addresses.
+            If the first and last objects are not the same version.
+        ValueError:
+            If the last object is not greater than the first.
+            If the version of the first address is not 4 or 6.
+
+    """
+    if (not (isinstance(first, _BaseAddress) and
+             isinstance(last, _BaseAddress))):
+        raise TypeError('first and last must be IP addresses, not networks')
+    if first.version != last.version:
+        raise TypeError("%s and %s are not of the same version" % (
+                        first, last))
+    if first > last:
+        raise ValueError('last IP address must be greater than first')
+
+    if first.version == 4:
+        ip = IPv4Network
+    elif first.version == 6:
+        ip = IPv6Network
+    else:
+        raise ValueError('unknown IP version')
+
+    ip_bits = first._max_prefixlen
+    first_int = first._ip
+    last_int = last._ip
+    while first_int <= last_int:
+        nbits = min(_count_righthand_zero_bits(first_int, ip_bits),
+                    _compat_bit_length(last_int - first_int + 1) - 1)
+        net = ip((first_int, ip_bits - nbits))
+        yield net
+        first_int += 1 << nbits
+        if first_int - 1 == ip._ALL_ONES:
+            break
+
+
+def _collapse_addresses_internal(addresses):
+    """Loops through the addresses, collapsing concurrent netblocks.
+
+    Example:
+
+        ip1 = IPv4Network('192.0.2.0/26')
+        ip2 = IPv4Network('192.0.2.64/26')
+        ip3 = IPv4Network('192.0.2.128/26')
+        ip4 = IPv4Network('192.0.2.192/26')
+
+        _collapse_addresses_internal([ip1, ip2, ip3, ip4]) ->
+          [IPv4Network('192.0.2.0/24')]
+
+        This shouldn't be called directly; it is called via
+          collapse_addresses([]).
+
+    Args:
+        addresses: A list of IPv4Network's or IPv6Network's
+
+    Returns:
+        A list of IPv4Network's or IPv6Network's depending on what we were
+        passed.
+
+    """
+    # First merge
+    to_merge = list(addresses)
+    subnets = {}
+    while to_merge:
+        net = to_merge.pop()
+        supernet = net.supernet()
+        existing = subnets.get(supernet)
+        if existing is None:
+            subnets[supernet] = net
+        elif existing != net:
+            # Merge consecutive subnets
+            del subnets[supernet]
+            to_merge.append(supernet)
+    # Then iterate over resulting networks, skipping subsumed subnets
+    last = None
+    for net in sorted(subnets.values()):
+        if last is not None:
+            # Since they are sorted,
+            # last.network_address <= net.network_address is a given.
+            if last.broadcast_address >= net.broadcast_address:
+                continue
+        yield net
+        last = net
+
+
+def collapse_addresses(addresses):
+    """Collapse a list of IP objects.
+
+    Example:
+        collapse_addresses([IPv4Network('192.0.2.0/25'),
+                            IPv4Network('192.0.2.128/25')]) ->
+                           [IPv4Network('192.0.2.0/24')]
+
+    Args:
+        addresses: An iterator of IPv4Network or IPv6Network objects.
+
+    Returns:
+        An iterator of the collapsed IPv(4|6)Network objects.
+
+    Raises:
+        TypeError: If passed a list of mixed version objects.
+
+    """
+    addrs = []
+    ips = []
+    nets = []
+
+    # split IP addresses and networks
+    for ip in addresses:
+        if isinstance(ip, _BaseAddress):
+            if ips and ips[-1]._version != ip._version:
+                raise TypeError("%s and %s are not of the same version" % (
+                                ip, ips[-1]))
+            ips.append(ip)
+        elif ip._prefixlen == ip._max_prefixlen:
+            if ips and ips[-1]._version != ip._version:
+                raise TypeError("%s and %s are not of the same version" % (
+                                ip, ips[-1]))
+            try:
+                ips.append(ip.ip)
+            except AttributeError:
+                ips.append(ip.network_address)
+        else:
+            if nets and nets[-1]._version != ip._version:
+                raise TypeError("%s and %s are not of the same version" % (
+                                ip, nets[-1]))
+            nets.append(ip)
+
+    # sort and dedup
+    ips = sorted(set(ips))
+
+    # find consecutive address ranges in the sorted sequence and summarize them
+    if ips:
+        for first, last in _find_address_range(ips):
+            addrs.extend(summarize_address_range(first, last))
+
+    return _collapse_addresses_internal(addrs + nets)
+
+
+def get_mixed_type_key(obj):
+    """Return a key suitable for sorting between networks and addresses.
+
+    Address and Network objects are not sortable by default; they're
+    fundamentally different so the expression
+
+        IPv4Address('192.0.2.0') <= IPv4Network('192.0.2.0/24')
+
+    doesn't make any sense.  There are some times however, where you may wish
+    to have ipaddress sort these for you anyway. If you need to do this, you
+    can use this function as the key= argument to sorted().
+
+    Args:
+      obj: either a Network or Address object.
+    Returns:
+      appropriate key.
+
+    """
+    if isinstance(obj, _BaseNetwork):
+        return obj._get_networks_key()
+    elif isinstance(obj, _BaseAddress):
+        return obj._get_address_key()
+    return NotImplemented
+
+
+class _IPAddressBase(_TotalOrderingMixin):
+
+    """The mother class."""
+
+    __slots__ = ()
+
+    @property
+    def exploded(self):
+        """Return the longhand version of the IP address as a string."""
+        return self._explode_shorthand_ip_string()
+
+    @property
+    def compressed(self):
+        """Return the shorthand version of the IP address as a string."""
+        return _compat_str(self)
+
+    @property
+    def reverse_pointer(self):
+        """The name of the reverse DNS pointer for the IP address, e.g.:
+            >>> ipaddress.ip_address("127.0.0.1").reverse_pointer
+            '1.0.0.127.in-addr.arpa'
+            >>> ipaddress.ip_address("2001:db8::1").reverse_pointer
+            '1.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.8.b.d.0.1.0.0.2.ip6.arpa'
+
+        """
+        return self._reverse_pointer()
+
+    @property
+    def version(self):
+        msg = '%200s has no version specified' % (type(self),)
+        raise NotImplementedError(msg)
+
+    def _check_int_address(self, address):
+        if address < 0:
+            msg = "%d (< 0) is not permitted as an IPv%d address"
+            raise AddressValueError(msg % (address, self._version))
+        if address > self._ALL_ONES:
+            msg = "%d (>= 2**%d) is not permitted as an IPv%d address"
+            raise AddressValueError(msg % (address, self._max_prefixlen,
+                                           self._version))
+
+    def _check_packed_address(self, address, expected_len):
+        address_len = len(address)
+        if address_len != expected_len:
+            msg = (
+                '%r (len %d != %d) is not permitted as an IPv%d address. '
+                'Did you pass in a bytes (str in Python 2) instead of'
+                ' a unicode object?')
+            raise AddressValueError(msg % (address, address_len,
+                                           expected_len, self._version))
+
+    @classmethod
+    def _ip_int_from_prefix(cls, prefixlen):
+        """Turn the prefix length into a bitwise netmask
+
+        Args:
+            prefixlen: An integer, the prefix length.
+
+        Returns:
+            An integer.
+
+        """
+        return cls._ALL_ONES ^ (cls._ALL_ONES >> prefixlen)
+
+    @classmethod
+    def _prefix_from_ip_int(cls, ip_int):
+        """Return prefix length from the bitwise netmask.
+
+        Args:
+            ip_int: An integer, the netmask in expanded bitwise format
+
+        Returns:
+            An integer, the prefix length.
+
+        Raises:
+            ValueError: If the input intermingles zeroes & ones
+        """
+        trailing_zeroes = _count_righthand_zero_bits(ip_int,
+                                                     cls._max_prefixlen)
+        prefixlen = cls._max_prefixlen - trailing_zeroes
+        leading_ones = ip_int >> trailing_zeroes
+        all_ones = (1 << prefixlen) - 1
+        if leading_ones != all_ones:
+            byteslen = cls._max_prefixlen // 8
+            details = _compat_to_bytes(ip_int, byteslen, 'big')
+            msg = 'Netmask pattern %r mixes zeroes & ones'
+            raise ValueError(msg % details)
+        return prefixlen
+
+    @classmethod
+    def _report_invalid_netmask(cls, netmask_str):
+        msg = '%r is not a valid netmask' % netmask_str
+        raise NetmaskValueError(msg)
+
+    @classmethod
+    def _prefix_from_prefix_string(cls, prefixlen_str):
+        """Return prefix length from a numeric string
+
+        Args:
+            prefixlen_str: The string to be converted
+
+        Returns:
+            An integer, the prefix length.
+
+        Raises:
+            NetmaskValueError: If the input is not a valid netmask
+        """
+        # int allows a leading +/- as well as surrounding whitespace,
+        # so we ensure that isn't the case
+        if not _BaseV4._DECIMAL_DIGITS.issuperset(prefixlen_str):
+            cls._report_invalid_netmask(prefixlen_str)
+        try:
+            prefixlen = int(prefixlen_str)
+        except ValueError:
+            cls._report_invalid_netmask(prefixlen_str)
+        if not (0 <= prefixlen <= cls._max_prefixlen):
+            cls._report_invalid_netmask(prefixlen_str)
+        return prefixlen
+
+    @classmethod
+    def _prefix_from_ip_string(cls, ip_str):
+        """Turn a netmask/hostmask string into a prefix length
+
+        Args:
+            ip_str: The netmask/hostmask to be converted
+
+        Returns:
+            An integer, the prefix length.
+
+        Raises:
+            NetmaskValueError: If the input is not a valid netmask/hostmask
+        """
+        # Parse the netmask/hostmask like an IP address.
+        try:
+            ip_int = cls._ip_int_from_string(ip_str)
+        except AddressValueError:
+            cls._report_invalid_netmask(ip_str)
+
+        # Try matching a netmask (this would be /1*0*/ as a bitwise regexp).
+        # Note that the two ambiguous cases (all-ones and all-zeroes) are
+        # treated as netmasks.
+        try:
+            return cls._prefix_from_ip_int(ip_int)
+        except ValueError:
+            pass
+
+        # Invert the bits, and try matching a /0+1+/ hostmask instead.
+        ip_int ^= cls._ALL_ONES
+        try:
+            return cls._prefix_from_ip_int(ip_int)
+        except ValueError:
+            cls._report_invalid_netmask(ip_str)
+
+    def __reduce__(self):
+        return self.__class__, (_compat_str(self),)
+
+
+class _BaseAddress(_IPAddressBase):
+
+    """A generic IP object.
+
+    This IP class contains the version independent methods which are
+    used by single IP addresses.
+    """
+
+    __slots__ = ()
+
+    def __int__(self):
+        return self._ip
+
+    def __eq__(self, other):
+        try:
+            return (self._ip == other._ip and
+                    self._version == other._version)
+        except AttributeError:
+            return NotImplemented
+
+    def __lt__(self, other):
+        if not isinstance(other, _IPAddressBase):
+            return NotImplemented
+        if not isinstance(other, _BaseAddress):
+            raise TypeError('%s and %s are not of the same type' % (
+                self, other))
+        if self._version != other._version:
+            raise TypeError('%s and %s are not of the same version' % (
+                self, other))
+        if self._ip != other._ip:
+            return self._ip < other._ip
+        return False
+
+    # Shorthand for Integer addition and subtraction. This is not
+    # meant to ever support addition/subtraction of addresses.
+    def __add__(self, other):
+        if not isinstance(other, _compat_int_types):
+            return NotImplemented
+        return self.__class__(int(self) + other)
+
+    def __sub__(self, other):
+        if not isinstance(other, _compat_int_types):
+            return NotImplemented
+        return self.__class__(int(self) - other)
+
+    def __repr__(self):
+        return '%s(%r)' % (self.__class__.__name__, _compat_str(self))
+
+    def __str__(self):
+        return _compat_str(self._string_from_ip_int(self._ip))
+
+    def __hash__(self):
+        return hash(hex(int(self._ip)))
+
+    def _get_address_key(self):
+        return (self._version, self)
+
+    def __reduce__(self):
+        return self.__class__, (self._ip,)
+
+
+class _BaseNetwork(_IPAddressBase):
+
+    """A generic IP network object.
+
+    This IP class contains the version independent methods which are
+    used by networks.
+
+    """
+    def __init__(self, address):
+        self._cache = {}
+
+    def __repr__(self):
+        return '%s(%r)' % (self.__class__.__name__, _compat_str(self))
+
+    def __str__(self):
+        return '%s/%d' % (self.network_address, self.prefixlen)
+
+    def hosts(self):
+        """Generate Iterator over usable hosts in a network.
+
+        This is like __iter__ except it doesn't return the network
+        or broadcast addresses.
+
+        """
+        network = int(self.network_address)
+        broadcast = int(self.broadcast_address)
+        for x in _compat_range(network + 1, broadcast):
+            yield self._address_class(x)
+
+    def __iter__(self):
+        network = int(self.network_address)
+        broadcast = int(self.broadcast_address)
+        for x in _compat_range(network, broadcast + 1):
+            yield self._address_class(x)
+
+    def __getitem__(self, n):
+        network = int(self.network_address)
+        broadcast = int(self.broadcast_address)
+        if n >= 0:
+            if network + n > broadcast:
+                raise IndexError('address out of range')
+            return self._address_class(network + n)
+        else:
+            n += 1
+            if broadcast + n < network:
+                raise IndexError('address out of range')
+            return self._address_class(broadcast + n)
+
+    def __lt__(self, other):
+        if not isinstance(other, _IPAddressBase):
+            return NotImplemented
+        if not isinstance(other, _BaseNetwork):
+            raise TypeError('%s and %s are not of the same type' % (
+                            self, other))
+        if self._version != other._version:
+            raise TypeError('%s and %s are not of the same version' % (
+                            self, other))
+        if self.network_address != other.network_address:
+            return self.network_address < other.network_address
+        if self.netmask != other.netmask:
+            return self.netmask < other.netmask
+        return False
+
+    def __eq__(self, other):
+        try:
+            return (self._version == other._version and
+                    self.network_address == other.network_address and
+                    int(self.netmask) == int(other.netmask))
+        except AttributeError:
+            return NotImplemented
+
+    def __hash__(self):
+        return hash(int(self.network_address) ^ int(self.netmask))
+
+    def __contains__(self, other):
+        # always false if one is v4 and the other is v6.
+        if self._version != other._version:
+            return False
+        # dealing with another network.
+        if isinstance(other, _BaseNetwork):
+            return False
+        # dealing with another address
+        else:
+            # address
+            return (int(self.network_address) <= int(other._ip) <=
+                    int(self.broadcast_address))
+
+    def overlaps(self, other):
+        """Tell if self is partly contained in other."""
+        return self.network_address in other or (
+            self.broadcast_address in other or (
+                other.network_address in self or (
+                    other.broadcast_address in self)))
+
+    @property
+    def broadcast_address(self):
+        x = self._cache.get('broadcast_address')
+        if x is None:
+            x = self._address_class(int(self.network_address) |
+                                    int(self.hostmask))
+            self._cache['broadcast_address'] = x
+        return x
+
+    @property
+    def hostmask(self):
+        x = self._cache.get('hostmask')
+        if x is None:
+            x = self._address_class(int(self.netmask) ^ self._ALL_ONES)
+            self._cache['hostmask'] = x
+        return x
+
+    @property
+    def with_prefixlen(self):
+        return '%s/%d' % (self.network_address, self._prefixlen)
+
+    @property
+    def with_netmask(self):
+        return '%s/%s' % (self.network_address, self.netmask)
+
+    @property
+    def with_hostmask(self):
+        return '%s/%s' % (self.network_address, self.hostmask)
+
+    @property
+    def num_addresses(self):
+        """Number of hosts in the current subnet."""
+        return int(self.broadcast_address) - int(self.network_address) + 1
+
+    @property
+    def _address_class(self):
+        # Returning bare address objects (rather than interfaces) allows for
+        # more consistent behaviour across the network address, broadcast
+        # address and individual host addresses.
+        msg = '%200s has no associated address class' % (type(self),)
+        raise NotImplementedError(msg)
+
+    @property
+    def prefixlen(self):
+        return self._prefixlen
+
+    def address_exclude(self, other):
+        """Remove an address from a larger block.
+
+        For example:
+
+            addr1 = ip_network('192.0.2.0/28')
+            addr2 = ip_network('192.0.2.1/32')
+            list(addr1.address_exclude(addr2)) =
+                [IPv4Network('192.0.2.0/32'), IPv4Network('192.0.2.2/31'),
+                 IPv4Network('192.0.2.4/30'), IPv4Network('192.0.2.8/29')]
+
+        or IPv6:
+
+            addr1 = ip_network('2001:db8::1/32')
+            addr2 = ip_network('2001:db8::1/128')
+            list(addr1.address_exclude(addr2)) =
+                [ip_network('2001:db8::1/128'),
+                 ip_network('2001:db8::2/127'),
+                 ip_network('2001:db8::4/126'),
+                 ip_network('2001:db8::8/125'),
+                 ...
+                 ip_network('2001:db8:8000::/33')]
+
+        Args:
+            other: An IPv4Network or IPv6Network object of the same type.
+
+        Returns:
+            An iterator of the IPv(4|6)Network objects which is self
+            minus other.
+
+        Raises:
+            TypeError: If self and other are of differing address
+              versions, or if other is not a network object.
+            ValueError: If other is not completely contained by self.
+
+        """
+        if not self._version == other._version:
+            raise TypeError("%s and %s are not of the same version" % (
+                            self, other))
+
+        if not isinstance(other, _BaseNetwork):
+            raise TypeError("%s is not a network object" % other)
+
+        if not other.subnet_of(self):
+            raise ValueError('%s not contained in %s' % (other, self))
+        if other == self:
+            return
+
+        # Make sure we're comparing the network of other.
+        other = other.__class__('%s/%s' % (other.network_address,
+                                           other.prefixlen))
+
+        s1, s2 = self.subnets()
+        while s1 != other and s2 != other:
+            if other.subnet_of(s1):
+                yield s2
+                s1, s2 = s1.subnets()
+            elif other.subnet_of(s2):
+                yield s1
+                s1, s2 = s2.subnets()
+            else:
+                # If we got here, there's a bug somewhere.
+                raise AssertionError('Error performing exclusion: '
+                                     's1: %s s2: %s other: %s' %
+                                     (s1, s2, other))
+        if s1 == other:
+            yield s2
+        elif s2 == other:
+            yield s1
+        else:
+            # If we got here, there's a bug somewhere.
+            raise AssertionError('Error performing exclusion: '
+                                 's1: %s s2: %s other: %s' %
+                                 (s1, s2, other))
+
+    def compare_networks(self, other):
+        """Compare two IP objects.
+
+        This is only concerned about the comparison of the integer
+        representation of the network addresses.  This means that the
+        host bits aren't considered at all in this method.  If you want
+        to compare host bits, you can easily enough do a
+        'HostA._ip < HostB._ip'
+
+        Args:
+            other: An IP object.
+
+        Returns:
+            If the IP versions of self and other are the same, returns:
+
+            -1 if self < other:
+              eg: IPv4Network('192.0.2.0/25') < IPv4Network('192.0.2.128/25')
+              IPv6Network('2001:db8::1000/124') <
+                  IPv6Network('2001:db8::2000/124')
+            0 if self == other
+              eg: IPv4Network('192.0.2.0/24') == IPv4Network('192.0.2.0/24')
+              IPv6Network('2001:db8::1000/124') ==
+                  IPv6Network('2001:db8::1000/124')
+            1 if self > other
+              eg: IPv4Network('192.0.2.128/25') > IPv4Network('192.0.2.0/25')
+                  IPv6Network('2001:db8::2000/124') >
+                      IPv6Network('2001:db8::1000/124')
+
+          Raises:
+              TypeError if the IP versions are different.
+
+        """
+        # does this need to raise a ValueError?
+        if self._version != other._version:
+            raise TypeError('%s and %s are not of the same type' % (
+                            self, other))
+        # self._version == other._version below here:
+        if self.network_address < other.network_address:
+            return -1
+        if self.network_address > other.network_address:
+            return 1
+        # self.network_address == other.network_address below here:
+        if self.netmask < other.netmask:
+            return -1
+        if self.netmask > other.netmask:
+            return 1
+        return 0
+
+    def _get_networks_key(self):
+        """Network-only key function.
+
+        Returns an object that identifies this address' network and
+        netmask. This function is a suitable "key" argument for sorted()
+        and list.sort().
+
+        """
+        return (self._version, self.network_address, self.netmask)
+
+    def subnets(self, prefixlen_diff=1, new_prefix=None):
+        """The subnets which join to make the current subnet.
+
+        In the case that self contains only one IP
+        (self._prefixlen == 32 for IPv4 or self._prefixlen == 128
+        for IPv6), yield an iterator with just ourself.
+
+        Args:
+            prefixlen_diff: An integer, the amount the prefix length
+              should be increased by. This should not be set if
+              new_prefix is also set.
+            new_prefix: The desired new prefix length. This must be a
+              larger number (smaller prefix) than the existing prefix.
+              This should not be set if prefixlen_diff is also set.
+
+        Returns:
+            An iterator of IPv(4|6) objects.
+
+        Raises:
+            ValueError: The prefixlen_diff is too small or too large.
+                OR
+            prefixlen_diff and new_prefix are both set or new_prefix
+              is a smaller number than the current prefix (smaller
+              number means a larger network)
+
+        """
+        if self._prefixlen == self._max_prefixlen:
+            yield self
+            return
+
+        if new_prefix is not None:
+            if new_prefix < self._prefixlen:
+                raise ValueError('new prefix must be longer')
+            if prefixlen_diff != 1:
+                raise ValueError('cannot set prefixlen_diff and new_prefix')
+            prefixlen_diff = new_prefix - self._prefixlen
+
+        if prefixlen_diff < 0:
+            raise ValueError('prefix length diff must be > 0')
+        new_prefixlen = self._prefixlen + prefixlen_diff
+
+        if new_prefixlen > self._max_prefixlen:
+            raise ValueError(
+                'prefix length diff %d is invalid for netblock %s' % (
+                    new_prefixlen, self))
+
+        start = int(self.network_address)
+        end = int(self.broadcast_address) + 1
+        step = (int(self.hostmask) + 1) >> prefixlen_diff
+        for new_addr in _compat_range(start, end, step):
+            current = self.__class__((new_addr, new_prefixlen))
+            yield current
+
+    def supernet(self, prefixlen_diff=1, new_prefix=None):
+        """The supernet containing the current network.
+
+        Args:
+            prefixlen_diff: An integer, the amount the prefix length of
+              the network should be decreased by.  For example, given a
+              /24 network and a prefixlen_diff of 3, a supernet with a
+              /21 netmask is returned.
+
+        Returns:
+            An IPv4 network object.
+
+        Raises:
+            ValueError: If self.prefixlen - prefixlen_diff < 0. I.e., you have
+              a negative prefix length.
+                OR
+            If prefixlen_diff and new_prefix are both set or new_prefix is a
+              larger number than the current prefix (larger number means a
+              smaller network)
+
+        """
+        if self._prefixlen == 0:
+            return self
+
+        if new_prefix is not None:
+            if new_prefix > self._prefixlen:
+                raise ValueError('new prefix must be shorter')
+            if prefixlen_diff != 1:
+                raise ValueError('cannot set prefixlen_diff and new_prefix')
+            prefixlen_diff = self._prefixlen - new_prefix
+
+        new_prefixlen = self.prefixlen - prefixlen_diff
+        if new_prefixlen < 0:
+            raise ValueError(
+                'current prefixlen is %d, cannot have a prefixlen_diff of %d' %
+                (self.prefixlen, prefixlen_diff))
+        return self.__class__((
+            int(self.network_address) & (int(self.netmask) << prefixlen_diff),
+            new_prefixlen))
+
+    @property
+    def is_multicast(self):
+        """Test if the address is reserved for multicast use.
+
+        Returns:
+            A boolean, True if the address is a multicast address.
+            See RFC 2373 2.7 for details.
+
+        """
+        return (self.network_address.is_multicast and
+                self.broadcast_address.is_multicast)
+
+    @staticmethod
+    def _is_subnet_of(a, b):
+        try:
+            # Always false if one is v4 and the other is v6.
+            if a._version != b._version:
+                raise TypeError("%s and %s are not of the same version" (a, b))
+            return (b.network_address <= a.network_address and
+                    b.broadcast_address >= a.broadcast_address)
+        except AttributeError:
+            raise TypeError("Unable to test subnet containment "
+                            "between %s and %s" % (a, b))
+
+    def subnet_of(self, other):
+        """Return True if this network is a subnet of other."""
+        return self._is_subnet_of(self, other)
+
+    def supernet_of(self, other):
+        """Return True if this network is a supernet of other."""
+        return self._is_subnet_of(other, self)
+
+    @property
+    def is_reserved(self):
+        """Test if the address is otherwise IETF reserved.
+
+        Returns:
+            A boolean, True if the address is within one of the
+            reserved IPv6 Network ranges.
+
+        """
+        return (self.network_address.is_reserved and
+                self.broadcast_address.is_reserved)
+
+    @property
+    def is_link_local(self):
+        """Test if the address is reserved for link-local.
+
+        Returns:
+            A boolean, True if the address is reserved per RFC 4291.
+
+        """
+        return (self.network_address.is_link_local and
+                self.broadcast_address.is_link_local)
+
+    @property
+    def is_private(self):
+        """Test if this address is allocated for private networks.
+
+        Returns:
+            A boolean, True if the address is reserved per
+            iana-ipv4-special-registry or iana-ipv6-special-registry.
+
+        """
+        return (self.network_address.is_private and
+                self.broadcast_address.is_private)
+
+    @property
+    def is_global(self):
+        """Test if this address is allocated for public networks.
+
+        Returns:
+            A boolean, True if the address is not reserved per
+            iana-ipv4-special-registry or iana-ipv6-special-registry.
+
+        """
+        return not self.is_private
+
+    @property
+    def is_unspecified(self):
+        """Test if the address is unspecified.
+
+        Returns:
+            A boolean, True if this is the unspecified address as defined in
+            RFC 2373 2.5.2.
+
+        """
+        return (self.network_address.is_unspecified and
+                self.broadcast_address.is_unspecified)
+
+    @property
+    def is_loopback(self):
+        """Test if the address is a loopback address.
+
+        Returns:
+            A boolean, True if the address is a loopback address as defined in
+            RFC 2373 2.5.3.
+
+        """
+        return (self.network_address.is_loopback and
+                self.broadcast_address.is_loopback)
+
+
+class _BaseV4(object):
+
+    """Base IPv4 object.
+
+    The following methods are used by IPv4 objects in both single IP
+    addresses and networks.
+
+    """
+
+    __slots__ = ()
+    _version = 4
+    # Equivalent to 255.255.255.255 or 32 bits of 1's.
+    _ALL_ONES = (2 ** IPV4LENGTH) - 1
+    _DECIMAL_DIGITS = frozenset('0123456789')
+
+    # the valid octets for host and netmasks. only useful for IPv4.
+    _valid_mask_octets = frozenset([255, 254, 252, 248, 240, 224, 192, 128, 0])
+
+    _max_prefixlen = IPV4LENGTH
+    # There are only a handful of valid v4 netmasks, so we cache them all
+    # when constructed (see _make_netmask()).
+    _netmask_cache = {}
+
+    def _explode_shorthand_ip_string(self):
+        return _compat_str(self)
+
+    @classmethod
+    def _make_netmask(cls, arg):
+        """Make a (netmask, prefix_len) tuple from the given argument.
+
+        Argument can be:
+        - an integer (the prefix length)
+        - a string representing the prefix length (e.g. "24")
+        - a string representing the prefix netmask (e.g. "255.255.255.0")
+        """
+        if arg not in cls._netmask_cache:
+            if isinstance(arg, _compat_int_types):
+                prefixlen = arg
+            else:
+                try:
+                    # Check for a netmask in prefix length form
+                    prefixlen = cls._prefix_from_prefix_string(arg)
+                except NetmaskValueError:
+                    # Check for a netmask or hostmask in dotted-quad form.
+                    # This may raise NetmaskValueError.
+                    prefixlen = cls._prefix_from_ip_string(arg)
+            netmask = IPv4Address(cls._ip_int_from_prefix(prefixlen))
+            cls._netmask_cache[arg] = netmask, prefixlen
+        return cls._netmask_cache[arg]
+
+    @classmethod
+    def _ip_int_from_string(cls, ip_str):
+        """Turn the given IP string into an integer for comparison.
+
+        Args:
+            ip_str: A string, the IP ip_str.
+
+        Returns:
+            The IP ip_str as an integer.
+
+        Raises:
+            AddressValueError: if ip_str isn't a valid IPv4 Address.
+
+        """
+        if not ip_str:
+            raise AddressValueError('Address cannot be empty')
+
+        octets = ip_str.split('.')
+        if len(octets) != 4:
+            raise AddressValueError("Expected 4 octets in %r" % ip_str)
+
+        try:
+            return _compat_int_from_byte_vals(
+                map(cls._parse_octet, octets), 'big')
+        except ValueError as exc:
+            raise AddressValueError("%s in %r" % (exc, ip_str))
+
+    @classmethod
+    def _parse_octet(cls, octet_str):
+        """Convert a decimal octet into an integer.
+
+        Args:
+            octet_str: A string, the number to parse.
+
+        Returns:
+            The octet as an integer.
+
+        Raises:
+            ValueError: if the octet isn't strictly a decimal from [0..255].
+
+        """
+        if not octet_str:
+            raise ValueError("Empty octet not permitted")
+        # Whitelist the characters, since int() allows a lot of bizarre stuff.
+        if not cls._DECIMAL_DIGITS.issuperset(octet_str):
+            msg = "Only decimal digits permitted in %r"
+            raise ValueError(msg % octet_str)
+        # We do the length check second, since the invalid character error
+        # is likely to be more informative for the user
+        if len(octet_str) > 3:
+            msg = "At most 3 characters permitted in %r"
+            raise ValueError(msg % octet_str)
+        # Convert to integer (we know digits are legal)
+        octet_int = int(octet_str, 10)
+        # Any octets that look like they *might* be written in octal,
+        # and which don't look exactly the same in both octal and
+        # decimal are rejected as ambiguous
+        if octet_int > 7 and octet_str[0] == '0':
+            msg = "Ambiguous (octal/decimal) value in %r not permitted"
+            raise ValueError(msg % octet_str)
+        if octet_int > 255:
+            raise ValueError("Octet %d (> 255) not permitted" % octet_int)
+        return octet_int
+
+    @classmethod
+    def _string_from_ip_int(cls, ip_int):
+        """Turns a 32-bit integer into dotted decimal notation.
+
+        Args:
+            ip_int: An integer, the IP address.
+
+        Returns:
+            The IP address as a string in dotted decimal notation.
+
+        """
+        return '.'.join(_compat_str(struct.unpack(b'!B', b)[0]
+                                    if isinstance(b, bytes)
+                                    else b)
+                        for b in _compat_to_bytes(ip_int, 4, 'big'))
+
+    def _is_hostmask(self, ip_str):
+        """Test if the IP string is a hostmask (rather than a netmask).
+
+        Args:
+            ip_str: A string, the potential hostmask.
+
+        Returns:
+            A boolean, True if the IP string is a hostmask.
+
+        """
+        bits = ip_str.split('.')
+        try:
+            parts = [x for x in map(int, bits) if x in self._valid_mask_octets]
+        except ValueError:
+            return False
+        if len(parts) != len(bits):
+            return False
+        if parts[0] < parts[-1]:
+            return True
+        return False
+
+    def _reverse_pointer(self):
+        """Return the reverse DNS pointer name for the IPv4 address.
+
+        This implements the method described in RFC1035 3.5.
+
+        """
+        reverse_octets = _compat_str(self).split('.')[::-1]
+        return '.'.join(reverse_octets) + '.in-addr.arpa'
+
+    @property
+    def max_prefixlen(self):
+        return self._max_prefixlen
+
+    @property
+    def version(self):
+        return self._version
+
+
+class IPv4Address(_BaseV4, _BaseAddress):
+
+    """Represent and manipulate single IPv4 Addresses."""
+
+    __slots__ = ('_ip', '__weakref__')
+
+    def __init__(self, address):
+
+        """
+        Args:
+            address: A string or integer representing the IP
+
+              Additionally, an integer can be passed, so
+              IPv4Address('192.0.2.1') == IPv4Address(3221225985).
+              or, more generally
+              IPv4Address(int(IPv4Address('192.0.2.1'))) ==
+                IPv4Address('192.0.2.1')
+
+        Raises:
+            AddressValueError: If ipaddress isn't a valid IPv4 address.
+
+        """
+        # Efficient constructor from integer.
+        if isinstance(address, _compat_int_types):
+            self._check_int_address(address)
+            self._ip = address
+            return
+
+        # Constructing from a packed address
+        if isinstance(address, bytes):
+            self._check_packed_address(address, 4)
+            bvs = _compat_bytes_to_byte_vals(address)
+            self._ip = _compat_int_from_byte_vals(bvs, 'big')
+            return
+
+        # Assume input argument to be string or any object representation
+        # which converts into a formatted IP string.
+        addr_str = _compat_str(address)
+        if '/' in addr_str:
+            raise AddressValueError("Unexpected '/' in %r" % address)
+        self._ip = self._ip_int_from_string(addr_str)
+
+    @property
+    def packed(self):
+        """The binary representation of this address."""
+        return v4_int_to_packed(self._ip)
+
+    @property
+    def is_reserved(self):
+        """Test if the address is otherwise IETF reserved.
+
+         Returns:
+             A boolean, True if the address is within the
+             reserved IPv4 Network range.
+
+        """
+        return self in self._constants._reserved_network
+
+    @property
+    def is_private(self):
+        """Test if this address is allocated for private networks.
+
+        Returns:
+            A boolean, True if the address is reserved per
+            iana-ipv4-special-registry.
+
+        """
+        return any(self in net for net in self._constants._private_networks)
+
+    @property
+    def is_global(self):
+        return (
+            self not in self._constants._public_network and
+            not self.is_private)
+
+    @property
+    def is_multicast(self):
+        """Test if the address is reserved for multicast use.
+
+        Returns:
+            A boolean, True if the address is multicast.
+            See RFC 3171 for details.
+
+        """
+        return self in self._constants._multicast_network
+
+    @property
+    def is_unspecified(self):
+        """Test if the address is unspecified.
+
+        Returns:
+            A boolean, True if this is the unspecified address as defined in
+            RFC 5735 3.
+
+        """
+        return self == self._constants._unspecified_address
+
+    @property
+    def is_loopback(self):
+        """Test if the address is a loopback address.
+
+        Returns:
+            A boolean, True if the address is a loopback per RFC 3330.
+
+        """
+        return self in self._constants._loopback_network
+
+    @property
+    def is_link_local(self):
+        """Test if the address is reserved for link-local.
+
+        Returns:
+            A boolean, True if the address is link-local per RFC 3927.
+
+        """
+        return self in self._constants._linklocal_network
+
+
+class IPv4Interface(IPv4Address):
+
+    def __init__(self, address):
+        if isinstance(address, (bytes, _compat_int_types)):
+            IPv4Address.__init__(self, address)
+            self.network = IPv4Network(self._ip)
+            self._prefixlen = self._max_prefixlen
+            return
+
+        if isinstance(address, tuple):
+            IPv4Address.__init__(self, address[0])
+            if len(address) > 1:
+                self._prefixlen = int(address[1])
+            else:
+                self._prefixlen = self._max_prefixlen
+
+            self.network = IPv4Network(address, strict=False)
+            self.netmask = self.network.netmask
+            self.hostmask = self.network.hostmask
+            return
+
+        addr = _split_optional_netmask(address)
+        IPv4Address.__init__(self, addr[0])
+
+        self.network = IPv4Network(address, strict=False)
+        self._prefixlen = self.network._prefixlen
+
+        self.netmask = self.network.netmask
+        self.hostmask = self.network.hostmask
+
+    def __str__(self):
+        return '%s/%d' % (self._string_from_ip_int(self._ip),
+                          self.network.prefixlen)
+
+    def __eq__(self, other):
+        address_equal = IPv4Address.__eq__(self, other)
+        if not address_equal or address_equal is NotImplemented:
+            return address_equal
+        try:
+            return self.network == other.network
+        except AttributeError:
+            # An interface with an associated network is NOT the
+            # same as an unassociated address. That's why the hash
+            # takes the extra info into account.
+            return False
+
+    def __lt__(self, other):
+        address_less = IPv4Address.__lt__(self, other)
+        if address_less is NotImplemented:
+            return NotImplemented
+        try:
+            return (self.network < other.network or
+                    self.network == other.network and address_less)
+        except AttributeError:
+            # We *do* allow addresses and interfaces to be sorted. The
+            # unassociated address is considered less than all interfaces.
+            return False
+
+    def __hash__(self):
+        return self._ip ^ self._prefixlen ^ int(self.network.network_address)
+
+    __reduce__ = _IPAddressBase.__reduce__
+
+    @property
+    def ip(self):
+        return IPv4Address(self._ip)
+
+    @property
+    def with_prefixlen(self):
+        return '%s/%s' % (self._string_from_ip_int(self._ip),
+                          self._prefixlen)
+
+    @property
+    def with_netmask(self):
+        return '%s/%s' % (self._string_from_ip_int(self._ip),
+                          self.netmask)
+
+    @property
+    def with_hostmask(self):
+        return '%s/%s' % (self._string_from_ip_int(self._ip),
+                          self.hostmask)
+
+
+class IPv4Network(_BaseV4, _BaseNetwork):
+
+    """This class represents and manipulates 32-bit IPv4 network + addresses..
+
+    Attributes: [examples for IPv4Network('192.0.2.0/27')]
+        .network_address: IPv4Address('192.0.2.0')
+        .hostmask: IPv4Address('0.0.0.31')
+        .broadcast_address: IPv4Address('192.0.2.32')
+        .netmask: IPv4Address('255.255.255.224')
+        .prefixlen: 27
+
+    """
+    # Class to use when creating address objects
+    _address_class = IPv4Address
+
+    def __init__(self, address, strict=True):
+
+        """Instantiate a new IPv4 network object.
+
+        Args:
+            address: A string or integer representing the IP [& network].
+              '192.0.2.0/24'
+              '192.0.2.0/255.255.255.0'
+              '192.0.0.2/0.0.0.255'
+              are all functionally the same in IPv4. Similarly,
+              '192.0.2.1'
+              '192.0.2.1/255.255.255.255'
+              '192.0.2.1/32'
+              are also functionally equivalent. That is to say, failing to
+              provide a subnetmask will create an object with a mask of /32.
+
+              If the mask (portion after the / in the argument) is given in
+              dotted quad form, it is treated as a netmask if it starts with a
+              non-zero field (e.g. /255.0.0.0 == /8) and as a hostmask if it
+              starts with a zero field (e.g. 0.255.255.255 == /8), with the
+              single exception of an all-zero mask which is treated as a
+              netmask == /0. If no mask is given, a default of /32 is used.
+
+              Additionally, an integer can be passed, so
+              IPv4Network('192.0.2.1') == IPv4Network(3221225985)
+              or, more generally
+              IPv4Interface(int(IPv4Interface('192.0.2.1'))) ==
+                IPv4Interface('192.0.2.1')
+
+        Raises:
+            AddressValueError: If ipaddress isn't a valid IPv4 address.
+            NetmaskValueError: If the netmask isn't valid for
+              an IPv4 address.
+            ValueError: If strict is True and a network address is not
+              supplied.
+
+        """
+        _BaseNetwork.__init__(self, address)
+
+        # Constructing from a packed address or integer
+        if isinstance(address, (_compat_int_types, bytes)):
+            self.network_address = IPv4Address(address)
+            self.netmask, self._prefixlen = self._make_netmask(
+                self._max_prefixlen)
+            # fixme: address/network test here.
+            return
+
+        if isinstance(address, tuple):
+            if len(address) > 1:
+                arg = address[1]
+            else:
+                # We weren't given an address[1]
+                arg = self._max_prefixlen
+            self.network_address = IPv4Address(address[0])
+            self.netmask, self._prefixlen = self._make_netmask(arg)
+            packed = int(self.network_address)
+            if packed & int(self.netmask) != packed:
+                if strict:
+                    raise ValueError('%s has host bits set' % self)
+                else:
+                    self.network_address = IPv4Address(packed &
+                                                       int(self.netmask))
+            return
+
+        # Assume input argument to be string or any object representation
+        # which converts into a formatted IP prefix string.
+        addr = _split_optional_netmask(address)
+        self.network_address = IPv4Address(self._ip_int_from_string(addr[0]))
+
+        if len(addr) == 2:
+            arg = addr[1]
+        else:
+            arg = self._max_prefixlen
+        self.netmask, self._prefixlen = self._make_netmask(arg)
+
+        if strict:
+            if (IPv4Address(int(self.network_address) & int(self.netmask)) !=
+                    self.network_address):
+                raise ValueError('%s has host bits set' % self)
+        self.network_address = IPv4Address(int(self.network_address) &
+                                           int(self.netmask))
+
+        if self._prefixlen == (self._max_prefixlen - 1):
+            self.hosts = self.__iter__
+
+    @property
+    def is_global(self):
+        """Test if this address is allocated for public networks.
+
+        Returns:
+            A boolean, True if the address is not reserved per
+            iana-ipv4-special-registry.
+
+        """
+        return (not (self.network_address in IPv4Network('100.64.0.0/10') and
+                self.broadcast_address in IPv4Network('100.64.0.0/10')) and
+                not self.is_private)
+
+
+class _IPv4Constants(object):
+
+    _linklocal_network = IPv4Network('169.254.0.0/16')
+
+    _loopback_network = IPv4Network('127.0.0.0/8')
+
+    _multicast_network = IPv4Network('224.0.0.0/4')
+
+    _public_network = IPv4Network('100.64.0.0/10')
+
+    _private_networks = [
+        IPv4Network('0.0.0.0/8'),
+        IPv4Network('10.0.0.0/8'),
+        IPv4Network('127.0.0.0/8'),
+        IPv4Network('169.254.0.0/16'),
+        IPv4Network('172.16.0.0/12'),
+        IPv4Network('192.0.0.0/29'),
+        IPv4Network('192.0.0.170/31'),
+        IPv4Network('192.0.2.0/24'),
+        IPv4Network('192.168.0.0/16'),
+        IPv4Network('198.18.0.0/15'),
+        IPv4Network('198.51.100.0/24'),
+        IPv4Network('203.0.113.0/24'),
+        IPv4Network('240.0.0.0/4'),
+        IPv4Network('255.255.255.255/32'),
+    ]
+
+    _reserved_network = IPv4Network('240.0.0.0/4')
+
+    _unspecified_address = IPv4Address('0.0.0.0')
+
+
+IPv4Address._constants = _IPv4Constants
+
+
+class _BaseV6(object):
+
+    """Base IPv6 object.
+
+    The following methods are used by IPv6 objects in both single IP
+    addresses and networks.
+
+    """
+
+    __slots__ = ()
+    _version = 6
+    _ALL_ONES = (2 ** IPV6LENGTH) - 1
+    _HEXTET_COUNT = 8
+    _HEX_DIGITS = frozenset('0123456789ABCDEFabcdef')
+    _max_prefixlen = IPV6LENGTH
+
+    # There are only a bunch of valid v6 netmasks, so we cache them all
+    # when constructed (see _make_netmask()).
+    _netmask_cache = {}
+
+    @classmethod
+    def _make_netmask(cls, arg):
+        """Make a (netmask, prefix_len) tuple from the given argument.
+
+        Argument can be:
+        - an integer (the prefix length)
+        - a string representing the prefix length (e.g. "24")
+        - a string representing the prefix netmask (e.g. "255.255.255.0")
+        """
+        if arg not in cls._netmask_cache:
+            if isinstance(arg, _compat_int_types):
+                prefixlen = arg
+            else:
+                prefixlen = cls._prefix_from_prefix_string(arg)
+            netmask = IPv6Address(cls._ip_int_from_prefix(prefixlen))
+            cls._netmask_cache[arg] = netmask, prefixlen
+        return cls._netmask_cache[arg]
+
+    @classmethod
+    def _ip_int_from_string(cls, ip_str):
+        """Turn an IPv6 ip_str into an integer.
+
+        Args:
+            ip_str: A string, the IPv6 ip_str.
+
+        Returns:
+            An int, the IPv6 address
+
+        Raises:
+            AddressValueError: if ip_str isn't a valid IPv6 Address.
+
+        """
+        if not ip_str:
+            raise AddressValueError('Address cannot be empty')
+
+        parts = ip_str.split(':')
+
+        # An IPv6 address needs at least 2 colons (3 parts).
+        _min_parts = 3
+        if len(parts) < _min_parts:
+            msg = "At least %d parts expected in %r" % (_min_parts, ip_str)
+            raise AddressValueError(msg)
+
+        # If the address has an IPv4-style suffix, convert it to hexadecimal.
+        if '.' in parts[-1]:
+            try:
+                ipv4_int = IPv4Address(parts.pop())._ip
+            except AddressValueError as exc:
+                raise AddressValueError("%s in %r" % (exc, ip_str))
+            parts.append('%x' % ((ipv4_int >> 16) & 0xFFFF))
+            parts.append('%x' % (ipv4_int & 0xFFFF))
+
+        # An IPv6 address can't have more than 8 colons (9 parts).
+        # The extra colon comes from using the "::" notation for a single
+        # leading or trailing zero part.
+        _max_parts = cls._HEXTET_COUNT + 1
+        if len(parts) > _max_parts:
+            msg = "At most %d colons permitted in %r" % (
+                _max_parts - 1, ip_str)
+            raise AddressValueError(msg)
+
+        # Disregarding the endpoints, find '::' with nothing in between.
+        # This indicates that a run of zeroes has been skipped.
+        skip_index = None
+        for i in _compat_range(1, len(parts) - 1):
+            if not parts[i]:
+                if skip_index is not None:
+                    # Can't have more than one '::'
+                    msg = "At most one '::' permitted in %r" % ip_str
+                    raise AddressValueError(msg)
+                skip_index = i
+
+        # parts_hi is the number of parts to copy from above/before the '::'
+        # parts_lo is the number of parts to copy from below/after the '::'
+        if skip_index is not None:
+            # If we found a '::', then check if it also covers the endpoints.
+            parts_hi = skip_index
+            parts_lo = len(parts) - skip_index - 1
+            if not parts[0]:
+                parts_hi -= 1
+                if parts_hi:
+                    msg = "Leading ':' only permitted as part of '::' in %r"
+                    raise AddressValueError(msg % ip_str)  # ^: requires ^::
+            if not parts[-1]:
+                parts_lo -= 1
+                if parts_lo:
+                    msg = "Trailing ':' only permitted as part of '::' in %r"
+                    raise AddressValueError(msg % ip_str)  # :$ requires ::$
+            parts_skipped = cls._HEXTET_COUNT - (parts_hi + parts_lo)
+            if parts_skipped < 1:
+                msg = "Expected at most %d other parts with '::' in %r"
+                raise AddressValueError(msg % (cls._HEXTET_COUNT - 1, ip_str))
+        else:
+            # Otherwise, allocate the entire address to parts_hi.  The
+            # endpoints could still be empty, but _parse_hextet() will check
+            # for that.
+            if len(parts) != cls._HEXTET_COUNT:
+                msg = "Exactly %d parts expected without '::' in %r"
+                raise AddressValueError(msg % (cls._HEXTET_COUNT, ip_str))
+            if not parts[0]:
+                msg = "Leading ':' only permitted as part of '::' in %r"
+                raise AddressValueError(msg % ip_str)  # ^: requires ^::
+            if not parts[-1]:
+                msg = "Trailing ':' only permitted as part of '::' in %r"
+                raise AddressValueError(msg % ip_str)  # :$ requires ::$
+            parts_hi = len(parts)
+            parts_lo = 0
+            parts_skipped = 0
+
+        try:
+            # Now, parse the hextets into a 128-bit integer.
+            ip_int = 0
+            for i in range(parts_hi):
+                ip_int <<= 16
+                ip_int |= cls._parse_hextet(parts[i])
+            ip_int <<= 16 * parts_skipped
+            for i in range(-parts_lo, 0):
+                ip_int <<= 16
+                ip_int |= cls._parse_hextet(parts[i])
+            return ip_int
+        except ValueError as exc:
+            raise AddressValueError("%s in %r" % (exc, ip_str))
+
+    @classmethod
+    def _parse_hextet(cls, hextet_str):
+        """Convert an IPv6 hextet string into an integer.
+
+        Args:
+            hextet_str: A string, the number to parse.
+
+        Returns:
+            The hextet as an integer.
+
+        Raises:
+            ValueError: if the input isn't strictly a hex number from
+              [0..FFFF].
+
+        """
+        # Whitelist the characters, since int() allows a lot of bizarre stuff.
+        if not cls._HEX_DIGITS.issuperset(hextet_str):
+            raise ValueError("Only hex digits permitted in %r" % hextet_str)
+        # We do the length check second, since the invalid character error
+        # is likely to be more informative for the user
+        if len(hextet_str) > 4:
+            msg = "At most 4 characters permitted in %r"
+            raise ValueError(msg % hextet_str)
+        # Length check means we can skip checking the integer value
+        return int(hextet_str, 16)
+
+    @classmethod
+    def _compress_hextets(cls, hextets):
+        """Compresses a list of hextets.
+
+        Compresses a list of strings, replacing the longest continuous
+        sequence of "0" in the list with "" and adding empty strings at
+        the beginning or at the end of the string such that subsequently
+        calling ":".join(hextets) will produce the compressed version of
+        the IPv6 address.
+
+        Args:
+            hextets: A list of strings, the hextets to compress.
+
+        Returns:
+            A list of strings.
+
+        """
+        best_doublecolon_start = -1
+        best_doublecolon_len = 0
+        doublecolon_start = -1
+        doublecolon_len = 0
+        for index, hextet in enumerate(hextets):
+            if hextet == '0':
+                doublecolon_len += 1
+                if doublecolon_start == -1:
+                    # Start of a sequence of zeros.
+                    doublecolon_start = index
+                if doublecolon_len > best_doublecolon_len:
+                    # This is the longest sequence of zeros so far.
+                    best_doublecolon_len = doublecolon_len
+                    best_doublecolon_start = doublecolon_start
+            else:
+                doublecolon_len = 0
+                doublecolon_start = -1
+
+        if best_doublecolon_len > 1:
+            best_doublecolon_end = (best_doublecolon_start +
+                                    best_doublecolon_len)
+            # For zeros at the end of the address.
+            if best_doublecolon_end == len(hextets):
+                hextets += ['']
+            hextets[best_doublecolon_start:best_doublecolon_end] = ['']
+            # For zeros at the beginning of the address.
+            if best_doublecolon_start == 0:
+                hextets = [''] + hextets
+
+        return hextets
+
+    @classmethod
+    def _string_from_ip_int(cls, ip_int=None):
+        """Turns a 128-bit integer into hexadecimal notation.
+
+        Args:
+            ip_int: An integer, the IP address.
+
+        Returns:
+            A string, the hexadecimal representation of the address.
+
+        Raises:
+            ValueError: The address is bigger than 128 bits of all ones.
+
+        """
+        if ip_int is None:
+            ip_int = int(cls._ip)
+
+        if ip_int > cls._ALL_ONES:
+            raise ValueError('IPv6 address is too large')
+
+        hex_str = '%032x' % ip_int
+        hextets = ['%x' % int(hex_str[x:x + 4], 16) for x in range(0, 32, 4)]
+
+        hextets = cls._compress_hextets(hextets)
+        return ':'.join(hextets)
+
+    def _explode_shorthand_ip_string(self):
+        """Expand a shortened IPv6 address.
+
+        Args:
+            ip_str: A string, the IPv6 address.
+
+        Returns:
+            A string, the expanded IPv6 address.
+
+        """
+        if isinstance(self, IPv6Network):
+            ip_str = _compat_str(self.network_address)
+        elif isinstance(self, IPv6Interface):
+            ip_str = _compat_str(self.ip)
+        else:
+            ip_str = _compat_str(self)
+
+        ip_int = self._ip_int_from_string(ip_str)
+        hex_str = '%032x' % ip_int
+        parts = [hex_str[x:x + 4] for x in range(0, 32, 4)]
+        if isinstance(self, (_BaseNetwork, IPv6Interface)):
+            return '%s/%d' % (':'.join(parts), self._prefixlen)
+        return ':'.join(parts)
+
+    def _reverse_pointer(self):
+        """Return the reverse DNS pointer name for the IPv6 address.
+
+        This implements the method described in RFC3596 2.5.
+
+        """
+        reverse_chars = self.exploded[::-1].replace(':', '')
+        return '.'.join(reverse_chars) + '.ip6.arpa'
+
+    @property
+    def max_prefixlen(self):
+        return self._max_prefixlen
+
+    @property
+    def version(self):
+        return self._version
+
+
+class IPv6Address(_BaseV6, _BaseAddress):
+
+    """Represent and manipulate single IPv6 Addresses."""
+
+    __slots__ = ('_ip', '__weakref__')
+
+    def __init__(self, address):
+        """Instantiate a new IPv6 address object.
+
+        Args:
+            address: A string or integer representing the IP
+
+              Additionally, an integer can be passed, so
+              IPv6Address('2001:db8::') ==
+                IPv6Address(42540766411282592856903984951653826560)
+              or, more generally
+              IPv6Address(int(IPv6Address('2001:db8::'))) ==
+                IPv6Address('2001:db8::')
+
+        Raises:
+            AddressValueError: If address isn't a valid IPv6 address.
+
+        """
+        # Efficient constructor from integer.
+        if isinstance(address, _compat_int_types):
+            self._check_int_address(address)
+            self._ip = address
+            return
+
+        # Constructing from a packed address
+        if isinstance(address, bytes):
+            self._check_packed_address(address, 16)
+            bvs = _compat_bytes_to_byte_vals(address)
+            self._ip = _compat_int_from_byte_vals(bvs, 'big')
+            return
+
+        # Assume input argument to be string or any object representation
+        # which converts into a formatted IP string.
+        addr_str = _compat_str(address)
+        if '/' in addr_str:
+            raise AddressValueError("Unexpected '/' in %r" % address)
+        self._ip = self._ip_int_from_string(addr_str)
+
+    @property
+    def packed(self):
+        """The binary representation of this address."""
+        return v6_int_to_packed(self._ip)
+
+    @property
+    def is_multicast(self):
+        """Test if the address is reserved for multicast use.
+
+        Returns:
+            A boolean, True if the address is a multicast address.
+            See RFC 2373 2.7 for details.
+
+        """
+        return self in self._constants._multicast_network
+
+    @property
+    def is_reserved(self):
+        """Test if the address is otherwise IETF reserved.
+
+        Returns:
+            A boolean, True if the address is within one of the
+            reserved IPv6 Network ranges.
+
+        """
+        return any(self in x for x in self._constants._reserved_networks)
+
+    @property
+    def is_link_local(self):
+        """Test if the address is reserved for link-local.
+
+        Returns:
+            A boolean, True if the address is reserved per RFC 4291.
+
+        """
+        return self in self._constants._linklocal_network
+
+    @property
+    def is_site_local(self):
+        """Test if the address is reserved for site-local.
+
+        Note that the site-local address space has been deprecated by RFC 3879.
+        Use is_private to test if this address is in the space of unique local
+        addresses as defined by RFC 4193.
+
+        Returns:
+            A boolean, True if the address is reserved per RFC 3513 2.5.6.
+
+        """
+        return self in self._constants._sitelocal_network
+
+    @property
+    def is_private(self):
+        """Test if this address is allocated for private networks.
+
+        Returns:
+            A boolean, True if the address is reserved per
+            iana-ipv6-special-registry.
+
+        """
+        return any(self in net for net in self._constants._private_networks)
+
+    @property
+    def is_global(self):
+        """Test if this address is allocated for public networks.
+
+        Returns:
+            A boolean, true if the address is not reserved per
+            iana-ipv6-special-registry.
+
+        """
+        return not self.is_private
+
+    @property
+    def is_unspecified(self):
+        """Test if the address is unspecified.
+
+        Returns:
+            A boolean, True if this is the unspecified address as defined in
+            RFC 2373 2.5.2.
+
+        """
+        return self._ip == 0
+
+    @property
+    def is_loopback(self):
+        """Test if the address is a loopback address.
+
+        Returns:
+            A boolean, True if the address is a loopback address as defined in
+            RFC 2373 2.5.3.
+
+        """
+        return self._ip == 1
+
+    @property
+    def ipv4_mapped(self):
+        """Return the IPv4 mapped address.
+
+        Returns:
+            If the IPv6 address is a v4 mapped address, return the
+            IPv4 mapped address. Return None otherwise.
+
+        """
+        if (self._ip >> 32) != 0xFFFF:
+            return None
+        return IPv4Address(self._ip & 0xFFFFFFFF)
+
+    @property
+    def teredo(self):
+        """Tuple of embedded teredo IPs.
+
+        Returns:
+            Tuple of the (server, client) IPs or None if the address
+            doesn't appear to be a teredo address (doesn't start with
+            2001::/32)
+
+        """
+        if (self._ip >> 96) != 0x20010000:
+            return None
+        return (IPv4Address((self._ip >> 64) & 0xFFFFFFFF),
+                IPv4Address(~self._ip & 0xFFFFFFFF))
+
+    @property
+    def sixtofour(self):
+        """Return the IPv4 6to4 embedded address.
+
+        Returns:
+            The IPv4 6to4-embedded address if present or None if the
+            address doesn't appear to contain a 6to4 embedded address.
+
+        """
+        if (self._ip >> 112) != 0x2002:
+            return None
+        return IPv4Address((self._ip >> 80) & 0xFFFFFFFF)
+
+
+class IPv6Interface(IPv6Address):
+
+    def __init__(self, address):
+        if isinstance(address, (bytes, _compat_int_types)):
+            IPv6Address.__init__(self, address)
+            self.network = IPv6Network(self._ip)
+            self._prefixlen = self._max_prefixlen
+            return
+        if isinstance(address, tuple):
+            IPv6Address.__init__(self, address[0])
+            if len(address) > 1:
+                self._prefixlen = int(address[1])
+            else:
+                self._prefixlen = self._max_prefixlen
+            self.network = IPv6Network(address, strict=False)
+            self.netmask = self.network.netmask
+            self.hostmask = self.network.hostmask
+            return
+
+        addr = _split_optional_netmask(address)
+        IPv6Address.__init__(self, addr[0])
+        self.network = IPv6Network(address, strict=False)
+        self.netmask = self.network.netmask
+        self._prefixlen = self.network._prefixlen
+        self.hostmask = self.network.hostmask
+
+    def __str__(self):
+        return '%s/%d' % (self._string_from_ip_int(self._ip),
+                          self.network.prefixlen)
+
+    def __eq__(self, other):
+        address_equal = IPv6Address.__eq__(self, other)
+        if not address_equal or address_equal is NotImplemented:
+            return address_equal
+        try:
+            return self.network == other.network
+        except AttributeError:
+            # An interface with an associated network is NOT the
+            # same as an unassociated address. That's why the hash
+            # takes the extra info into account.
+            return False
+
+    def __lt__(self, other):
+        address_less = IPv6Address.__lt__(self, other)
+        if address_less is NotImplemented:
+            return NotImplemented
+        try:
+            return (self.network < other.network or
+                    self.network == other.network and address_less)
+        except AttributeError:
+            # We *do* allow addresses and interfaces to be sorted. The
+            # unassociated address is considered less than all interfaces.
+            return False
+
+    def __hash__(self):
+        return self._ip ^ self._prefixlen ^ int(self.network.network_address)
+
+    __reduce__ = _IPAddressBase.__reduce__
+
+    @property
+    def ip(self):
+        return IPv6Address(self._ip)
+
+    @property
+    def with_prefixlen(self):
+        return '%s/%s' % (self._string_from_ip_int(self._ip),
+                          self._prefixlen)
+
+    @property
+    def with_netmask(self):
+        return '%s/%s' % (self._string_from_ip_int(self._ip),
+                          self.netmask)
+
+    @property
+    def with_hostmask(self):
+        return '%s/%s' % (self._string_from_ip_int(self._ip),
+                          self.hostmask)
+
+    @property
+    def is_unspecified(self):
+        return self._ip == 0 and self.network.is_unspecified
+
+    @property
+    def is_loopback(self):
+        return self._ip == 1 and self.network.is_loopback
+
+
+class IPv6Network(_BaseV6, _BaseNetwork):
+
+    """This class represents and manipulates 128-bit IPv6 networks.
+
+    Attributes: [examples for IPv6('2001:db8::1000/124')]
+        .network_address: IPv6Address('2001:db8::1000')
+        .hostmask: IPv6Address('::f')
+        .broadcast_address: IPv6Address('2001:db8::100f')
+        .netmask: IPv6Address('ffff:ffff:ffff:ffff:ffff:ffff:ffff:fff0')
+        .prefixlen: 124
+
+    """
+
+    # Class to use when creating address objects
+    _address_class = IPv6Address
+
+    def __init__(self, address, strict=True):
+        """Instantiate a new IPv6 Network object.
+
+        Args:
+            address: A string or integer representing the IPv6 network or the
+              IP and prefix/netmask.
+              '2001:db8::/128'
+              '2001:db8:0000:0000:0000:0000:0000:0000/128'
+              '2001:db8::'
+              are all functionally the same in IPv6.  That is to say,
+              failing to provide a subnetmask will create an object with
+              a mask of /128.
+
+              Additionally, an integer can be passed, so
+              IPv6Network('2001:db8::') ==
+                IPv6Network(42540766411282592856903984951653826560)
+              or, more generally
+              IPv6Network(int(IPv6Network('2001:db8::'))) ==
+                IPv6Network('2001:db8::')
+
+            strict: A boolean. If true, ensure that we have been passed
+              A true network address, eg, 2001:db8::1000/124 and not an
+              IP address on a network, eg, 2001:db8::1/124.
+
+        Raises:
+            AddressValueError: If address isn't a valid IPv6 address.
+            NetmaskValueError: If the netmask isn't valid for
+              an IPv6 address.
+            ValueError: If strict was True and a network address was not
+              supplied.
+
+        """
+        _BaseNetwork.__init__(self, address)
+
+        # Efficient constructor from integer or packed address
+        if isinstance(address, (bytes, _compat_int_types)):
+            self.network_address = IPv6Address(address)
+            self.netmask, self._prefixlen = self._make_netmask(
+                self._max_prefixlen)
+            return
+
+        if isinstance(address, tuple):
+            if len(address) > 1:
+                arg = address[1]
+            else:
+                arg = self._max_prefixlen
+            self.netmask, self._prefixlen = self._make_netmask(arg)
+            self.network_address = IPv6Address(address[0])
+            packed = int(self.network_address)
+            if packed & int(self.netmask) != packed:
+                if strict:
+                    raise ValueError('%s has host bits set' % self)
+                else:
+                    self.network_address = IPv6Address(packed &
+                                                       int(self.netmask))
+            return
+
+        # Assume input argument to be string or any object representation
+        # which converts into a formatted IP prefix string.
+        addr = _split_optional_netmask(address)
+
+        self.network_address = IPv6Address(self._ip_int_from_string(addr[0]))
+
+        if len(addr) == 2:
+            arg = addr[1]
+        else:
+            arg = self._max_prefixlen
+        self.netmask, self._prefixlen = self._make_netmask(arg)
+
+        if strict:
+            if (IPv6Address(int(self.network_address) & int(self.netmask)) !=
+                    self.network_address):
+                raise ValueError('%s has host bits set' % self)
+        self.network_address = IPv6Address(int(self.network_address) &
+                                           int(self.netmask))
+
+        if self._prefixlen == (self._max_prefixlen - 1):
+            self.hosts = self.__iter__
+
+    def hosts(self):
+        """Generate Iterator over usable hosts in a network.
+
+          This is like __iter__ except it doesn't return the
+          Subnet-Router anycast address.
+
+        """
+        network = int(self.network_address)
+        broadcast = int(self.broadcast_address)
+        for x in _compat_range(network + 1, broadcast + 1):
+            yield self._address_class(x)
+
+    @property
+    def is_site_local(self):
+        """Test if the address is reserved for site-local.
+
+        Note that the site-local address space has been deprecated by RFC 3879.
+        Use is_private to test if this address is in the space of unique local
+        addresses as defined by RFC 4193.
+
+        Returns:
+            A boolean, True if the address is reserved per RFC 3513 2.5.6.
+
+        """
+        return (self.network_address.is_site_local and
+                self.broadcast_address.is_site_local)
+
+
+class _IPv6Constants(object):
+
+    _linklocal_network = IPv6Network('fe80::/10')
+
+    _multicast_network = IPv6Network('ff00::/8')
+
+    _private_networks = [
+        IPv6Network('::1/128'),
+        IPv6Network('::/128'),
+        IPv6Network('::ffff:0:0/96'),
+        IPv6Network('100::/64'),
+        IPv6Network('2001::/23'),
+        IPv6Network('2001:2::/48'),
+        IPv6Network('2001:db8::/32'),
+        IPv6Network('2001:10::/28'),
+        IPv6Network('fc00::/7'),
+        IPv6Network('fe80::/10'),
+    ]
+
+    _reserved_networks = [
+        IPv6Network('::/8'), IPv6Network('100::/8'),
+        IPv6Network('200::/7'), IPv6Network('400::/6'),
+        IPv6Network('800::/5'), IPv6Network('1000::/4'),
+        IPv6Network('4000::/3'), IPv6Network('6000::/3'),
+        IPv6Network('8000::/3'), IPv6Network('A000::/3'),
+        IPv6Network('C000::/3'), IPv6Network('E000::/4'),
+        IPv6Network('F000::/5'), IPv6Network('F800::/6'),
+        IPv6Network('FE00::/9'),
+    ]
+
+    _sitelocal_network = IPv6Network('fec0::/10')
+
+
+IPv6Address._constants = _IPv6Constants
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/ipaddress.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/ipaddress.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..e273b4788b361ef9e4699206e23302ccb80ccd8e
GIT binary patch
literal 85785
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
K#KI-3#S{VHjzf?D

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/lockfile/__init__.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/lockfile/__init__.py
new file mode 100644
index 0000000..a6f44a5
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/lockfile/__init__.py
@@ -0,0 +1,347 @@
+# -*- coding: utf-8 -*-
+
+"""
+lockfile.py - Platform-independent advisory file locks.
+
+Requires Python 2.5 unless you apply 2.4.diff
+Locking is done on a per-thread basis instead of a per-process basis.
+
+Usage:
+
+>>> lock = LockFile('somefile')
+>>> try:
+...     lock.acquire()
+... except AlreadyLocked:
+...     print 'somefile', 'is locked already.'
+... except LockFailed:
+...     print 'somefile', 'can\\'t be locked.'
+... else:
+...     print 'got lock'
+got lock
+>>> print lock.is_locked()
+True
+>>> lock.release()
+
+>>> lock = LockFile('somefile')
+>>> print lock.is_locked()
+False
+>>> with lock:
+...    print lock.is_locked()
+True
+>>> print lock.is_locked()
+False
+
+>>> lock = LockFile('somefile')
+>>> # It is okay to lock twice from the same thread...
+>>> with lock:
+...     lock.acquire()
+...
+>>> # Though no counter is kept, so you can't unlock multiple times...
+>>> print lock.is_locked()
+False
+
+Exceptions:
+
+    Error - base class for other exceptions
+        LockError - base class for all locking exceptions
+            AlreadyLocked - Another thread or process already holds the lock
+            LockFailed - Lock failed for some other reason
+        UnlockError - base class for all unlocking exceptions
+            AlreadyUnlocked - File was not locked.
+            NotMyLock - File was locked but not by the current thread/process
+"""
+
+from __future__ import absolute_import
+
+import functools
+import os
+import socket
+import threading
+import warnings
+
+# Work with PEP8 and non-PEP8 versions of threading module.
+if not hasattr(threading, "current_thread"):
+    threading.current_thread = threading.currentThread
+if not hasattr(threading.Thread, "get_name"):
+    threading.Thread.get_name = threading.Thread.getName
+
+__all__ = ['Error', 'LockError', 'LockTimeout', 'AlreadyLocked',
+           'LockFailed', 'UnlockError', 'NotLocked', 'NotMyLock',
+           'LinkFileLock', 'MkdirFileLock', 'SQLiteFileLock',
+           'LockBase', 'locked']
+
+
+class Error(Exception):
+    """
+    Base class for other exceptions.
+
+    >>> try:
+    ...   raise Error
+    ... except Exception:
+    ...   pass
+    """
+    pass
+
+
+class LockError(Error):
+    """
+    Base class for error arising from attempts to acquire the lock.
+
+    >>> try:
+    ...   raise LockError
+    ... except Error:
+    ...   pass
+    """
+    pass
+
+
+class LockTimeout(LockError):
+    """Raised when lock creation fails within a user-defined period of time.
+
+    >>> try:
+    ...   raise LockTimeout
+    ... except LockError:
+    ...   pass
+    """
+    pass
+
+
+class AlreadyLocked(LockError):
+    """Some other thread/process is locking the file.
+
+    >>> try:
+    ...   raise AlreadyLocked
+    ... except LockError:
+    ...   pass
+    """
+    pass
+
+
+class LockFailed(LockError):
+    """Lock file creation failed for some other reason.
+
+    >>> try:
+    ...   raise LockFailed
+    ... except LockError:
+    ...   pass
+    """
+    pass
+
+
+class UnlockError(Error):
+    """
+    Base class for errors arising from attempts to release the lock.
+
+    >>> try:
+    ...   raise UnlockError
+    ... except Error:
+    ...   pass
+    """
+    pass
+
+
+class NotLocked(UnlockError):
+    """Raised when an attempt is made to unlock an unlocked file.
+
+    >>> try:
+    ...   raise NotLocked
+    ... except UnlockError:
+    ...   pass
+    """
+    pass
+
+
+class NotMyLock(UnlockError):
+    """Raised when an attempt is made to unlock a file someone else locked.
+
+    >>> try:
+    ...   raise NotMyLock
+    ... except UnlockError:
+    ...   pass
+    """
+    pass
+
+
+class _SharedBase(object):
+    def __init__(self, path):
+        self.path = path
+
+    def acquire(self, timeout=None):
+        """
+        Acquire the lock.
+
+        * If timeout is omitted (or None), wait forever trying to lock the
+          file.
+
+        * If timeout > 0, try to acquire the lock for that many seconds.  If
+          the lock period expires and the file is still locked, raise
+          LockTimeout.
+
+        * If timeout <= 0, raise AlreadyLocked immediately if the file is
+          already locked.
+        """
+        raise NotImplemented("implement in subclass")
+
+    def release(self):
+        """
+        Release the lock.
+
+        If the file is not locked, raise NotLocked.
+        """
+        raise NotImplemented("implement in subclass")
+
+    def __enter__(self):
+        """
+        Context manager support.
+        """
+        self.acquire()
+        return self
+
+    def __exit__(self, *_exc):
+        """
+        Context manager support.
+        """
+        self.release()
+
+    def __repr__(self):
+        return "<%s: %r>" % (self.__class__.__name__, self.path)
+
+
+class LockBase(_SharedBase):
+    """Base class for platform-specific lock classes."""
+    def __init__(self, path, threaded=True, timeout=None):
+        """
+        >>> lock = LockBase('somefile')
+        >>> lock = LockBase('somefile', threaded=False)
+        """
+        super(LockBase, self).__init__(path)
+        self.lock_file = os.path.abspath(path) + ".lock"
+        self.hostname = socket.gethostname()
+        self.pid = os.getpid()
+        if threaded:
+            t = threading.current_thread()
+            # Thread objects in Python 2.4 and earlier do not have ident
+            # attrs.  Worm around that.
+            ident = getattr(t, "ident", hash(t))
+            self.tname = "-%x" % (ident & 0xffffffff)
+        else:
+            self.tname = ""
+        dirname = os.path.dirname(self.lock_file)
+
+        # unique name is mostly about the current process, but must
+        # also contain the path -- otherwise, two adjacent locked
+        # files conflict (one file gets locked, creating lock-file and
+        # unique file, the other one gets locked, creating lock-file
+        # and overwriting the already existing lock-file, then one
+        # gets unlocked, deleting both lock-file and unique file,
+        # finally the last lock errors out upon releasing.
+        self.unique_name = os.path.join(dirname,
+                                        "%s%s.%s%s" % (self.hostname,
+                                                       self.tname,
+                                                       self.pid,
+                                                       hash(self.path)))
+        self.timeout = timeout
+
+    def is_locked(self):
+        """
+        Tell whether or not the file is locked.
+        """
+        raise NotImplemented("implement in subclass")
+
+    def i_am_locking(self):
+        """
+        Return True if this object is locking the file.
+        """
+        raise NotImplemented("implement in subclass")
+
+    def break_lock(self):
+        """
+        Remove a lock.  Useful if a locking thread failed to unlock.
+        """
+        raise NotImplemented("implement in subclass")
+
+    def __repr__(self):
+        return "<%s: %r -- %r>" % (self.__class__.__name__, self.unique_name,
+                                   self.path)
+
+
+def _fl_helper(cls, mod, *args, **kwds):
+    warnings.warn("Import from %s module instead of lockfile package" % mod,
+                  DeprecationWarning, stacklevel=2)
+    # This is a bit funky, but it's only for awhile.  The way the unit tests
+    # are constructed this function winds up as an unbound method, so it
+    # actually takes three args, not two.  We want to toss out self.
+    if not isinstance(args[0], str):
+        # We are testing, avoid the first arg
+        args = args[1:]
+    if len(args) == 1 and not kwds:
+        kwds["threaded"] = True
+    return cls(*args, **kwds)
+
+
+def LinkFileLock(*args, **kwds):
+    """Factory function provided for backwards compatibility.
+
+    Do not use in new code.  Instead, import LinkLockFile from the
+    lockfile.linklockfile module.
+    """
+    from . import linklockfile
+    return _fl_helper(linklockfile.LinkLockFile, "lockfile.linklockfile",
+                      *args, **kwds)
+
+
+def MkdirFileLock(*args, **kwds):
+    """Factory function provided for backwards compatibility.
+
+    Do not use in new code.  Instead, import MkdirLockFile from the
+    lockfile.mkdirlockfile module.
+    """
+    from . import mkdirlockfile
+    return _fl_helper(mkdirlockfile.MkdirLockFile, "lockfile.mkdirlockfile",
+                      *args, **kwds)
+
+
+def SQLiteFileLock(*args, **kwds):
+    """Factory function provided for backwards compatibility.
+
+    Do not use in new code.  Instead, import SQLiteLockFile from the
+    lockfile.mkdirlockfile module.
+    """
+    from . import sqlitelockfile
+    return _fl_helper(sqlitelockfile.SQLiteLockFile, "lockfile.sqlitelockfile",
+                      *args, **kwds)
+
+
+def locked(path, timeout=None):
+    """Decorator which enables locks for decorated function.
+
+    Arguments:
+     - path: path for lockfile.
+     - timeout (optional): Timeout for acquiring lock.
+
+     Usage:
+         @locked('/var/run/myname', timeout=0)
+         def myname(...):
+             ...
+    """
+    def decor(func):
+        @functools.wraps(func)
+        def wrapper(*args, **kwargs):
+            lock = FileLock(path, timeout=timeout)
+            lock.acquire()
+            try:
+                return func(*args, **kwargs)
+            finally:
+                lock.release()
+        return wrapper
+    return decor
+
+
+if hasattr(os, "link"):
+    from . import linklockfile as _llf
+    LockFile = _llf.LinkLockFile
+else:
+    from . import mkdirlockfile as _mlf
+    LockFile = _mlf.MkdirLockFile
+
+FileLock = LockFile
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/lockfile/__init__.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/lockfile/__init__.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..6747c61408128050c2755ce5094bb1a741f7df16
GIT binary patch
literal 13475
zcmZSn%**AGdLky70Sb5-7#JKJ7#ND>m>3vR7#N}$7*ZG+QkWQW7#VVz7^0XM7(sky
zh8$*wC}yx6GeZswLlg^)&B_qP3S+Y|M6tox><m%t45=IpscZ}>EDX&|48;W?b`~dy
zjOSv=V}QzLaWkZ_f)z{$No8>}Wbr^5@w^~qDQpZW><lR!3@MxpDO?OG+zcr^3@N+}
zDSQkm{0u1q3@L&PDMAeCybMu%3@L03sr(FSj0`El3@r={%?u2YQ34?SsRCe85xA%z
z$jDSdu&5|pR0w1XR8$NuDh#q1Dk=^a6#=;gYOVxaR21aAR8g?Gl5kNmkc*+BQgBgm
zh7@UrR0*(J8Mvq<$VaJ?U{P7Ps1!qr9EcMo&5$AwX2>w4D1aHV3@M6Wh8#l*Gee3J
zLklBAlma+>Sr}53L4jNJn=wU&Aw`uTN0A{{i6KgvfiYE?AxniJN|hl`k^v;A29{G}
zh*D=@OjT#d(g4Y&sxm}rf=mt8P-g(86IKQWuAKbj?6l0BRK0>q1zm-JoWzo}{Gwdl
z%)FG;g4Dc})Vvaf#FVnk;{2jY1&}%gkcMJCF0P=|!qUv5)MABz%94!yJOv{?Q-#vJ
zoYdlCh06R=g~Wn_oJs{FJrli@%(OHvpZw(P%)E4k%wmO<{Jd0!{5*w3g@V)~-I9!=
z)Wj5pq{QOPVuj4S;t~)qKMg8dP?VnxG7&7T$Hf&|oS2?!#l>Z3X9sqOf~^9`WVg(m
zR1Njw{M=NK6V)}r@+C!;R$O{|dI}%_a<yJ!GT6x)nqcA7isaOS5(UQ`kOL|~#-yeo
zG!ztN=9MTQ%+yg(&nyPpnVO=I2+^abj%*Of1h>S@90H~!C+5YdmnbBqLJfl%l2e?D
zVS9Rh30Rdn7mNk=8N_X1FJ%_TgXq*04Nb0)qS92bJV->ZC^aWFu{c#jleo~rVWwMR
zPBFyL^30M9uw&q^#GwW53>@+hBjFCk7lq0So+Y3plb@YfsZf#+wqBv6JTo~}A+0Ds
zSD_>$RiQXBH&p?WiuCmKz{X-a6|56A{=q7h6+$xdOVcwH^70ju^GoweQj0+LWv3RD
z=qMEDgHv*HVxD>lC~4;>XDj5E=9FX><fJN;Wag$8!z{$_Q&(_8%goO!w&LOfB}Uhx
zqWmHST~MM=RY=ZBEG||^%P&&MFUd$PQh+2&kZQ16ka|$c!l5TICkN~|P~O6#6Qmm@
zfh*`LIOahtf`pkuevtw!mqC-YLPma0N-;QaK`9CD43J?Ur$7?9f-X4gDWrjuJlF%E
z3<&i_QEFmwejZ$FXdcKUJbowzD<JF(h(W0-3c3oQOs`O$Sgeo-%_XTRdT<LtZuQGA
z@df8=WW^wNq^2k&m6m|@B~^m`nOs^_1S;wvVWJNW5Uxy6)vCeBz`#(#&%nTtm{gpf
zQ(BT5pP5^bUsU2(!pFeC0M!}~(OSa6z`&56S`wd^n44O{%D}(?_H+p+0|Nsn>>xaD
zC@&;4H#NVsqy$uTqeN2)7gPl#tV=)|AYO+U05Z-mzXW7rY6{qJxMxdvKw2~NvO(bk
zQUEsHH#;S>2rdG0cW|IjW=Ses2;^>%YNy2F)DkuZ1_nq#!CM!gKyU)JE<k!y85p7%
z!EFpChM-_@02P-rFff3FA7lcaRILZe1E3NdTtb6l3Q|fJC1w_<Du6u*HV7mNNz)4O
zEMx_jQBWvIEG`CfHJCv$1oA;VINamo!QmGlpPQdjnv)tIU&7A7zz`pwlAjzOuK|uz
zI8j`{z`&qiP?TAgSdyw=mRO{pmY<W7T2!o`l%ijrl$4iinp<pSm}H(_m2P2bQJ#}k
zWo7^Z>3RAg`URN<x}ZucF(*gYt<1yIH~=IB#_?sTc`5lt`k-(G)k^yD@tJv<CGqik
z1(iV{2YZ3)U={`j1~v{hM&iSH8jf&I1s5ubMVZB*Tm&v26H7``a|=p}K}9FD?gOWG
zkdp{S11K$Ej|z}IxT7IRfPsM_NDxE_F)%O;iqHlHau|7`Js0E=P`XS}D9=dE1DCZ5
z$wjG&C7Jno;Igk+0aV>&g4#2s#i>QQDXD3hd8sL&#!Y5^ib8%GxT+u~xS^#1I7uU=
zeRxa^tw0BreM#^@XD20zcQ7z81n1|bLhBMp$qFl!LG?2z0fSOGsQw4#EkdD-Qnn70
z@CB98x#Wd!JE(>LwPrwJhnkvGQ?S?MghCjUNFjCAFbQ5zjZr~f@Xo|nLKiFGETW+;
zcA|@Dqy_<cpo2^9p;cahs_$lafRj`uPC_fB6Y~_HRUfFZ$W2U11=WC%CZ<AS9<(hF
zO6r+8sf1ECyqSd_#z?_Gv_hJbfq|hP9?~S0%yUQzX~=*9s8;~$@~7q$!~47h+JNxJ
z?63)QP<wtBa+rgg^zp$NiAAX?pcXT{0m#I_zyNM&J2EgZz#G~v44?r#(C`@}ctnT=
zG_VH}WCacAfEeJhIS_*#GzJG^aDdw8pmHo3WF`zdgBtOm4o3|mLk$B%Jb0`S(uVf~
zx8zGe&833Gk_-)y7BH_kH76}d1f@AQAnj&w?+VtAUIq$IkP{ggF+B)sg_eK^K${sE
zn!v-L!QgH}aX%xpp91Q5I6_8*(2HD<l$L@gr0JGl3K@gQ%`7QNO;OOuFH-Q!&r8+R
zQ7BK$ECE%Qsb#4}3MECA;3f%dlp-S)oOnS-DS$Hqw4ebApqOo^V4wri4JxD1Tj?Ov
z6-qJ^OB8Yw^C}gJQ<L-aQi}By6g<<AOb0cCKusc8n=`ed06a36n3n?f8MvCyELJEk
z$%GCUq^9U7fV*2rrhuw&XcH8dQ*CTPZUt*Z9XC_R%*{<r$xJLs&8bw#OhdL6$p+Z?
z0?4h%o%Lc-1_p-A+=86cTu>)GGf$zoGzmN|0!@*iKBr%Pi6=}+Y6>`Q27&Z}`*xtw
znEcWbL~mnYk|!v$L8EXbJazIVgZj=O3`(rv?1wvbM!?z*pkxvR8NvgHCMe91q6L&T
zGg86n3RK4-hCrb4ssOLH5Mv^Qf;mVWl*2&|1qbY42ux^`XeT@{+2DZ*awj-2L5ZV=
zfguY#L%>+WzyK-CinWk~(m6k`B((yZjS|ySixi4W3qV6Sh`<3CeL<3gDg-#eqZX;4
zQOWrDgP<?~70nDRT#VpQ03|0-D7b@4bktBtVPpsfXAu%Z0g~T>q(H#{G9H`|z*Rte
zYDMxurwC9JF+M)E0yK(p0u&q|Co-^r0|OKgpivcYk^m*-6h=_>mc_u31z|8Tq%kpw
zK|;l^7-W=<YO$4qYLOkdUH}iG#m9q7o%ndjC<eI30~rhshQZ<cqSS(-`1o^h-!uAY
zaDp0Tpdtk_>>>sl3<D(;P%Q;c(ct(Dk_IW01rhR~=!K7ff&Dcg<z<jC0|UcSkXJxs
zmTZii%sc{|9GvW&Z1C0)C`vI~Ls3i&sm!4H!4yV@7AEklB@=kkj1ATrVh7DsLK;CS
ztY9flSZk<Q57fd+EJhxBFM!Q^6&Iu?XQpK)LkD_5WAmxSddZ;R1QqU}WCKoNA3%Z3
zz)->nN@UGU3|UMJHH-|+j0}t=%nVs93|XvDehMRlIH;M$#!$k}ki`L-#RPFV89?f|
zU|ep78YYIKZiW&bhAdu?U@Z$n2_HiZxS3bN4`MVkGBh(Y)Pmc4HLM`-If#Kw5@5*V
z1hx1eY>=re3|WF8XJxU098}8&wu*%zONgO{4HRgg!jcoLKmbf~gGRSOf-E5QX)Fw4
z%}gMPcwvSbW-vnpH0v6y0rGt@XiOYlr-MduK{XR}5(m_fMVW^K)nXuwU!4wg{w6iW
z7Cbqm2{*qOG>W7LvH?7no(Y<dEC!_sUDXQD|NsC02c_Z?5K+v@z`&qdtXixGBK$PK
zO#_hb;?jcDq99Q57zEB4pfV%B7~Gl#Hysj_ib0KCaQ+8b6c1`Gfk(iL^OLhvOTZ2F
z^wg4!{NfVupgt%R;2h8>OnPcbL1sz`$XOs7<PgY^Rc2m#5UBV7+moJJl2}qw1TIW7
z5{omy9)g$%N?9qHMPSoGDJ?5MGY@QSX<lYwX)1V3J4gbQX+bK%g%QO4Ag4gAN=*SP
zC;?j+qzKC81|SWfpc%jn4hr!rpbV}6atNy!qa-6gBR?Y>BM-9#qX-ixqbMg2BPSyp
zBO9Y6q*4QU02D>wTm~xCu(#qZkt_F*)SMj9@GN-#EWZdmu>)!ogJKfYIs!#2DecWc
z)(`?EDEK_@S5Rnz0tl(z191t27pOA{&s9OGC8b4q3ZRKv1#n|MvsfWNDJwM@+|dDr
z7Puz^ZC@hVNJFdv393{w;}dhiGvt|h>A%SfIzQy37L=NsUzVzn2(BOW6cj>>Q`1Uw
zK%oc`f&?6BMFDtnAT<TltAmU@4cTzyVqjoMDoRbv1_vY~BLhP*D8(TqKv1CtPJp21
z1!ltwRJSlQq%k9!U!dX`+Wb<`)de@gKxPEVfeJ2At`9N-u?AHGEC|$WVh8yi<WvSm
zAx1w9P|!fyih>~bf@ZwH1w1Hg1%b*uaGeum3X(Jf5#}HQWDvMeMi2wj{sKkAB~Y#a
zWff2%%&*AF27=%L6_7VUHK;$Re*v0mC;>O7LGjDTAXdTz8iGn;W@u(&1T}hUm_Th3
z$r8u{F)L7mCWVzjzLp8J?yH0q#BXK<HB_>h7>W`=EeoEa1cnke5G#d^!6uIZ)YPb9
z0`dDmoj6ck=T~gVz`)=Mo^FRM`A{uZfXwP5FBSq7S>VFHATc>RF+CML{aaj;n4F!H
zT9%rV2}-V@b_+u$sCo%92Gxup<H6%e<%vaknR)5O;D`fpN<h)*l3Gxdnhc)i3x_BG
z8w#3TEiOsSOHKvX_r)beU^*u?FUSI9Dk#jrBFQ<$U^+KH1#EC)5!8n4@|5BMj(4z6
z;?r{CGg5O3Qj2&%X&RIi7#MjOd0B*+co`)bc_CBMphgWm4X81IN7O(|3K<x385wGs
z7#K^KKrx%e3~G4SFn}7peM}6&8lZ3}UdX_};Fg$N0$w{-nwJcoGc72}FUw2;4Zi0W
zDI_H(XO|}yr4%b9=jRqAmSiSn=46&sLI*lr^1)SkX>qDTW}ZS`YPmvkeo886^b4|1
zOh*B-5JSNyGcOx7d<9y~07)h#(BU^&%FxTn%*%#xpeYDaAcK<xxc3iUIf1MWT;IVo
zp_l;nUyu?gGrNKa7f^Qql!=gC0`6A^If3MzK?F$U0LOd~Hv<EM6ezwy4Oa#>0Y)Aw
z#Pec$#WQ#n3xSBv1+8>}MH;S{291BCC@coGRAIXGP^6IJ+8q>);J5}EfZ`hT$Ob7L
z=*R{oNL6Y__7ZwUHe`VkHDVi7wiOrVWR|4DVz?MILImUJp~@k}w<kQlK}MiD2tC3<
zY6m*PL8;OJEy6){AE*=u)1aChl+xQ77}^;@17azR3~dacg1iP)YJ=1ib1*V6xTGfM
z7bTYD7b%oyWF}`Qq~;|i<)lK^zd{x(ra)AH%5iAP4lT4Di_%L$!}!IJNl^t|1yJ|e
z3QU5hGvL7v>5u4w*T;Y+Sv2wsKs7{Sj;56YbRq(*0WzWvYFUG{LakANE(HdSE`YHE
zNHR4=Lmj+`tEe<jKerOpqgK~}Szv2`7+6q9NljCLDA3T;)6;}H7HpD&f&yq^Cx{Im
zS_Fj(s6G=0g&ru1A?=_J2GDQ`BqZCJK+Ri7U^X){)G~r9Lg-i{cq|JP10XZxL1x&4
zY6}L24o1)d`wk|CW=6(ZNHxj`8v9|a5@hIrw1yZNKuw|W6b5i5%LJB<NCCBuK#uYQ
z_xZsI5!{jiRezxTf*AAz%YmyP@Q4Peu7x&3K%oVe1-DMpO7oJzLkbWRL7nvhX_10Q
zO3I583kp(;JU|H<)WBw75@O_HWM&j(0uO0}M`}P0F3Hc&DFzRtfOHgtC4)e{wIF{`
zQw$VBNPYsh{6Mk;<1tVp3Y=%$LEZu-1qMbH4p3@h07nDDr9nX;*Mp(};v-Ne2plZ~
z;_x8Q!dGj!n|Xw|zzGJ_OhUArg1}81a0r9zJ<!xk5U3RmX=%o%m6ntirN+mDe8vzI
z04h~gKm=$TLXZxKWd+I-peA`nVljA_3{;dsm)3@Ww+KK+(m>4?2p^nO(o;+P5_407
zKyeKgh>uUq$%&5#rxEy~QSfrhAW)bGfubP@WJnOmvLMg^S`cV_B?y$zz<C5R5CR^W
zhKw45>U(gzDF{@b27w#~>Dqxp2GIrt2TOcTPFj!~$S)w1L3t6BCxbwN0+G+nNel7-
zdDt5s$>5j<5d#vx;DW;j(xtL90rdqz&Szs1VB%qfLT1pAoe-laScH?2hgpnAj7N+c
c3?a0xm=z}<CpQT4Nb)lZF!C@7Fmf^h03L)L`2YX_

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/lockfile/linklockfile.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/lockfile/linklockfile.py
new file mode 100644
index 0000000..2ca9be0
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/lockfile/linklockfile.py
@@ -0,0 +1,73 @@
+from __future__ import absolute_import
+
+import time
+import os
+
+from . import (LockBase, LockFailed, NotLocked, NotMyLock, LockTimeout,
+               AlreadyLocked)
+
+
+class LinkLockFile(LockBase):
+    """Lock access to a file using atomic property of link(2).
+
+    >>> lock = LinkLockFile('somefile')
+    >>> lock = LinkLockFile('somefile', threaded=False)
+    """
+
+    def acquire(self, timeout=None):
+        try:
+            open(self.unique_name, "wb").close()
+        except IOError:
+            raise LockFailed("failed to create %s" % self.unique_name)
+
+        timeout = timeout if timeout is not None else self.timeout
+        end_time = time.time()
+        if timeout is not None and timeout > 0:
+            end_time += timeout
+
+        while True:
+            # Try and create a hard link to it.
+            try:
+                os.link(self.unique_name, self.lock_file)
+            except OSError:
+                # Link creation failed.  Maybe we've double-locked?
+                nlinks = os.stat(self.unique_name).st_nlink
+                if nlinks == 2:
+                    # The original link plus the one I created == 2.  We're
+                    # good to go.
+                    return
+                else:
+                    # Otherwise the lock creation failed.
+                    if timeout is not None and time.time() > end_time:
+                        os.unlink(self.unique_name)
+                        if timeout > 0:
+                            raise LockTimeout("Timeout waiting to acquire"
+                                              " lock for %s" %
+                                              self.path)
+                        else:
+                            raise AlreadyLocked("%s is already locked" %
+                                                self.path)
+                    time.sleep(timeout is not None and timeout / 10 or 0.1)
+            else:
+                # Link creation succeeded.  We're good to go.
+                return
+
+    def release(self):
+        if not self.is_locked():
+            raise NotLocked("%s is not locked" % self.path)
+        elif not os.path.exists(self.unique_name):
+            raise NotMyLock("%s is locked, but not by me" % self.path)
+        os.unlink(self.unique_name)
+        os.unlink(self.lock_file)
+
+    def is_locked(self):
+        return os.path.exists(self.lock_file)
+
+    def i_am_locking(self):
+        return (self.is_locked() and
+                os.path.exists(self.unique_name) and
+                os.stat(self.unique_name).st_nlink == 2)
+
+    def break_lock(self):
+        if os.path.exists(self.lock_file):
+            os.unlink(self.lock_file)
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/lockfile/linklockfile.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/lockfile/linklockfile.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..e862bd27d68098773efea674bfd39de99e1e5636
GIT binary patch
literal 3238
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

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/lockfile/mkdirlockfile.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/lockfile/mkdirlockfile.py
new file mode 100644
index 0000000..05a8c96
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/lockfile/mkdirlockfile.py
@@ -0,0 +1,84 @@
+from __future__ import absolute_import, division
+
+import time
+import os
+import sys
+import errno
+
+from . import (LockBase, LockFailed, NotLocked, NotMyLock, LockTimeout,
+               AlreadyLocked)
+
+
+class MkdirLockFile(LockBase):
+    """Lock file by creating a directory."""
+    def __init__(self, path, threaded=True, timeout=None):
+        """
+        >>> lock = MkdirLockFile('somefile')
+        >>> lock = MkdirLockFile('somefile', threaded=False)
+        """
+        LockBase.__init__(self, path, threaded, timeout)
+        # Lock file itself is a directory.  Place the unique file name into
+        # it.
+        self.unique_name = os.path.join(self.lock_file,
+                                        "%s.%s%s" % (self.hostname,
+                                                     self.tname,
+                                                     self.pid))
+
+    def acquire(self, timeout=None):
+        timeout = timeout if timeout is not None else self.timeout
+        end_time = time.time()
+        if timeout is not None and timeout > 0:
+            end_time += timeout
+
+        if timeout is None:
+            wait = 0.1
+        else:
+            wait = max(0, timeout / 10)
+
+        while True:
+            try:
+                os.mkdir(self.lock_file)
+            except OSError:
+                err = sys.exc_info()[1]
+                if err.errno == errno.EEXIST:
+                    # Already locked.
+                    if os.path.exists(self.unique_name):
+                        # Already locked by me.
+                        return
+                    if timeout is not None and time.time() > end_time:
+                        if timeout > 0:
+                            raise LockTimeout("Timeout waiting to acquire"
+                                              " lock for %s" %
+                                              self.path)
+                        else:
+                            # Someone else has the lock.
+                            raise AlreadyLocked("%s is already locked" %
+                                                self.path)
+                    time.sleep(wait)
+                else:
+                    # Couldn't create the lock for some other reason
+                    raise LockFailed("failed to create %s" % self.lock_file)
+            else:
+                open(self.unique_name, "wb").close()
+                return
+
+    def release(self):
+        if not self.is_locked():
+            raise NotLocked("%s is not locked" % self.path)
+        elif not os.path.exists(self.unique_name):
+            raise NotMyLock("%s is locked, but not by me" % self.path)
+        os.unlink(self.unique_name)
+        os.rmdir(self.lock_file)
+
+    def is_locked(self):
+        return os.path.exists(self.lock_file)
+
+    def i_am_locking(self):
+        return (self.is_locked() and
+                os.path.exists(self.unique_name))
+
+    def break_lock(self):
+        if os.path.exists(self.lock_file):
+            for name in os.listdir(self.lock_file):
+                os.unlink(os.path.join(self.lock_file, name))
+            os.rmdir(self.lock_file)
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/lockfile/mkdirlockfile.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/lockfile/mkdirlockfile.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..08ccb35dfce6cfefee6da743aa7c648823acd6de
GIT binary patch
literal 3802
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
Ae*gdg

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/lockfile/pidlockfile.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/lockfile/pidlockfile.py
new file mode 100644
index 0000000..069e85b
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/lockfile/pidlockfile.py
@@ -0,0 +1,190 @@
+# -*- coding: utf-8 -*-
+
+# pidlockfile.py
+#
+# Copyright © 2008–2009 Ben Finney <ben+python@benfinney.id.au>
+#
+# This is free software: you may copy, modify, and/or distribute this work
+# under the terms of the Python Software Foundation License, version 2 or
+# later as published by the Python Software Foundation.
+# No warranty expressed or implied. See the file LICENSE.PSF-2 for details.
+
+""" Lockfile behaviour implemented via Unix PID files.
+    """
+
+from __future__ import absolute_import
+
+import errno
+import os
+import time
+
+from . import (LockBase, AlreadyLocked, LockFailed, NotLocked, NotMyLock,
+               LockTimeout)
+
+
+class PIDLockFile(LockBase):
+    """ Lockfile implemented as a Unix PID file.
+
+    The lock file is a normal file named by the attribute `path`.
+    A lock's PID file contains a single line of text, containing
+    the process ID (PID) of the process that acquired the lock.
+
+    >>> lock = PIDLockFile('somefile')
+    >>> lock = PIDLockFile('somefile')
+    """
+
+    def __init__(self, path, threaded=False, timeout=None):
+        # pid lockfiles don't support threaded operation, so always force
+        # False as the threaded arg.
+        LockBase.__init__(self, path, False, timeout)
+        self.unique_name = self.path
+
+    def read_pid(self):
+        """ Get the PID from the lock file.
+            """
+        return read_pid_from_pidfile(self.path)
+
+    def is_locked(self):
+        """ Test if the lock is currently held.
+
+            The lock is held if the PID file for this lock exists.
+
+            """
+        return os.path.exists(self.path)
+
+    def i_am_locking(self):
+        """ Test if the lock is held by the current process.
+
+        Returns ``True`` if the current process ID matches the
+        number stored in the PID file.
+        """
+        return self.is_locked() and os.getpid() == self.read_pid()
+
+    def acquire(self, timeout=None):
+        """ Acquire the lock.
+
+        Creates the PID file for this lock, or raises an error if
+        the lock could not be acquired.
+        """
+
+        timeout = timeout if timeout is not None else self.timeout
+        end_time = time.time()
+        if timeout is not None and timeout > 0:
+            end_time += timeout
+
+        while True:
+            try:
+                write_pid_to_pidfile(self.path)
+            except OSError as exc:
+                if exc.errno == errno.EEXIST:
+                    # The lock creation failed.  Maybe sleep a bit.
+                    if time.time() > end_time:
+                        if timeout is not None and timeout > 0:
+                            raise LockTimeout("Timeout waiting to acquire"
+                                              " lock for %s" %
+                                              self.path)
+                        else:
+                            raise AlreadyLocked("%s is already locked" %
+                                                self.path)
+                    time.sleep(timeout is not None and timeout / 10 or 0.1)
+                else:
+                    raise LockFailed("failed to create %s" % self.path)
+            else:
+                return
+
+    def release(self):
+        """ Release the lock.
+
+            Removes the PID file to release the lock, or raises an
+            error if the current process does not hold the lock.
+
+            """
+        if not self.is_locked():
+            raise NotLocked("%s is not locked" % self.path)
+        if not self.i_am_locking():
+            raise NotMyLock("%s is locked, but not by me" % self.path)
+        remove_existing_pidfile(self.path)
+
+    def break_lock(self):
+        """ Break an existing lock.
+
+            Removes the PID file if it already exists, otherwise does
+            nothing.
+
+            """
+        remove_existing_pidfile(self.path)
+
+
+def read_pid_from_pidfile(pidfile_path):
+    """ Read the PID recorded in the named PID file.
+
+        Read and return the numeric PID recorded as text in the named
+        PID file. If the PID file cannot be read, or if the content is
+        not a valid PID, return ``None``.
+
+        """
+    pid = None
+    try:
+        pidfile = open(pidfile_path, 'r')
+    except IOError:
+        pass
+    else:
+        # According to the FHS 2.3 section on PID files in /var/run:
+        #
+        #   The file must consist of the process identifier in
+        #   ASCII-encoded decimal, followed by a newline character.
+        #
+        #   Programs that read PID files should be somewhat flexible
+        #   in what they accept; i.e., they should ignore extra
+        #   whitespace, leading zeroes, absence of the trailing
+        #   newline, or additional lines in the PID file.
+
+        line = pidfile.readline().strip()
+        try:
+            pid = int(line)
+        except ValueError:
+            pass
+        pidfile.close()
+
+    return pid
+
+
+def write_pid_to_pidfile(pidfile_path):
+    """ Write the PID in the named PID file.
+
+        Get the numeric process ID (“PID”) of the current process
+        and write it to the named file as a line of text.
+
+        """
+    open_flags = (os.O_CREAT | os.O_EXCL | os.O_WRONLY)
+    open_mode = 0o644
+    pidfile_fd = os.open(pidfile_path, open_flags, open_mode)
+    pidfile = os.fdopen(pidfile_fd, 'w')
+
+    # According to the FHS 2.3 section on PID files in /var/run:
+    #
+    #   The file must consist of the process identifier in
+    #   ASCII-encoded decimal, followed by a newline character. For
+    #   example, if crond was process number 25, /var/run/crond.pid
+    #   would contain three characters: two, five, and newline.
+
+    pid = os.getpid()
+    pidfile.write("%s\n" % pid)
+    pidfile.close()
+
+
+def remove_existing_pidfile(pidfile_path):
+    """ Remove the named PID file if it exists.
+
+        Removing a PID file that doesn't already exist puts us in the
+        desired state, so we ignore the condition if the file does not
+        exist.
+
+        """
+    try:
+        os.remove(pidfile_path)
+    except OSError as exc:
+        if exc.errno == errno.ENOENT:
+            pass
+        else:
+            raise
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/lockfile/pidlockfile.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/lockfile/pidlockfile.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..35dd65b1a9e361289316bd393b46d9b66ea3921a
GIT binary patch
literal 6473
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

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/lockfile/sqlitelockfile.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/lockfile/sqlitelockfile.py
new file mode 100644
index 0000000..f997e24
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/lockfile/sqlitelockfile.py
@@ -0,0 +1,156 @@
+from __future__ import absolute_import, division
+
+import time
+import os
+
+try:
+    unicode
+except NameError:
+    unicode = str
+
+from . import LockBase, NotLocked, NotMyLock, LockTimeout, AlreadyLocked
+
+
+class SQLiteLockFile(LockBase):
+    "Demonstrate SQL-based locking."
+
+    testdb = None
+
+    def __init__(self, path, threaded=True, timeout=None):
+        """
+        >>> lock = SQLiteLockFile('somefile')
+        >>> lock = SQLiteLockFile('somefile', threaded=False)
+        """
+        LockBase.__init__(self, path, threaded, timeout)
+        self.lock_file = unicode(self.lock_file)
+        self.unique_name = unicode(self.unique_name)
+
+        if SQLiteLockFile.testdb is None:
+            import tempfile
+            _fd, testdb = tempfile.mkstemp()
+            os.close(_fd)
+            os.unlink(testdb)
+            del _fd, tempfile
+            SQLiteLockFile.testdb = testdb
+
+        import sqlite3
+        self.connection = sqlite3.connect(SQLiteLockFile.testdb)
+
+        c = self.connection.cursor()
+        try:
+            c.execute("create table locks"
+                      "("
+                      "   lock_file varchar(32),"
+                      "   unique_name varchar(32)"
+                      ")")
+        except sqlite3.OperationalError:
+            pass
+        else:
+            self.connection.commit()
+            import atexit
+            atexit.register(os.unlink, SQLiteLockFile.testdb)
+
+    def acquire(self, timeout=None):
+        timeout = timeout if timeout is not None else self.timeout
+        end_time = time.time()
+        if timeout is not None and timeout > 0:
+            end_time += timeout
+
+        if timeout is None:
+            wait = 0.1
+        elif timeout <= 0:
+            wait = 0
+        else:
+            wait = timeout / 10
+
+        cursor = self.connection.cursor()
+
+        while True:
+            if not self.is_locked():
+                # Not locked.  Try to lock it.
+                cursor.execute("insert into locks"
+                               "  (lock_file, unique_name)"
+                               "  values"
+                               "  (?, ?)",
+                               (self.lock_file, self.unique_name))
+                self.connection.commit()
+
+                # Check to see if we are the only lock holder.
+                cursor.execute("select * from locks"
+                               "  where unique_name = ?",
+                               (self.unique_name,))
+                rows = cursor.fetchall()
+                if len(rows) > 1:
+                    # Nope.  Someone else got there.  Remove our lock.
+                    cursor.execute("delete from locks"
+                                   "  where unique_name = ?",
+                                   (self.unique_name,))
+                    self.connection.commit()
+                else:
+                    # Yup.  We're done, so go home.
+                    return
+            else:
+                # Check to see if we are the only lock holder.
+                cursor.execute("select * from locks"
+                               "  where unique_name = ?",
+                               (self.unique_name,))
+                rows = cursor.fetchall()
+                if len(rows) == 1:
+                    # We're the locker, so go home.
+                    return
+
+            # Maybe we should wait a bit longer.
+            if timeout is not None and time.time() > end_time:
+                if timeout > 0:
+                    # No more waiting.
+                    raise LockTimeout("Timeout waiting to acquire"
+                                      " lock for %s" %
+                                      self.path)
+                else:
+                    # Someone else has the lock and we are impatient..
+                    raise AlreadyLocked("%s is already locked" % self.path)
+
+            # Well, okay.  We'll give it a bit longer.
+            time.sleep(wait)
+
+    def release(self):
+        if not self.is_locked():
+            raise NotLocked("%s is not locked" % self.path)
+        if not self.i_am_locking():
+            raise NotMyLock("%s is locked, but not by me (by %s)" %
+                            (self.unique_name, self._who_is_locking()))
+        cursor = self.connection.cursor()
+        cursor.execute("delete from locks"
+                       "  where unique_name = ?",
+                       (self.unique_name,))
+        self.connection.commit()
+
+    def _who_is_locking(self):
+        cursor = self.connection.cursor()
+        cursor.execute("select unique_name from locks"
+                       "  where lock_file = ?",
+                       (self.lock_file,))
+        return cursor.fetchone()[0]
+
+    def is_locked(self):
+        cursor = self.connection.cursor()
+        cursor.execute("select * from locks"
+                       "  where lock_file = ?",
+                       (self.lock_file,))
+        rows = cursor.fetchall()
+        return not not rows
+
+    def i_am_locking(self):
+        cursor = self.connection.cursor()
+        cursor.execute("select * from locks"
+                       "  where lock_file = ?"
+                       "    and unique_name = ?",
+                       (self.lock_file, self.unique_name))
+        return not not cursor.fetchall()
+
+    def break_lock(self):
+        cursor = self.connection.cursor()
+        cursor.execute("delete from locks"
+                       "  where lock_file = ?",
+                       (self.lock_file,))
+        self.connection.commit()
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/lockfile/sqlitelockfile.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/lockfile/sqlitelockfile.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..d10223bdf84f4496a983a5e94bcedbd47f8c8e5e
GIT binary patch
literal 5126
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
Q4-+#Z2O}>d7n24v0GkSJCjbBd

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/lockfile/symlinklockfile.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/lockfile/symlinklockfile.py
new file mode 100644
index 0000000..23b41f5
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/lockfile/symlinklockfile.py
@@ -0,0 +1,70 @@
+from __future__ import absolute_import
+
+import os
+import time
+
+from . import (LockBase, NotLocked, NotMyLock, LockTimeout,
+               AlreadyLocked)
+
+
+class SymlinkLockFile(LockBase):
+    """Lock access to a file using symlink(2)."""
+
+    def __init__(self, path, threaded=True, timeout=None):
+        # super(SymlinkLockFile).__init(...)
+        LockBase.__init__(self, path, threaded, timeout)
+        # split it back!
+        self.unique_name = os.path.split(self.unique_name)[1]
+
+    def acquire(self, timeout=None):
+        # Hopefully unnecessary for symlink.
+        # try:
+        #     open(self.unique_name, "wb").close()
+        # except IOError:
+        #     raise LockFailed("failed to create %s" % self.unique_name)
+        timeout = timeout if timeout is not None else self.timeout
+        end_time = time.time()
+        if timeout is not None and timeout > 0:
+            end_time += timeout
+
+        while True:
+            # Try and create a symbolic link to it.
+            try:
+                os.symlink(self.unique_name, self.lock_file)
+            except OSError:
+                # Link creation failed.  Maybe we've double-locked?
+                if self.i_am_locking():
+                    # Linked to out unique name. Proceed.
+                    return
+                else:
+                    # Otherwise the lock creation failed.
+                    if timeout is not None and time.time() > end_time:
+                        if timeout > 0:
+                            raise LockTimeout("Timeout waiting to acquire"
+                                              " lock for %s" %
+                                              self.path)
+                        else:
+                            raise AlreadyLocked("%s is already locked" %
+                                                self.path)
+                    time.sleep(timeout / 10 if timeout is not None else 0.1)
+            else:
+                # Link creation succeeded.  We're good to go.
+                return
+
+    def release(self):
+        if not self.is_locked():
+            raise NotLocked("%s is not locked" % self.path)
+        elif not self.i_am_locking():
+            raise NotMyLock("%s is locked, but not by me" % self.path)
+        os.unlink(self.lock_file)
+
+    def is_locked(self):
+        return os.path.islink(self.lock_file)
+
+    def i_am_locking(self):
+        return (os.path.islink(self.lock_file)
+                and os.readlink(self.lock_file) == self.unique_name)
+
+    def break_lock(self):
+        if os.path.islink(self.lock_file):  # exists && link
+            os.unlink(self.lock_file)
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/lockfile/symlinklockfile.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/lockfile/symlinklockfile.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..d77402e7e94681138709815f92011e58c14aade0
GIT binary patch
literal 3201
zcmZSn%**AGdLky70ScHI7#JKJ7#NDP7#J8*7#LC*8FCmHav2$-7#SErd?tn*CWa^`
zupARZ4l_d(GeZh9LkbH+4husrD?=13LoORb6dOY>J3|yZLoNqH6bC~tCqon`17iv+
zLn<pn8Y4pr8$$~NLo)+IWE2-e3KK)H20H@-Lng=#8jK7K3?=*w3=D}$#rZj<C8_b5
zxdr(}C4QM884XsDGzS9%gHL{Pwo_tpY6&L;1A||F35cJX0^|8sg7_ueP=z6xxvBZ3
zB_+HJ3=EDrMX8A?VENP(uuZ|0xjC76*&rQmnK`K_f#C!S3||HYhExVn7^E<OJfF(U
zkirfMn-(UJhe2#6h89MUw^NuwUW;M}g-8nn$nz<zU=dEJucNpaf`T<bJ}6d)x=tZ6
zIXShsSfM0eAyFYMGbdG{v^X;_U7;A_E)641y<`>!1_lrY`QI7jCNoe#Ffe2>GSo0I
z)G#vCFfr6HGc>a>FqSYeWHB>jv4AA9SQ(lbK`xc7VPJ@71w~u11`{a6Ai>GTz`zg$
z3fK~mi{j%m^D;}~<4Zs)@{3DA78WFyWR!qxEiTB(ECGjTX<lYwX=;34Vs5GiNC{Y7
zacWLl5GTk{Ad^ZmK!Kc^QUZ$D5=iK4fa4cL6qhqFFz6Q)WtJtDr0SO?7U`$u=cJ?-
z73(LZ=$9uY<>i{@78@BRnWtB!TbNpu=VVox8Gt}~o_>gaL1uw&W?pegVor{(TbYNa
zaR5jNjN{8v^HTDQ^mFo)vq1r=4-G;XU$3At2;?GAIw%G?oq<V=DH-HjP{IfK5*)S?
zjNl+mVPMGSWGE5>1#cc3I5-&@Y8e?o0n7wSzO_ssDX20ZFq@Gfn}wms2OJ%Y4Cb{=
z40#L;6-OCLm>G(M87rk2N>~`OSixpNOk`(hW@2Cr&zr@-Qo_NI&Bai}&B(~eSi``O
z#R;;bs2?0@HH;t%<eaAn`)ioMwmn6%`8-1jI7@-_b2ErFGcq(WG88^#DB%HRQxwrW
z2CzxIVBHX}GBSefVPO!>V`fMJCmqH@e};$@28Q55e}-@ntpQ3he&D=Xtj55=0L@wo
z<%yXkphOEw#L0!FnMJ7zpioyx%P&$;EiM*eU|>)!R>&+?NQC4+uxx5dCKm$(L;9?l
zAh6S3gAbH|KoR4YpO+d0=YdiXIF*GIm8J%P6BsBOp|KkT%I4sl53(^H6!GA6=O64^
zRFq#-!UHN?;uCY@LDHFd=|Lb1z-cuI6y=cAos*hcpaDt+K_KN2t3ei}=B31gtREby
z7woS@NcajfFfbIWfbtWYG$RkA1S2mKClfQH6eBMa4-*Ts93u}S8<PMN8>0ZDI&(58
zlY=nGi{L~a!N34chTwv@Sc#zoTuy*e2oo&b<SBtwFoV)zu?r~arZ9m;5GoiLN>~}P
z*ubLfpt1&3O9X=h(yv$m9_e}cCC~^jmWB(0q9Zj$M<J=SL;<8AsZt>~6<joeBQvuY
z9AT*`L7)r@i7!!5c?I$UBoTnpVrd?z@D2in2DtJ7$KN1|t)kSN)WqUcP<dU<1&S?3
z9!4=RhQ|rWf8aO)d7=bdsAn;OgOnK*q`_c+`GLz?u)o1!Q3CROX7Ql)e2^pq1A{Fn
zje@+#z=-KvJy2%H@NK>>11Jbs5dH_HNmhnzP&)yXg8jfn5F#LgWI%}m9CV-z3#xd)
zfdVQOz#%t?QbZ6a0Xu*K1ylwxFp6Rc79Fg?Qlx<%ER1>JCK@btfQm9~ff6Lez`!ur
z!l8tVfq@~ZC^az~oX1^|L&Q%56m!r938;|~9}iX@AD^3_Qks(*9}g}C<Kt8EljGxq
z1VOP6YA}Lp_8<um7gWZ8(;qmzgXBOV0LprUqgV(6<y=qz6!S4KFt9PQG4ZqUD08xN
zGIO#({0@?gk54NtDJ@Ekj}HPl9TK&m614=(1?2=t!3Zu6LCFbRn}H2S_!G<;$o3XE
Y9&I2oX9se0F({J?F!3<*Fln#=0JLGo-~a#s

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/msgpack/__init__.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/msgpack/__init__.py
new file mode 100644
index 0000000..2afca5a
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/msgpack/__init__.py
@@ -0,0 +1,66 @@
+# coding: utf-8
+from pip._vendor.msgpack._version import version
+from pip._vendor.msgpack.exceptions import *
+
+from collections import namedtuple
+
+
+class ExtType(namedtuple('ExtType', 'code data')):
+    """ExtType represents ext type in msgpack."""
+    def __new__(cls, code, data):
+        if not isinstance(code, int):
+            raise TypeError("code must be int")
+        if not isinstance(data, bytes):
+            raise TypeError("data must be bytes")
+        if not 0 <= code <= 127:
+            raise ValueError("code must be 0~127")
+        return super(ExtType, cls).__new__(cls, code, data)
+
+
+import os
+if os.environ.get('MSGPACK_PUREPYTHON'):
+    from pip._vendor.msgpack.fallback import Packer, unpackb, Unpacker
+else:
+    try:
+        from pip._vendor.msgpack._packer import Packer
+        from pip._vendor.msgpack._unpacker import unpackb, Unpacker
+    except ImportError:
+        from pip._vendor.msgpack.fallback import Packer, unpackb, Unpacker
+
+
+def pack(o, stream, **kwargs):
+    """
+    Pack object `o` and write it to `stream`
+
+    See :class:`Packer` for options.
+    """
+    packer = Packer(**kwargs)
+    stream.write(packer.pack(o))
+
+
+def packb(o, **kwargs):
+    """
+    Pack object `o` and return packed bytes
+
+    See :class:`Packer` for options.
+    """
+    return Packer(**kwargs).pack(o)
+
+
+def unpack(stream, **kwargs):
+    """
+    Unpack an object from `stream`.
+
+    Raises `ExtraData` when `stream` contains extra bytes.
+    See :class:`Unpacker` for options.
+    """
+    data = stream.read()
+    return unpackb(data, **kwargs)
+
+
+# alias for compatibility to simplejson/marshal/pickle.
+load = unpack
+loads = unpackb
+
+dump = pack
+dumps = packb
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/msgpack/__init__.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/msgpack/__init__.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..3a48dd89d762608985016309179e6b6a5145dbfe
GIT binary patch
literal 2871
zcmZSn%**AGdLky70SZ_d7#JKF7#NDh85tN-7#LC*8FCmHav2$-7#SErd?tn*CWa6Y
zi<u#ZnIV^jA&P~8F@=R8m4zXNg&~ENp_z#xjgcXRjiH5sp_zdpGKv*!5IaK-8$%Qu
zLn<3X7CS>02SW-6Lo*{oQ5#s6lOczbA(x9Gii;tan<0vuA(w|Ciid$QFN&d33#@{R
zA%_>L0_+fOh8#Xrwc&ZX3@oYq4B1=^MfVvP8NteM8qCNLk-`IVW0U|x3NM%;$dJMZ
zW(YB)3Nb_pGo*4eM2Rq@3NS>8GNcMJM2Rt^urmZ}@G~$lWd8sE|Gx$!0|P?|I|Bnl
zS!z*nW_}(-03@mfVRA7rFytlXrlypX7UZOYmAY1xgj5!!7IQK%FeK-vq$;E&mL$R>
z0HoIm903dr45<vDa8F@ih++c8L<<8$6f;9mum%%IfjR>N1Jo>qqSS(-)Z)~<l46C_
ziV}sA%7Rpd%shqM;`D;V<ZQiUW(EcZ5N2UuU~mR$ZU#A=fuV+xp@b0>W5sd|C15+6
z85x=w8S)qyN*EYwm>5c!!Ll}BStd|~L1a^yL3&x3vl$ukgFz9W&B&0)#K6Q@oX$`J
zNd|C(SQ$##7-|?m24%5>7&VL_qnnu-f;HF}7#RGD1z<suTUuPAkOXpjNwE+E0|O{%
z6kvi$l_jagnV^K4Sr769NC7wiVG0cD42{e+I6z(lg?nakW?pegVqS7;3CQo6c_k&F
zFb4&`Yf({tQ3)uqgAFYKDGy7`DNRL46qgpH76pMcf@3W{J}<RAK3)SX03woeic3Jj
z3336L0dlJb$aP?%IG=%mLBF6Vvn;VBRlh8;NIxw<CndG0SU)L6zdR`^FV{4;*vK%+
zJiRL2!qlQXC#%ZL00h$W^h5LuG7EIUj?c-_bu07mG!6g>fpL6UYF<iykv=qT_2c6+
z^D;}~<Mj$EgFxN@;bK0JI~e()P==A8Q3K@G5>VL0$Ac1Nd_36G@$tF&DWy57@$pb!
zrsOBb$Ab+5djmlXh=)J{4RUia$n|WDY>a*-pjh_}b`NlL_Kpt-4RQ^L4Ds;ygTxCc
zH3cLlXQvi{eN&nTO8rS-Ux$L(sYT#y83Zx}oQr~l85kIXL_p~el&L`0fb8@Jr7ty5
zLIUT4UIvC*aDvZbWT;_g$YKJe;$}urc3@0lWPoPK2nGfQE(HYz1&|XI@{_VslS>p5
z@)Hyi^HLPbi!w`66*5Z{O7ayFic5-86LS-|z^a2&Qx&X|a}tY-tr9>wQ;QN5((;QG
z@(W5b^Ye=Jz=|Lq1iKrYY{ABXlO4#5kjMoU9r-1oFo2j3W@eWs7Nr-1nIM&^MFSk8
zVhjun@}STK1vLX34`VXO*`TloVQ{#Eq6Ad>Ff#NqFn~gw0Tj@|;Fv28#}~*&sU@XF
zc?w{UrYL~3HVI)2Nf4l<5d?B2gewk8ACe3V3<Dc(;7AAgD@hX+c%ZOiU;_soD7k_#
zIOsqQtzlru0@u8?OrXNOh6z+s_kvO>D5Q&fU;zlp5ekWUu%wz+l%ESvn|hFd3rfr^
zPAyhQaIGjQN_0sqNlZ{E&q&RKD^p0$&nrpH%mdduMTw9wha_3#bPcf!Ysv-(GdLv|
zr6#6;^CLJj2T8y}K8SbVgCCTuAjOFhDEz^Rmz{@E1C%^UWEdD23Nj1yphdGDv}gwL
z!L5QIP-$EuheK6rMRF=6tCw(t%Ax$6oYZ7+)(-+jGo%UvvGR+-rCMrUS!Pjw9=J|R
zPc6Y|ds<>nPEulWHn`9Lhby?8E0M<Gj(AY=N-Zjp#U&5%e`*ofnVz`?`9&q*>Jpq=
zf<VRwf%JmoGABPV1)OF<3`j+pQkq);76LJf5!ngM8i?8jTrb!_>OVVB02iw;Ffa%(
naxn=o%k%Is3NgwvF*6D<N-^>>Dll_$adL9<urabRu`vPwvU94y

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/msgpack/_version.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/msgpack/_version.py
new file mode 100644
index 0000000..d28f0de
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/msgpack/_version.py
@@ -0,0 +1 @@
+version = (0, 5, 6)
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/msgpack/_version.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/msgpack/_version.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..8cd57af49662b87a5ad109fed55811fab6889ac5
GIT binary patch
literal 251
zcmZSn%**AGdLky70ScHI7#JKF7#NDV7#J8*SQw%h7*d!Sf;Ctf7#K1^YBIqrHU<U;
zKMjy#G(inU1_p)_b_NE9vecsD%=|nJkR}9CoX^0(pkGjwS(aFms$Z5^q@R|blag9g
zte=#kU!Ihdmus3^Y-E^Zo?ex1VQNvHlT~GA00QZG`XTxSnFYF;dBr7(IXSv+Wgec!
x0U#kTjxS5iOUW<N&n-?bNKDSwkB8c?S5R5P!N9;^lbfGXnv-e=a$hmXO#r7xIYs~g

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/msgpack/exceptions.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/msgpack/exceptions.py
new file mode 100644
index 0000000..9766881
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/msgpack/exceptions.py
@@ -0,0 +1,41 @@
+class UnpackException(Exception):
+    """Deprecated.  Use Exception instead to catch all exception during unpacking."""
+
+
+class BufferFull(UnpackException):
+    pass
+
+
+class OutOfData(UnpackException):
+    pass
+
+
+class UnpackValueError(UnpackException, ValueError):
+    """Deprecated.  Use ValueError instead."""
+
+
+class ExtraData(UnpackValueError):
+    def __init__(self, unpacked, extra):
+        self.unpacked = unpacked
+        self.extra = extra
+
+    def __str__(self):
+        return "unpack(b) received extra data."
+
+
+class PackException(Exception):
+    """Deprecated.  Use Exception instead to catch all exception during packing."""
+
+
+class PackValueError(PackException, ValueError):
+    """PackValueError is raised when type of input data is supported but it's value is unsupported.
+
+    Deprecated.  Use ValueError instead.
+    """
+
+
+class PackOverflowError(PackValueError, OverflowError):
+    """PackOverflowError is raised when integer value is out of range of msgpack support [-2**31, 2**32).
+
+    Deprecated.  Use ValueError instead.
+    """
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/msgpack/exceptions.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/msgpack/exceptions.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..f6cec9a12735e058e913a10746e0197ae65c928f
GIT binary patch
literal 3313
zcmZSn%**AGdLky70ScHI7#JKF7#NE8GB7ZtFfgPtFr+auq%bnHFfcSTFhoW%GNdpu
zq%wj<nc<>L3@I!yQC7GpGeZg+NHmp&A&rS4g&i)z%8<grkje@+gcB~x#*o4VvydAu
z%Fd9&!;s3(05yacF2TW&!pD%x!H~)cHk}_X!Nrgwz!0n<$iTo*!q33K5Smwzn4Ile
zk(^pkl9`_e_bVd<1A`ODuY3$(kAnQhz!1g65EQHdk}LLRU|?`bEhtJ&PAo}H(Nj<e
zElyQ{o1>7KS6q^sn4(aUuaKNrlANKCn3JQB3bRHbrL-tBFI}M&Y<p&2x}F9oa7#EC
z7#QN?^AdAY<Ks)Xz?|Itl+qj!mmSPa$xn`t*8oKbf+#LzU|`TMD9S8LEJ@WbODxh)
z%g;$kEh^SeO3^P*O3KSM%`G-EOfpZeO1ChzD9_2NGBW^y^gR6#{esK_U65-Nb8>Xu
z$~-)c13*Gx9AB22my%zkpIe*`3MGBG`-}AoDuY0d00#vV0|NsaBiOx8rD<uYMQ)`z
zIhY{{@?0tdLlh$@3_+STKpKNUMg)Oa2oHf-1LP|f1_lOJP{f0r#Ku^{$-uziUs~dy
z=8{;FI8;3a@({=)#ZXTPz*Bx$VoqtQYf({t5vJd8C4CiaNgrVlEbT+mG$MY3KuH`N
zwFqK>BAJbWfq@q-l3goGiW0F$vJ`R|&;l+7Af;XuGbk;C0yP=rIS>YMoIys5F)%RH
zFf!CIFvK%3)G&b=jG$r@Qh@k@Q$IMzLrQ_vloC)hrGlIRDGfkLu{bp+EeMozf;br%
z7zR4vz|M`2&&<m#iH{co`4Z$t21ZWCWKcGSVX*%}GAWD<!C-&-70WR&FhD%2k))|m
zl$xBHS(cij0QRmzN@7W(9>jAXGlIAVgI^&9ZgELbd^{*F!Fh*)Q3K>Jq(sflz`zj1
zgW_JWM+PWmgB%U2+=@ZYWMkxHDFLPP0P^ZMPiz^T)H)7SbHHmjq<{lu7H~)*hye;S
zPzZstI5>vc7)wCq9w@{RMH=yCV>bf>1FBwy%wmP2#LVK<6ovAP)I5cf%7Rpd{4|Bk
zyn@maaLNa%C@w81$S*2MO;JcHEm6oUQ7={~0~O66xzaqitR5Gaf`WnqM#BT)RCwtN
zRtPRg24$dw0vS{$Kmwhm1e9n&0q0+qT9lTPUru73G!Yu^DB3}RhaB{oc_pdosYQs8
z%`YthMMY6!UOG5VpbZ@bXm~3`>l$fk85`;-fG8u);S>6xrmrff{03E5Y%G2npkfT%
z)`4elaQiL@REz|H>LqaV4w1})KvifEsI&<JWuG8Wbb^Z-ln4j{*@MX6VAjB7a&XOM
a18Gd#f$ErIkc-7wKv0rJj8lw7k{tl^NHkag

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/msgpack/fallback.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/msgpack/fallback.py
new file mode 100644
index 0000000..9418421
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/msgpack/fallback.py
@@ -0,0 +1,977 @@
+"""Fallback pure Python implementation of msgpack"""
+
+import sys
+import struct
+import warnings
+
+if sys.version_info[0] == 3:
+    PY3 = True
+    int_types = int
+    Unicode = str
+    xrange = range
+    def dict_iteritems(d):
+        return d.items()
+else:
+    PY3 = False
+    int_types = (int, long)
+    Unicode = unicode
+    def dict_iteritems(d):
+        return d.iteritems()
+
+
+if hasattr(sys, 'pypy_version_info'):
+    # cStringIO is slow on PyPy, StringIO is faster.  However: PyPy's own
+    # StringBuilder is fastest.
+    from __pypy__ import newlist_hint
+    try:
+        from __pypy__.builders import BytesBuilder as StringBuilder
+    except ImportError:
+        from __pypy__.builders import StringBuilder
+    USING_STRINGBUILDER = True
+    class StringIO(object):
+        def __init__(self, s=b''):
+            if s:
+                self.builder = StringBuilder(len(s))
+                self.builder.append(s)
+            else:
+                self.builder = StringBuilder()
+        def write(self, s):
+            if isinstance(s, memoryview):
+                s = s.tobytes()
+            elif isinstance(s, bytearray):
+                s = bytes(s)
+            self.builder.append(s)
+        def getvalue(self):
+            return self.builder.build()
+else:
+    USING_STRINGBUILDER = False
+    from io import BytesIO as StringIO
+    newlist_hint = lambda size: []
+
+
+from pip._vendor.msgpack.exceptions import (
+    BufferFull,
+    OutOfData,
+    UnpackValueError,
+    PackValueError,
+    PackOverflowError,
+    ExtraData)
+
+from pip._vendor.msgpack import ExtType
+
+
+EX_SKIP                 = 0
+EX_CONSTRUCT            = 1
+EX_READ_ARRAY_HEADER    = 2
+EX_READ_MAP_HEADER      = 3
+
+TYPE_IMMEDIATE          = 0
+TYPE_ARRAY              = 1
+TYPE_MAP                = 2
+TYPE_RAW                = 3
+TYPE_BIN                = 4
+TYPE_EXT                = 5
+
+DEFAULT_RECURSE_LIMIT = 511
+
+
+def _check_type_strict(obj, t, type=type, tuple=tuple):
+    if type(t) is tuple:
+        return type(obj) in t
+    else:
+        return type(obj) is t
+
+
+def _get_data_from_buffer(obj):
+    try:
+        view = memoryview(obj)
+    except TypeError:
+        # try to use legacy buffer protocol if 2.7, otherwise re-raise
+        if not PY3:
+            view = memoryview(buffer(obj))
+            warnings.warn("using old buffer interface to unpack %s; "
+                          "this leads to unpacking errors if slicing is used and "
+                          "will be removed in a future version" % type(obj),
+                          RuntimeWarning)
+        else:
+            raise
+    if view.itemsize != 1:
+        raise ValueError("cannot unpack from multi-byte object")
+    return view
+
+
+def unpack(stream, **kwargs):
+    warnings.warn(
+        "Direct calling implementation's unpack() is deprecated, Use msgpack.unpack() or unpackb() instead.",
+        PendingDeprecationWarning)
+    data = stream.read()
+    return unpackb(data, **kwargs)
+
+
+def unpackb(packed, **kwargs):
+    """
+    Unpack an object from `packed`.
+
+    Raises `ExtraData` when `packed` contains extra bytes.
+    See :class:`Unpacker` for options.
+    """
+    unpacker = Unpacker(None, **kwargs)
+    unpacker.feed(packed)
+    try:
+        ret = unpacker._unpack()
+    except OutOfData:
+        raise UnpackValueError("Data is not enough.")
+    if unpacker._got_extradata():
+        raise ExtraData(ret, unpacker._get_extradata())
+    return ret
+
+
+class Unpacker(object):
+    """Streaming unpacker.
+
+    arguments:
+
+    :param file_like:
+        File-like object having `.read(n)` method.
+        If specified, unpacker reads serialized data from it and :meth:`feed()` is not usable.
+
+    :param int read_size:
+        Used as `file_like.read(read_size)`. (default: `min(16*1024, max_buffer_size)`)
+
+    :param bool use_list:
+        If true, unpack msgpack array to Python list.
+        Otherwise, unpack to Python tuple. (default: True)
+
+    :param bool raw:
+        If true, unpack msgpack raw to Python bytes (default).
+        Otherwise, unpack to Python str (or unicode on Python 2) by decoding
+        with UTF-8 encoding (recommended).
+        Currently, the default is true, but it will be changed to false in
+        near future.  So you must specify it explicitly for keeping backward
+        compatibility.
+
+        *encoding* option which is deprecated overrides this option.
+
+    :param callable object_hook:
+        When specified, it should be callable.
+        Unpacker calls it with a dict argument after unpacking msgpack map.
+        (See also simplejson)
+
+    :param callable object_pairs_hook:
+        When specified, it should be callable.
+        Unpacker calls it with a list of key-value pairs after unpacking msgpack map.
+        (See also simplejson)
+
+    :param str encoding:
+        Encoding used for decoding msgpack raw.
+        If it is None (default), msgpack raw is deserialized to Python bytes.
+
+    :param str unicode_errors:
+        (deprecated) Used for decoding msgpack raw with *encoding*.
+        (default: `'strict'`)
+
+    :param int max_buffer_size:
+        Limits size of data waiting unpacked.  0 means system's INT_MAX (default).
+        Raises `BufferFull` exception when it is insufficient.
+        You should set this parameter when unpacking data from untrusted source.
+
+    :param int max_str_len:
+        Limits max length of str. (default: 2**31-1)
+
+    :param int max_bin_len:
+        Limits max length of bin. (default: 2**31-1)
+
+    :param int max_array_len:
+        Limits max length of array. (default: 2**31-1)
+
+    :param int max_map_len:
+        Limits max length of map. (default: 2**31-1)
+
+
+    example of streaming deserialize from file-like object::
+
+        unpacker = Unpacker(file_like, raw=False)
+        for o in unpacker:
+            process(o)
+
+    example of streaming deserialize from socket::
+
+        unpacker = Unpacker(raw=False)
+        while True:
+            buf = sock.recv(1024**2)
+            if not buf:
+                break
+            unpacker.feed(buf)
+            for o in unpacker:
+                process(o)
+    """
+
+    def __init__(self, file_like=None, read_size=0, use_list=True, raw=True,
+                 object_hook=None, object_pairs_hook=None, list_hook=None,
+                 encoding=None, unicode_errors=None, max_buffer_size=0,
+                 ext_hook=ExtType,
+                 max_str_len=2147483647, # 2**32-1
+                 max_bin_len=2147483647,
+                 max_array_len=2147483647,
+                 max_map_len=2147483647,
+                 max_ext_len=2147483647):
+
+        if encoding is not None:
+            warnings.warn(
+                "encoding is deprecated, Use raw=False instead.",
+                PendingDeprecationWarning)
+
+        if unicode_errors is None:
+            unicode_errors = 'strict'
+
+        if file_like is None:
+            self._feeding = True
+        else:
+            if not callable(file_like.read):
+                raise TypeError("`file_like.read` must be callable")
+            self.file_like = file_like
+            self._feeding = False
+
+        #: array of bytes fed.
+        self._buffer = bytearray()
+        # Some very old pythons don't support `struct.unpack_from()` with a
+        # `bytearray`. So we wrap it in a `buffer()` there.
+        if sys.version_info < (2, 7, 6):
+            self._buffer_view = buffer(self._buffer)
+        else:
+            self._buffer_view = self._buffer
+        #: Which position we currently reads
+        self._buff_i = 0
+
+        # When Unpacker is used as an iterable, between the calls to next(),
+        # the buffer is not "consumed" completely, for efficiency sake.
+        # Instead, it is done sloppily.  To make sure we raise BufferFull at
+        # the correct moments, we have to keep track of how sloppy we were.
+        # Furthermore, when the buffer is incomplete (that is: in the case
+        # we raise an OutOfData) we need to rollback the buffer to the correct
+        # state, which _buf_checkpoint records.
+        self._buf_checkpoint = 0
+
+        self._max_buffer_size = max_buffer_size or 2**31-1
+        if read_size > self._max_buffer_size:
+            raise ValueError("read_size must be smaller than max_buffer_size")
+        self._read_size = read_size or min(self._max_buffer_size, 16*1024)
+        self._raw = bool(raw)
+        self._encoding = encoding
+        self._unicode_errors = unicode_errors
+        self._use_list = use_list
+        self._list_hook = list_hook
+        self._object_hook = object_hook
+        self._object_pairs_hook = object_pairs_hook
+        self._ext_hook = ext_hook
+        self._max_str_len = max_str_len
+        self._max_bin_len = max_bin_len
+        self._max_array_len = max_array_len
+        self._max_map_len = max_map_len
+        self._max_ext_len = max_ext_len
+        self._stream_offset = 0
+
+        if list_hook is not None and not callable(list_hook):
+            raise TypeError('`list_hook` is not callable')
+        if object_hook is not None and not callable(object_hook):
+            raise TypeError('`object_hook` is not callable')
+        if object_pairs_hook is not None and not callable(object_pairs_hook):
+            raise TypeError('`object_pairs_hook` is not callable')
+        if object_hook is not None and object_pairs_hook is not None:
+            raise TypeError("object_pairs_hook and object_hook are mutually "
+                            "exclusive")
+        if not callable(ext_hook):
+            raise TypeError("`ext_hook` is not callable")
+
+    def feed(self, next_bytes):
+        assert self._feeding
+        view = _get_data_from_buffer(next_bytes)
+        if (len(self._buffer) - self._buff_i + len(view) > self._max_buffer_size):
+            raise BufferFull
+
+        # Strip buffer before checkpoint before reading file.
+        if self._buf_checkpoint > 0:
+            del self._buffer[:self._buf_checkpoint]
+            self._buff_i -= self._buf_checkpoint
+            self._buf_checkpoint = 0
+
+        self._buffer += view
+
+    def _consume(self):
+        """ Gets rid of the used parts of the buffer. """
+        self._stream_offset += self._buff_i - self._buf_checkpoint
+        self._buf_checkpoint = self._buff_i
+
+    def _got_extradata(self):
+        return self._buff_i < len(self._buffer)
+
+    def _get_extradata(self):
+        return self._buffer[self._buff_i:]
+
+    def read_bytes(self, n):
+        return self._read(n)
+
+    def _read(self, n):
+        # (int) -> bytearray
+        self._reserve(n)
+        i = self._buff_i
+        self._buff_i = i+n
+        return self._buffer[i:i+n]
+
+    def _reserve(self, n):
+        remain_bytes = len(self._buffer) - self._buff_i - n
+
+        # Fast path: buffer has n bytes already
+        if remain_bytes >= 0:
+            return
+
+        if self._feeding:
+            self._buff_i = self._buf_checkpoint
+            raise OutOfData
+
+        # Strip buffer before checkpoint before reading file.
+        if self._buf_checkpoint > 0:
+            del self._buffer[:self._buf_checkpoint]
+            self._buff_i -= self._buf_checkpoint
+            self._buf_checkpoint = 0
+
+        # Read from file
+        remain_bytes = -remain_bytes
+        while remain_bytes > 0:
+            to_read_bytes = max(self._read_size, remain_bytes)
+            read_data = self.file_like.read(to_read_bytes)
+            if not read_data:
+                break
+            assert isinstance(read_data, bytes)
+            self._buffer += read_data
+            remain_bytes -= len(read_data)
+
+        if len(self._buffer) < n + self._buff_i:
+            self._buff_i = 0  # rollback
+            raise OutOfData
+
+    def _read_header(self, execute=EX_CONSTRUCT):
+        typ = TYPE_IMMEDIATE
+        n = 0
+        obj = None
+        self._reserve(1)
+        b = self._buffer[self._buff_i]
+        self._buff_i += 1
+        if b & 0b10000000 == 0:
+            obj = b
+        elif b & 0b11100000 == 0b11100000:
+            obj = -1 - (b ^ 0xff)
+        elif b & 0b11100000 == 0b10100000:
+            n = b & 0b00011111
+            typ = TYPE_RAW
+            if n > self._max_str_len:
+                raise UnpackValueError("%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 UnpackValueError("%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 UnpackValueError("%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 UnpackValueError("%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 = struct.unpack_from(">H", self._buffer_view, self._buff_i)[0]
+            self._buff_i += 2
+            if n > self._max_bin_len:
+                raise UnpackValueError("%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 = struct.unpack_from(">I", self._buffer_view, self._buff_i)[0]
+            self._buff_i += 4
+            if n > self._max_bin_len:
+                raise UnpackValueError("%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 = struct.unpack_from('Bb', self._buffer_view, self._buff_i)
+            self._buff_i += 2
+            if L > self._max_ext_len:
+                raise UnpackValueError("%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 = struct.unpack_from('>Hb', self._buffer_view, self._buff_i)
+            self._buff_i += 3
+            if L > self._max_ext_len:
+                raise UnpackValueError("%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 = struct.unpack_from('>Ib', self._buffer_view, self._buff_i)
+            self._buff_i += 5
+            if L > self._max_ext_len:
+                raise UnpackValueError("%s exceeds max_ext_len(%s)" % (L, self._max_ext_len))
+            obj = self._read(L)
+        elif b == 0xca:
+            self._reserve(4)
+            obj = struct.unpack_from(">f", self._buffer_view, self._buff_i)[0]
+            self._buff_i += 4
+        elif b == 0xcb:
+            self._reserve(8)
+            obj = struct.unpack_from(">d", self._buffer_view, 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 = struct.unpack_from(">H", self._buffer_view, self._buff_i)[0]
+            self._buff_i += 2
+        elif b == 0xce:
+            self._reserve(4)
+            obj = struct.unpack_from(">I", self._buffer_view, self._buff_i)[0]
+            self._buff_i += 4
+        elif b == 0xcf:
+            self._reserve(8)
+            obj = struct.unpack_from(">Q", self._buffer_view, self._buff_i)[0]
+            self._buff_i += 8
+        elif b == 0xd0:
+            self._reserve(1)
+            obj = struct.unpack_from("b", self._buffer_view, self._buff_i)[0]
+            self._buff_i += 1
+        elif b == 0xd1:
+            self._reserve(2)
+            obj = struct.unpack_from(">h", self._buffer_view, self._buff_i)[0]
+            self._buff_i += 2
+        elif b == 0xd2:
+            self._reserve(4)
+            obj = struct.unpack_from(">i", self._buffer_view, self._buff_i)[0]
+            self._buff_i += 4
+        elif b == 0xd3:
+            self._reserve(8)
+            obj = struct.unpack_from(">q", self._buffer_view, self._buff_i)[0]
+            self._buff_i += 8
+        elif b == 0xd4:  # fixext 1
+            typ = TYPE_EXT
+            if self._max_ext_len < 1:
+                raise UnpackValueError("%s exceeds max_ext_len(%s)" % (1, self._max_ext_len))
+            self._reserve(2)
+            n, obj = struct.unpack_from("b1s", self._buffer_view, self._buff_i)
+            self._buff_i += 2
+        elif b == 0xd5:  # fixext 2
+            typ = TYPE_EXT
+            if self._max_ext_len < 2:
+                raise UnpackValueError("%s exceeds max_ext_len(%s)" % (2, self._max_ext_len))
+            self._reserve(3)
+            n, obj = struct.unpack_from("b2s", self._buffer_view, self._buff_i)
+            self._buff_i += 3
+        elif b == 0xd6:  # fixext 4
+            typ = TYPE_EXT
+            if self._max_ext_len < 4:
+                raise UnpackValueError("%s exceeds max_ext_len(%s)" % (4, self._max_ext_len))
+            self._reserve(5)
+            n, obj = struct.unpack_from("b4s", self._buffer_view, self._buff_i)
+            self._buff_i += 5
+        elif b == 0xd7:  # fixext 8
+            typ = TYPE_EXT
+            if self._max_ext_len < 8:
+                raise UnpackValueError("%s exceeds max_ext_len(%s)" % (8, self._max_ext_len))
+            self._reserve(9)
+            n, obj = struct.unpack_from("b8s", self._buffer_view, self._buff_i)
+            self._buff_i += 9
+        elif b == 0xd8:  # fixext 16
+            typ = TYPE_EXT
+            if self._max_ext_len < 16:
+                raise UnpackValueError("%s exceeds max_ext_len(%s)" % (16, self._max_ext_len))
+            self._reserve(17)
+            n, obj = struct.unpack_from("b16s", self._buffer_view, 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 UnpackValueError("%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, = struct.unpack_from(">H", self._buffer_view, self._buff_i)
+            self._buff_i += 2
+            if n > self._max_str_len:
+                raise UnpackValueError("%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, = struct.unpack_from(">I", self._buffer_view, self._buff_i)
+            self._buff_i += 4
+            if n > self._max_str_len:
+                raise UnpackValueError("%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, = struct.unpack_from(">H", self._buffer_view, self._buff_i)
+            self._buff_i += 2
+            if n > self._max_array_len:
+                raise UnpackValueError("%s exceeds max_array_len(%s)", n, self._max_array_len)
+        elif b == 0xdd:
+            typ = TYPE_ARRAY
+            self._reserve(4)
+            n, = struct.unpack_from(">I", self._buffer_view, self._buff_i)
+            self._buff_i += 4
+            if n > self._max_array_len:
+                raise UnpackValueError("%s exceeds max_array_len(%s)", n, self._max_array_len)
+        elif b == 0xde:
+            self._reserve(2)
+            n, = struct.unpack_from(">H", self._buffer_view, self._buff_i)
+            self._buff_i += 2
+            if n > self._max_map_len:
+                raise UnpackValueError("%s exceeds max_map_len(%s)", n, self._max_map_len)
+            typ = TYPE_MAP
+        elif b == 0xdf:
+            self._reserve(4)
+            n, = struct.unpack_from(">I", self._buffer_view, self._buff_i)
+            self._buff_i += 4
+            if n > self._max_map_len:
+                raise UnpackValueError("%s exceeds max_map_len(%s)", n, self._max_map_len)
+            typ = TYPE_MAP
+        else:
+            raise UnpackValueError("Unknown header: 0x%x" % b)
+        return typ, n, obj
+
+    def _unpack(self, execute=EX_CONSTRUCT):
+        typ, n, obj = self._read_header(execute)
+
+        if execute == EX_READ_ARRAY_HEADER:
+            if typ != TYPE_ARRAY:
+                raise UnpackValueError("Expected array")
+            return n
+        if execute == EX_READ_MAP_HEADER:
+            if typ != TYPE_MAP:
+                raise UnpackValueError("Expected map")
+            return n
+        # TODO should we eliminate the recursion?
+        if typ == TYPE_ARRAY:
+            if execute == EX_SKIP:
+                for i in xrange(n):
+                    # TODO check whether we need to call `list_hook`
+                    self._unpack(EX_SKIP)
+                return
+            ret = newlist_hint(n)
+            for i in xrange(n):
+                ret.append(self._unpack(EX_CONSTRUCT))
+            if self._list_hook is not None:
+                ret = self._list_hook(ret)
+            # TODO is the interaction between `list_hook` and `use_list` ok?
+            return ret if self._use_list else tuple(ret)
+        if typ == TYPE_MAP:
+            if execute == EX_SKIP:
+                for i in xrange(n):
+                    # TODO check whether we need to call hooks
+                    self._unpack(EX_SKIP)
+                    self._unpack(EX_SKIP)
+                return
+            if self._object_pairs_hook is not None:
+                ret = self._object_pairs_hook(
+                    (self._unpack(EX_CONSTRUCT),
+                     self._unpack(EX_CONSTRUCT))
+                    for _ in xrange(n))
+            else:
+                ret = {}
+                for _ in xrange(n):
+                    key = self._unpack(EX_CONSTRUCT)
+                    ret[key] = self._unpack(EX_CONSTRUCT)
+                if self._object_hook is not None:
+                    ret = self._object_hook(ret)
+            return ret
+        if execute == EX_SKIP:
+            return
+        if typ == TYPE_RAW:
+            if self._encoding is not None:
+                obj = obj.decode(self._encoding, self._unicode_errors)
+            elif self._raw:
+                obj = bytes(obj)
+            else:
+                obj = obj.decode('utf_8')
+            return obj
+        if typ == TYPE_EXT:
+            return self._ext_hook(n, bytes(obj))
+        if typ == TYPE_BIN:
+            return bytes(obj)
+        assert typ == TYPE_IMMEDIATE
+        return obj
+
+    def __iter__(self):
+        return self
+
+    def __next__(self):
+        try:
+            ret = self._unpack(EX_CONSTRUCT)
+            self._consume()
+            return ret
+        except OutOfData:
+            self._consume()
+            raise StopIteration
+
+    next = __next__
+
+    def skip(self, write_bytes=None):
+        self._unpack(EX_SKIP)
+        if write_bytes is not None:
+            warnings.warn("`write_bytes` option is deprecated.  Use `.tell()` instead.", DeprecationWarning)
+            write_bytes(self._buffer[self._buf_checkpoint:self._buff_i])
+        self._consume()
+
+    def unpack(self, write_bytes=None):
+        ret = self._unpack(EX_CONSTRUCT)
+        if write_bytes is not None:
+            warnings.warn("`write_bytes` option is deprecated.  Use `.tell()` instead.", DeprecationWarning)
+            write_bytes(self._buffer[self._buf_checkpoint:self._buff_i])
+        self._consume()
+        return ret
+
+    def read_array_header(self, write_bytes=None):
+        ret = self._unpack(EX_READ_ARRAY_HEADER)
+        if write_bytes is not None:
+            warnings.warn("`write_bytes` option is deprecated.  Use `.tell()` instead.", DeprecationWarning)
+            write_bytes(self._buffer[self._buf_checkpoint:self._buff_i])
+        self._consume()
+        return ret
+
+    def read_map_header(self, write_bytes=None):
+        ret = self._unpack(EX_READ_MAP_HEADER)
+        if write_bytes is not None:
+            warnings.warn("`write_bytes` option is deprecated.  Use `.tell()` instead.", DeprecationWarning)
+            write_bytes(self._buffer[self._buf_checkpoint:self._buff_i])
+        self._consume()
+        return ret
+
+    def tell(self):
+        return self._stream_offset
+
+
+class Packer(object):
+    """
+    MessagePack Packer
+
+    usage:
+
+        packer = Packer()
+        astream.write(packer.pack(a))
+        astream.write(packer.pack(b))
+
+    Packer's constructor has some keyword arguments:
+
+    :param callable default:
+        Convert user type to builtin type that Packer supports.
+        See also simplejson's document.
+
+    :param bool use_single_float:
+        Use single precision float type for float. (default: False)
+
+    :param bool autoreset:
+        Reset buffer after each pack and return its content as `bytes`. (default: True).
+        If set this to false, use `bytes()` to get content and `.reset()` to clear buffer.
+
+    :param bool use_bin_type:
+        Use bin type introduced in msgpack spec 2.0 for bytes.
+        It also enables str8 type for unicode.
+
+    :param bool strict_types:
+        If set to true, types will be checked to be exact. Derived classes
+        from serializeable types will not be serialized and will be
+        treated as unsupported type and forwarded to default.
+        Additionally tuples will not be serialized as lists.
+        This is useful when trying to implement accurate serialization
+        for python types.
+
+    :param str encoding:
+        (deprecated) Convert unicode to bytes with this encoding. (default: 'utf-8')
+
+    :param str unicode_errors:
+        Error handler for encoding unicode. (default: 'strict')
+    """
+    def __init__(self, default=None, encoding=None, unicode_errors=None,
+                 use_single_float=False, autoreset=True, use_bin_type=False,
+                 strict_types=False):
+        if encoding is None:
+            encoding = 'utf_8'
+        else:
+            warnings.warn(
+                "encoding is deprecated, Use raw=False instead.",
+                PendingDeprecationWarning)
+
+        if unicode_errors is None:
+            unicode_errors = 'strict'
+
+        self._strict_types = strict_types
+        self._use_float = use_single_float
+        self._autoreset = autoreset
+        self._use_bin_type = use_bin_type
+        self._encoding = encoding
+        self._unicode_errors = unicode_errors
+        self._buffer = StringIO()
+        if default is not None:
+            if not callable(default):
+                raise TypeError("default must be callable")
+        self._default = default
+
+    def _pack(self, obj, nest_limit=DEFAULT_RECURSE_LIMIT,
+              check=isinstance, check_type_strict=_check_type_strict):
+        default_used = False
+        if self._strict_types:
+            check = check_type_strict
+            list_types = list
+        else:
+            list_types = (list, tuple)
+        while True:
+            if nest_limit < 0:
+                raise PackValueError("recursion limit exceeded")
+            if obj is None:
+                return self._buffer.write(b"\xc0")
+            if check(obj, bool):
+                if obj:
+                    return self._buffer.write(b"\xc3")
+                return self._buffer.write(b"\xc2")
+            if check(obj, int_types):
+                if 0 <= obj < 0x80:
+                    return self._buffer.write(struct.pack("B", obj))
+                if -0x20 <= obj < 0:
+                    return self._buffer.write(struct.pack("b", obj))
+                if 0x80 <= obj <= 0xff:
+                    return self._buffer.write(struct.pack("BB", 0xcc, obj))
+                if -0x80 <= obj < 0:
+                    return self._buffer.write(struct.pack(">Bb", 0xd0, obj))
+                if 0xff < obj <= 0xffff:
+                    return self._buffer.write(struct.pack(">BH", 0xcd, obj))
+                if -0x8000 <= obj < -0x80:
+                    return self._buffer.write(struct.pack(">Bh", 0xd1, obj))
+                if 0xffff < obj <= 0xffffffff:
+                    return self._buffer.write(struct.pack(">BI", 0xce, obj))
+                if -0x80000000 <= obj < -0x8000:
+                    return self._buffer.write(struct.pack(">Bi", 0xd2, obj))
+                if 0xffffffff < obj <= 0xffffffffffffffff:
+                    return self._buffer.write(struct.pack(">BQ", 0xcf, obj))
+                if -0x8000000000000000 <= obj < -0x80000000:
+                    return self._buffer.write(struct.pack(">Bq", 0xd3, obj))
+                if not default_used and self._default is not None:
+                    obj = self._default(obj)
+                    default_used = True
+                    continue
+                raise PackOverflowError("Integer value out of range")
+            if check(obj, (bytes, bytearray)):
+                n = len(obj)
+                if n >= 2**32:
+                    raise PackValueError("%s is too large" % type(obj).__name__)
+                self._pack_bin_header(n)
+                return self._buffer.write(obj)
+            if check(obj, Unicode):
+                if self._encoding is None:
+                    raise TypeError(
+                        "Can't encode unicode string: "
+                        "no encoding is specified")
+                obj = obj.encode(self._encoding, self._unicode_errors)
+                n = len(obj)
+                if n >= 2**32:
+                    raise PackValueError("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:
+                    raise PackValueError("Memoryview is too large")
+                self._pack_bin_header(n)
+                return self._buffer.write(obj)
+            if check(obj, float):
+                if self._use_float:
+                    return self._buffer.write(struct.pack(">Bf", 0xca, obj))
+                return self._buffer.write(struct.pack(">Bd", 0xcb, obj))
+            if check(obj, ExtType):
+                code = obj.code
+                data = obj.data
+                assert isinstance(code, int)
+                assert isinstance(data, bytes)
+                L = len(data)
+                if L == 1:
+                    self._buffer.write(b'\xd4')
+                elif L == 2:
+                    self._buffer.write(b'\xd5')
+                elif L == 4:
+                    self._buffer.write(b'\xd6')
+                elif L == 8:
+                    self._buffer.write(b'\xd7')
+                elif L == 16:
+                    self._buffer.write(b'\xd8')
+                elif L <= 0xff:
+                    self._buffer.write(struct.pack(">BB", 0xc7, L))
+                elif L <= 0xffff:
+                    self._buffer.write(struct.pack(">BH", 0xc8, L))
+                else:
+                    self._buffer.write(struct.pack(">BI", 0xc9, L))
+                self._buffer.write(struct.pack("b", code))
+                self._buffer.write(data)
+                return
+            if check(obj, list_types):
+                n = len(obj)
+                self._pack_array_header(n)
+                for i in xrange(n):
+                    self._pack(obj[i], nest_limit - 1)
+                return
+            if check(obj, dict):
+                return self._pack_map_pairs(len(obj), dict_iteritems(obj),
+                                               nest_limit - 1)
+            if not default_used and self._default is not None:
+                obj = self._default(obj)
+                default_used = 1
+                continue
+            raise TypeError("Cannot serialize %r" % (obj, ))
+
+    def pack(self, obj):
+        try:
+            self._pack(obj)
+        except:
+            self._buffer = StringIO()  # force reset
+            raise
+        ret = self._buffer.getvalue()
+        if self._autoreset:
+            self._buffer = StringIO()
+        elif USING_STRINGBUILDER:
+            self._buffer = StringIO(ret)
+        return ret
+
+    def pack_map_pairs(self, pairs):
+        self._pack_map_pairs(len(pairs), pairs)
+        ret = self._buffer.getvalue()
+        if self._autoreset:
+            self._buffer = StringIO()
+        elif USING_STRINGBUILDER:
+            self._buffer = StringIO(ret)
+        return ret
+
+    def pack_array_header(self, n):
+        if n >= 2**32:
+            raise PackValueError
+        self._pack_array_header(n)
+        ret = self._buffer.getvalue()
+        if self._autoreset:
+            self._buffer = StringIO()
+        elif USING_STRINGBUILDER:
+            self._buffer = StringIO(ret)
+        return ret
+
+    def pack_map_header(self, n):
+        if n >= 2**32:
+            raise PackValueError
+        self._pack_map_header(n)
+        ret = self._buffer.getvalue()
+        if self._autoreset:
+            self._buffer = StringIO()
+        elif USING_STRINGBUILDER:
+            self._buffer = StringIO(ret)
+        return ret
+
+    def pack_ext_type(self, typecode, data):
+        if not isinstance(typecode, int):
+            raise TypeError("typecode must have int type.")
+        if not 0 <= typecode <= 127:
+            raise ValueError("typecode should be 0-127")
+        if not isinstance(data, bytes):
+            raise TypeError("data must have bytes type")
+        L = len(data)
+        if L > 0xffffffff:
+            raise PackValueError("Too large data")
+        if L == 1:
+            self._buffer.write(b'\xd4')
+        elif L == 2:
+            self._buffer.write(b'\xd5')
+        elif L == 4:
+            self._buffer.write(b'\xd6')
+        elif L == 8:
+            self._buffer.write(b'\xd7')
+        elif L == 16:
+            self._buffer.write(b'\xd8')
+        elif L <= 0xff:
+            self._buffer.write(b'\xc7' + struct.pack('B', L))
+        elif L <= 0xffff:
+            self._buffer.write(b'\xc8' + struct.pack('>H', L))
+        else:
+            self._buffer.write(b'\xc9' + struct.pack('>I', L))
+        self._buffer.write(struct.pack('B', typecode))
+        self._buffer.write(data)
+
+    def _pack_array_header(self, n):
+        if n <= 0x0f:
+            return self._buffer.write(struct.pack('B', 0x90 + n))
+        if n <= 0xffff:
+            return self._buffer.write(struct.pack(">BH", 0xdc, n))
+        if n <= 0xffffffff:
+            return self._buffer.write(struct.pack(">BI", 0xdd, n))
+        raise PackValueError("Array is too large")
+
+    def _pack_map_header(self, n):
+        if n <= 0x0f:
+            return self._buffer.write(struct.pack('B', 0x80 + n))
+        if n <= 0xffff:
+            return self._buffer.write(struct.pack(">BH", 0xde, n))
+        if n <= 0xffffffff:
+            return self._buffer.write(struct.pack(">BI", 0xdf, n))
+        raise PackValueError("Dict is too large")
+
+    def _pack_map_pairs(self, n, pairs, nest_limit=DEFAULT_RECURSE_LIMIT):
+        self._pack_map_header(n)
+        for (k, v) in pairs:
+            self._pack(k, nest_limit - 1)
+            self._pack(v, nest_limit - 1)
+
+    def _pack_raw_header(self, n):
+        if n <= 0x1f:
+            self._buffer.write(struct.pack('B', 0xa0 + n))
+        elif self._use_bin_type and n <= 0xff:
+            self._buffer.write(struct.pack('>BB', 0xd9, n))
+        elif n <= 0xffff:
+            self._buffer.write(struct.pack(">BH", 0xda, n))
+        elif n <= 0xffffffff:
+            self._buffer.write(struct.pack(">BI", 0xdb, n))
+        else:
+            raise PackValueError('Raw is too large')
+
+    def _pack_bin_header(self, n):
+        if not self._use_bin_type:
+            return self._pack_raw_header(n)
+        elif n <= 0xff:
+            return self._buffer.write(struct.pack('>BB', 0xc4, n))
+        elif n <= 0xffff:
+            return self._buffer.write(struct.pack(">BH", 0xc5, n))
+        elif n <= 0xffffffff:
+            return self._buffer.write(struct.pack(">BI", 0xc6, n))
+        else:
+            raise PackValueError('Bin is too large')
+
+    def bytes(self):
+        return self._buffer.getvalue()
+
+    def reset(self):
+        self._buffer = StringIO()
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/msgpack/fallback.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/msgpack/fallback.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..b1992318b1e890cb5ba4d3b52dc3e08118b6c995
GIT binary patch
literal 32803
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

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/packaging/__about__.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/packaging/__about__.py
new file mode 100644
index 0000000..7481c9e
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/packaging/__about__.py
@@ -0,0 +1,27 @@
+# This file is dual licensed under the terms of the Apache License, Version
+# 2.0, and the BSD License. See the LICENSE file in the root of this repository
+# for complete details.
+from __future__ import absolute_import, division, print_function
+
+__all__ = [
+    "__title__",
+    "__summary__",
+    "__uri__",
+    "__version__",
+    "__author__",
+    "__email__",
+    "__license__",
+    "__copyright__",
+]
+
+__title__ = "packaging"
+__summary__ = "Core utilities for Python packages"
+__uri__ = "https://github.com/pypa/packaging"
+
+__version__ = "19.0"
+
+__author__ = "Donald Stufft and individual contributors"
+__email__ = "donald@stufft.io"
+
+__license__ = "BSD or Apache License, Version 2.0"
+__copyright__ = "Copyright 2014-2019 %s" % __author__
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/packaging/__about__.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/packaging/__about__.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..d8870ad27f956e7ff0bc2575a81bef55326b4a47
GIT binary patch
literal 841
zcmZSn%**AGdLky70SY)67#JK97#WI-7#J8*7#LC*8FCmHav2$-7#VVz7^0XMa+w*T
zm>C#Tm>5!+8B$mnQdk*M*cejS8B#bHQaBmXIT)f?7*e<xqF5PHxEZ3@7*co`qSzTy
zcp0KN7*hBcqBt2+_!*+O7*YfnqPQ7S1Q}8}8N{M^7*d27f;EI07#K1^ZqZ<7U|=ZW
zXJBAROe)ULDJ@Bj&&(~zFDfYkIWZ-(EVDQ>Kd*$3fq|i*C^N4lKCLt_xdbG{$-ux6
zA77GLl9L)AU&0OM6_@7bCKgr3$Ct2!`K3jfaJjP7B9Kw>@g-bfxx~_vjQpbb_!5Xg
zskw=nIdH`}naQbn#UO)u!HSdf3o45;(=$q->I)K+vlG)Z^U{lz7#J9w^NUgyN=q_x
zGD|X3ixtxHixdJXOEU8F6d>wSi;EQ*7#K22N(zdt^!3v-OEOB6^pf*)^$RKs67?a9
zK!&j}FfbTe>KPPkGB7Z><mV;kq$mWJl%}PXC?w{kC}ie=0wkq0F-IXeKd+=HGpV#B
zzo@ua02GN})egmA)q0uvV23#cyC~!rDL57+CTFB7_&_|RqYwrO3I!uQgJLnT`=P#5
zFfuSS(KRwKv{X<n_R|3Q9U59`r6r|Bsqyhaphyd1WME(jVgkh+B%Bj-a^mBIKv5Y4
z@<I?RNS+NufaHTfQ5ggZ<{(heYk-VE5a1-JUr>};mRORiUzS*;pO&AKl3G-(pOm6s
zo|KfAYnoeZWSC^0UX^ZPYEhn(Rb^%X0_l1BA^HWG1-hAe#U+V3Il69T9-hVlAR#c0
zFH6l!$uB|#uYP=dVp4u-NqoFsK_xhS+2rP@l;)(`fgD||z`(#D!_3Tx3^|$E7}*%v
KnAn)WBqIQpanDEq

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/packaging/__init__.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/packaging/__init__.py
new file mode 100644
index 0000000..a0cf67d
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/packaging/__init__.py
@@ -0,0 +1,26 @@
+# This file is dual licensed under the terms of the Apache License, Version
+# 2.0, and the BSD License. See the LICENSE file in the root of this repository
+# for complete details.
+from __future__ import absolute_import, division, print_function
+
+from .__about__ import (
+    __author__,
+    __copyright__,
+    __email__,
+    __license__,
+    __summary__,
+    __title__,
+    __uri__,
+    __version__,
+)
+
+__all__ = [
+    "__title__",
+    "__summary__",
+    "__uri__",
+    "__version__",
+    "__author__",
+    "__email__",
+    "__license__",
+    "__copyright__",
+]
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/packaging/__init__.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/packaging/__init__.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..b90467cb34d63efd20465654eb4be5bca6e07c22
GIT binary patch
literal 663
zcmZSn%**AGdLky70SY)67#JK97#WHy7#J8*7#LC*8FCmHav2$-7#VVz7^0XMa+w*T
zm>C#Tm>5!+8FE+{a#<OoSQ&EJ7^2u1a@iT8*coy;7@{~Bayc2II2m%e7^1isa=96z
zxEXSJ7@~L>7*kjnQdk*M*cejS8B#bHQaBk>xENBn8PYizqIelnco>2;co`TNGC?lV
zU}j)oDB)*dU`R|V&d(_=NsZ6UEyyn_DFHb&C9^EEI5R)5gpYxNp`a);uOvRLG%vX%
zGe0krk%56h1Ei>gi-Cb5K0dLuBqP5lKE4EGc6@wtenDkXW_m_Re0&KfSV3xTVrEW!
zd<i$0my?;Cnpd0(=NFge<|Y<Z!c~`KmgInB*}<wyi!$LV%TkL#Zi<f&0@)q}QV;~P
zAqeD-Adr88SQ!`?g4jR=3j+g#p9aYJP-mu<mXsEy#>WSNd>;hzL=Y1w2tX#p$0sJ`
zmzKoGLrekbMKTI(5!gzQTCi;;AhG!P#GIV?cny$&2%@-<fq_B4peVB}u_RT$EU`#G
zEk7qEwWwG>DMi0LDJd`4G`HBuFv&c<D&4}=qC6+7%FF-+()08~^b0ZzbTjjcOA>Q(
zblu84JdFcDLSP(UmYSE6U!-4<n4F!Mo|%`fA0MBYmst`YuUAkBjy0Ry{FKt1R6CIS
Ri-i~%7-X2Nc$gWHApl>Ujg0^R

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/packaging/_compat.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/packaging/_compat.py
new file mode 100644
index 0000000..25da473
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/packaging/_compat.py
@@ -0,0 +1,31 @@
+# This file is dual licensed under the terms of the Apache License, Version
+# 2.0, and the BSD License. See the LICENSE file in the root of this repository
+# for complete details.
+from __future__ import absolute_import, division, print_function
+
+import sys
+
+
+PY2 = sys.version_info[0] == 2
+PY3 = sys.version_info[0] == 3
+
+# flake8: noqa
+
+if PY3:
+    string_types = (str,)
+else:
+    string_types = (basestring,)
+
+
+def with_metaclass(meta, *bases):
+    """
+    Create a base class with a metaclass.
+    """
+    # This requires a bit of explanation: the basic idea is to make a dummy
+    # metaclass for one level of class instantiation that replaces itself with
+    # the actual metaclass.
+    class metaclass(meta):
+        def __new__(cls, name, this_bases, d):
+            return meta(name, bases, d)
+
+    return type.__new__(metaclass, "temporary_class", (), {})
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/packaging/_compat.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/packaging/_compat.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..5c5437f3b8ddb4f513d3274e8d5512c5703fc2e1
GIT binary patch
literal 1404
zcmZSn%**AGdLky70ScHH7#JK97#WJo7#J8*7#LC*8FCmHav2$-7#VVz7^0XMa+w*T
zm>C#Ba!d?4EDTXB45=&(S*#${k}1p#*-Q*kY{)_^U?FyfRCb1<1cp=&hBQWoC{Bhv
zPKH!2C_9Cfp@o4Vikl&Yi6K~nje&t76XYHZW(Ed^5`G2-hQy@e{G8H~)cDNYg8ZVA
z5)P2-GRrcHGxPIG_!t-%3W_rGO5)Q>^O8$4^Yi>NLH@`DX-{TkU|;|-SQ!`?*g-xs
z1?gpE=wJj{-p;_#&d89)1hTn}fuWg!A+nZ<p@e}Ui;<y*i6MoVA%z9xm}VA+U=5HF
z#rg~k3|tBd3JT6esfi`23W*9yiN&c3$vKI|#R}z_B^e5d3c0BziC_Ueu*won1_lPW
z7)n?(fm|fTz`&5o019G+a~K%f7(l@t6s!UAK{5*i0|N{TgER>+Fo66}!^qIVz)-`?
z(9FyLQR=4w4m*(I5|GD}bBaqqoV>)`)DkXGh-PFK$AcVQTmmvWMFSLAB_Pj11VM^H
zt_7P@T)@D<pkGjwS(aFms$Z5^q@R|blag9gte=#kU!Ihdmus3^Y-E^Zo?ex1VQNvH
zlT~GA00QZG`XTxSnFYF;dBr7(IXSv+Wgec!0U#kTjxS5iOUW<NFGx(zPE60tOV^K2
z&d)7KEYT~dEMaG0V2F>;OD&I&mtkOFC<eKZff14(Kye=*5AscXJlH?+@wxdar8%kb
z@j)Q(ft?NZQxHgL5Ge4$VgurpAW#%Y!~DR;2u{u=si0(>SX3DgP9<R1fn5xasFKQp
zRESSNdcp38_yoj7sD+4ud^aE-17|x>dXERC6|g@<K;8tU9tL)K77ZRyQUgUue0*AI
zNof%%en2TR2$bl8KrsqVp2d~LB_O3`sYRgN9G{t&mJgN)h%|!I#$dX*qzJ6AxTGjE
zFFhU<O2y##hooANU=XORfP@gpCNOJY0tb}xY#_<f4iqBAph8N9iHBL3QJ95|k%x(s
F830HmM4kWu

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/packaging/_structures.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/packaging/_structures.py
new file mode 100644
index 0000000..68dcca6
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/packaging/_structures.py
@@ -0,0 +1,68 @@
+# This file is dual licensed under the terms of the Apache License, Version
+# 2.0, and the BSD License. See the LICENSE file in the root of this repository
+# for complete details.
+from __future__ import absolute_import, division, print_function
+
+
+class Infinity(object):
+    def __repr__(self):
+        return "Infinity"
+
+    def __hash__(self):
+        return hash(repr(self))
+
+    def __lt__(self, other):
+        return False
+
+    def __le__(self, other):
+        return False
+
+    def __eq__(self, other):
+        return isinstance(other, self.__class__)
+
+    def __ne__(self, other):
+        return not isinstance(other, self.__class__)
+
+    def __gt__(self, other):
+        return True
+
+    def __ge__(self, other):
+        return True
+
+    def __neg__(self):
+        return NegativeInfinity
+
+
+Infinity = Infinity()
+
+
+class NegativeInfinity(object):
+    def __repr__(self):
+        return "-Infinity"
+
+    def __hash__(self):
+        return hash(repr(self))
+
+    def __lt__(self, other):
+        return True
+
+    def __le__(self, other):
+        return True
+
+    def __eq__(self, other):
+        return isinstance(other, self.__class__)
+
+    def __ne__(self, other):
+        return not isinstance(other, self.__class__)
+
+    def __gt__(self, other):
+        return False
+
+    def __ge__(self, other):
+        return False
+
+    def __neg__(self):
+        return Infinity
+
+
+NegativeInfinity = NegativeInfinity()
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/packaging/_structures.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/packaging/_structures.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..5657dde2d6726a806e87b7b8f20ffa76e2beb72f
GIT binary patch
literal 5013
zcmZSn%**AGdLky70ScHI7#JK97#WJ=7#J8*7#LC*8FCmHav2$-7#VVz7^0XMa+w*T
zm>C#Tm>5!77}6LSQkWT97#Nxv7$T!s8B$q6tSDB76c(5?D_ok5A(ag*&Bl<z#t^K*
z&cMKs39?rMWNQgO0|P^1QgMDxX-R5)W^O@#QAr60$Q7AonZ=p;c_n-d3=9QDnRzAg
zX{C9|B_JV?yk}loW?p7VCEO2;3=9lTAU{MhFfgPtfSjJf0CGhX6UaX;3?L7rFo8u_
zpzen_86?HVkOFpc6g$Y3AQ29R6n3y;PKFc?FoTOBC|HA&fq@|zWETuOgY0AhxtNh5
zSc8dyfx#~b<TDMhA3>^0K(fWDIcX3fka%$k0|SG8K~ZK|Vo9ogSz?iXT7FJSYEiL%
zQi^_gQc_;7X>PHRVUl@zRl0?#MR`tEm6-tur03~}=oe%b=w{{>mn7!o=(?48cp3+Q
zgupnyEHy7Bzev9zF*!RiJu@#|Kfbu6s5H5xv?#S$ub>hfw(;>rsRc#x@t|-l2DzAl
z5$+|B)4^U6U|?V<VPGg>WT;_aXl4YVU=5IW{J@?BdnzNbI0MW8nFp2(0{M0D_!H#7
z_;_vx1_qcvLEZ&nkWaw=1Ua~bfdS?>ka!6z0|SFwVoq@?*sEYafyMGmGE$2MgYVcF
z7#QN?b4udlLD_>8zXfqJFfbsz6~qPNf|4ZITLYIap*~8Dj~B!eTj;5>h7pu1vltng
zncy)8iq#U3cQT8?nIkVbwS*HKPRTim#l`XQgVxunh4Jws_<Ritk`e|6WMA{Z5-iBu
zLA(qM3_+lzFlhalml_{0j>V6l{Dw0hg7RiaQ7KY39AxP=y(B(fibP)pfnsye##4G~
ze7r1@k3jJQ!#Lv!R9E<=rYDwUmZicf=D}4RfLa~#@p-A~@$m`>-)Vqq256O-mzbLx
z9}g}-;^TAkQ%ZAE<Ku%sH9-)lo(uvh4dMaiGf<Ny2;}7;ArMy>M2MmkqXS!(f}0;8
z4;O>n$HvIXj0%H5WzAr0Hx+}5Yh8E(0@q5Qv<I$$!C?v}2CR|-rv{J{U==RNaUhId
zJ>hCJ1%Yb0AW+l{s@wri;M$06kqoL+Kp5mVT$z557GvOisy9sh0xE6{vG@f&y&*RY
zhDy622vm%k;PV`)o*b&J9&r6&j>UI)vlOWO8+<JTa5ZN&O#A|>t!<I~0*Vh9##z*X
z^4s7lu|e$(2ZT4k4VfS@P)h{V$Oczb;8Go291f9Y3#eJ54)PQBW{V$q=m^?CODhG9
zXvD_{ff@-xpa={CRahmU3N}9}D>b<U+zJ9WbwD*X1A-W^<^#B)X#;6m+JU+@#h`|z
M46~RlC$pF=0LRdb3;+NC

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/packaging/markers.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/packaging/markers.py
new file mode 100644
index 0000000..5482476
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/packaging/markers.py
@@ -0,0 +1,296 @@
+# This file is dual licensed under the terms of the Apache License, Version
+# 2.0, and the BSD License. See the LICENSE file in the root of this repository
+# for complete details.
+from __future__ import absolute_import, division, print_function
+
+import operator
+import os
+import platform
+import sys
+
+from pip._vendor.pyparsing import ParseException, ParseResults, stringStart, stringEnd
+from pip._vendor.pyparsing import ZeroOrMore, Group, Forward, QuotedString
+from pip._vendor.pyparsing import Literal as L  # noqa
+
+from ._compat import string_types
+from .specifiers import Specifier, InvalidSpecifier
+
+
+__all__ = [
+    "InvalidMarker",
+    "UndefinedComparison",
+    "UndefinedEnvironmentName",
+    "Marker",
+    "default_environment",
+]
+
+
+class InvalidMarker(ValueError):
+    """
+    An invalid marker was found, users should refer to PEP 508.
+    """
+
+
+class UndefinedComparison(ValueError):
+    """
+    An invalid operation was attempted on a value that doesn't support it.
+    """
+
+
+class UndefinedEnvironmentName(ValueError):
+    """
+    A name was attempted to be used that does not exist inside of the
+    environment.
+    """
+
+
+class Node(object):
+    def __init__(self, value):
+        self.value = value
+
+    def __str__(self):
+        return str(self.value)
+
+    def __repr__(self):
+        return "<{0}({1!r})>".format(self.__class__.__name__, str(self))
+
+    def serialize(self):
+        raise NotImplementedError
+
+
+class Variable(Node):
+    def serialize(self):
+        return str(self)
+
+
+class Value(Node):
+    def serialize(self):
+        return '"{0}"'.format(self)
+
+
+class Op(Node):
+    def serialize(self):
+        return str(self)
+
+
+VARIABLE = (
+    L("implementation_version")
+    | L("platform_python_implementation")
+    | L("implementation_name")
+    | L("python_full_version")
+    | L("platform_release")
+    | L("platform_version")
+    | L("platform_machine")
+    | L("platform_system")
+    | L("python_version")
+    | L("sys_platform")
+    | L("os_name")
+    | L("os.name")
+    | L("sys.platform")  # PEP-345
+    | L("platform.version")  # PEP-345
+    | L("platform.machine")  # PEP-345
+    | L("platform.python_implementation")  # PEP-345
+    | L("python_implementation")  # PEP-345
+    | L("extra")  # undocumented setuptools legacy
+)
+ALIASES = {
+    "os.name": "os_name",
+    "sys.platform": "sys_platform",
+    "platform.version": "platform_version",
+    "platform.machine": "platform_machine",
+    "platform.python_implementation": "platform_python_implementation",
+    "python_implementation": "platform_python_implementation",
+}
+VARIABLE.setParseAction(lambda s, l, t: Variable(ALIASES.get(t[0], t[0])))
+
+VERSION_CMP = (
+    L("===") | L("==") | L(">=") | L("<=") | L("!=") | L("~=") | L(">") | L("<")
+)
+
+MARKER_OP = VERSION_CMP | L("not in") | L("in")
+MARKER_OP.setParseAction(lambda s, l, t: Op(t[0]))
+
+MARKER_VALUE = QuotedString("'") | QuotedString('"')
+MARKER_VALUE.setParseAction(lambda s, l, t: Value(t[0]))
+
+BOOLOP = L("and") | L("or")
+
+MARKER_VAR = VARIABLE | MARKER_VALUE
+
+MARKER_ITEM = Group(MARKER_VAR + MARKER_OP + MARKER_VAR)
+MARKER_ITEM.setParseAction(lambda s, l, t: tuple(t[0]))
+
+LPAREN = L("(").suppress()
+RPAREN = L(")").suppress()
+
+MARKER_EXPR = Forward()
+MARKER_ATOM = MARKER_ITEM | Group(LPAREN + MARKER_EXPR + RPAREN)
+MARKER_EXPR << MARKER_ATOM + ZeroOrMore(BOOLOP + MARKER_EXPR)
+
+MARKER = stringStart + MARKER_EXPR + stringEnd
+
+
+def _coerce_parse_result(results):
+    if isinstance(results, ParseResults):
+        return [_coerce_parse_result(i) for i in results]
+    else:
+        return results
+
+
+def _format_marker(marker, first=True):
+    assert isinstance(marker, (list, tuple, string_types))
+
+    # Sometimes we have a structure like [[...]] which is a single item list
+    # where the single item is itself it's own list. In that case we want skip
+    # the rest of this function so that we don't get extraneous () on the
+    # outside.
+    if (
+        isinstance(marker, list)
+        and len(marker) == 1
+        and isinstance(marker[0], (list, tuple))
+    ):
+        return _format_marker(marker[0])
+
+    if isinstance(marker, list):
+        inner = (_format_marker(m, first=False) for m in marker)
+        if first:
+            return " ".join(inner)
+        else:
+            return "(" + " ".join(inner) + ")"
+    elif isinstance(marker, tuple):
+        return " ".join([m.serialize() for m in marker])
+    else:
+        return marker
+
+
+_operators = {
+    "in": lambda lhs, rhs: lhs in rhs,
+    "not in": lambda lhs, rhs: lhs not in rhs,
+    "<": operator.lt,
+    "<=": operator.le,
+    "==": operator.eq,
+    "!=": operator.ne,
+    ">=": operator.ge,
+    ">": operator.gt,
+}
+
+
+def _eval_op(lhs, op, rhs):
+    try:
+        spec = Specifier("".join([op.serialize(), rhs]))
+    except InvalidSpecifier:
+        pass
+    else:
+        return spec.contains(lhs)
+
+    oper = _operators.get(op.serialize())
+    if oper is None:
+        raise UndefinedComparison(
+            "Undefined {0!r} on {1!r} and {2!r}.".format(op, lhs, rhs)
+        )
+
+    return oper(lhs, rhs)
+
+
+_undefined = object()
+
+
+def _get_env(environment, name):
+    value = environment.get(name, _undefined)
+
+    if value is _undefined:
+        raise UndefinedEnvironmentName(
+            "{0!r} does not exist in evaluation environment.".format(name)
+        )
+
+    return value
+
+
+def _evaluate_markers(markers, environment):
+    groups = [[]]
+
+    for marker in markers:
+        assert isinstance(marker, (list, tuple, string_types))
+
+        if isinstance(marker, list):
+            groups[-1].append(_evaluate_markers(marker, environment))
+        elif isinstance(marker, tuple):
+            lhs, op, rhs = marker
+
+            if isinstance(lhs, Variable):
+                lhs_value = _get_env(environment, lhs.value)
+                rhs_value = rhs.value
+            else:
+                lhs_value = lhs.value
+                rhs_value = _get_env(environment, rhs.value)
+
+            groups[-1].append(_eval_op(lhs_value, op, rhs_value))
+        else:
+            assert marker in ["and", "or"]
+            if marker == "or":
+                groups.append([])
+
+    return any(all(item) for item in groups)
+
+
+def format_full_version(info):
+    version = "{0.major}.{0.minor}.{0.micro}".format(info)
+    kind = info.releaselevel
+    if kind != "final":
+        version += kind[0] + str(info.serial)
+    return version
+
+
+def default_environment():
+    if hasattr(sys, "implementation"):
+        iver = format_full_version(sys.implementation.version)
+        implementation_name = sys.implementation.name
+    else:
+        iver = "0"
+        implementation_name = ""
+
+    return {
+        "implementation_name": implementation_name,
+        "implementation_version": iver,
+        "os_name": os.name,
+        "platform_machine": platform.machine(),
+        "platform_release": platform.release(),
+        "platform_system": platform.system(),
+        "platform_version": platform.version(),
+        "python_full_version": platform.python_version(),
+        "platform_python_implementation": platform.python_implementation(),
+        "python_version": platform.python_version()[:3],
+        "sys_platform": sys.platform,
+    }
+
+
+class Marker(object):
+    def __init__(self, marker):
+        try:
+            self._markers = _coerce_parse_result(MARKER.parseString(marker))
+        except ParseException as e:
+            err_str = "Invalid marker: {0!r}, parse error at {1!r}".format(
+                marker, marker[e.loc : e.loc + 8]
+            )
+            raise InvalidMarker(err_str)
+
+    def __str__(self):
+        return _format_marker(self._markers)
+
+    def __repr__(self):
+        return "<Marker({0!r})>".format(str(self))
+
+    def evaluate(self, environment=None):
+        """Evaluate a marker.
+
+        Return the boolean from evaluating the given marker against the
+        environment. environment is an optional argument to override all or
+        part of the determined environment.
+
+        The environment is determined from the current Python process.
+        """
+        current_environment = default_environment()
+        if environment is not None:
+            current_environment.update(environment)
+
+        return _evaluate_markers(self._markers, current_environment)
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/packaging/markers.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/packaging/markers.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..24e28cbeb3ab3b4dc10cf0b91eea0eafe0497c0f
GIT binary patch
literal 13362
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
D6dv5e

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/packaging/requirements.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/packaging/requirements.py
new file mode 100644
index 0000000..dbc5f11
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/packaging/requirements.py
@@ -0,0 +1,138 @@
+# This file is dual licensed under the terms of the Apache License, Version
+# 2.0, and the BSD License. See the LICENSE file in the root of this repository
+# for complete details.
+from __future__ import absolute_import, division, print_function
+
+import string
+import re
+
+from pip._vendor.pyparsing import stringStart, stringEnd, originalTextFor, ParseException
+from pip._vendor.pyparsing import ZeroOrMore, Word, Optional, Regex, Combine
+from pip._vendor.pyparsing import Literal as L  # noqa
+from pip._vendor.six.moves.urllib import parse as urlparse
+
+from .markers import MARKER_EXPR, Marker
+from .specifiers import LegacySpecifier, Specifier, SpecifierSet
+
+
+class InvalidRequirement(ValueError):
+    """
+    An invalid requirement was found, users should refer to PEP 508.
+    """
+
+
+ALPHANUM = Word(string.ascii_letters + string.digits)
+
+LBRACKET = L("[").suppress()
+RBRACKET = L("]").suppress()
+LPAREN = L("(").suppress()
+RPAREN = L(")").suppress()
+COMMA = L(",").suppress()
+SEMICOLON = L(";").suppress()
+AT = L("@").suppress()
+
+PUNCTUATION = Word("-_.")
+IDENTIFIER_END = ALPHANUM | (ZeroOrMore(PUNCTUATION) + ALPHANUM)
+IDENTIFIER = Combine(ALPHANUM + ZeroOrMore(IDENTIFIER_END))
+
+NAME = IDENTIFIER("name")
+EXTRA = IDENTIFIER
+
+URI = Regex(r"[^ ]+")("url")
+URL = AT + URI
+
+EXTRAS_LIST = EXTRA + ZeroOrMore(COMMA + EXTRA)
+EXTRAS = (LBRACKET + Optional(EXTRAS_LIST) + RBRACKET)("extras")
+
+VERSION_PEP440 = Regex(Specifier._regex_str, re.VERBOSE | re.IGNORECASE)
+VERSION_LEGACY = Regex(LegacySpecifier._regex_str, re.VERBOSE | re.IGNORECASE)
+
+VERSION_ONE = VERSION_PEP440 ^ VERSION_LEGACY
+VERSION_MANY = Combine(
+    VERSION_ONE + ZeroOrMore(COMMA + VERSION_ONE), joinString=",", adjacent=False
+)("_raw_spec")
+_VERSION_SPEC = Optional(((LPAREN + VERSION_MANY + RPAREN) | VERSION_MANY))
+_VERSION_SPEC.setParseAction(lambda s, l, t: t._raw_spec or "")
+
+VERSION_SPEC = originalTextFor(_VERSION_SPEC)("specifier")
+VERSION_SPEC.setParseAction(lambda s, l, t: t[1])
+
+MARKER_EXPR = originalTextFor(MARKER_EXPR())("marker")
+MARKER_EXPR.setParseAction(
+    lambda s, l, t: Marker(s[t._original_start : t._original_end])
+)
+MARKER_SEPARATOR = SEMICOLON
+MARKER = MARKER_SEPARATOR + MARKER_EXPR
+
+VERSION_AND_MARKER = VERSION_SPEC + Optional(MARKER)
+URL_AND_MARKER = URL + Optional(MARKER)
+
+NAMED_REQUIREMENT = NAME + Optional(EXTRAS) + (URL_AND_MARKER | VERSION_AND_MARKER)
+
+REQUIREMENT = stringStart + NAMED_REQUIREMENT + stringEnd
+# pyparsing isn't thread safe during initialization, so we do it eagerly, see
+# issue #104
+REQUIREMENT.parseString("x[]")
+
+
+class Requirement(object):
+    """Parse a requirement.
+
+    Parse a given requirement string into its parts, such as name, specifier,
+    URL, and extras. Raises InvalidRequirement on a badly-formed requirement
+    string.
+    """
+
+    # TODO: Can we test whether something is contained within a requirement?
+    #       If so how do we do that? Do we need to test against the _name_ of
+    #       the thing as well as the version? What about the markers?
+    # TODO: Can we normalize the name and extra name?
+
+    def __init__(self, requirement_string):
+        try:
+            req = REQUIREMENT.parseString(requirement_string)
+        except ParseException as e:
+            raise InvalidRequirement(
+                'Parse error at "{0!r}": {1}'.format(
+                    requirement_string[e.loc : e.loc + 8], e.msg
+                )
+            )
+
+        self.name = req.name
+        if req.url:
+            parsed_url = urlparse.urlparse(req.url)
+            if parsed_url.scheme == "file":
+                if urlparse.urlunparse(parsed_url) != req.url:
+                    raise InvalidRequirement("Invalid URL given")
+            elif not (parsed_url.scheme and parsed_url.netloc) or (
+                not parsed_url.scheme and not parsed_url.netloc
+            ):
+                raise InvalidRequirement("Invalid URL: {0}".format(req.url))
+            self.url = req.url
+        else:
+            self.url = None
+        self.extras = set(req.extras.asList() if req.extras else [])
+        self.specifier = SpecifierSet(req.specifier)
+        self.marker = req.marker if req.marker else None
+
+    def __str__(self):
+        parts = [self.name]
+
+        if self.extras:
+            parts.append("[{0}]".format(",".join(sorted(self.extras))))
+
+        if self.specifier:
+            parts.append(str(self.specifier))
+
+        if self.url:
+            parts.append("@ {0}".format(self.url))
+            if self.marker:
+                parts.append(" ")
+
+        if self.marker:
+            parts.append("; {0}".format(self.marker))
+
+        return "".join(parts)
+
+    def __repr__(self):
+        return "<Requirement({0!r})>".format(str(self))
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/packaging/requirements.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/packaging/requirements.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..e76d15a63e1445523f3afb55a2a7db5ee6fc2057
GIT binary patch
literal 5695
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
Vm_!-b7`d207-W(J6CX1#GXTL`?+pL|

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/packaging/specifiers.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/packaging/specifiers.py
new file mode 100644
index 0000000..743576a
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/packaging/specifiers.py
@@ -0,0 +1,749 @@
+# This file is dual licensed under the terms of the Apache License, Version
+# 2.0, and the BSD License. See the LICENSE file in the root of this repository
+# for complete details.
+from __future__ import absolute_import, division, print_function
+
+import abc
+import functools
+import itertools
+import re
+
+from ._compat import string_types, with_metaclass
+from .version import Version, LegacyVersion, parse
+
+
+class InvalidSpecifier(ValueError):
+    """
+    An invalid specifier was found, users should refer to PEP 440.
+    """
+
+
+class BaseSpecifier(with_metaclass(abc.ABCMeta, object)):
+    @abc.abstractmethod
+    def __str__(self):
+        """
+        Returns the str representation of this Specifier like object. This
+        should be representative of the Specifier itself.
+        """
+
+    @abc.abstractmethod
+    def __hash__(self):
+        """
+        Returns a hash value for this Specifier like object.
+        """
+
+    @abc.abstractmethod
+    def __eq__(self, other):
+        """
+        Returns a boolean representing whether or not the two Specifier like
+        objects are equal.
+        """
+
+    @abc.abstractmethod
+    def __ne__(self, other):
+        """
+        Returns a boolean representing whether or not the two Specifier like
+        objects are not equal.
+        """
+
+    @abc.abstractproperty
+    def prereleases(self):
+        """
+        Returns whether or not pre-releases as a whole are allowed by this
+        specifier.
+        """
+
+    @prereleases.setter
+    def prereleases(self, value):
+        """
+        Sets whether or not pre-releases as a whole are allowed by this
+        specifier.
+        """
+
+    @abc.abstractmethod
+    def contains(self, item, prereleases=None):
+        """
+        Determines if the given item is contained within this specifier.
+        """
+
+    @abc.abstractmethod
+    def filter(self, iterable, prereleases=None):
+        """
+        Takes an iterable of items and filters them so that only items which
+        are contained within this specifier are allowed in it.
+        """
+
+
+class _IndividualSpecifier(BaseSpecifier):
+
+    _operators = {}
+
+    def __init__(self, spec="", prereleases=None):
+        match = self._regex.search(spec)
+        if not match:
+            raise InvalidSpecifier("Invalid specifier: '{0}'".format(spec))
+
+        self._spec = (match.group("operator").strip(), match.group("version").strip())
+
+        # Store whether or not this Specifier should accept prereleases
+        self._prereleases = prereleases
+
+    def __repr__(self):
+        pre = (
+            ", prereleases={0!r}".format(self.prereleases)
+            if self._prereleases is not None
+            else ""
+        )
+
+        return "<{0}({1!r}{2})>".format(self.__class__.__name__, str(self), pre)
+
+    def __str__(self):
+        return "{0}{1}".format(*self._spec)
+
+    def __hash__(self):
+        return hash(self._spec)
+
+    def __eq__(self, other):
+        if isinstance(other, string_types):
+            try:
+                other = self.__class__(other)
+            except InvalidSpecifier:
+                return NotImplemented
+        elif not isinstance(other, self.__class__):
+            return NotImplemented
+
+        return self._spec == other._spec
+
+    def __ne__(self, other):
+        if isinstance(other, string_types):
+            try:
+                other = self.__class__(other)
+            except InvalidSpecifier:
+                return NotImplemented
+        elif not isinstance(other, self.__class__):
+            return NotImplemented
+
+        return self._spec != other._spec
+
+    def _get_operator(self, op):
+        return getattr(self, "_compare_{0}".format(self._operators[op]))
+
+    def _coerce_version(self, version):
+        if not isinstance(version, (LegacyVersion, Version)):
+            version = parse(version)
+        return version
+
+    @property
+    def operator(self):
+        return self._spec[0]
+
+    @property
+    def version(self):
+        return self._spec[1]
+
+    @property
+    def prereleases(self):
+        return self._prereleases
+
+    @prereleases.setter
+    def prereleases(self, value):
+        self._prereleases = value
+
+    def __contains__(self, item):
+        return self.contains(item)
+
+    def contains(self, item, prereleases=None):
+        # Determine if prereleases are to be allowed or not.
+        if prereleases is None:
+            prereleases = self.prereleases
+
+        # Normalize item to a Version or LegacyVersion, this allows us to have
+        # a shortcut for ``"2.0" in Specifier(">=2")
+        item = self._coerce_version(item)
+
+        # Determine if we should be supporting prereleases in this specifier
+        # or not, if we do not support prereleases than we can short circuit
+        # logic if this version is a prereleases.
+        if item.is_prerelease and not prereleases:
+            return False
+
+        # Actually do the comparison to determine if this item is contained
+        # within this Specifier or not.
+        return self._get_operator(self.operator)(item, self.version)
+
+    def filter(self, iterable, prereleases=None):
+        yielded = False
+        found_prereleases = []
+
+        kw = {"prereleases": prereleases if prereleases is not None else True}
+
+        # Attempt to iterate over all the values in the iterable and if any of
+        # them match, yield them.
+        for version in iterable:
+            parsed_version = self._coerce_version(version)
+
+            if self.contains(parsed_version, **kw):
+                # If our version is a prerelease, and we were not set to allow
+                # prereleases, then we'll store it for later incase nothing
+                # else matches this specifier.
+                if parsed_version.is_prerelease and not (
+                    prereleases or self.prereleases
+                ):
+                    found_prereleases.append(version)
+                # Either this is not a prerelease, or we should have been
+                # accepting prereleases from the beginning.
+                else:
+                    yielded = True
+                    yield version
+
+        # Now that we've iterated over everything, determine if we've yielded
+        # any values, and if we have not and we have any prereleases stored up
+        # then we will go ahead and yield the prereleases.
+        if not yielded and found_prereleases:
+            for version in found_prereleases:
+                yield version
+
+
+class LegacySpecifier(_IndividualSpecifier):
+
+    _regex_str = r"""
+        (?P<operator>(==|!=|<=|>=|<|>))
+        \s*
+        (?P<version>
+            [^,;\s)]* # Since this is a "legacy" specifier, and the version
+                      # string can be just about anything, we match everything
+                      # except for whitespace, a semi-colon for marker support,
+                      # a closing paren since versions can be enclosed in
+                      # them, and a comma since it's a version separator.
+        )
+        """
+
+    _regex = re.compile(r"^\s*" + _regex_str + r"\s*$", re.VERBOSE | re.IGNORECASE)
+
+    _operators = {
+        "==": "equal",
+        "!=": "not_equal",
+        "<=": "less_than_equal",
+        ">=": "greater_than_equal",
+        "<": "less_than",
+        ">": "greater_than",
+    }
+
+    def _coerce_version(self, version):
+        if not isinstance(version, LegacyVersion):
+            version = LegacyVersion(str(version))
+        return version
+
+    def _compare_equal(self, prospective, spec):
+        return prospective == self._coerce_version(spec)
+
+    def _compare_not_equal(self, prospective, spec):
+        return prospective != self._coerce_version(spec)
+
+    def _compare_less_than_equal(self, prospective, spec):
+        return prospective <= self._coerce_version(spec)
+
+    def _compare_greater_than_equal(self, prospective, spec):
+        return prospective >= self._coerce_version(spec)
+
+    def _compare_less_than(self, prospective, spec):
+        return prospective < self._coerce_version(spec)
+
+    def _compare_greater_than(self, prospective, spec):
+        return prospective > self._coerce_version(spec)
+
+
+def _require_version_compare(fn):
+    @functools.wraps(fn)
+    def wrapped(self, prospective, spec):
+        if not isinstance(prospective, Version):
+            return False
+        return fn(self, prospective, spec)
+
+    return wrapped
+
+
+class Specifier(_IndividualSpecifier):
+
+    _regex_str = r"""
+        (?P<operator>(~=|==|!=|<=|>=|<|>|===))
+        (?P<version>
+            (?:
+                # The identity operators allow for an escape hatch that will
+                # do an exact string match of the version you wish to install.
+                # This will not be parsed by PEP 440 and we cannot determine
+                # any semantic meaning from it. This operator is discouraged
+                # but included entirely as an escape hatch.
+                (?<====)  # Only match for the identity operator
+                \s*
+                [^\s]*    # We just match everything, except for whitespace
+                          # since we are only testing for strict identity.
+            )
+            |
+            (?:
+                # The (non)equality operators allow for wild card and local
+                # versions to be specified so we have to define these two
+                # operators separately to enable that.
+                (?<===|!=)            # Only match for equals and not equals
+
+                \s*
+                v?
+                (?:[0-9]+!)?          # epoch
+                [0-9]+(?:\.[0-9]+)*   # release
+                (?:                   # pre release
+                    [-_\.]?
+                    (a|b|c|rc|alpha|beta|pre|preview)
+                    [-_\.]?
+                    [0-9]*
+                )?
+                (?:                   # post release
+                    (?:-[0-9]+)|(?:[-_\.]?(post|rev|r)[-_\.]?[0-9]*)
+                )?
+
+                # You cannot use a wild card and a dev or local version
+                # together so group them with a | and make them optional.
+                (?:
+                    (?:[-_\.]?dev[-_\.]?[0-9]*)?         # dev release
+                    (?:\+[a-z0-9]+(?:[-_\.][a-z0-9]+)*)? # local
+                    |
+                    \.\*  # Wild card syntax of .*
+                )?
+            )
+            |
+            (?:
+                # The compatible operator requires at least two digits in the
+                # release segment.
+                (?<=~=)               # Only match for the compatible operator
+
+                \s*
+                v?
+                (?:[0-9]+!)?          # epoch
+                [0-9]+(?:\.[0-9]+)+   # release  (We have a + instead of a *)
+                (?:                   # pre release
+                    [-_\.]?
+                    (a|b|c|rc|alpha|beta|pre|preview)
+                    [-_\.]?
+                    [0-9]*
+                )?
+                (?:                                   # post release
+                    (?:-[0-9]+)|(?:[-_\.]?(post|rev|r)[-_\.]?[0-9]*)
+                )?
+                (?:[-_\.]?dev[-_\.]?[0-9]*)?          # dev release
+            )
+            |
+            (?:
+                # All other operators only allow a sub set of what the
+                # (non)equality operators do. Specifically they do not allow
+                # local versions to be specified nor do they allow the prefix
+                # matching wild cards.
+                (?<!==|!=|~=)         # We have special cases for these
+                                      # operators so we want to make sure they
+                                      # don't match here.
+
+                \s*
+                v?
+                (?:[0-9]+!)?          # epoch
+                [0-9]+(?:\.[0-9]+)*   # release
+                (?:                   # pre release
+                    [-_\.]?
+                    (a|b|c|rc|alpha|beta|pre|preview)
+                    [-_\.]?
+                    [0-9]*
+                )?
+                (?:                                   # post release
+                    (?:-[0-9]+)|(?:[-_\.]?(post|rev|r)[-_\.]?[0-9]*)
+                )?
+                (?:[-_\.]?dev[-_\.]?[0-9]*)?          # dev release
+            )
+        )
+        """
+
+    _regex = re.compile(r"^\s*" + _regex_str + r"\s*$", re.VERBOSE | re.IGNORECASE)
+
+    _operators = {
+        "~=": "compatible",
+        "==": "equal",
+        "!=": "not_equal",
+        "<=": "less_than_equal",
+        ">=": "greater_than_equal",
+        "<": "less_than",
+        ">": "greater_than",
+        "===": "arbitrary",
+    }
+
+    @_require_version_compare
+    def _compare_compatible(self, prospective, spec):
+        # Compatible releases have an equivalent combination of >= and ==. That
+        # is that ~=2.2 is equivalent to >=2.2,==2.*. This allows us to
+        # implement this in terms of the other specifiers instead of
+        # implementing it ourselves. The only thing we need to do is construct
+        # the other specifiers.
+
+        # We want everything but the last item in the version, but we want to
+        # ignore post and dev releases and we want to treat the pre-release as
+        # it's own separate segment.
+        prefix = ".".join(
+            list(
+                itertools.takewhile(
+                    lambda x: (not x.startswith("post") and not x.startswith("dev")),
+                    _version_split(spec),
+                )
+            )[:-1]
+        )
+
+        # Add the prefix notation to the end of our string
+        prefix += ".*"
+
+        return self._get_operator(">=")(prospective, spec) and self._get_operator("==")(
+            prospective, prefix
+        )
+
+    @_require_version_compare
+    def _compare_equal(self, prospective, spec):
+        # We need special logic to handle prefix matching
+        if spec.endswith(".*"):
+            # In the case of prefix matching we want to ignore local segment.
+            prospective = Version(prospective.public)
+            # Split the spec out by dots, and pretend that there is an implicit
+            # dot in between a release segment and a pre-release segment.
+            spec = _version_split(spec[:-2])  # Remove the trailing .*
+
+            # Split the prospective version out by dots, and pretend that there
+            # is an implicit dot in between a release segment and a pre-release
+            # segment.
+            prospective = _version_split(str(prospective))
+
+            # Shorten the prospective version to be the same length as the spec
+            # so that we can determine if the specifier is a prefix of the
+            # prospective version or not.
+            prospective = prospective[: len(spec)]
+
+            # Pad out our two sides with zeros so that they both equal the same
+            # length.
+            spec, prospective = _pad_version(spec, prospective)
+        else:
+            # Convert our spec string into a Version
+            spec = Version(spec)
+
+            # If the specifier does not have a local segment, then we want to
+            # act as if the prospective version also does not have a local
+            # segment.
+            if not spec.local:
+                prospective = Version(prospective.public)
+
+        return prospective == spec
+
+    @_require_version_compare
+    def _compare_not_equal(self, prospective, spec):
+        return not self._compare_equal(prospective, spec)
+
+    @_require_version_compare
+    def _compare_less_than_equal(self, prospective, spec):
+        return prospective <= Version(spec)
+
+    @_require_version_compare
+    def _compare_greater_than_equal(self, prospective, spec):
+        return prospective >= Version(spec)
+
+    @_require_version_compare
+    def _compare_less_than(self, prospective, spec):
+        # Convert our spec to a Version instance, since we'll want to work with
+        # it as a version.
+        spec = Version(spec)
+
+        # Check to see if the prospective version is less than the spec
+        # version. If it's not we can short circuit and just return False now
+        # instead of doing extra unneeded work.
+        if not prospective < spec:
+            return False
+
+        # This special case is here so that, unless the specifier itself
+        # includes is a pre-release version, that we do not accept pre-release
+        # versions for the version mentioned in the specifier (e.g. <3.1 should
+        # not match 3.1.dev0, but should match 3.0.dev0).
+        if not spec.is_prerelease and prospective.is_prerelease:
+            if Version(prospective.base_version) == Version(spec.base_version):
+                return False
+
+        # If we've gotten to here, it means that prospective version is both
+        # less than the spec version *and* it's not a pre-release of the same
+        # version in the spec.
+        return True
+
+    @_require_version_compare
+    def _compare_greater_than(self, prospective, spec):
+        # Convert our spec to a Version instance, since we'll want to work with
+        # it as a version.
+        spec = Version(spec)
+
+        # Check to see if the prospective version is greater than the spec
+        # version. If it's not we can short circuit and just return False now
+        # instead of doing extra unneeded work.
+        if not prospective > spec:
+            return False
+
+        # This special case is here so that, unless the specifier itself
+        # includes is a post-release version, that we do not accept
+        # post-release versions for the version mentioned in the specifier
+        # (e.g. >3.1 should not match 3.0.post0, but should match 3.2.post0).
+        if not spec.is_postrelease and prospective.is_postrelease:
+            if Version(prospective.base_version) == Version(spec.base_version):
+                return False
+
+        # Ensure that we do not allow a local version of the version mentioned
+        # in the specifier, which is technically greater than, to match.
+        if prospective.local is not None:
+            if Version(prospective.base_version) == Version(spec.base_version):
+                return False
+
+        # If we've gotten to here, it means that prospective version is both
+        # greater than the spec version *and* it's not a pre-release of the
+        # same version in the spec.
+        return True
+
+    def _compare_arbitrary(self, prospective, spec):
+        return str(prospective).lower() == str(spec).lower()
+
+    @property
+    def prereleases(self):
+        # If there is an explicit prereleases set for this, then we'll just
+        # blindly use that.
+        if self._prereleases is not None:
+            return self._prereleases
+
+        # Look at all of our specifiers and determine if they are inclusive
+        # operators, and if they are if they are including an explicit
+        # prerelease.
+        operator, version = self._spec
+        if operator in ["==", ">=", "<=", "~=", "==="]:
+            # The == specifier can include a trailing .*, if it does we
+            # want to remove before parsing.
+            if operator == "==" and version.endswith(".*"):
+                version = version[:-2]
+
+            # Parse the version, and if it is a pre-release than this
+            # specifier allows pre-releases.
+            if parse(version).is_prerelease:
+                return True
+
+        return False
+
+    @prereleases.setter
+    def prereleases(self, value):
+        self._prereleases = value
+
+
+_prefix_regex = re.compile(r"^([0-9]+)((?:a|b|c|rc)[0-9]+)$")
+
+
+def _version_split(version):
+    result = []
+    for item in version.split("."):
+        match = _prefix_regex.search(item)
+        if match:
+            result.extend(match.groups())
+        else:
+            result.append(item)
+    return result
+
+
+def _pad_version(left, right):
+    left_split, right_split = [], []
+
+    # Get the release segment of our versions
+    left_split.append(list(itertools.takewhile(lambda x: x.isdigit(), left)))
+    right_split.append(list(itertools.takewhile(lambda x: x.isdigit(), right)))
+
+    # Get the rest of our versions
+    left_split.append(left[len(left_split[0]) :])
+    right_split.append(right[len(right_split[0]) :])
+
+    # Insert our padding
+    left_split.insert(1, ["0"] * max(0, len(right_split[0]) - len(left_split[0])))
+    right_split.insert(1, ["0"] * max(0, len(left_split[0]) - len(right_split[0])))
+
+    return (list(itertools.chain(*left_split)), list(itertools.chain(*right_split)))
+
+
+class SpecifierSet(BaseSpecifier):
+    def __init__(self, specifiers="", prereleases=None):
+        # Split on , to break each indidivual specifier into it's own item, and
+        # strip each item to remove leading/trailing whitespace.
+        specifiers = [s.strip() for s in specifiers.split(",") if s.strip()]
+
+        # Parsed each individual specifier, attempting first to make it a
+        # Specifier and falling back to a LegacySpecifier.
+        parsed = set()
+        for specifier in specifiers:
+            try:
+                parsed.add(Specifier(specifier))
+            except InvalidSpecifier:
+                parsed.add(LegacySpecifier(specifier))
+
+        # Turn our parsed specifiers into a frozen set and save them for later.
+        self._specs = frozenset(parsed)
+
+        # Store our prereleases value so we can use it later to determine if
+        # we accept prereleases or not.
+        self._prereleases = prereleases
+
+    def __repr__(self):
+        pre = (
+            ", prereleases={0!r}".format(self.prereleases)
+            if self._prereleases is not None
+            else ""
+        )
+
+        return "<SpecifierSet({0!r}{1})>".format(str(self), pre)
+
+    def __str__(self):
+        return ",".join(sorted(str(s) for s in self._specs))
+
+    def __hash__(self):
+        return hash(self._specs)
+
+    def __and__(self, other):
+        if isinstance(other, string_types):
+            other = SpecifierSet(other)
+        elif not isinstance(other, SpecifierSet):
+            return NotImplemented
+
+        specifier = SpecifierSet()
+        specifier._specs = frozenset(self._specs | other._specs)
+
+        if self._prereleases is None and other._prereleases is not None:
+            specifier._prereleases = other._prereleases
+        elif self._prereleases is not None and other._prereleases is None:
+            specifier._prereleases = self._prereleases
+        elif self._prereleases == other._prereleases:
+            specifier._prereleases = self._prereleases
+        else:
+            raise ValueError(
+                "Cannot combine SpecifierSets with True and False prerelease "
+                "overrides."
+            )
+
+        return specifier
+
+    def __eq__(self, other):
+        if isinstance(other, string_types):
+            other = SpecifierSet(other)
+        elif isinstance(other, _IndividualSpecifier):
+            other = SpecifierSet(str(other))
+        elif not isinstance(other, SpecifierSet):
+            return NotImplemented
+
+        return self._specs == other._specs
+
+    def __ne__(self, other):
+        if isinstance(other, string_types):
+            other = SpecifierSet(other)
+        elif isinstance(other, _IndividualSpecifier):
+            other = SpecifierSet(str(other))
+        elif not isinstance(other, SpecifierSet):
+            return NotImplemented
+
+        return self._specs != other._specs
+
+    def __len__(self):
+        return len(self._specs)
+
+    def __iter__(self):
+        return iter(self._specs)
+
+    @property
+    def prereleases(self):
+        # If we have been given an explicit prerelease modifier, then we'll
+        # pass that through here.
+        if self._prereleases is not None:
+            return self._prereleases
+
+        # If we don't have any specifiers, and we don't have a forced value,
+        # then we'll just return None since we don't know if this should have
+        # pre-releases or not.
+        if not self._specs:
+            return None
+
+        # Otherwise we'll see if any of the given specifiers accept
+        # prereleases, if any of them do we'll return True, otherwise False.
+        return any(s.prereleases for s in self._specs)
+
+    @prereleases.setter
+    def prereleases(self, value):
+        self._prereleases = value
+
+    def __contains__(self, item):
+        return self.contains(item)
+
+    def contains(self, item, prereleases=None):
+        # Ensure that our item is a Version or LegacyVersion instance.
+        if not isinstance(item, (LegacyVersion, Version)):
+            item = parse(item)
+
+        # Determine if we're forcing a prerelease or not, if we're not forcing
+        # one for this particular filter call, then we'll use whatever the
+        # SpecifierSet thinks for whether or not we should support prereleases.
+        if prereleases is None:
+            prereleases = self.prereleases
+
+        # We can determine if we're going to allow pre-releases by looking to
+        # see if any of the underlying items supports them. If none of them do
+        # and this item is a pre-release then we do not allow it and we can
+        # short circuit that here.
+        # Note: This means that 1.0.dev1 would not be contained in something
+        #       like >=1.0.devabc however it would be in >=1.0.debabc,>0.0.dev0
+        if not prereleases and item.is_prerelease:
+            return False
+
+        # We simply dispatch to the underlying specs here to make sure that the
+        # given version is contained within all of them.
+        # Note: This use of all() here means that an empty set of specifiers
+        #       will always return True, this is an explicit design decision.
+        return all(s.contains(item, prereleases=prereleases) for s in self._specs)
+
+    def filter(self, iterable, prereleases=None):
+        # Determine if we're forcing a prerelease or not, if we're not forcing
+        # one for this particular filter call, then we'll use whatever the
+        # SpecifierSet thinks for whether or not we should support prereleases.
+        if prereleases is None:
+            prereleases = self.prereleases
+
+        # If we have any specifiers, then we want to wrap our iterable in the
+        # filter method for each one, this will act as a logical AND amongst
+        # each specifier.
+        if self._specs:
+            for spec in self._specs:
+                iterable = spec.filter(iterable, prereleases=bool(prereleases))
+            return iterable
+        # If we do not have any specifiers, then we need to have a rough filter
+        # which will filter out any pre-releases, unless there are no final
+        # releases, and which will filter out LegacyVersion in general.
+        else:
+            filtered = []
+            found_prereleases = []
+
+            for item in iterable:
+                # Ensure that we some kind of Version class for this item.
+                if not isinstance(item, (LegacyVersion, Version)):
+                    parsed_version = parse(item)
+                else:
+                    parsed_version = item
+
+                # Filter out any item which is parsed as a LegacyVersion
+                if isinstance(parsed_version, LegacyVersion):
+                    continue
+
+                # Store any item which is a pre-release for later unless we've
+                # already found a final version or we are accepting prereleases
+                if parsed_version.is_prerelease and not prereleases:
+                    if not filtered:
+                        found_prereleases.append(item)
+                else:
+                    filtered.append(item)
+
+            # If we've found no items except for pre-releases, then we'll go
+            # ahead and use the pre-releases
+            if not filtered and found_prereleases and prereleases is None:
+                return found_prereleases
+
+            return filtered
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/packaging/specifiers.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/packaging/specifiers.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..ffb6520ac95217d8f33ba43b40ab66febebeae62
GIT binary patch
literal 28139
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
b7^4ic7@LxXSd*9`CzsfN27Z3fDOo}QfpXeg

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/packaging/utils.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/packaging/utils.py
new file mode 100644
index 0000000..8841878
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/packaging/utils.py
@@ -0,0 +1,57 @@
+# This file is dual licensed under the terms of the Apache License, Version
+# 2.0, and the BSD License. See the LICENSE file in the root of this repository
+# for complete details.
+from __future__ import absolute_import, division, print_function
+
+import re
+
+from .version import InvalidVersion, Version
+
+
+_canonicalize_regex = re.compile(r"[-_.]+")
+
+
+def canonicalize_name(name):
+    # This is taken from PEP 503.
+    return _canonicalize_regex.sub("-", name).lower()
+
+
+def canonicalize_version(version):
+    """
+    This is very similar to Version.__str__, but has one subtle differences
+    with the way it handles the release segment.
+    """
+
+    try:
+        version = Version(version)
+    except InvalidVersion:
+        # Legacy versions cannot be normalized
+        return version
+
+    parts = []
+
+    # Epoch
+    if version.epoch != 0:
+        parts.append("{0}!".format(version.epoch))
+
+    # Release segment
+    # NB: This strips trailing '.0's to normalize
+    parts.append(re.sub(r"(\.0)+$", "", ".".join(str(x) for x in version.release)))
+
+    # Pre-release
+    if version.pre is not None:
+        parts.append("".join(str(x) for x in version.pre))
+
+    # Post-release
+    if version.post is not None:
+        parts.append(".post{0}".format(version.post))
+
+    # Development release
+    if version.dev is not None:
+        parts.append(".dev{0}".format(version.dev))
+
+    # Local version segment
+    if version.local is not None:
+        parts.append("+{0}".format(version.local))
+
+    return "".join(parts)
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/packaging/utils.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/packaging/utils.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..0df6518789b6183723708d6db05dfa9978ea693d
GIT binary patch
literal 2143
zcmZSn%**AGdLky70ScHH7#JK97#WH|A}I_EDU1v`3=Fx93{i{>xl9aEObofq3{lJs
zj37BCh8z}#C>DkkW`-0Nh8$LgTsDR%HilewhA4Ih##9!DEDnYgR)%IqhA2*k6gGwy
z28Jjuh7@)%gPS3Ri6K~ngMon|6J)stGXn!d2|oh^Lt;{KeokpgYJ6sHL4Hw52}nsw
zW?5!&W`14?9|HqJK~ZL2NqkyqUUErhex6?@BLf422FT@LS<k$(#GK5Ou+$>326hGp
z1}M9jje&t7S~p%VRy!G_2ZTYkI)gkc2C|-kA&U{@=NblvW+sL#CWdAPhG4MKekCB)
zx)4_iGcYj3Cnx6R=Vc}*=44i-#uufgr&g4J3@a{8Dq&?{V93cYPc6~_X)0l1U|`5g
z%uUq*`x8VI=P@ua=ob`amL-;?>X#)J>8IuAq@)%V>nEk?mnS9V<(lRe8yO~<r&pz0
zm|B$QWL23NfIxbleu#cSW`S;IUU5lcPL8fynTMxw07wXo<I7U>Qu2%R3lfvF6Vo&E
z()CMAGINUc3Mxwk85kH)+zfIOC^(BjLC3%Z4iXR(6k^~Y@n&RTs1#r*VPF7-2O~o*
z14DS85CcmIBSSV9Ly-ytBO_xC14D2`Is-#3BS=ve6DahunHh@07-|?9vY0`UoW%l_
zYGwqb1;#uEs9XsvLlzq}^`x*eWU)gNNeu%i<+wnUH#37Zfy6i&Qn(qiIT?!fLJde^
z0c!#$D2M`>CPoIZH4F?{+%QcqV464>pf2JDncR#}$^%m>%m{TnCrl|1no?evQahMZ
zE|^kYB&84s)`0yTtii*;z);-8z`($zprD`-l95@gkXfuymReM)P@I{YnUh$gP?E0z
zO{{wH@x>)Y@$oteNu?zU8HvRT`FW`dpwyL<s*sYImX=zSnwOkf3^uDgvm`^IBqLR!
zJh4(C6Qn#ZB`38QEL4=5lbTqZs!*Joo|~Fiq6gLh&T_?|gjsD+t5^(*a*Y^015Is}
z5>WaCCw4t}iU6l;P$rRP0H=jmK~Q{y(goOOVT^^$3@M<T0!r?FkVFsGQ&I%ZJSCuH
zrDp&(wPHYXK`|!-1A|R^YF=tZL6Mz0C_+GPV`HGiuR*-90w@TSpMpSz*dX$yHo}+1
zpt4l2Aiubz+MpI3>v}1vWgs>vDQH(4)cR?Fy#V3{fuayxmZcWtCufv^O3%cCg4Dbe
zFf%Q`C^xYL9JNKML7)@_F6grIGxJJ7JZQQD7m5W%sbERJ{5%K)<OHxxN@^L{ik$r9
z#2iRs0ckFSmfoO}v>>slq<BEXvqS{F?1Z`xR1p*_fpQERGot__FB2;h8#6zn42uyn
zKcgCm1;b3>++V^4syX7*N=r(MQsd);Kstj!nI;I73WGq#1%dJyIOu~wkpK?L<ow)%
x%$(F9Pz(ftj0lnir8to8fejZ>a<a+IPbtkwwF9}f800t^CLSg+W`1T)RsdCx;l%&|

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/packaging/version.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/packaging/version.py
new file mode 100644
index 0000000..95157a1
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/packaging/version.py
@@ -0,0 +1,420 @@
+# This file is dual licensed under the terms of the Apache License, Version
+# 2.0, and the BSD License. See the LICENSE file in the root of this repository
+# for complete details.
+from __future__ import absolute_import, division, print_function
+
+import collections
+import itertools
+import re
+
+from ._structures import Infinity
+
+
+__all__ = ["parse", "Version", "LegacyVersion", "InvalidVersion", "VERSION_PATTERN"]
+
+
+_Version = collections.namedtuple(
+    "_Version", ["epoch", "release", "dev", "pre", "post", "local"]
+)
+
+
+def parse(version):
+    """
+    Parse the given version string and return either a :class:`Version` object
+    or a :class:`LegacyVersion` object depending on if the given version is
+    a valid PEP 440 version or a legacy version.
+    """
+    try:
+        return Version(version)
+    except InvalidVersion:
+        return LegacyVersion(version)
+
+
+class InvalidVersion(ValueError):
+    """
+    An invalid version was found, users should refer to PEP 440.
+    """
+
+
+class _BaseVersion(object):
+    def __hash__(self):
+        return hash(self._key)
+
+    def __lt__(self, other):
+        return self._compare(other, lambda s, o: s < o)
+
+    def __le__(self, other):
+        return self._compare(other, lambda s, o: s <= o)
+
+    def __eq__(self, other):
+        return self._compare(other, lambda s, o: s == o)
+
+    def __ge__(self, other):
+        return self._compare(other, lambda s, o: s >= o)
+
+    def __gt__(self, other):
+        return self._compare(other, lambda s, o: s > o)
+
+    def __ne__(self, other):
+        return self._compare(other, lambda s, o: s != o)
+
+    def _compare(self, other, method):
+        if not isinstance(other, _BaseVersion):
+            return NotImplemented
+
+        return method(self._key, other._key)
+
+
+class LegacyVersion(_BaseVersion):
+    def __init__(self, version):
+        self._version = str(version)
+        self._key = _legacy_cmpkey(self._version)
+
+    def __str__(self):
+        return self._version
+
+    def __repr__(self):
+        return "<LegacyVersion({0})>".format(repr(str(self)))
+
+    @property
+    def public(self):
+        return self._version
+
+    @property
+    def base_version(self):
+        return self._version
+
+    @property
+    def epoch(self):
+        return -1
+
+    @property
+    def release(self):
+        return None
+
+    @property
+    def pre(self):
+        return None
+
+    @property
+    def post(self):
+        return None
+
+    @property
+    def dev(self):
+        return None
+
+    @property
+    def local(self):
+        return None
+
+    @property
+    def is_prerelease(self):
+        return False
+
+    @property
+    def is_postrelease(self):
+        return False
+
+    @property
+    def is_devrelease(self):
+        return False
+
+
+_legacy_version_component_re = re.compile(r"(\d+ | [a-z]+ | \.| -)", re.VERBOSE)
+
+_legacy_version_replacement_map = {
+    "pre": "c",
+    "preview": "c",
+    "-": "final-",
+    "rc": "c",
+    "dev": "@",
+}
+
+
+def _parse_version_parts(s):
+    for part in _legacy_version_component_re.split(s):
+        part = _legacy_version_replacement_map.get(part, part)
+
+        if not part or part == ".":
+            continue
+
+        if part[:1] in "0123456789":
+            # pad for numeric comparison
+            yield part.zfill(8)
+        else:
+            yield "*" + part
+
+    # ensure that alpha/beta/candidate are before final
+    yield "*final"
+
+
+def _legacy_cmpkey(version):
+    # We hardcode an epoch of -1 here. A PEP 440 version can only have a epoch
+    # greater than or equal to 0. This will effectively put the LegacyVersion,
+    # which uses the defacto standard originally implemented by setuptools,
+    # as before all PEP 440 versions.
+    epoch = -1
+
+    # This scheme is taken from pkg_resources.parse_version setuptools prior to
+    # it's adoption of the packaging library.
+    parts = []
+    for part in _parse_version_parts(version.lower()):
+        if part.startswith("*"):
+            # remove "-" before a prerelease tag
+            if part < "*final":
+                while parts and parts[-1] == "*final-":
+                    parts.pop()
+
+            # remove trailing zeros from each series of numeric parts
+            while parts and parts[-1] == "00000000":
+                parts.pop()
+
+        parts.append(part)
+    parts = tuple(parts)
+
+    return epoch, parts
+
+
+# Deliberately not anchored to the start and end of the string, to make it
+# easier for 3rd party code to reuse
+VERSION_PATTERN = r"""
+    v?
+    (?:
+        (?:(?P<epoch>[0-9]+)!)?                           # epoch
+        (?P<release>[0-9]+(?:\.[0-9]+)*)                  # release segment
+        (?P<pre>                                          # pre-release
+            [-_\.]?
+            (?P<pre_l>(a|b|c|rc|alpha|beta|pre|preview))
+            [-_\.]?
+            (?P<pre_n>[0-9]+)?
+        )?
+        (?P<post>                                         # post release
+            (?:-(?P<post_n1>[0-9]+))
+            |
+            (?:
+                [-_\.]?
+                (?P<post_l>post|rev|r)
+                [-_\.]?
+                (?P<post_n2>[0-9]+)?
+            )
+        )?
+        (?P<dev>                                          # dev release
+            [-_\.]?
+            (?P<dev_l>dev)
+            [-_\.]?
+            (?P<dev_n>[0-9]+)?
+        )?
+    )
+    (?:\+(?P<local>[a-z0-9]+(?:[-_\.][a-z0-9]+)*))?       # local version
+"""
+
+
+class Version(_BaseVersion):
+
+    _regex = re.compile(r"^\s*" + VERSION_PATTERN + r"\s*$", re.VERBOSE | re.IGNORECASE)
+
+    def __init__(self, version):
+        # Validate the version and parse it into pieces
+        match = self._regex.search(version)
+        if not match:
+            raise InvalidVersion("Invalid version: '{0}'".format(version))
+
+        # Store the parsed out pieces of the version
+        self._version = _Version(
+            epoch=int(match.group("epoch")) if match.group("epoch") else 0,
+            release=tuple(int(i) for i in match.group("release").split(".")),
+            pre=_parse_letter_version(match.group("pre_l"), match.group("pre_n")),
+            post=_parse_letter_version(
+                match.group("post_l"), match.group("post_n1") or match.group("post_n2")
+            ),
+            dev=_parse_letter_version(match.group("dev_l"), match.group("dev_n")),
+            local=_parse_local_version(match.group("local")),
+        )
+
+        # Generate a key which will be used for sorting
+        self._key = _cmpkey(
+            self._version.epoch,
+            self._version.release,
+            self._version.pre,
+            self._version.post,
+            self._version.dev,
+            self._version.local,
+        )
+
+    def __repr__(self):
+        return "<Version({0})>".format(repr(str(self)))
+
+    def __str__(self):
+        parts = []
+
+        # Epoch
+        if self.epoch != 0:
+            parts.append("{0}!".format(self.epoch))
+
+        # Release segment
+        parts.append(".".join(str(x) for x in self.release))
+
+        # Pre-release
+        if self.pre is not None:
+            parts.append("".join(str(x) for x in self.pre))
+
+        # Post-release
+        if self.post is not None:
+            parts.append(".post{0}".format(self.post))
+
+        # Development release
+        if self.dev is not None:
+            parts.append(".dev{0}".format(self.dev))
+
+        # Local version segment
+        if self.local is not None:
+            parts.append("+{0}".format(self.local))
+
+        return "".join(parts)
+
+    @property
+    def epoch(self):
+        return self._version.epoch
+
+    @property
+    def release(self):
+        return self._version.release
+
+    @property
+    def pre(self):
+        return self._version.pre
+
+    @property
+    def post(self):
+        return self._version.post[1] if self._version.post else None
+
+    @property
+    def dev(self):
+        return self._version.dev[1] if self._version.dev else None
+
+    @property
+    def local(self):
+        if self._version.local:
+            return ".".join(str(x) for x in self._version.local)
+        else:
+            return None
+
+    @property
+    def public(self):
+        return str(self).split("+", 1)[0]
+
+    @property
+    def base_version(self):
+        parts = []
+
+        # Epoch
+        if self.epoch != 0:
+            parts.append("{0}!".format(self.epoch))
+
+        # Release segment
+        parts.append(".".join(str(x) for x in self.release))
+
+        return "".join(parts)
+
+    @property
+    def is_prerelease(self):
+        return self.dev is not None or self.pre is not None
+
+    @property
+    def is_postrelease(self):
+        return self.post is not None
+
+    @property
+    def is_devrelease(self):
+        return self.dev is not None
+
+
+def _parse_letter_version(letter, number):
+    if letter:
+        # We consider there to be an implicit 0 in a pre-release if there is
+        # not a numeral associated with it.
+        if number is None:
+            number = 0
+
+        # We normalize any letters to their lower case form
+        letter = letter.lower()
+
+        # We consider some words to be alternate spellings of other words and
+        # in those cases we want to normalize the spellings to our preferred
+        # spelling.
+        if letter == "alpha":
+            letter = "a"
+        elif letter == "beta":
+            letter = "b"
+        elif letter in ["c", "pre", "preview"]:
+            letter = "rc"
+        elif letter in ["rev", "r"]:
+            letter = "post"
+
+        return letter, int(number)
+    if not letter and number:
+        # We assume if we are given a number, but we are not given a letter
+        # then this is using the implicit post release syntax (e.g. 1.0-1)
+        letter = "post"
+
+        return letter, int(number)
+
+
+_local_version_separators = re.compile(r"[\._-]")
+
+
+def _parse_local_version(local):
+    """
+    Takes a string like abc.1.twelve and turns it into ("abc", 1, "twelve").
+    """
+    if local is not None:
+        return tuple(
+            part.lower() if not part.isdigit() else int(part)
+            for part in _local_version_separators.split(local)
+        )
+
+
+def _cmpkey(epoch, release, pre, post, dev, local):
+    # When we compare a release version, we want to compare it with all of the
+    # trailing zeros removed. So we'll use a reverse the list, drop all the now
+    # leading zeros until we come to something non zero, then take the rest
+    # re-reverse it back into the correct order and make it a tuple and use
+    # that for our sorting key.
+    release = tuple(
+        reversed(list(itertools.dropwhile(lambda x: x == 0, reversed(release))))
+    )
+
+    # We need to "trick" the sorting algorithm to put 1.0.dev0 before 1.0a0.
+    # We'll do this by abusing the pre segment, but we _only_ want to do this
+    # if there is not a pre or a post segment. If we have one of those then
+    # the normal sorting rules will handle this case correctly.
+    if pre is None and post is None and dev is not None:
+        pre = -Infinity
+    # Versions without a pre-release (except as noted above) should sort after
+    # those with one.
+    elif pre is None:
+        pre = Infinity
+
+    # Versions without a post segment should sort before those with one.
+    if post is None:
+        post = -Infinity
+
+    # Versions without a development segment should sort after those with one.
+    if dev is None:
+        dev = Infinity
+
+    if local is None:
+        # Versions without a local segment should sort before those with one.
+        local = -Infinity
+    else:
+        # Versions with a local segment need that segment parsed to implement
+        # the sorting rules in PEP440.
+        # - Alpha numeric segments sort before numeric segments
+        # - Alpha numeric segments sort lexicographically
+        # - Numeric segments sort numerically
+        # - Shorter versions sort before longer versions when the prefixes
+        #   match exactly
+        local = tuple((i, "") if isinstance(i, int) else (-Infinity, i) for i in local)
+
+    return epoch, release, pre, post, dev, local
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/packaging/version.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/packaging/version.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..6e0bf37a9ba4efe7d42bc7863fb24b91f12b026f
GIT binary patch
literal 19025
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

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/pep517/__init__.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/pep517/__init__.py
new file mode 100644
index 0000000..9c1a098
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/pep517/__init__.py
@@ -0,0 +1,4 @@
+"""Wrappers to build Python packages using PEP 517 hooks
+"""
+
+__version__ = '0.5.0'
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/pep517/__init__.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/pep517/__init__.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..3681885a9a808fe6a7390596361c046e9026ff00
GIT binary patch
literal 308
zcmZSn%**AGdLky70SXuy7#JKF7#NBL7#J8*7#N}$7*ZG+q8J%cm>7aJm_agT3=9n6
zMTrFksYS&KCHV?TrI|S?3IUZR8Tok%1&PVoiRr1u3Z=!FdFcuPt^o?BhUN+x`T5z!
zT*a&m3=9T(rg{c`8cYlf3?=Lg3=Hw{Df!9q@g>|~c3Emsab|vAe7pw8K?tHakAZ<f
zzo00yEU_e2zbvsxKP^8eCAFwnKPg4OJSizJ*EF}-$S}z~y(-<p)S^5mtIEs(1k&^L
zL-Y$W3v@H{ic1o6a&+CwJUop9Ktf;~UzVDel3%1>kXm4BXs#b0pP83g5+AQuP+7vk
Wz`$UWo1apelWGTYZZU{pV*&tCT2H$G

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/pep517/_in_process.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/pep517/_in_process.py
new file mode 100644
index 0000000..d6524b6
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/pep517/_in_process.py
@@ -0,0 +1,207 @@
+"""This is invoked in a subprocess to call the build backend hooks.
+
+It expects:
+- Command line args: hook_name, control_dir
+- Environment variable: PEP517_BUILD_BACKEND=entry.point:spec
+- control_dir/input.json:
+  - {"kwargs": {...}}
+
+Results:
+- control_dir/output.json
+  - {"return_val": ...}
+"""
+from glob import glob
+from importlib import import_module
+import os
+from os.path import join as pjoin
+import re
+import shutil
+import sys
+
+# This is run as a script, not a module, so it can't do a relative import
+import compat
+
+
+class BackendUnavailable(Exception):
+    """Raised if we cannot import the backend"""
+
+
+def _build_backend():
+    """Find and load the build backend"""
+    ep = os.environ['PEP517_BUILD_BACKEND']
+    mod_path, _, obj_path = ep.partition(':')
+    try:
+        obj = import_module(mod_path)
+    except ImportError:
+        raise BackendUnavailable
+    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):
+    """Invoke optional prepare_metadata_for_build_wheel
+
+    Implements a fallback by building a wheel if the hook isn't defined.
+    """
+    backend = _build_backend()
+    try:
+        hook = backend.prepare_metadata_for_build_wheel
+    except AttributeError:
+        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 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
+
+
+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 = compat.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:
+        json_out['no_backend'] = True
+    except GotUnsupportedOperation:
+        json_out['unsupported'] = True
+
+    compat.write_json(json_out, pjoin(control_dir, 'output.json'), indent=2)
+
+
+if __name__ == '__main__':
+    main()
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/pep517/_in_process.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/pep517/_in_process.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..618412413428b35adb6422ef6d321422881df761
GIT binary patch
literal 7785
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

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/pep517/build.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/pep517/build.py
new file mode 100644
index 0000000..ac6c949
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/pep517/build.py
@@ -0,0 +1,108 @@
+"""Build a project using PEP 517 hooks.
+"""
+import argparse
+import logging
+import os
+import contextlib
+from pip._vendor import pytoml
+import shutil
+import errno
+import tempfile
+
+from .envbuild import BuildEnvironment
+from .wrappers import Pep517HookCaller
+
+log = logging.getLogger(__name__)
+
+
+@contextlib.contextmanager
+def tempdir():
+    td = tempfile.mkdtemp()
+    try:
+        yield td
+    finally:
+        shutil.rmtree(td)
+
+
+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 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 build(source_dir, dist, dest=None):
+    pyproject = os.path.join(source_dir, 'pyproject.toml')
+    dest = os.path.join(source_dir, dest or 'dist')
+    mkdir_p(dest)
+
+    with open(pyproject) as f:
+        pyproject_data = pytoml.load(f)
+    # Ensure the mandatory data can be loaded
+    buildsys = pyproject_data['build-system']
+    requires = buildsys['requires']
+    backend = buildsys['build-backend']
+
+    hooks = Pep517HookCaller(source_dir, backend)
+
+    with BuildEnvironment() as env:
+        env.pip_install(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):
+    # 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/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/pep517/build.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/pep517/build.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..c60d7801a00914d09daf308cb2bfc1414fdfc39c
GIT binary patch
literal 3865
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

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/pep517/check.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/pep517/check.py
new file mode 100644
index 0000000..f4cdc6b
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/pep517/check.py
@@ -0,0 +1,202 @@
+"""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.pytoml import TomlError, 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']
+        log.info('Loaded pyproject.toml')
+    except (TomlError, KeyError):
+        log.error("Invalid pyproject.toml", exc_info=True)
+        return False
+
+    hooks = Pep517HookCaller(source_dir, backend)
+
+    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):
+    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/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/pep517/check.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/pep517/check.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..46d47fb0d0b9deb798c787278f12c82589f2f67e
GIT binary patch
literal 6183
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

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/pep517/colorlog.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/pep517/colorlog.py
new file mode 100644
index 0000000..69c8a59
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/pep517/colorlog.py
@@ -0,0 +1,115 @@
+"""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/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/pep517/colorlog.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/pep517/colorlog.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..3f7cacb3428301ad441103383b4d9daf3b6c2efe
GIT binary patch
literal 3906
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

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/pep517/compat.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/pep517/compat.py
new file mode 100644
index 0000000..01c66fc
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/pep517/compat.py
@@ -0,0 +1,23 @@
+"""Handle reading and writing JSON in UTF-8, on Python 3 and 2."""
+import json
+import sys
+
+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)
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/pep517/compat.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/pep517/compat.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..0f11bf4bbae056861f6965a229822ad51a342b3b
GIT binary patch
literal 1587
zcmZSn%**AGdLky70ScHH7#JKF7#NCU7#J8*7#N}$7*ZG+QkWQW7#X4%VQeObC?<wf
zCWb6#h7@K7$rKibY*vOMH-;2eh86~fC>DkkHZX&gAy0@Qg&oXhVMyTsGgv{!1#57E
zY_VZrVDL!HOUX%9C`wIC$;?YvNX$!7C@;z^0kOS;{rwa&^Atiu+;lB;6!P;F0xC-~
z^79mo!OD#EGXMYo|KBeY<oHZx1_p*?ko#E}7#KJh7#O@kHkdLnFqAMb)WF=H!pzXj
z#Mm#zP|M6v!pM-t#8AV)P{Yhn!^F_b#K0Jy!oUz1k;1?btN}8{uY{3-fuXzvWL#=q
zaz4m~#jFer45cM$x)vHBD@#D?@(WV)z>KWod<Y|@G`9e3L<vYyeo_`#x*)M6qlArt
zfg!s*u_(P5Y<ijo$oXKRIER6OLBF6Vvn;VBRlh8;NIxw<CndG0SU)L6zdR`^FV{4;
z*vK%+JiRL2!qlQXC#%ZL00h$W^h5LuG7EGw^NLFnb8>Xu$~-)c13*Gx9AB22my%zk
zUyxd0YG|&XoS$2eSfW=@S;7VKUQuRAYCOp0?4S?>`G<i~f-xE7bx?SM-0KXI(T9d5
zEKNYeQiP$F5f+w=49$!T!B|7FC<tUATIdCVEC>Px5jcEu@)J`uz(OEPgFwL!4j3>&
z|Ih)YQBb-B2M#wV2;hMOawLcY3P8++*387vuYjJ!QkX!w1)R_rF%ufd!15&gVH5<i
z5uB=mK#4F297v!@8|aV<0)><yB7lUjq#jM=)B_42yy*rM9DXGrvM33h&k!jk2ow{8
zCzS;8FfcHPBKutf6fY&9c!`fs$xn`tha_-NDle`qE&-`8OD!tS%+HI@%uCA$2OiiI
qa56^_^iS}h3}=&@pHiBWY6s4(d<+Z>Y>YgNJWRq&oGd(SoGbu17+Gup

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/pep517/envbuild.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/pep517/envbuild.py
new file mode 100644
index 0000000..f7ac5f4
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/pep517/envbuild.py
@@ -0,0 +1,158 @@
+"""Build wheels/sdists by installing build deps to a temporary environment.
+"""
+
+import os
+import logging
+from pip._vendor import pytoml
+import shutil
+from subprocess import check_call
+import sys
+from sysconfig import get_paths
+from tempfile import mkdtemp
+
+from .wrappers import Pep517HookCaller
+
+log = logging.getLogger(__name__)
+
+
+def _load_pyproject(source_dir):
+    with open(os.path.join(source_dir, 'pyproject.toml')) as f:
+        pyproject_data = pytoml.load(f)
+    buildsys = pyproject_data['build-system']
+    return buildsys['requires'], buildsys['build-backend']
+
+
+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)
+        check_call([
+            sys.executable, '-m', 'pip', 'install', '--ignore-installed',
+            '--prefix', self.path] + list(reqs))
+
+    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 = _load_pyproject(source_dir)
+    hooks = Pep517HookCaller(source_dir, backend)
+
+    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 = _load_pyproject(source_dir)
+    hooks = Pep517HookCaller(source_dir, backend)
+
+    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/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/pep517/envbuild.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/pep517/envbuild.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..279c6c55e32a004448a37cabc221ea79220b4af4
GIT binary patch
literal 5625
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

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/pep517/wrappers.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/pep517/wrappers.py
new file mode 100644
index 0000000..b14b899
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/pep517/wrappers.py
@@ -0,0 +1,163 @@
+from contextlib import contextmanager
+import os
+from os.path import dirname, abspath, join as pjoin
+import shutil
+from subprocess import check_call
+import sys
+from tempfile import mkdtemp
+
+from . import compat
+
+_in_proc_script = pjoin(dirname(abspath(__file__)), '_in_process.py')
+
+
+@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."""
+
+
+class UnsupportedOperation(Exception):
+    """May be raised by build_sdist if the backend indicates that it can't."""
+
+
+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)
+
+
+class Pep517HookCaller(object):
+    """A wrapper around a source directory to be built with a PEP 517 backend.
+
+    source_dir : The path to the source directory, containing pyproject.toml.
+    backend : The build backend spec, as per PEP 517, from pyproject.toml.
+    """
+    def __init__(self, source_dir, build_backend):
+        self.source_dir = abspath(source_dir)
+        self.build_backend = build_backend
+        self._subprocess_runner = default_subprocess_runner
+
+    # TODO: Is this over-engineered? Maybe frontends only need to
+    #       set this when creating the wrapper, not on every call.
+    @contextmanager
+    def subprocess_runner(self, runner):
+        prev = self._subprocess_runner
+        self._subprocess_runner = runner
+        yield
+        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):
+        """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.
+        """
+        return self._call_hook('prepare_metadata_for_build_wheel', {
+            'metadata_directory': abspath(metadata_directory),
+            'config_settings': config_settings,
+        })
+
+    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).
+        if sys.version_info[0] == 2:
+            build_backend = self.build_backend.encode('ASCII')
+        else:
+            build_backend = self.build_backend
+
+        with tempdir() as td:
+            compat.write_json({'kwargs': kwargs}, pjoin(td, 'input.json'),
+                              indent=2)
+
+            # Run the hook in a subprocess
+            self._subprocess_runner(
+                [sys.executable, _in_proc_script, hook_name, td],
+                cwd=self.source_dir,
+                extra_environ={'PEP517_BUILD_BACKEND': build_backend}
+            )
+
+            data = compat.read_json(pjoin(td, 'output.json'))
+            if data.get('unsupported'):
+                raise UnsupportedOperation
+            if data.get('no_backend'):
+                raise BackendUnavailable
+            return data['return_val']
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/pep517/wrappers.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/pep517/wrappers.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..fd165aed79fc6ae4576681777e4f559daee579a1
GIT binary patch
literal 7144
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
bk%v)+k%tjP3or>VNi*|vim`~X@N)tHnNIn|

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/pkg_resources/__init__.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/pkg_resources/__init__.py
new file mode 100644
index 0000000..fdd40de
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/pkg_resources/__init__.py
@@ -0,0 +1,3286 @@
+# coding: utf-8
+"""
+Package resource API
+--------------------
+
+A resource is a logical file contained within a package, or a logical
+subdirectory thereof.  The package resource API expects resource names
+to have their path parts separated with ``/``, *not* whatever the local
+path separator is.  Do not use os.path operations to manipulate resource
+names being passed into the API.
+
+The package resource API is designed to work with normal filesystem packages,
+.egg files, and unpacked .egg files.  It can also work in a limited way with
+.zip files and with custom PEP 302 loaders that support the ``get_data()``
+method.
+"""
+
+from __future__ import absolute_import
+
+import sys
+import os
+import io
+import time
+import re
+import types
+import zipfile
+import zipimport
+import warnings
+import stat
+import functools
+import pkgutil
+import operator
+import platform
+import collections
+import plistlib
+import email.parser
+import errno
+import tempfile
+import textwrap
+import itertools
+import inspect
+import ntpath
+import posixpath
+from pkgutil import get_importer
+
+try:
+    import _imp
+except ImportError:
+    # Python 3.2 compatibility
+    import imp as _imp
+
+try:
+    FileExistsError
+except NameError:
+    FileExistsError = OSError
+
+from 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
+    WRITE_SUPPORT = False
+
+from os import open as os_open
+from os.path import isdir, split
+
+try:
+    import importlib.machinery as importlib_machinery
+    # access attribute to force import under delayed import mechanisms.
+    importlib_machinery.__name__
+except ImportError:
+    importlib_machinery = None
+
+from . import py31compat
+from pip._vendor import appdirs
+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')
+
+
+__metaclass__ = type
+
+
+if (3, 0) < sys.version_info < (3, 4):
+    raise RuntimeError("Python 3.4 or later is required")
+
+if six.PY2:
+    # Those builtin exceptions are only defined in Python 3
+    PermissionError = None
+    NotADirectoryError = None
+
+# declare some globals that will be defined later to
+# satisfy the linters.
+require = None
+working_set = None
+add_activation_listener = None
+resources_stream = None
+cleanup_resources = None
+resource_dir = None
+resource_stream = None
+set_extraction_path = None
+resource_isdir = None
+resource_string = None
+iter_entry_points = None
+resource_listdir = None
+resource_filename = None
+resource_exists = None
+_distribution_finders = None
+_namespace_handlers = None
+_namespace_packages = None
+
+
+class PEP440Warning(RuntimeWarning):
+    """
+    Used when there is an issue with a version or specifier not complying with
+    PEP 440.
+    """
+
+
+def parse_version(v):
+    try:
+        return packaging.version.Version(v)
+    except packaging.version.InvalidVersion:
+        return packaging.version.LegacyVersion(v)
+
+
+_state_vars = {}
+
+
+def _declare_state(vartype, **kw):
+    globals().update(kw)
+    _state_vars.update(dict.fromkeys(kw, vartype))
+
+
+def __getstate__():
+    state = {}
+    g = globals()
+    for k, v in _state_vars.items():
+        state[k] = g['_sget_' + v](g[k])
+    return state
+
+
+def __setstate__(state):
+    g = globals()
+    for k, v in state.items():
+        g['_sset_' + _state_vars[k]](k, g[k], v)
+    return state
+
+
+def _sget_dict(val):
+    return val.copy()
+
+
+def _sset_dict(key, ob, state):
+    ob.clear()
+    ob.update(state)
+
+
+def _sget_object(val):
+    return val.__getstate__()
+
+
+def _sset_object(key, ob, state):
+    ob.__setstate__(state)
+
+
+_sget_none = _sset_none = lambda *args: None
+
+
+def get_supported_platform():
+    """Return this platform's maximum compatible version.
+
+    distutils.util.get_platform() normally reports the minimum version
+    of Mac OS X that would be required to *use* extensions produced by
+    distutils.  But what we want when checking compatibility is to know the
+    version of Mac OS X that we are *running*.  To allow usage of packages that
+    explicitly require a newer version of Mac OS X, we must also know the
+    current version of the OS.
+
+    If this condition occurs for any other platform with a version in its
+    platform strings, this function should be extended accordingly.
+    """
+    plat = get_build_platform()
+    m = macosVersionString.match(plat)
+    if m is not None and sys.platform == "darwin":
+        try:
+            plat = 'macosx-%s-%s' % ('.'.join(_macosx_vers()[:2]), m.group(3))
+        except ValueError:
+            # not Mac OS X
+            pass
+    return plat
+
+
+__all__ = [
+    # Basic resource access and distribution/entry point discovery
+    'require', 'run_script', 'get_provider', 'get_distribution',
+    'load_entry_point', 'get_entry_map', 'get_entry_info',
+    'iter_entry_points',
+    'resource_string', 'resource_stream', 'resource_filename',
+    'resource_listdir', 'resource_exists', 'resource_isdir',
+
+    # Environmental control
+    'declare_namespace', 'working_set', 'add_activation_listener',
+    'find_distributions', 'set_extraction_path', 'cleanup_resources',
+    'get_default_cache',
+
+    # Primary implementation classes
+    'Environment', 'WorkingSet', 'ResourceManager',
+    'Distribution', 'Requirement', 'EntryPoint',
+
+    # Exceptions
+    'ResolutionError', 'VersionConflict', 'DistributionNotFound',
+    'UnknownExtra', 'ExtractionError',
+
+    # Warnings
+    'PEP440Warning',
+
+    # Parsing functions and string utilities
+    'parse_requirements', 'parse_version', 'safe_name', 'safe_version',
+    'get_platform', 'compatible_platforms', 'yield_lines', 'split_sections',
+    'safe_extra', 'to_filename', 'invalid_marker', 'evaluate_marker',
+
+    # filesystem utilities
+    'ensure_directory', 'normalize_path',
+
+    # Distribution "precedence" constants
+    'EGG_DIST', 'BINARY_DIST', 'SOURCE_DIST', 'CHECKOUT_DIST', 'DEVELOP_DIST',
+
+    # "Provider" interfaces, implementations, and registration/lookup APIs
+    'IMetadataProvider', 'IResourceProvider', 'FileMetadata',
+    'PathMetadata', 'EggMetadata', 'EmptyProvider', 'empty_provider',
+    'NullProvider', 'EggProvider', 'DefaultProvider', 'ZipProvider',
+    'register_finder', 'register_namespace_handler', 'register_loader_type',
+    'fixup_namespace_packages', 'get_importer',
+
+    # Warnings
+    'PkgResourcesDeprecationWarning',
+
+    # Deprecated/backward compatibility only
+    'run_main', 'AvailableDistributions',
+]
+
+
+class ResolutionError(Exception):
+    """Abstract base for dependency resolution errors"""
+
+    def __repr__(self):
+        return self.__class__.__name__ + repr(self.args)
+
+
+class VersionConflict(ResolutionError):
+    """
+    An already-installed version conflicts with the requested version.
+
+    Should be initialized with the installed Distribution and the requested
+    Requirement.
+    """
+
+    _template = "{self.dist} is installed but {self.req} is required"
+
+    @property
+    def dist(self):
+        return self.args[0]
+
+    @property
+    def req(self):
+        return self.args[1]
+
+    def report(self):
+        return self._template.format(**locals())
+
+    def with_context(self, required_by):
+        """
+        If required_by is non-empty, return a version of self that is a
+        ContextualVersionConflict.
+        """
+        if not required_by:
+            return self
+        args = self.args + (required_by,)
+        return ContextualVersionConflict(*args)
+
+
+class ContextualVersionConflict(VersionConflict):
+    """
+    A VersionConflict that accepts a third parameter, the set of the
+    requirements that required the installed Distribution.
+    """
+
+    _template = VersionConflict._template + ' by {self.required_by}'
+
+    @property
+    def required_by(self):
+        return self.args[2]
+
+
+class DistributionNotFound(ResolutionError):
+    """A requested distribution was not found"""
+
+    _template = ("The '{self.req}' distribution was not found "
+                 "and is required by {self.requirers_str}")
+
+    @property
+    def req(self):
+        return self.args[0]
+
+    @property
+    def requirers(self):
+        return self.args[1]
+
+    @property
+    def requirers_str(self):
+        if not self.requirers:
+            return 'the application'
+        return ', '.join(self.requirers)
+
+    def report(self):
+        return self._template.format(**locals())
+
+    def __str__(self):
+        return self.report()
+
+
+class UnknownExtra(ResolutionError):
+    """Distribution doesn't have an "extra feature" of the given name"""
+
+
+_provider_factories = {}
+
+PY_MAJOR = sys.version[:3]
+EGG_DIST = 3
+BINARY_DIST = 2
+SOURCE_DIST = 1
+CHECKOUT_DIST = 0
+DEVELOP_DIST = -1
+
+
+def register_loader_type(loader_type, provider_factory):
+    """Register `provider_factory` to make providers for `loader_type`
+
+    `loader_type` is the type or class of a PEP 302 ``module.__loader__``,
+    and `provider_factory` is a function that, passed a *module* object,
+    returns an ``IResourceProvider`` for that module.
+    """
+    _provider_factories[loader_type] = provider_factory
+
+
+def get_provider(moduleOrReq):
+    """Return an IResourceProvider for the named module or requirement"""
+    if isinstance(moduleOrReq, Requirement):
+        return working_set.find(moduleOrReq) or require(str(moduleOrReq))[0]
+    try:
+        module = sys.modules[moduleOrReq]
+    except KeyError:
+        __import__(moduleOrReq)
+        module = sys.modules[moduleOrReq]
+    loader = getattr(module, '__loader__', None)
+    return _find_adapter(_provider_factories, loader)(module)
+
+
+def _macosx_vers(_cache=[]):
+    if not _cache:
+        version = platform.mac_ver()[0]
+        # fallback for MacPorts
+        if version == '':
+            plist = '/System/Library/CoreServices/SystemVersion.plist'
+            if os.path.exists(plist):
+                if hasattr(plistlib, 'readPlist'):
+                    plist_content = plistlib.readPlist(plist)
+                    if 'ProductVersion' in plist_content:
+                        version = plist_content['ProductVersion']
+
+        _cache.append(version.split('.'))
+    return _cache[0]
+
+
+def _macosx_arch(machine):
+    return {'PowerPC': 'ppc', 'Power_Macintosh': 'ppc'}.get(machine, machine)
+
+
+def get_build_platform():
+    """Return this platform's string for platform-specific distributions
+
+    XXX Currently this is the same as ``distutils.util.get_platform()``, but it
+    needs some hacks for Linux and Mac OS X.
+    """
+    from sysconfig import get_platform
+
+    plat = get_platform()
+    if sys.platform == "darwin" and not plat.startswith('macosx-'):
+        try:
+            version = _macosx_vers()
+            machine = os.uname()[4].replace(" ", "_")
+            return "macosx-%d.%d-%s" % (
+                int(version[0]), int(version[1]),
+                _macosx_arch(machine),
+            )
+        except ValueError:
+            # if someone is running a non-Mac darwin system, this will fall
+            # through to the default implementation
+            pass
+    return plat
+
+
+macosVersionString = re.compile(r"macosx-(\d+)\.(\d+)-(.*)")
+darwinVersionString = re.compile(r"darwin-(\d+)\.(\d+)\.(\d+)-(.*)")
+# XXX backward compat
+get_platform = get_build_platform
+
+
+def compatible_platforms(provided, required):
+    """Can code for the `provided` platform run on the `required` platform?
+
+    Returns true if either platform is ``None``, or the platforms are equal.
+
+    XXX Needs compatibility checks for Linux and other unixy OSes.
+    """
+    if provided is None or required is None or provided == required:
+        # easy case
+        return True
+
+    # Mac OS X special cases
+    reqMac = macosVersionString.match(required)
+    if reqMac:
+        provMac = macosVersionString.match(provided)
+
+        # is this a Mac package?
+        if not provMac:
+            # this is backwards compatibility for packages built before
+            # setuptools 0.6. All packages built after this point will
+            # use the new macosx designation.
+            provDarwin = darwinVersionString.match(provided)
+            if provDarwin:
+                dversion = int(provDarwin.group(1))
+                macosversion = "%s.%s" % (reqMac.group(1), reqMac.group(2))
+                if dversion == 7 and macosversion >= "10.3" or \
+                        dversion == 8 and macosversion >= "10.4":
+                    return True
+            # egg isn't macosx or legacy darwin
+            return False
+
+        # are they the same major version and machine type?
+        if provMac.group(1) != reqMac.group(1) or \
+                provMac.group(3) != reqMac.group(3):
+            return False
+
+        # is the required OS major update >= the provided one?
+        if int(provMac.group(2)) > int(reqMac.group(2)):
+            return False
+
+        return True
+
+    # XXX Linux and other platforms' special cases should go here
+    return False
+
+
+def run_script(dist_spec, script_name):
+    """Locate distribution `dist_spec` and run its `script_name` script"""
+    ns = sys._getframe(1).f_globals
+    name = ns['__name__']
+    ns.clear()
+    ns['__name__'] = name
+    require(dist_spec)[0].run_script(script_name, ns)
+
+
+# backward compatibility
+run_main = run_script
+
+
+def get_distribution(dist):
+    """Return a current distribution object for a Requirement or string"""
+    if isinstance(dist, six.string_types):
+        dist = Requirement.parse(dist)
+    if isinstance(dist, Requirement):
+        dist = get_provider(dist)
+    if not isinstance(dist, Distribution):
+        raise TypeError("Expected string, Requirement, or Distribution", dist)
+    return dist
+
+
+def load_entry_point(dist, group, name):
+    """Return `name` entry point of `group` for `dist` or raise ImportError"""
+    return get_distribution(dist).load_entry_point(group, name)
+
+
+def get_entry_map(dist, group=None):
+    """Return the entry point map for `group`, or the full entry map"""
+    return get_distribution(dist).get_entry_map(group)
+
+
+def get_entry_info(dist, group, name):
+    """Return the EntryPoint object for `group`+`name`, or ``None``"""
+    return get_distribution(dist).get_entry_info(group, name)
+
+
+class IMetadataProvider:
+    def has_metadata(name):
+        """Does the package's distribution contain the named metadata?"""
+
+    def get_metadata(name):
+        """The named metadata resource as a string"""
+
+    def get_metadata_lines(name):
+        """Yield named metadata resource as list of non-blank non-comment lines
+
+       Leading and trailing whitespace is stripped from each line, and lines
+       with ``#`` as the first non-blank character are omitted."""
+
+    def metadata_isdir(name):
+        """Is the named metadata a directory?  (like ``os.path.isdir()``)"""
+
+    def metadata_listdir(name):
+        """List of metadata names in the directory (like ``os.listdir()``)"""
+
+    def run_script(script_name, namespace):
+        """Execute the named script in the supplied namespace dictionary"""
+
+
+class IResourceProvider(IMetadataProvider):
+    """An object that provides access to package resources"""
+
+    def get_resource_filename(manager, resource_name):
+        """Return a true filesystem path for `resource_name`
+
+        `manager` must be an ``IResourceManager``"""
+
+    def get_resource_stream(manager, resource_name):
+        """Return a readable file-like object for `resource_name`
+
+        `manager` must be an ``IResourceManager``"""
+
+    def get_resource_string(manager, resource_name):
+        """Return a string containing the contents of `resource_name`
+
+        `manager` must be an ``IResourceManager``"""
+
+    def has_resource(resource_name):
+        """Does the package contain the named resource?"""
+
+    def resource_isdir(resource_name):
+        """Is the named resource a directory?  (like ``os.path.isdir()``)"""
+
+    def resource_listdir(resource_name):
+        """List of resource names in the directory (like ``os.listdir()``)"""
+
+
+class WorkingSet:
+    """A collection of active distributions on sys.path (or a similar list)"""
+
+    def __init__(self, entries=None):
+        """Create working set from list of path entries (default=sys.path)"""
+        self.entries = []
+        self.entry_keys = {}
+        self.by_key = {}
+        self.callbacks = []
+
+        if entries is None:
+            entries = sys.path
+
+        for entry in entries:
+            self.add_entry(entry)
+
+    @classmethod
+    def _build_master(cls):
+        """
+        Prepare the master working set.
+        """
+        ws = cls()
+        try:
+            from __main__ import __requires__
+        except ImportError:
+            # The main program does not list any requirements
+            return ws
+
+        # ensure the requirements are met
+        try:
+            ws.require(__requires__)
+        except VersionConflict:
+            return cls._build_from_requirements(__requires__)
+
+        return ws
+
+    @classmethod
+    def _build_from_requirements(cls, req_spec):
+        """
+        Build a working set from a requirement spec. Rewrites sys.path.
+        """
+        # try it without defaults already on sys.path
+        # by starting with an empty path
+        ws = cls([])
+        reqs = parse_requirements(req_spec)
+        dists = ws.resolve(reqs, Environment())
+        for dist in dists:
+            ws.add(dist)
+
+        # add any missing entries from sys.path
+        for entry in sys.path:
+            if entry not in ws.entries:
+                ws.add_entry(entry)
+
+        # then copy back to sys.path
+        sys.path[:] = ws.entries
+        return ws
+
+    def add_entry(self, entry):
+        """Add a path item to ``.entries``, finding any distributions on it
+
+        ``find_distributions(entry, True)`` is used to find distributions
+        corresponding to the path entry, and they are added.  `entry` is
+        always appended to ``.entries``, even if it is already present.
+        (This is because ``sys.path`` can contain the same value more than
+        once, and the ``.entries`` of the ``sys.path`` WorkingSet should always
+        equal ``sys.path``.)
+        """
+        self.entry_keys.setdefault(entry, [])
+        self.entries.append(entry)
+        for dist in find_distributions(entry, True):
+            self.add(dist, entry, False)
+
+    def __contains__(self, dist):
+        """True if `dist` is the active distribution for its project"""
+        return self.by_key.get(dist.key) == dist
+
+    def find(self, req):
+        """Find a distribution matching requirement `req`
+
+        If there is an active distribution for the requested project, this
+        returns it as long as it meets the version requirement specified by
+        `req`.  But, if there is an active distribution for the project and it
+        does *not* meet the `req` requirement, ``VersionConflict`` is raised.
+        If there is no active distribution for the requested project, ``None``
+        is returned.
+        """
+        dist = self.by_key.get(req.key)
+        if dist is not None and dist not in req:
+            # XXX add more info
+            raise VersionConflict(dist, req)
+        return dist
+
+    def iter_entry_points(self, group, name=None):
+        """Yield entry point objects from `group` matching `name`
+
+        If `name` is None, yields all entry points in `group` from all
+        distributions in the working set, otherwise only ones matching
+        both `group` and `name` are yielded (in distribution order).
+        """
+        return (
+            entry
+            for dist in self
+            for entry in dist.get_entry_map(group).values()
+            if name is None or name == entry.name
+        )
+
+    def run_script(self, requires, script_name):
+        """Locate distribution for `requires` and run `script_name` script"""
+        ns = sys._getframe(1).f_globals
+        name = ns['__name__']
+        ns.clear()
+        ns['__name__'] = name
+        self.require(requires)[0].run_script(script_name, ns)
+
+    def __iter__(self):
+        """Yield distributions for non-duplicate projects in the working set
+
+        The yield order is the order in which the items' path entries were
+        added to the working set.
+        """
+        seen = {}
+        for item in self.entries:
+            if item not in self.entry_keys:
+                # workaround a cache issue
+                continue
+
+            for key in self.entry_keys[item]:
+                if key not in seen:
+                    seen[key] = 1
+                    yield self.by_key[key]
+
+    def add(self, dist, entry=None, insert=True, replace=False):
+        """Add `dist` to working set, associated with `entry`
+
+        If `entry` is unspecified, it defaults to the ``.location`` of `dist`.
+        On exit from this routine, `entry` is added to the end of the working
+        set's ``.entries`` (if it wasn't already present).
+
+        `dist` is only added to the working set if it's for a project that
+        doesn't already have a distribution in the set, unless `replace=True`.
+        If it's added, any callbacks registered with the ``subscribe()`` method
+        will be called.
+        """
+        if insert:
+            dist.insert_on(self.entries, entry, replace=replace)
+
+        if entry is None:
+            entry = dist.location
+        keys = self.entry_keys.setdefault(entry, [])
+        keys2 = self.entry_keys.setdefault(dist.location, [])
+        if not replace and dist.key in self.by_key:
+            # ignore hidden distros
+            return
+
+        self.by_key[dist.key] = dist
+        if dist.key not in keys:
+            keys.append(dist.key)
+        if dist.key not in keys2:
+            keys2.append(dist.key)
+        self._added_new(dist)
+
+    def resolve(self, requirements, env=None, installer=None,
+                replace_conflicting=False, extras=None):
+        """List all distributions needed to (recursively) meet `requirements`
+
+        `requirements` must be a sequence of ``Requirement`` objects.  `env`,
+        if supplied, should be an ``Environment`` instance.  If
+        not supplied, it defaults to all distributions available within any
+        entry or distribution in the working set.  `installer`, if supplied,
+        will be invoked with each requirement that cannot be met by an
+        already-installed distribution; it should return a ``Distribution`` or
+        ``None``.
+
+        Unless `replace_conflicting=True`, raises a VersionConflict exception
+        if
+        any requirements are found on the path that have the correct name but
+        the wrong version.  Otherwise, if an `installer` is supplied it will be
+        invoked to obtain the correct version of the requirement and activate
+        it.
+
+        `extras` is a list of the extras to be used with these requirements.
+        This is important because extra requirements may look like `my_req;
+        extra = "my_extra"`, which would otherwise be interpreted as a purely
+        optional requirement.  Instead, we want to be able to assert that these
+        requirements are truly required.
+        """
+
+        # set up the stack
+        requirements = list(requirements)[::-1]
+        # set of processed requirements
+        processed = {}
+        # key -> dist
+        best = {}
+        to_activate = []
+
+        req_extras = _ReqExtras()
+
+        # Mapping of requirement to set of distributions that required it;
+        # useful for reporting info about conflicts.
+        required_by = collections.defaultdict(set)
+
+        while requirements:
+            # process dependencies breadth-first
+            req = requirements.pop(0)
+            if req in processed:
+                # Ignore cyclic or redundant dependencies
+                continue
+
+            if not req_extras.markers_pass(req, extras):
+                continue
+
+            dist = best.get(req.key)
+            if dist is None:
+                # Find the best distribution and add it to the map
+                dist = self.by_key.get(req.key)
+                if dist is None or (dist not in req and replace_conflicting):
+                    ws = self
+                    if env is None:
+                        if dist is None:
+                            env = Environment(self.entries)
+                        else:
+                            # Use an empty environment and workingset to avoid
+                            # any further conflicts with the conflicting
+                            # distribution
+                            env = Environment([])
+                            ws = WorkingSet([])
+                    dist = best[req.key] = env.best_match(
+                        req, ws, installer,
+                        replace_conflicting=replace_conflicting
+                    )
+                    if dist is None:
+                        requirers = required_by.get(req, None)
+                        raise DistributionNotFound(req, requirers)
+                to_activate.append(dist)
+            if dist not in req:
+                # Oops, the "best" so far conflicts with a dependency
+                dependent_req = required_by[req]
+                raise VersionConflict(dist, req).with_context(dependent_req)
+
+            # push the new requirements onto the stack
+            new_requirements = dist.requires(req.extras)[::-1]
+            requirements.extend(new_requirements)
+
+            # Register the new requirements needed by req
+            for new_requirement in new_requirements:
+                required_by[new_requirement].add(req.project_name)
+                req_extras[new_requirement] = req.extras
+
+            processed[req] = True
+
+        # return list of distros to activate
+        return to_activate
+
+    def find_plugins(
+            self, plugin_env, full_env=None, installer=None, fallback=True):
+        """Find all activatable distributions in `plugin_env`
+
+        Example usage::
+
+            distributions, errors = working_set.find_plugins(
+                Environment(plugin_dirlist)
+            )
+            # add plugins+libs to sys.path
+            map(working_set.add, distributions)
+            # display errors
+            print('Could not load', errors)
+
+        The `plugin_env` should be an ``Environment`` instance that contains
+        only distributions that are in the project's "plugin directory" or
+        directories. The `full_env`, if supplied, should be an ``Environment``
+        contains all currently-available distributions.  If `full_env` is not
+        supplied, one is created automatically from the ``WorkingSet`` this
+        method is called on, which will typically mean that every directory on
+        ``sys.path`` will be scanned for distributions.
+
+        `installer` is a standard installer callback as used by the
+        ``resolve()`` method. The `fallback` flag indicates whether we should
+        attempt to resolve older versions of a plugin if the newest version
+        cannot be resolved.
+
+        This method returns a 2-tuple: (`distributions`, `error_info`), where
+        `distributions` is a list of the distributions found in `plugin_env`
+        that were loadable, along with any other distributions that are needed
+        to resolve their dependencies.  `error_info` is a dictionary mapping
+        unloadable plugin distributions to an exception instance describing the
+        error that occurred. Usually this will be a ``DistributionNotFound`` or
+        ``VersionConflict`` instance.
+        """
+
+        plugin_projects = list(plugin_env)
+        # scan project names in alphabetic order
+        plugin_projects.sort()
+
+        error_info = {}
+        distributions = {}
+
+        if full_env is None:
+            env = Environment(self.entries)
+            env += plugin_env
+        else:
+            env = full_env + plugin_env
+
+        shadow_set = self.__class__([])
+        # put all our entries in shadow_set
+        list(map(shadow_set.add, self))
+
+        for project_name in plugin_projects:
+
+            for dist in plugin_env[project_name]:
+
+                req = [dist.as_requirement()]
+
+                try:
+                    resolvees = shadow_set.resolve(req, env, installer)
+
+                except ResolutionError as v:
+                    # save error info
+                    error_info[dist] = v
+                    if fallback:
+                        # try the next older version of project
+                        continue
+                    else:
+                        # give up on this project, keep going
+                        break
+
+                else:
+                    list(map(shadow_set.add, resolvees))
+                    distributions.update(dict.fromkeys(resolvees))
+
+                    # success, no need to try any more versions of this project
+                    break
+
+        distributions = list(distributions)
+        distributions.sort()
+
+        return distributions, error_info
+
+    def require(self, *requirements):
+        """Ensure that distributions matching `requirements` are activated
+
+        `requirements` must be a string or a (possibly-nested) sequence
+        thereof, specifying the distributions and versions required.  The
+        return value is a sequence of the distributions that needed to be
+        activated to fulfill the requirements; all relevant distributions are
+        included, even if they were already activated in this working set.
+        """
+        needed = self.resolve(parse_requirements(requirements))
+
+        for dist in needed:
+            self.add(dist)
+
+        return needed
+
+    def subscribe(self, callback, existing=True):
+        """Invoke `callback` for all distributions
+
+        If `existing=True` (default),
+        call on all existing ones, as well.
+        """
+        if callback in self.callbacks:
+            return
+        self.callbacks.append(callback)
+        if not existing:
+            return
+        for dist in self:
+            callback(dist)
+
+    def _added_new(self, dist):
+        for callback in self.callbacks:
+            callback(dist)
+
+    def __getstate__(self):
+        return (
+            self.entries[:], self.entry_keys.copy(), self.by_key.copy(),
+            self.callbacks[:]
+        )
+
+    def __setstate__(self, e_k_b_c):
+        entries, keys, by_key, callbacks = e_k_b_c
+        self.entries = entries[:]
+        self.entry_keys = keys.copy()
+        self.by_key = by_key.copy()
+        self.callbacks = callbacks[:]
+
+
+class _ReqExtras(dict):
+    """
+    Map each requirement to the extras that demanded it.
+    """
+
+    def markers_pass(self, req, extras=None):
+        """
+        Evaluate markers for req against each extra that
+        demanded it.
+
+        Return False if the req has a marker and fails
+        evaluation. Otherwise, return True.
+        """
+        extra_evals = (
+            req.marker.evaluate({'extra': extra})
+            for extra in self.get(req, ()) + (extras or (None,))
+        )
+        return not req.marker or any(extra_evals)
+
+
+class Environment:
+    """Searchable snapshot of distributions on a search path"""
+
+    def __init__(
+            self, search_path=None, platform=get_supported_platform(),
+            python=PY_MAJOR):
+        """Snapshot distributions available on a search path
+
+        Any distributions found on `search_path` are added to the environment.
+        `search_path` should be a sequence of ``sys.path`` items.  If not
+        supplied, ``sys.path`` is used.
+
+        `platform` is an optional string specifying the name of the platform
+        that platform-specific distributions must be compatible with.  If
+        unspecified, it defaults to the current platform.  `python` is an
+        optional string naming the desired version of Python (e.g. ``'3.6'``);
+        it defaults to the current version.
+
+        You may explicitly set `platform` (and/or `python`) to ``None`` if you
+        wish to map *all* distributions, not just those compatible with the
+        running platform or Python version.
+        """
+        self._distmap = {}
+        self.platform = platform
+        self.python = python
+        self.scan(search_path)
+
+    def can_add(self, dist):
+        """Is distribution `dist` acceptable for this environment?
+
+        The distribution must match the platform and python version
+        requirements specified when this environment was created, or False
+        is returned.
+        """
+        py_compat = (
+            self.python is None
+            or dist.py_version is None
+            or dist.py_version == self.python
+        )
+        return py_compat and compatible_platforms(dist.platform, self.platform)
+
+    def remove(self, dist):
+        """Remove `dist` from the environment"""
+        self._distmap[dist.key].remove(dist)
+
+    def scan(self, search_path=None):
+        """Scan `search_path` for distributions usable in this environment
+
+        Any distributions found are added to the environment.
+        `search_path` should be a sequence of ``sys.path`` items.  If not
+        supplied, ``sys.path`` is used.  Only distributions conforming to
+        the platform/python version defined at initialization are added.
+        """
+        if search_path is None:
+            search_path = sys.path
+
+        for item in search_path:
+            for dist in find_distributions(item):
+                self.add(dist)
+
+    def __getitem__(self, project_name):
+        """Return a newest-to-oldest list of distributions for `project_name`
+
+        Uses case-insensitive `project_name` comparison, assuming all the
+        project's distributions use their project's name converted to all
+        lowercase as their key.
+
+        """
+        distribution_key = project_name.lower()
+        return self._distmap.get(distribution_key, [])
+
+    def add(self, dist):
+        """Add `dist` if we ``can_add()`` it and it has not already been added
+        """
+        if self.can_add(dist) and dist.has_version():
+            dists = self._distmap.setdefault(dist.key, [])
+            if dist not in dists:
+                dists.append(dist)
+                dists.sort(key=operator.attrgetter('hashcmp'), reverse=True)
+
+    def best_match(
+            self, req, working_set, installer=None, replace_conflicting=False):
+        """Find distribution best matching `req` and usable on `working_set`
+
+        This calls the ``find(req)`` method of the `working_set` to see if a
+        suitable distribution is already active.  (This may raise
+        ``VersionConflict`` if an unsuitable version of the project is already
+        active in the specified `working_set`.)  If a suitable distribution
+        isn't active, this method returns the newest distribution in the
+        environment that meets the ``Requirement`` in `req`.  If no suitable
+        distribution is found, and `installer` is supplied, then the result of
+        calling the environment's ``obtain(req, installer)`` method will be
+        returned.
+        """
+        try:
+            dist = working_set.find(req)
+        except VersionConflict:
+            if not replace_conflicting:
+                raise
+            dist = None
+        if dist is not None:
+            return dist
+        for dist in self[req.key]:
+            if dist in req:
+                return dist
+        # try to download/install
+        return self.obtain(req, installer)
+
+    def obtain(self, requirement, installer=None):
+        """Obtain a distribution matching `requirement` (e.g. via download)
+
+        Obtain a distro that matches requirement (e.g. via download).  In the
+        base ``Environment`` class, this routine just returns
+        ``installer(requirement)``, unless `installer` is None, in which case
+        None is returned instead.  This method is a hook that allows subclasses
+        to attempt other ways of obtaining a distribution before falling back
+        to the `installer` argument."""
+        if installer is not None:
+            return installer(requirement)
+
+    def __iter__(self):
+        """Yield the unique project names of the available distributions"""
+        for key in self._distmap.keys():
+            if self[key]:
+                yield key
+
+    def __iadd__(self, other):
+        """In-place addition of a distribution or environment"""
+        if isinstance(other, Distribution):
+            self.add(other)
+        elif isinstance(other, Environment):
+            for project in other:
+                for dist in other[project]:
+                    self.add(dist)
+        else:
+            raise TypeError("Can't add %r to environment" % (other,))
+        return self
+
+    def __add__(self, other):
+        """Add an environment or distribution to an environment"""
+        new = self.__class__([], platform=None, python=None)
+        for env in self, other:
+            new += env
+        return new
+
+
+# XXX backward compatibility
+AvailableDistributions = Environment
+
+
+class ExtractionError(RuntimeError):
+    """An error occurred extracting a resource
+
+    The following attributes are available from instances of this exception:
+
+    manager
+        The resource manager that raised this exception
+
+    cache_path
+        The base directory for resource extraction
+
+    original_error
+        The exception instance that caused extraction to fail
+    """
+
+
+class ResourceManager:
+    """Manage resource extraction and packages"""
+    extraction_path = None
+
+    def __init__(self):
+        self.cached_files = {}
+
+    def resource_exists(self, package_or_requirement, resource_name):
+        """Does the named resource exist?"""
+        return get_provider(package_or_requirement).has_resource(resource_name)
+
+    def resource_isdir(self, package_or_requirement, resource_name):
+        """Is the named resource an existing directory?"""
+        return get_provider(package_or_requirement).resource_isdir(
+            resource_name
+        )
+
+    def resource_filename(self, package_or_requirement, resource_name):
+        """Return a true filesystem path for specified resource"""
+        return get_provider(package_or_requirement).get_resource_filename(
+            self, resource_name
+        )
+
+    def resource_stream(self, package_or_requirement, resource_name):
+        """Return a readable file-like object for specified resource"""
+        return get_provider(package_or_requirement).get_resource_stream(
+            self, resource_name
+        )
+
+    def resource_string(self, package_or_requirement, resource_name):
+        """Return specified resource as a string"""
+        return get_provider(package_or_requirement).get_resource_string(
+            self, resource_name
+        )
+
+    def resource_listdir(self, package_or_requirement, resource_name):
+        """List the contents of the named resource directory"""
+        return get_provider(package_or_requirement).resource_listdir(
+            resource_name
+        )
+
+    def extraction_error(self):
+        """Give an error message for problems extracting file(s)"""
+
+        old_exc = sys.exc_info()[1]
+        cache_path = self.extraction_path or get_default_cache()
+
+        tmpl = textwrap.dedent("""
+            Can't extract file(s) to egg cache
+
+            The following error occurred while trying to extract file(s)
+            to the Python egg cache:
+
+              {old_exc}
+
+            The Python egg cache directory is currently set to:
+
+              {cache_path}
+
+            Perhaps your account does not have write access to this directory?
+            You can change the cache directory by setting the PYTHON_EGG_CACHE
+            environment variable to point to an accessible directory.
+            """).lstrip()
+        err = ExtractionError(tmpl.format(**locals()))
+        err.manager = self
+        err.cache_path = cache_path
+        err.original_error = old_exc
+        raise err
+
+    def get_cache_path(self, archive_name, names=()):
+        """Return absolute location in cache for `archive_name` and `names`
+
+        The parent directory of the resulting path will be created if it does
+        not already exist.  `archive_name` should be the base filename of the
+        enclosing egg (which may not be the name of the enclosing zipfile!),
+        including its ".egg" extension.  `names`, if provided, should be a
+        sequence of path name parts "under" the egg's extraction location.
+
+        This method should only be called by resource providers that need to
+        obtain an extraction location, and only for names they intend to
+        extract, as it tracks the generated names for possible cleanup later.
+        """
+        extract_path = self.extraction_path or get_default_cache()
+        target_path = os.path.join(extract_path, archive_name + '-tmp', *names)
+        try:
+            _bypass_ensure_directory(target_path)
+        except Exception:
+            self.extraction_error()
+
+        self._warn_unsafe_extraction_path(extract_path)
+
+        self.cached_files[target_path] = 1
+        return target_path
+
+    @staticmethod
+    def _warn_unsafe_extraction_path(path):
+        """
+        If the default extraction path is overridden and set to an insecure
+        location, such as /tmp, it opens up an opportunity for an attacker to
+        replace an extracted file with an unauthorized payload. Warn the user
+        if a known insecure location is used.
+
+        See Distribute #375 for more details.
+        """
+        if os.name == 'nt' and not path.startswith(os.environ['windir']):
+            # On Windows, permissions are generally restrictive by default
+            #  and temp directories are not writable by other users, so
+            #  bypass the warning.
+            return
+        mode = os.stat(path).st_mode
+        if mode & stat.S_IWOTH or mode & stat.S_IWGRP:
+            msg = (
+                "%s is writable by group/others and vulnerable to attack "
+                "when "
+                "used with get_resource_filename. Consider a more secure "
+                "location (set with .set_extraction_path or the "
+                "PYTHON_EGG_CACHE environment variable)." % path
+            )
+            warnings.warn(msg, UserWarning)
+
+    def postprocess(self, tempname, filename):
+        """Perform any platform-specific postprocessing of `tempname`
+
+        This is where Mac header rewrites should be done; other platforms don't
+        have anything special they should do.
+
+        Resource providers should call this method ONLY after successfully
+        extracting a compressed resource.  They must NOT call it on resources
+        that are already in the filesystem.
+
+        `tempname` is the current (temporary) name of the file, and `filename`
+        is the name it will be renamed to by the caller after this routine
+        returns.
+        """
+
+        if os.name == 'posix':
+            # Make the resource executable
+            mode = ((os.stat(tempname).st_mode) | 0o555) & 0o7777
+            os.chmod(tempname, mode)
+
+    def set_extraction_path(self, path):
+        """Set the base path where resources will be extracted to, if needed.
+
+        If you do not call this routine before any extractions take place, the
+        path defaults to the return value of ``get_default_cache()``.  (Which
+        is based on the ``PYTHON_EGG_CACHE`` environment variable, with various
+        platform-specific fallbacks.  See that routine's documentation for more
+        details.)
+
+        Resources are extracted to subdirectories of this path based upon
+        information given by the ``IResourceProvider``.  You may set this to a
+        temporary directory, but then you must call ``cleanup_resources()`` to
+        delete the extracted files when done.  There is no guarantee that
+        ``cleanup_resources()`` will be able to remove all extracted files.
+
+        (Note: you may not change the extraction path for a given resource
+        manager once resources have been extracted, unless you first call
+        ``cleanup_resources()``.)
+        """
+        if self.cached_files:
+            raise ValueError(
+                "Can't change extraction path, files already extracted"
+            )
+
+        self.extraction_path = path
+
+    def cleanup_resources(self, force=False):
+        """
+        Delete all extracted resource files and directories, returning a list
+        of the file and directory names that could not be successfully removed.
+        This function does not have any concurrency protection, so it should
+        generally only be called when the extraction path is a temporary
+        directory exclusive to a single process.  This method is not
+        automatically called; you must call it explicitly or register it as an
+        ``atexit`` function if you wish to ensure cleanup of a temporary
+        directory used for extractions.
+        """
+        # XXX
+
+
+def get_default_cache():
+    """
+    Return the ``PYTHON_EGG_CACHE`` environment variable
+    or a platform-relevant user cache dir for an app
+    named "Python-Eggs".
+    """
+    return (
+        os.environ.get('PYTHON_EGG_CACHE')
+        or appdirs.user_cache_dir(appname='Python-Eggs')
+    )
+
+
+def safe_name(name):
+    """Convert an arbitrary string to a standard distribution name
+
+    Any runs of non-alphanumeric/. characters are replaced with a single '-'.
+    """
+    return re.sub('[^A-Za-z0-9.]+', '-', name)
+
+
+def safe_version(version):
+    """
+    Convert an arbitrary string to a standard version string
+    """
+    try:
+        # normalize the version
+        return str(packaging.version.Version(version))
+    except packaging.version.InvalidVersion:
+        version = version.replace(' ', '.')
+        return re.sub('[^A-Za-z0-9.]+', '-', version)
+
+
+def safe_extra(extra):
+    """Convert an arbitrary string to a standard 'extra' name
+
+    Any runs of non-alphanumeric characters are replaced with a single '_',
+    and the result is always lowercased.
+    """
+    return re.sub('[^A-Za-z0-9.-]+', '_', extra).lower()
+
+
+def to_filename(name):
+    """Convert a project or version name to its filename-escaped form
+
+    Any '-' characters are currently replaced with '_'.
+    """
+    return name.replace('-', '_')
+
+
+def invalid_marker(text):
+    """
+    Validate text as a PEP 508 environment marker; return an exception
+    if invalid or False otherwise.
+    """
+    try:
+        evaluate_marker(text)
+    except SyntaxError as e:
+        e.filename = None
+        e.lineno = None
+        return e
+    return False
+
+
+def evaluate_marker(text, extra=None):
+    """
+    Evaluate a PEP 508 environment marker.
+    Return a boolean indicating the marker result in this environment.
+    Raise SyntaxError if marker is invalid.
+
+    This implementation uses the 'pyparsing' module.
+    """
+    try:
+        marker = packaging.markers.Marker(text)
+        return marker.evaluate()
+    except packaging.markers.InvalidMarker as e:
+        raise SyntaxError(e)
+
+
+class NullProvider:
+    """Try to implement resources and metadata for arbitrary PEP 302 loaders"""
+
+    egg_name = None
+    egg_info = None
+    loader = None
+
+    def __init__(self, module):
+        self.loader = getattr(module, '__loader__', None)
+        self.module_path = os.path.dirname(getattr(module, '__file__', ''))
+
+    def get_resource_filename(self, manager, resource_name):
+        return self._fn(self.module_path, resource_name)
+
+    def get_resource_stream(self, manager, resource_name):
+        return io.BytesIO(self.get_resource_string(manager, resource_name))
+
+    def get_resource_string(self, manager, resource_name):
+        return self._get(self._fn(self.module_path, resource_name))
+
+    def has_resource(self, resource_name):
+        return self._has(self._fn(self.module_path, resource_name))
+
+    def _get_metadata_path(self, name):
+        return self._fn(self.egg_info, name)
+
+    def has_metadata(self, name):
+        if not self.egg_info:
+            return self.egg_info
+
+        path = self._get_metadata_path(name)
+        return self._has(path)
+
+    def get_metadata(self, name):
+        if not self.egg_info:
+            return ""
+        value = self._get(self._fn(self.egg_info, name))
+        return value.decode('utf-8') if six.PY3 else value
+
+    def get_metadata_lines(self, name):
+        return yield_lines(self.get_metadata(name))
+
+    def resource_isdir(self, resource_name):
+        return self._isdir(self._fn(self.module_path, resource_name))
+
+    def metadata_isdir(self, name):
+        return self.egg_info and self._isdir(self._fn(self.egg_info, name))
+
+    def resource_listdir(self, resource_name):
+        return self._listdir(self._fn(self.module_path, resource_name))
+
+    def metadata_listdir(self, name):
+        if self.egg_info:
+            return self._listdir(self._fn(self.egg_info, name))
+        return []
+
+    def run_script(self, script_name, namespace):
+        script = 'scripts/' + script_name
+        if not self.has_metadata(script):
+            raise ResolutionError(
+                "Script {script!r} not found in metadata at {self.egg_info!r}"
+                .format(**locals()),
+            )
+        script_text = self.get_metadata(script).replace('\r\n', '\n')
+        script_text = script_text.replace('\r', '\n')
+        script_filename = self._fn(self.egg_info, script)
+        namespace['__file__'] = script_filename
+        if os.path.exists(script_filename):
+            source = open(script_filename).read()
+            code = compile(source, script_filename, 'exec')
+            exec(code, namespace, namespace)
+        else:
+            from linecache import cache
+            cache[script_filename] = (
+                len(script_text), 0, script_text.split('\n'), script_filename
+            )
+            script_code = compile(script_text, script_filename, 'exec')
+            exec(script_code, namespace, namespace)
+
+    def _has(self, path):
+        raise NotImplementedError(
+            "Can't perform this operation for unregistered loader type"
+        )
+
+    def _isdir(self, path):
+        raise NotImplementedError(
+            "Can't perform this operation for unregistered loader type"
+        )
+
+    def _listdir(self, path):
+        raise NotImplementedError(
+            "Can't perform this operation for unregistered loader type"
+        )
+
+    def _fn(self, base, resource_name):
+        self._validate_resource_path(resource_name)
+        if resource_name:
+            return os.path.join(base, *resource_name.split('/'))
+        return base
+
+    @staticmethod
+    def _validate_resource_path(path):
+        """
+        Validate the resource paths according to the docs.
+        https://setuptools.readthedocs.io/en/latest/pkg_resources.html#basic-resource-access
+
+        >>> warned = getfixture('recwarn')
+        >>> warnings.simplefilter('always')
+        >>> vrp = NullProvider._validate_resource_path
+        >>> vrp('foo/bar.txt')
+        >>> bool(warned)
+        False
+        >>> vrp('../foo/bar.txt')
+        >>> bool(warned)
+        True
+        >>> warned.clear()
+        >>> vrp('/foo/bar.txt')
+        >>> bool(warned)
+        True
+        >>> vrp('foo/../../bar.txt')
+        >>> bool(warned)
+        True
+        >>> warned.clear()
+        >>> vrp('foo/f../bar.txt')
+        >>> bool(warned)
+        False
+
+        Windows path separators are straight-up disallowed.
+        >>> vrp(r'\\foo/bar.txt')
+        Traceback (most recent call last):
+        ...
+        ValueError: Use of .. or absolute path in a resource path \
+is not allowed.
+
+        >>> vrp(r'C:\\foo/bar.txt')
+        Traceback (most recent call last):
+        ...
+        ValueError: Use of .. or absolute path in a resource path \
+is not allowed.
+
+        Blank values are allowed
+
+        >>> vrp('')
+        >>> bool(warned)
+        False
+
+        Non-string values are not.
+
+        >>> vrp(None)
+        Traceback (most recent call last):
+        ...
+        AttributeError: ...
+        """
+        invalid = (
+            os.path.pardir in path.split(posixpath.sep) or
+            posixpath.isabs(path) or
+            ntpath.isabs(path)
+        )
+        if not invalid:
+            return
+
+        msg = "Use of .. or absolute path in a resource path is not allowed."
+
+        # Aggressively disallow Windows absolute paths
+        if ntpath.isabs(path) and not posixpath.isabs(path):
+            raise ValueError(msg)
+
+        # for compatibility, warn; in future
+        # raise ValueError(msg)
+        warnings.warn(
+            msg[:-1] + " and will raise exceptions in a future release.",
+            DeprecationWarning,
+            stacklevel=4,
+        )
+
+    def _get(self, path):
+        if hasattr(self.loader, 'get_data'):
+            return self.loader.get_data(path)
+        raise NotImplementedError(
+            "Can't perform this operation for loaders without 'get_data()'"
+        )
+
+
+register_loader_type(object, NullProvider)
+
+
+class EggProvider(NullProvider):
+    """Provider based on a virtual filesystem"""
+
+    def __init__(self, module):
+        NullProvider.__init__(self, module)
+        self._setup_prefix()
+
+    def _setup_prefix(self):
+        # we assume here that our metadata may be nested inside a "basket"
+        # of multiple eggs; that's why we use module_path instead of .archive
+        path = self.module_path
+        old = None
+        while path != old:
+            if _is_egg_path(path):
+                self.egg_name = os.path.basename(path)
+                self.egg_info = os.path.join(path, 'EGG-INFO')
+                self.egg_root = path
+                break
+            old = path
+            path, base = os.path.split(path)
+
+
+class DefaultProvider(EggProvider):
+    """Provides access to package resources in the filesystem"""
+
+    def _has(self, path):
+        return os.path.exists(path)
+
+    def _isdir(self, path):
+        return os.path.isdir(path)
+
+    def _listdir(self, path):
+        return os.listdir(path)
+
+    def get_resource_stream(self, manager, resource_name):
+        return open(self._fn(self.module_path, resource_name), 'rb')
+
+    def _get(self, path):
+        with open(path, 'rb') as stream:
+            return stream.read()
+
+    @classmethod
+    def _register(cls):
+        loader_names = 'SourceFileLoader', 'SourcelessFileLoader',
+        for name in loader_names:
+            loader_cls = getattr(importlib_machinery, name, type(None))
+            register_loader_type(loader_cls, cls)
+
+
+DefaultProvider._register()
+
+
+class EmptyProvider(NullProvider):
+    """Provider that returns nothing for all requests"""
+
+    module_path = None
+
+    _isdir = _has = lambda self, path: False
+
+    def _get(self, path):
+        return ''
+
+    def _listdir(self, path):
+        return []
+
+    def __init__(self):
+        pass
+
+
+empty_provider = EmptyProvider()
+
+
+class ZipManifests(dict):
+    """
+    zip manifest builder
+    """
+
+    @classmethod
+    def build(cls, path):
+        """
+        Build a dictionary similar to the zipimport directory
+        caches, except instead of tuples, store ZipInfo objects.
+
+        Use a platform-specific path separator (os.sep) for the path keys
+        for compatibility with pypy on Windows.
+        """
+        with zipfile.ZipFile(path) as zfile:
+            items = (
+                (
+                    name.replace('/', os.sep),
+                    zfile.getinfo(name),
+                )
+                for name in zfile.namelist()
+            )
+            return dict(items)
+
+    load = build
+
+
+class MemoizedZipManifests(ZipManifests):
+    """
+    Memoized zipfile manifests.
+    """
+    manifest_mod = collections.namedtuple('manifest_mod', 'manifest mtime')
+
+    def load(self, path):
+        """
+        Load a manifest at path or return a suitable manifest already loaded.
+        """
+        path = os.path.normpath(path)
+        mtime = os.stat(path).st_mtime
+
+        if path not in self or self[path].mtime != mtime:
+            manifest = self.build(path)
+            self[path] = self.manifest_mod(manifest, mtime)
+
+        return self[path].manifest
+
+
+class ZipProvider(EggProvider):
+    """Resource support for zips and eggs"""
+
+    eagers = None
+    _zip_manifests = MemoizedZipManifests()
+
+    def __init__(self, module):
+        EggProvider.__init__(self, module)
+        self.zip_pre = self.loader.archive + os.sep
+
+    def _zipinfo_name(self, fspath):
+        # Convert a virtual filename (full path to file) into a zipfile subpath
+        # usable with the zipimport directory cache for our target archive
+        fspath = fspath.rstrip(os.sep)
+        if fspath == self.loader.archive:
+            return ''
+        if fspath.startswith(self.zip_pre):
+            return fspath[len(self.zip_pre):]
+        raise AssertionError(
+            "%s is not a subpath of %s" % (fspath, self.zip_pre)
+        )
+
+    def _parts(self, zip_path):
+        # Convert a zipfile subpath into an egg-relative path part list.
+        # pseudo-fs path
+        fspath = self.zip_pre + zip_path
+        if fspath.startswith(self.egg_root + os.sep):
+            return fspath[len(self.egg_root) + 1:].split(os.sep)
+        raise AssertionError(
+            "%s is not a subpath of %s" % (fspath, self.egg_root)
+        )
+
+    @property
+    def zipinfo(self):
+        return self._zip_manifests.load(self.loader.archive)
+
+    def get_resource_filename(self, manager, resource_name):
+        if not self.egg_name:
+            raise NotImplementedError(
+                "resource_filename() only supported for .egg, not .zip"
+            )
+        # no need to lock for extraction, since we use temp names
+        zip_path = self._resource_to_zip(resource_name)
+        eagers = self._get_eager_resources()
+        if '/'.join(self._parts(zip_path)) in eagers:
+            for name in eagers:
+                self._extract_resource(manager, self._eager_to_zip(name))
+        return self._extract_resource(manager, zip_path)
+
+    @staticmethod
+    def _get_date_and_size(zip_stat):
+        size = zip_stat.file_size
+        # ymdhms+wday, yday, dst
+        date_time = zip_stat.date_time + (0, 0, -1)
+        # 1980 offset already done
+        timestamp = time.mktime(date_time)
+        return timestamp, size
+
+    def _extract_resource(self, manager, zip_path):
+
+        if zip_path in self._index():
+            for name in self._index()[zip_path]:
+                last = self._extract_resource(
+                    manager, os.path.join(zip_path, name)
+                )
+            # return the extracted directory name
+            return os.path.dirname(last)
+
+        timestamp, size = self._get_date_and_size(self.zipinfo[zip_path])
+
+        if not WRITE_SUPPORT:
+            raise IOError('"os.rename" and "os.unlink" are not supported '
+                          'on this platform')
+        try:
+
+            real_path = manager.get_cache_path(
+                self.egg_name, self._parts(zip_path)
+            )
+
+            if self._is_current(real_path, zip_path):
+                return real_path
+
+            outf, tmpnam = _mkstemp(
+                ".$extract",
+                dir=os.path.dirname(real_path),
+            )
+            os.write(outf, self.loader.get_data(zip_path))
+            os.close(outf)
+            utime(tmpnam, (timestamp, timestamp))
+            manager.postprocess(tmpnam, real_path)
+
+            try:
+                rename(tmpnam, real_path)
+
+            except os.error:
+                if os.path.isfile(real_path):
+                    if self._is_current(real_path, zip_path):
+                        # the file became current since it was checked above,
+                        #  so proceed.
+                        return real_path
+                    # Windows, del old file and retry
+                    elif os.name == 'nt':
+                        unlink(real_path)
+                        rename(tmpnam, real_path)
+                        return real_path
+                raise
+
+        except os.error:
+            # report a user-friendly error
+            manager.extraction_error()
+
+        return real_path
+
+    def _is_current(self, file_path, zip_path):
+        """
+        Return True if the file_path is current for this zip_path
+        """
+        timestamp, size = self._get_date_and_size(self.zipinfo[zip_path])
+        if not os.path.isfile(file_path):
+            return False
+        stat = os.stat(file_path)
+        if stat.st_size != size or stat.st_mtime != timestamp:
+            return False
+        # check that the contents match
+        zip_contents = self.loader.get_data(zip_path)
+        with open(file_path, 'rb') as f:
+            file_contents = f.read()
+        return zip_contents == file_contents
+
+    def _get_eager_resources(self):
+        if self.eagers is None:
+            eagers = []
+            for name in ('native_libs.txt', 'eager_resources.txt'):
+                if self.has_metadata(name):
+                    eagers.extend(self.get_metadata_lines(name))
+            self.eagers = eagers
+        return self.eagers
+
+    def _index(self):
+        try:
+            return self._dirindex
+        except AttributeError:
+            ind = {}
+            for path in self.zipinfo:
+                parts = path.split(os.sep)
+                while parts:
+                    parent = os.sep.join(parts[:-1])
+                    if parent in ind:
+                        ind[parent].append(parts[-1])
+                        break
+                    else:
+                        ind[parent] = [parts.pop()]
+            self._dirindex = ind
+            return ind
+
+    def _has(self, fspath):
+        zip_path = self._zipinfo_name(fspath)
+        return zip_path in self.zipinfo or zip_path in self._index()
+
+    def _isdir(self, fspath):
+        return self._zipinfo_name(fspath) in self._index()
+
+    def _listdir(self, fspath):
+        return list(self._index().get(self._zipinfo_name(fspath), ()))
+
+    def _eager_to_zip(self, resource_name):
+        return self._zipinfo_name(self._fn(self.egg_root, resource_name))
+
+    def _resource_to_zip(self, resource_name):
+        return self._zipinfo_name(self._fn(self.module_path, resource_name))
+
+
+register_loader_type(zipimport.zipimporter, ZipProvider)
+
+
+class FileMetadata(EmptyProvider):
+    """Metadata handler for standalone PKG-INFO files
+
+    Usage::
+
+        metadata = FileMetadata("/path/to/PKG-INFO")
+
+    This provider rejects all data and metadata requests except for PKG-INFO,
+    which is treated as existing, and will be the contents of the file at
+    the provided location.
+    """
+
+    def __init__(self, path):
+        self.path = path
+
+    def _get_metadata_path(self, name):
+        return self.path
+
+    def has_metadata(self, name):
+        return name == 'PKG-INFO' and os.path.isfile(self.path)
+
+    def get_metadata(self, name):
+        if name != 'PKG-INFO':
+            raise KeyError("No metadata except PKG-INFO is available")
+
+        with io.open(self.path, encoding='utf-8', errors="replace") as f:
+            metadata = f.read()
+        self._warn_on_replacement(metadata)
+        return metadata
+
+    def _warn_on_replacement(self, metadata):
+        # Python 2.7 compat for: replacement_char = '�'
+        replacement_char = b'\xef\xbf\xbd'.decode('utf-8')
+        if replacement_char in metadata:
+            tmpl = "{self.path} could not be properly decoded in UTF-8"
+            msg = tmpl.format(**locals())
+            warnings.warn(msg)
+
+    def get_metadata_lines(self, name):
+        return yield_lines(self.get_metadata(name))
+
+
+class PathMetadata(DefaultProvider):
+    """Metadata provider for egg directories
+
+    Usage::
+
+        # Development eggs:
+
+        egg_info = "/path/to/PackageName.egg-info"
+        base_dir = os.path.dirname(egg_info)
+        metadata = PathMetadata(base_dir, egg_info)
+        dist_name = os.path.splitext(os.path.basename(egg_info))[0]
+        dist = Distribution(basedir, project_name=dist_name, metadata=metadata)
+
+        # Unpacked egg directories:
+
+        egg_path = "/path/to/PackageName-ver-pyver-etc.egg"
+        metadata = PathMetadata(egg_path, os.path.join(egg_path,'EGG-INFO'))
+        dist = Distribution.from_filename(egg_path, metadata=metadata)
+    """
+
+    def __init__(self, path, egg_info):
+        self.module_path = path
+        self.egg_info = egg_info
+
+
+class EggMetadata(ZipProvider):
+    """Metadata provider for .egg files"""
+
+    def __init__(self, importer):
+        """Create a metadata provider from a zipimporter"""
+
+        self.zip_pre = importer.archive + os.sep
+        self.loader = importer
+        if importer.prefix:
+            self.module_path = os.path.join(importer.archive, importer.prefix)
+        else:
+            self.module_path = importer.archive
+        self._setup_prefix()
+
+
+_declare_state('dict', _distribution_finders={})
+
+
+def register_finder(importer_type, distribution_finder):
+    """Register `distribution_finder` to find distributions in sys.path items
+
+    `importer_type` is the type or class of a PEP 302 "Importer" (sys.path item
+    handler), and `distribution_finder` is a callable that, passed a path
+    item and the importer instance, yields ``Distribution`` instances found on
+    that path item.  See ``pkg_resources.find_on_path`` for an example."""
+    _distribution_finders[importer_type] = distribution_finder
+
+
+def find_distributions(path_item, only=False):
+    """Yield distributions accessible via `path_item`"""
+    importer = get_importer(path_item)
+    finder = _find_adapter(_distribution_finders, importer)
+    return finder(importer, path_item, only)
+
+
+def find_eggs_in_zip(importer, path_item, only=False):
+    """
+    Find eggs in zip files; possibly multiple nested eggs.
+    """
+    if importer.archive.endswith('.whl'):
+        # wheels are not supported with this finder
+        # they don't have PKG-INFO metadata, and won't ever contain eggs
+        return
+    metadata = EggMetadata(importer)
+    if metadata.has_metadata('PKG-INFO'):
+        yield Distribution.from_filename(path_item, metadata=metadata)
+    if only:
+        # don't yield nested distros
+        return
+    for subitem in metadata.resource_listdir(''):
+        if _is_egg_path(subitem):
+            subpath = os.path.join(path_item, subitem)
+            dists = find_eggs_in_zip(zipimport.zipimporter(subpath), subpath)
+            for dist in dists:
+                yield dist
+        elif subitem.lower().endswith('.dist-info'):
+            subpath = os.path.join(path_item, subitem)
+            submeta = EggMetadata(zipimport.zipimporter(subpath))
+            submeta.egg_info = subpath
+            yield Distribution.from_location(path_item, subitem, submeta)
+
+
+register_finder(zipimport.zipimporter, find_eggs_in_zip)
+
+
+def find_nothing(importer, path_item, only=False):
+    return ()
+
+
+register_finder(object, find_nothing)
+
+
+def _by_version_descending(names):
+    """
+    Given a list of filenames, return them in descending order
+    by version number.
+
+    >>> names = 'bar', 'foo', 'Python-2.7.10.egg', 'Python-2.7.2.egg'
+    >>> _by_version_descending(names)
+    ['Python-2.7.10.egg', 'Python-2.7.2.egg', 'foo', 'bar']
+    >>> names = 'Setuptools-1.2.3b1.egg', 'Setuptools-1.2.3.egg'
+    >>> _by_version_descending(names)
+    ['Setuptools-1.2.3.egg', 'Setuptools-1.2.3b1.egg']
+    >>> names = 'Setuptools-1.2.3b1.egg', 'Setuptools-1.2.3.post1.egg'
+    >>> _by_version_descending(names)
+    ['Setuptools-1.2.3.post1.egg', 'Setuptools-1.2.3b1.egg']
+    """
+    def _by_version(name):
+        """
+        Parse each component of the filename
+        """
+        name, ext = os.path.splitext(name)
+        parts = itertools.chain(name.split('-'), [ext])
+        return [packaging.version.parse(part) for part in parts]
+
+    return sorted(names, key=_by_version, reverse=True)
+
+
+def find_on_path(importer, path_item, only=False):
+    """Yield distributions accessible on a sys.path directory"""
+    path_item = _normalize_cached(path_item)
+
+    if _is_unpacked_egg(path_item):
+        yield Distribution.from_filename(
+            path_item, metadata=PathMetadata(
+                path_item, os.path.join(path_item, 'EGG-INFO')
+            )
+        )
+        return
+
+    entries = safe_listdir(path_item)
+
+    # for performance, before sorting by version,
+    # screen entries for only those that will yield
+    # distributions
+    filtered = (
+        entry
+        for entry in entries
+        if dist_factory(path_item, entry, only)
+    )
+
+    # scan for .egg and .egg-info in directory
+    path_item_entries = _by_version_descending(filtered)
+    for entry in path_item_entries:
+        fullpath = os.path.join(path_item, entry)
+        factory = dist_factory(path_item, entry, only)
+        for dist in factory(fullpath):
+            yield dist
+
+
+def dist_factory(path_item, entry, only):
+    """
+    Return a dist_factory for a path_item and entry
+    """
+    lower = entry.lower()
+    is_meta = any(map(lower.endswith, ('.egg-info', '.dist-info')))
+    return (
+        distributions_from_metadata
+        if is_meta else
+        find_distributions
+        if not only and _is_egg_path(entry) else
+        resolve_egg_link
+        if not only and lower.endswith('.egg-link') else
+        NoDists()
+    )
+
+
+class NoDists:
+    """
+    >>> bool(NoDists())
+    False
+
+    >>> list(NoDists()('anything'))
+    []
+    """
+    def __bool__(self):
+        return False
+    if six.PY2:
+        __nonzero__ = __bool__
+
+    def __call__(self, fullpath):
+        return iter(())
+
+
+def safe_listdir(path):
+    """
+    Attempt to list contents of path, but suppress some exceptions.
+    """
+    try:
+        return os.listdir(path)
+    except (PermissionError, NotADirectoryError):
+        pass
+    except OSError as e:
+        # Ignore the directory if does not exist, not a directory or
+        # permission denied
+        ignorable = (
+            e.errno in (errno.ENOTDIR, errno.EACCES, errno.ENOENT)
+            # Python 2 on Windows needs to be handled this way :(
+            or getattr(e, "winerror", None) == 267
+        )
+        if not ignorable:
+            raise
+    return ()
+
+
+def distributions_from_metadata(path):
+    root = os.path.dirname(path)
+    if os.path.isdir(path):
+        if len(os.listdir(path)) == 0:
+            # empty metadata dir; skip
+            return
+        metadata = PathMetadata(root, path)
+    else:
+        metadata = FileMetadata(path)
+    entry = os.path.basename(path)
+    yield Distribution.from_location(
+        root, entry, metadata, precedence=DEVELOP_DIST,
+    )
+
+
+def non_empty_lines(path):
+    """
+    Yield non-empty lines from file at path
+    """
+    with open(path) as f:
+        for line in f:
+            line = line.strip()
+            if line:
+                yield line
+
+
+def resolve_egg_link(path):
+    """
+    Given a path to an .egg-link, resolve distributions
+    present in the referenced path.
+    """
+    referenced_paths = non_empty_lines(path)
+    resolved_paths = (
+        os.path.join(os.path.dirname(path), ref)
+        for ref in referenced_paths
+    )
+    dist_groups = map(find_distributions, resolved_paths)
+    return next(dist_groups, ())
+
+
+register_finder(pkgutil.ImpImporter, find_on_path)
+
+if hasattr(importlib_machinery, 'FileFinder'):
+    register_finder(importlib_machinery.FileFinder, find_on_path)
+
+_declare_state('dict', _namespace_handlers={})
+_declare_state('dict', _namespace_packages={})
+
+
+def register_namespace_handler(importer_type, namespace_handler):
+    """Register `namespace_handler` to declare namespace packages
+
+    `importer_type` is the type or class of a PEP 302 "Importer" (sys.path item
+    handler), and `namespace_handler` is a callable like this::
+
+        def namespace_handler(importer, path_entry, moduleName, module):
+            # return a path_entry to use for child packages
+
+    Namespace handlers are only called if the importer object has already
+    agreed that it can handle the relevant path item, and they should only
+    return a subpath if the module __path__ does not already contain an
+    equivalent subpath.  For an example namespace handler, see
+    ``pkg_resources.file_ns_handler``.
+    """
+    _namespace_handlers[importer_type] = namespace_handler
+
+
+def _handle_ns(packageName, path_item):
+    """Ensure that named package includes a subpath of path_item (if needed)"""
+
+    importer = get_importer(path_item)
+    if importer is None:
+        return None
+
+    # capture warnings due to #1111
+    with warnings.catch_warnings():
+        warnings.simplefilter("ignore")
+        loader = importer.find_module(packageName)
+
+    if loader is None:
+        return None
+    module = sys.modules.get(packageName)
+    if module is None:
+        module = sys.modules[packageName] = types.ModuleType(packageName)
+        module.__path__ = []
+        _set_parent_ns(packageName)
+    elif not hasattr(module, '__path__'):
+        raise TypeError("Not a package:", packageName)
+    handler = _find_adapter(_namespace_handlers, importer)
+    subpath = handler(importer, path_item, packageName, module)
+    if subpath is not None:
+        path = module.__path__
+        path.append(subpath)
+        loader.load_module(packageName)
+        _rebuild_mod_path(path, packageName, module)
+    return subpath
+
+
+def _rebuild_mod_path(orig_path, package_name, module):
+    """
+    Rebuild module.__path__ ensuring that all entries are ordered
+    corresponding to their sys.path order
+    """
+    sys_path = [_normalize_cached(p) for p in sys.path]
+
+    def safe_sys_path_index(entry):
+        """
+        Workaround for #520 and #513.
+        """
+        try:
+            return sys_path.index(entry)
+        except ValueError:
+            return float('inf')
+
+    def position_in_sys_path(path):
+        """
+        Return the ordinal of the path based on its position in sys.path
+        """
+        path_parts = path.split(os.sep)
+        module_parts = package_name.count('.') + 1
+        parts = path_parts[:-module_parts]
+        return safe_sys_path_index(_normalize_cached(os.sep.join(parts)))
+
+    new_path = sorted(orig_path, key=position_in_sys_path)
+    new_path = [_normalize_cached(p) for p in new_path]
+
+    if isinstance(module.__path__, list):
+        module.__path__[:] = new_path
+    else:
+        module.__path__ = new_path
+
+
+def declare_namespace(packageName):
+    """Declare that package 'packageName' is a namespace package"""
+
+    _imp.acquire_lock()
+    try:
+        if packageName in _namespace_packages:
+            return
+
+        path = sys.path
+        parent, _, _ = packageName.rpartition('.')
+
+        if parent:
+            declare_namespace(parent)
+            if parent not in _namespace_packages:
+                __import__(parent)
+            try:
+                path = sys.modules[parent].__path__
+            except AttributeError:
+                raise TypeError("Not a package:", parent)
+
+        # Track what packages are namespaces, so when new path items are added,
+        # they can be updated
+        _namespace_packages.setdefault(parent or None, []).append(packageName)
+        _namespace_packages.setdefault(packageName, [])
+
+        for path_item in path:
+            # Ensure all the parent's path items are reflected in the child,
+            # if they apply
+            _handle_ns(packageName, path_item)
+
+    finally:
+        _imp.release_lock()
+
+
+def fixup_namespace_packages(path_item, parent=None):
+    """Ensure that previously-declared namespace packages include path_item"""
+    _imp.acquire_lock()
+    try:
+        for package in _namespace_packages.get(parent, ()):
+            subpath = _handle_ns(package, path_item)
+            if subpath:
+                fixup_namespace_packages(subpath, package)
+    finally:
+        _imp.release_lock()
+
+
+def file_ns_handler(importer, path_item, packageName, module):
+    """Compute an ns-package subpath for a filesystem or zipfile importer"""
+
+    subpath = os.path.join(path_item, packageName.split('.')[-1])
+    normalized = _normalize_cached(subpath)
+    for item in module.__path__:
+        if _normalize_cached(item) == normalized:
+            break
+    else:
+        # Only return the path if it's not already there
+        return subpath
+
+
+register_namespace_handler(pkgutil.ImpImporter, file_ns_handler)
+register_namespace_handler(zipimport.zipimporter, file_ns_handler)
+
+if hasattr(importlib_machinery, 'FileFinder'):
+    register_namespace_handler(importlib_machinery.FileFinder, file_ns_handler)
+
+
+def null_ns_handler(importer, path_item, packageName, module):
+    return None
+
+
+register_namespace_handler(object, null_ns_handler)
+
+
+def normalize_path(filename):
+    """Normalize a file/dir name for comparison purposes"""
+    return os.path.normcase(os.path.realpath(os.path.normpath(_cygwin_patch(filename))))
+
+
+def _cygwin_patch(filename):  # pragma: nocover
+    """
+    Contrary to POSIX 2008, on Cygwin, getcwd (3) contains
+    symlink components. Using
+    os.path.abspath() works around this limitation. A fix in os.getcwd()
+    would probably better, in Cygwin even more so, except
+    that this seems to be by design...
+    """
+    return os.path.abspath(filename) if sys.platform == 'cygwin' else filename
+
+
+def _normalize_cached(filename, _cache={}):
+    try:
+        return _cache[filename]
+    except KeyError:
+        _cache[filename] = result = normalize_path(filename)
+        return result
+
+
+def _is_egg_path(path):
+    """
+    Determine if given path appears to be an egg.
+    """
+    return path.lower().endswith('.egg')
+
+
+def _is_unpacked_egg(path):
+    """
+    Determine if given path appears to be an unpacked egg.
+    """
+    return (
+        _is_egg_path(path) and
+        os.path.isfile(os.path.join(path, 'EGG-INFO', 'PKG-INFO'))
+    )
+
+
+def _set_parent_ns(packageName):
+    parts = packageName.split('.')
+    name = parts.pop()
+    if parts:
+        parent = '.'.join(parts)
+        setattr(sys.modules[parent], name, sys.modules[packageName])
+
+
+def yield_lines(strs):
+    """Yield non-empty/non-comment lines of a string or sequence"""
+    if isinstance(strs, six.string_types):
+        for s in strs.splitlines():
+            s = s.strip()
+            # skip blank lines/comments
+            if s and not s.startswith('#'):
+                yield s
+    else:
+        for ss in strs:
+            for s in yield_lines(ss):
+                yield s
+
+
+MODULE = re.compile(r"\w+(\.\w+)*$").match
+EGG_NAME = re.compile(
+    r"""
+    (?P<name>[^-]+) (
+        -(?P<ver>[^-]+) (
+            -py(?P<pyver>[^-]+) (
+                -(?P<plat>.+)
+            )?
+        )?
+    )?
+    """,
+    re.VERBOSE | re.IGNORECASE,
+).match
+
+
+class EntryPoint:
+    """Object representing an advertised importable object"""
+
+    def __init__(self, name, module_name, attrs=(), extras=(), dist=None):
+        if not MODULE(module_name):
+            raise ValueError("Invalid module name", module_name)
+        self.name = name
+        self.module_name = module_name
+        self.attrs = tuple(attrs)
+        self.extras = tuple(extras)
+        self.dist = dist
+
+    def __str__(self):
+        s = "%s = %s" % (self.name, self.module_name)
+        if self.attrs:
+            s += ':' + '.'.join(self.attrs)
+        if self.extras:
+            s += ' [%s]' % ','.join(self.extras)
+        return s
+
+    def __repr__(self):
+        return "EntryPoint.parse(%r)" % str(self)
+
+    def load(self, require=True, *args, **kwargs):
+        """
+        Require packages for this EntryPoint, then resolve it.
+        """
+        if not require or args or kwargs:
+            warnings.warn(
+                "Parameters to load are deprecated.  Call .resolve and "
+                ".require separately.",
+                PkgResourcesDeprecationWarning,
+                stacklevel=2,
+            )
+        if require:
+            self.require(*args, **kwargs)
+        return self.resolve()
+
+    def resolve(self):
+        """
+        Resolve the entry point from its module and attrs.
+        """
+        module = __import__(self.module_name, fromlist=['__name__'], level=0)
+        try:
+            return functools.reduce(getattr, self.attrs, module)
+        except AttributeError as exc:
+            raise ImportError(str(exc))
+
+    def require(self, env=None, installer=None):
+        if self.extras and not self.dist:
+            raise UnknownExtra("Can't require() without a distribution", self)
+
+        # Get the requirements for this entry point with all its extras and
+        # then resolve them. We have to pass `extras` along when resolving so
+        # that the working set knows what extras we want. Otherwise, for
+        # dist-info distributions, the working set will assume that the
+        # requirements for that extra are purely optional and skip over them.
+        reqs = self.dist.requires(self.extras)
+        items = working_set.resolve(reqs, env, installer, extras=self.extras)
+        list(map(working_set.add, items))
+
+    pattern = re.compile(
+        r'\s*'
+        r'(?P<name>.+?)\s*'
+        r'=\s*'
+        r'(?P<module>[\w.]+)\s*'
+        r'(:\s*(?P<attr>[\w.]+))?\s*'
+        r'(?P<extras>\[.*\])?\s*$'
+    )
+
+    @classmethod
+    def parse(cls, src, dist=None):
+        """Parse a single entry point from string `src`
+
+        Entry point syntax follows the form::
+
+            name = some.module:some.attr [extra1, extra2]
+
+        The entry name and module name are required, but the ``:attrs`` and
+        ``[extras]`` parts are optional
+        """
+        m = cls.pattern.match(src)
+        if not m:
+            msg = "EntryPoint must be in 'name=module:attrs [extras]' format"
+            raise ValueError(msg, src)
+        res = m.groupdict()
+        extras = cls._parse_extras(res['extras'])
+        attrs = res['attr'].split('.') if res['attr'] else ()
+        return cls(res['name'], res['module'], attrs, extras, dist)
+
+    @classmethod
+    def _parse_extras(cls, extras_spec):
+        if not extras_spec:
+            return ()
+        req = Requirement.parse('x' + extras_spec)
+        if req.specs:
+            raise ValueError()
+        return req.extras
+
+    @classmethod
+    def parse_group(cls, group, lines, dist=None):
+        """Parse an entry point group"""
+        if not MODULE(group):
+            raise ValueError("Invalid group name", group)
+        this = {}
+        for line in yield_lines(lines):
+            ep = cls.parse(line, dist)
+            if ep.name in this:
+                raise ValueError("Duplicate entry point", group, ep.name)
+            this[ep.name] = ep
+        return this
+
+    @classmethod
+    def parse_map(cls, data, dist=None):
+        """Parse a map of entry point groups"""
+        if isinstance(data, dict):
+            data = data.items()
+        else:
+            data = split_sections(data)
+        maps = {}
+        for group, lines in data:
+            if group is None:
+                if not lines:
+                    continue
+                raise ValueError("Entry points must be listed in groups")
+            group = group.strip()
+            if group in maps:
+                raise ValueError("Duplicate group name", group)
+            maps[group] = cls.parse_group(group, lines, dist)
+        return maps
+
+
+def _remove_md5_fragment(location):
+    if not location:
+        return ''
+    parsed = urllib.parse.urlparse(location)
+    if parsed[-1].startswith('md5='):
+        return urllib.parse.urlunparse(parsed[:-1] + ('',))
+    return location
+
+
+def _version_from_file(lines):
+    """
+    Given an iterable of lines from a Metadata file, return
+    the value of the Version field, if present, or None otherwise.
+    """
+    def is_version_line(line):
+        return line.lower().startswith('version:')
+    version_lines = filter(is_version_line, lines)
+    line = next(iter(version_lines), '')
+    _, _, value = line.partition(':')
+    return safe_version(value.strip()) or None
+
+
+class Distribution:
+    """Wrap an actual or potential sys.path entry w/metadata"""
+    PKG_INFO = 'PKG-INFO'
+
+    def __init__(
+            self, location=None, metadata=None, project_name=None,
+            version=None, py_version=PY_MAJOR, platform=None,
+            precedence=EGG_DIST):
+        self.project_name = safe_name(project_name or 'Unknown')
+        if version is not None:
+            self._version = safe_version(version)
+        self.py_version = py_version
+        self.platform = platform
+        self.location = location
+        self.precedence = precedence
+        self._provider = metadata or empty_provider
+
+    @classmethod
+    def from_location(cls, location, basename, metadata=None, **kw):
+        project_name, version, py_version, platform = [None] * 4
+        basename, ext = os.path.splitext(basename)
+        if ext.lower() in _distributionImpl:
+            cls = _distributionImpl[ext.lower()]
+
+            match = EGG_NAME(basename)
+            if match:
+                project_name, version, py_version, platform = match.group(
+                    'name', 'ver', 'pyver', 'plat'
+                )
+        return cls(
+            location, metadata, project_name=project_name, version=version,
+            py_version=py_version, platform=platform, **kw
+        )._reload_version()
+
+    def _reload_version(self):
+        return self
+
+    @property
+    def hashcmp(self):
+        return (
+            self.parsed_version,
+            self.precedence,
+            self.key,
+            _remove_md5_fragment(self.location),
+            self.py_version or '',
+            self.platform or '',
+        )
+
+    def __hash__(self):
+        return hash(self.hashcmp)
+
+    def __lt__(self, other):
+        return self.hashcmp < other.hashcmp
+
+    def __le__(self, other):
+        return self.hashcmp <= other.hashcmp
+
+    def __gt__(self, other):
+        return self.hashcmp > other.hashcmp
+
+    def __ge__(self, other):
+        return self.hashcmp >= other.hashcmp
+
+    def __eq__(self, other):
+        if not isinstance(other, self.__class__):
+            # It's not a Distribution, so they are not equal
+            return False
+        return self.hashcmp == other.hashcmp
+
+    def __ne__(self, other):
+        return not self == other
+
+    # These properties have to be lazy so that we don't have to load any
+    # metadata until/unless it's actually needed.  (i.e., some distributions
+    # may not know their name or version without loading PKG-INFO)
+
+    @property
+    def key(self):
+        try:
+            return self._key
+        except AttributeError:
+            self._key = key = self.project_name.lower()
+            return key
+
+    @property
+    def parsed_version(self):
+        if not hasattr(self, "_parsed_version"):
+            self._parsed_version = parse_version(self.version)
+
+        return self._parsed_version
+
+    def _warn_legacy_version(self):
+        LV = packaging.version.LegacyVersion
+        is_legacy = isinstance(self._parsed_version, LV)
+        if not is_legacy:
+            return
+
+        # While an empty version is technically a legacy version and
+        # is not a valid PEP 440 version, it's also unlikely to
+        # actually come from someone and instead it is more likely that
+        # it comes from setuptools attempting to parse a filename and
+        # including it in the list. So for that we'll gate this warning
+        # on if the version is anything at all or not.
+        if not self.version:
+            return
+
+        tmpl = textwrap.dedent("""
+            '{project_name} ({version})' is being parsed as a legacy,
+            non PEP 440,
+            version. You may find odd behavior and sort order.
+            In particular it will be sorted as less than 0.0. It
+            is recommended to migrate to PEP 440 compatible
+            versions.
+            """).strip().replace('\n', ' ')
+
+        warnings.warn(tmpl.format(**vars(self)), PEP440Warning)
+
+    @property
+    def version(self):
+        try:
+            return self._version
+        except AttributeError:
+            version = self._get_version()
+            if version is None:
+                path = self._get_metadata_path_for_display(self.PKG_INFO)
+                msg = (
+                    "Missing 'Version:' header and/or {} file at path: {}"
+                ).format(self.PKG_INFO, path)
+                raise ValueError(msg, self)
+
+            return version
+
+    @property
+    def _dep_map(self):
+        """
+        A map of extra to its list of (direct) requirements
+        for this distribution, including the null extra.
+        """
+        try:
+            return self.__dep_map
+        except AttributeError:
+            self.__dep_map = self._filter_extras(self._build_dep_map())
+        return self.__dep_map
+
+    @staticmethod
+    def _filter_extras(dm):
+        """
+        Given a mapping of extras to dependencies, strip off
+        environment markers and filter out any dependencies
+        not matching the markers.
+        """
+        for extra in list(filter(None, dm)):
+            new_extra = extra
+            reqs = dm.pop(extra)
+            new_extra, _, marker = extra.partition(':')
+            fails_marker = marker and (
+                invalid_marker(marker)
+                or not evaluate_marker(marker)
+            )
+            if fails_marker:
+                reqs = []
+            new_extra = safe_extra(new_extra) or None
+
+            dm.setdefault(new_extra, []).extend(reqs)
+        return dm
+
+    def _build_dep_map(self):
+        dm = {}
+        for name in 'requires.txt', 'depends.txt':
+            for extra, reqs in split_sections(self._get_metadata(name)):
+                dm.setdefault(extra, []).extend(parse_requirements(reqs))
+        return dm
+
+    def requires(self, extras=()):
+        """List of Requirements needed for this distro if `extras` are used"""
+        dm = self._dep_map
+        deps = []
+        deps.extend(dm.get(None, ()))
+        for ext in extras:
+            try:
+                deps.extend(dm[safe_extra(ext)])
+            except KeyError:
+                raise UnknownExtra(
+                    "%s has no such extra feature %r" % (self, ext)
+                )
+        return deps
+
+    def _get_metadata_path_for_display(self, name):
+        """
+        Return the path to the given metadata file, if available.
+        """
+        try:
+            # We need to access _get_metadata_path() on the provider object
+            # directly rather than through this class's __getattr__()
+            # since _get_metadata_path() is marked private.
+            path = self._provider._get_metadata_path(name)
+
+        # Handle exceptions e.g. in case the distribution's metadata
+        # provider doesn't support _get_metadata_path().
+        except Exception:
+            return '[could not detect]'
+
+        return path
+
+    def _get_metadata(self, name):
+        if self.has_metadata(name):
+            for line in self.get_metadata_lines(name):
+                yield line
+
+    def _get_version(self):
+        lines = self._get_metadata(self.PKG_INFO)
+        version = _version_from_file(lines)
+
+        return version
+
+    def activate(self, path=None, replace=False):
+        """Ensure distribution is importable on `path` (default=sys.path)"""
+        if path is None:
+            path = sys.path
+        self.insert_on(path, replace=replace)
+        if path is sys.path:
+            fixup_namespace_packages(self.location)
+            for pkg in self._get_metadata('namespace_packages.txt'):
+                if pkg in sys.modules:
+                    declare_namespace(pkg)
+
+    def egg_name(self):
+        """Return what this distribution's standard .egg filename should be"""
+        filename = "%s-%s-py%s" % (
+            to_filename(self.project_name), to_filename(self.version),
+            self.py_version or PY_MAJOR
+        )
+
+        if self.platform:
+            filename += '-' + self.platform
+        return filename
+
+    def __repr__(self):
+        if self.location:
+            return "%s (%s)" % (self, self.location)
+        else:
+            return str(self)
+
+    def __str__(self):
+        try:
+            version = getattr(self, 'version', None)
+        except ValueError:
+            version = None
+        version = version or "[unknown version]"
+        return "%s %s" % (self.project_name, version)
+
+    def __getattr__(self, attr):
+        """Delegate all unrecognized public attributes to .metadata provider"""
+        if attr.startswith('_'):
+            raise AttributeError(attr)
+        return getattr(self._provider, attr)
+
+    def __dir__(self):
+        return list(
+            set(super(Distribution, self).__dir__())
+            | set(
+                attr for attr in self._provider.__dir__()
+                if not attr.startswith('_')
+            )
+        )
+
+    if not hasattr(object, '__dir__'):
+        # python 2.7 not supported
+        del __dir__
+
+    @classmethod
+    def from_filename(cls, filename, metadata=None, **kw):
+        return cls.from_location(
+            _normalize_cached(filename), os.path.basename(filename), metadata,
+            **kw
+        )
+
+    def as_requirement(self):
+        """Return a ``Requirement`` that matches this distribution exactly"""
+        if isinstance(self.parsed_version, packaging.version.Version):
+            spec = "%s==%s" % (self.project_name, self.parsed_version)
+        else:
+            spec = "%s===%s" % (self.project_name, self.parsed_version)
+
+        return Requirement.parse(spec)
+
+    def load_entry_point(self, group, name):
+        """Return the `name` entry point of `group` or raise ImportError"""
+        ep = self.get_entry_info(group, name)
+        if ep is None:
+            raise ImportError("Entry point %r not found" % ((group, name),))
+        return ep.load()
+
+    def get_entry_map(self, group=None):
+        """Return the entry point map for `group`, or the full entry map"""
+        try:
+            ep_map = self._ep_map
+        except AttributeError:
+            ep_map = self._ep_map = EntryPoint.parse_map(
+                self._get_metadata('entry_points.txt'), self
+            )
+        if group is not None:
+            return ep_map.get(group, {})
+        return ep_map
+
+    def get_entry_info(self, group, name):
+        """Return the EntryPoint object for `group`+`name`, or ``None``"""
+        return self.get_entry_map(group).get(name)
+
+    def insert_on(self, path, loc=None, replace=False):
+        """Ensure self.location is on path
+
+        If replace=False (default):
+            - If location is already in path anywhere, do nothing.
+            - Else:
+              - If it's an egg and its parent directory is on path,
+                insert just ahead of the parent.
+              - Else: add to the end of path.
+        If replace=True:
+            - If location is already on path anywhere (not eggs)
+              or higher priority than its parent (eggs)
+              do nothing.
+            - Else:
+              - If it's an egg and its parent directory is on path,
+                insert just ahead of the parent,
+                removing any lower-priority entries.
+              - Else: add it to the front of path.
+        """
+
+        loc = loc or self.location
+        if not loc:
+            return
+
+        nloc = _normalize_cached(loc)
+        bdir = os.path.dirname(nloc)
+        npath = [(p and _normalize_cached(p) or p) for p in path]
+
+        for p, item in enumerate(npath):
+            if item == nloc:
+                if replace:
+                    break
+                else:
+                    # don't modify path (even removing duplicates) if
+                    # found and not replace
+                    return
+            elif item == bdir and self.precedence == EGG_DIST:
+                # if it's an .egg, give it precedence over its directory
+                # UNLESS it's already been added to sys.path and replace=False
+                if (not replace) and nloc in npath[p:]:
+                    return
+                if path is sys.path:
+                    self.check_version_conflict()
+                path.insert(p, loc)
+                npath.insert(p, nloc)
+                break
+        else:
+            if path is sys.path:
+                self.check_version_conflict()
+            if replace:
+                path.insert(0, loc)
+            else:
+                path.append(loc)
+            return
+
+        # p is the spot where we found or inserted loc; now remove duplicates
+        while True:
+            try:
+                np = npath.index(nloc, p + 1)
+            except ValueError:
+                break
+            else:
+                del npath[np], path[np]
+                # ha!
+                p = np
+
+        return
+
+    def check_version_conflict(self):
+        if self.key == 'setuptools':
+            # ignore the inevitable setuptools self-conflicts  :(
+            return
+
+        nsp = dict.fromkeys(self._get_metadata('namespace_packages.txt'))
+        loc = normalize_path(self.location)
+        for modname in self._get_metadata('top_level.txt'):
+            if (modname not in sys.modules or modname in nsp
+                    or modname in _namespace_packages):
+                continue
+            if modname in ('pkg_resources', 'setuptools', 'site'):
+                continue
+            fn = getattr(sys.modules[modname], '__file__', None)
+            if fn and (normalize_path(fn).startswith(loc) or
+                       fn.startswith(self.location)):
+                continue
+            issue_warning(
+                "Module %s was already imported from %s, but %s is being added"
+                " to sys.path" % (modname, fn, self.location),
+            )
+
+    def has_version(self):
+        try:
+            self.version
+        except ValueError:
+            issue_warning("Unbuilt egg for " + repr(self))
+            return False
+        return True
+
+    def clone(self, **kw):
+        """Copy this distribution, substituting in any changed keyword args"""
+        names = 'project_name version py_version platform location precedence'
+        for attr in names.split():
+            kw.setdefault(attr, getattr(self, attr, None))
+        kw.setdefault('metadata', self._provider)
+        return self.__class__(**kw)
+
+    @property
+    def extras(self):
+        return [dep for dep in self._dep_map if dep]
+
+
+class EggInfoDistribution(Distribution):
+    def _reload_version(self):
+        """
+        Packages installed by distutils (e.g. numpy or scipy),
+        which uses an old safe_version, and so
+        their version numbers can get mangled when
+        converted to filenames (e.g., 1.11.0.dev0+2329eae to
+        1.11.0.dev0_2329eae). These distributions will not be
+        parsed properly
+        downstream by Distribution and safe_version, so
+        take an extra step and try to get the version number from
+        the metadata file itself instead of the filename.
+        """
+        md_version = self._get_version()
+        if md_version:
+            self._version = md_version
+        return self
+
+
+class DistInfoDistribution(Distribution):
+    """
+    Wrap an actual or potential sys.path entry
+    w/metadata, .dist-info style.
+    """
+    PKG_INFO = 'METADATA'
+    EQEQ = re.compile(r"([\(,])\s*(\d.*?)\s*([,\)])")
+
+    @property
+    def _parsed_pkg_info(self):
+        """Parse and cache metadata"""
+        try:
+            return self._pkg_info
+        except AttributeError:
+            metadata = self.get_metadata(self.PKG_INFO)
+            self._pkg_info = email.parser.Parser().parsestr(metadata)
+            return self._pkg_info
+
+    @property
+    def _dep_map(self):
+        try:
+            return self.__dep_map
+        except AttributeError:
+            self.__dep_map = self._compute_dependencies()
+            return self.__dep_map
+
+    def _compute_dependencies(self):
+        """Recompute this distribution's dependencies."""
+        dm = self.__dep_map = {None: []}
+
+        reqs = []
+        # Including any condition expressions
+        for req in self._parsed_pkg_info.get_all('Requires-Dist') or []:
+            reqs.extend(parse_requirements(req))
+
+        def reqs_for_extra(extra):
+            for req in reqs:
+                if not req.marker or req.marker.evaluate({'extra': extra}):
+                    yield req
+
+        common = frozenset(reqs_for_extra(None))
+        dm[None].extend(common)
+
+        for extra in self._parsed_pkg_info.get_all('Provides-Extra') or []:
+            s_extra = safe_extra(extra.strip())
+            dm[s_extra] = list(frozenset(reqs_for_extra(extra)) - common)
+
+        return dm
+
+
+_distributionImpl = {
+    '.egg': Distribution,
+    '.egg-info': EggInfoDistribution,
+    '.dist-info': DistInfoDistribution,
+}
+
+
+def issue_warning(*args, **kw):
+    level = 1
+    g = globals()
+    try:
+        # find the first stack frame that is *not* code in
+        # the pkg_resources module, to use for the warning
+        while sys._getframe(level).f_globals is g:
+            level += 1
+    except ValueError:
+        pass
+    warnings.warn(stacklevel=level + 1, *args, **kw)
+
+
+class RequirementParseError(ValueError):
+    def __str__(self):
+        return ' '.join(self.args)
+
+
+def parse_requirements(strs):
+    """Yield ``Requirement`` objects for each specification in `strs`
+
+    `strs` must be a string, or a (possibly-nested) iterable thereof.
+    """
+    # create a steppable iterator, so we can handle \-continuations
+    lines = iter(yield_lines(strs))
+
+    for line in lines:
+        # Drop comments -- a hash without a space may be in a URL.
+        if ' #' in line:
+            line = line[:line.find(' #')]
+        # If there is a line continuation, drop it, and append the next line.
+        if line.endswith('\\'):
+            line = line[:-2].strip()
+            try:
+                line += next(lines)
+            except StopIteration:
+                return
+        yield Requirement(line)
+
+
+class Requirement(packaging.requirements.Requirement):
+    def __init__(self, requirement_string):
+        """DO NOT CALL THIS UNDOCUMENTED METHOD; use Requirement.parse()!"""
+        try:
+            super(Requirement, self).__init__(requirement_string)
+        except packaging.requirements.InvalidRequirement as e:
+            raise RequirementParseError(str(e))
+        self.unsafe_name = self.name
+        project_name = safe_name(self.name)
+        self.project_name, self.key = project_name, project_name.lower()
+        self.specs = [
+            (spec.operator, spec.version) for spec in self.specifier]
+        self.extras = tuple(map(safe_extra, self.extras))
+        self.hashCmp = (
+            self.key,
+            self.specifier,
+            frozenset(self.extras),
+            str(self.marker) if self.marker else None,
+        )
+        self.__hash = hash(self.hashCmp)
+
+    def __eq__(self, other):
+        return (
+            isinstance(other, Requirement) and
+            self.hashCmp == other.hashCmp
+        )
+
+    def __ne__(self, other):
+        return not self == other
+
+    def __contains__(self, item):
+        if isinstance(item, Distribution):
+            if item.key != self.key:
+                return False
+
+            item = item.version
+
+        # Allow prereleases always in order to match the previous behavior of
+        # this method. In the future this should be smarter and follow PEP 440
+        # more accurately.
+        return self.specifier.contains(item, prereleases=True)
+
+    def __hash__(self):
+        return self.__hash
+
+    def __repr__(self):
+        return "Requirement.parse(%r)" % str(self)
+
+    @staticmethod
+    def parse(s):
+        req, = parse_requirements(s)
+        return req
+
+
+def _always_object(classes):
+    """
+    Ensure object appears in the mro even
+    for old-style classes.
+    """
+    if object not in classes:
+        return classes + (object,)
+    return classes
+
+
+def _find_adapter(registry, ob):
+    """Return an adapter factory for `ob` from `registry`"""
+    types = _always_object(inspect.getmro(getattr(ob, '__class__', type(ob))))
+    for t in types:
+        if t in registry:
+            return registry[t]
+
+
+def ensure_directory(path):
+    """Ensure that the parent directory of `path` exists"""
+    dirname = os.path.dirname(path)
+    py31compat.makedirs(dirname, exist_ok=True)
+
+
+def _bypass_ensure_directory(path):
+    """Sandbox-bypassing version of ensure_directory()"""
+    if not WRITE_SUPPORT:
+        raise IOError('"os.mkdir" not supported on this platform.')
+    dirname, filename = split(path)
+    if dirname and filename and not isdir(dirname):
+        _bypass_ensure_directory(dirname)
+        try:
+            mkdir(dirname, 0o755)
+        except FileExistsError:
+            pass
+
+
+def split_sections(s):
+    """Split a string or iterable thereof into (section, content) pairs
+
+    Each ``section`` is a stripped version of the section header ("[section]")
+    and each ``content`` is a list of stripped lines excluding blank lines and
+    comment-only lines.  If there are any such lines before the first section
+    header, they're returned in a first ``section`` of ``None``.
+    """
+    section = None
+    content = []
+    for line in yield_lines(s):
+        if line.startswith("["):
+            if line.endswith("]"):
+                if section or content:
+                    yield section, content
+                section = line[1:-1].strip()
+                content = []
+            else:
+                raise ValueError("Invalid section heading", line)
+        else:
+            content.append(line)
+
+    # wrap up last segment
+    yield section, content
+
+
+def _mkstemp(*args, **kw):
+    old_open = os.open
+    try:
+        # temporarily bypass sandboxing
+        os.open = os_open
+        return tempfile.mkstemp(*args, **kw)
+    finally:
+        # and then put it back
+        os.open = old_open
+
+
+# Silence the PEP440Warning by default, so that end users don't get hit by it
+# randomly just because they use pkg_resources. We want to append the rule
+# because we want earlier uses of filterwarnings to take precedence over this
+# one.
+warnings.filterwarnings("ignore", category=PEP440Warning, append=True)
+
+
+# from jaraco.functools 1.3
+def _call_aside(f, *args, **kwargs):
+    f(*args, **kwargs)
+    return f
+
+
+@_call_aside
+def _initialize(g=globals()):
+    "Set up global resource manager (deliberately not state-saved)"
+    manager = ResourceManager()
+    g['_manager'] = manager
+    g.update(
+        (name, getattr(manager, name))
+        for name in dir(manager)
+        if not name.startswith('_')
+    )
+
+
+@_call_aside
+def _initialize_master_working_set():
+    """
+    Prepare the master working set and make the ``require()``
+    API available.
+
+    This function has explicit effects on the global state
+    of pkg_resources. It is intended to be invoked once at
+    the initialization of this module.
+
+    Invocation by other packages is unsupported and done
+    at their own risk.
+    """
+    working_set = WorkingSet._build_master()
+    _declare_state('object', working_set=working_set)
+
+    require = working_set.require
+    iter_entry_points = working_set.iter_entry_points
+    add_activation_listener = working_set.subscribe
+    run_script = working_set.run_script
+    # backward compatibility
+    run_main = run_script
+    # Activate all distributions already on sys.path with replace=False and
+    # ensure that all distributions added to the working set in the future
+    # (e.g. by calling ``require()``) will get activated as well,
+    # with higher priority (replace=True).
+    tuple(
+        dist.activate(replace=False)
+        for dist in working_set
+    )
+    add_activation_listener(
+        lambda dist: dist.activate(replace=True),
+        existing=False,
+    )
+    working_set.entries = []
+    # match order
+    list(map(working_set.add_entry, sys.path))
+    globals().update(locals())
+
+class PkgResourcesDeprecationWarning(Warning):
+    """
+    Base class for warning about deprecations in ``pkg_resources``
+
+    This class is not derived from ``DeprecationWarning``, and as such is
+    visible by default.
+    """
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/pkg_resources/__init__.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/pkg_resources/__init__.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..7a9b33104b310ffd300614cfd4ca800758b66ba5
GIT binary patch
literal 137751
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
Cv8&?%

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/pkg_resources/py31compat.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/pkg_resources/py31compat.py
new file mode 100644
index 0000000..a2d3007
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/pkg_resources/py31compat.py
@@ -0,0 +1,23 @@
+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/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/pkg_resources/py31compat.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/pkg_resources/py31compat.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..89d813b64dd28a19875e0aca9ce8f0f20b31fe04
GIT binary patch
literal 881
zcmZSn%**AGdLky70SZ_c7#JKF7#NBh85kH+7#LC*8FCmHqTp;shA2juI1@t@6PV4!
zki*Q7%fb-F!oZly%8<g$(89<N#m11z!jQ$zP>{-y!p@M&#E`|oz`~r($dI4Rkix-`
z&A^by#K6QD#mSJ$$xu|nkjlo8$HtJ#z>vko5XA+uIaq^}fq^0O|NsC0{WKUE7#K>J
zK~Br8NM>SSU;wdM85kIxL1JDE3=EZm3?&Q<S&R%d3=GYT42<D<Mhq+^Obppv3`MRC
zjI~S*j5Ul5JjFH)HB1ay%plXUSQxUI8H(H(niv=g-5By186r{`7=po;`DuVmF9BJV
zUtGe$z`&53n4OxESyWuY&cMLnAM9FGlwVW=Qj}U$l$T$^#=yYf>Kfr09HIeoTL~yE
z3ld8*z<N_FGK)*%^RvNTNUccL00lUhC@yDUV9+lp$}CGPN!2e)EYeTQ&q+xwD%MX*
z(JxO*%F8v)EjBVtGEc8cw=lIR&&jGXGXR0~JpB;;g3JQl%)H`~#GD*mw=xe;;{cEl
z7{`~T=B4Bp=@(?D#}}m*=a&{GrxxoMR2my5=jRqAmgp5!mhdnzFvP?B6>n?^@@6p?
z$Zd?wjDn2(jFOC*AkSoiJd+8E0}W7sAjH64MQ|ZXxEUB2f<TIcK-$1wF0L#t0SOmm
z7U)4876h^e9DZ(zImM|#oUj-Uh%^E_tSq&tI5R&lJ~J;Zzl4v0fgvw7HKiEt+#rxk
pz(I&01~f21foGGOpHiBWY6tRtG04q4j694yOajb2Je-X3OaQuczgGYN

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/progress/__init__.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/progress/__init__.py
new file mode 100644
index 0000000..e434c25
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/progress/__init__.py
@@ -0,0 +1,177 @@
+# 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/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/progress/__init__.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/progress/__init__.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..6660af50fab970192cadafe2242c143f6605c559
GIT binary patch
literal 8933
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

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/progress/bar.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/progress/bar.py
new file mode 100644
index 0000000..8819efd
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/progress/bar.py
@@ -0,0 +1,91 @@
+# -*- 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/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/progress/bar.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/progress/bar.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..39b46d9578e1856c72e0e16cdf812e0e62dc5d8c
GIT binary patch
literal 4043
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

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/progress/counter.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/progress/counter.py
new file mode 100644
index 0000000..d955ca4
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/progress/counter.py
@@ -0,0 +1,41 @@
+# -*- 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/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/progress/counter.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/progress/counter.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..fad423ae25468a5aa615bd49f83ed15405c79140
GIT binary patch
literal 2422
zcmZSn%**AGdLky70ScHI7#JKFm>7zi7#J8*7#LC*8FCmHav2$-7#SE-m>5!+8FH8y
za+w*Tm>F_e7@}Ah7*kjnQkfaj7#UJn8Cn<^ni&`(qgWYI*ceh-z@qGMQ8tDY4wxt>
zT$G(5g^MAT9julcF3Q1>!ov`(!OOtFkoo`r|Nk0{3=9k<0t^fcrFogj`6;RKIhiG?
zMTt4ZnIIVrCXh4-0|SF+URq{eW=U!Zh!aqhpI($&TwKD=z`)>~Uz%5vS_JniNS_nP
zuYwE=45<ttFQzbn91z9C5EKlyFd3u<ghAor3{oq_z`#($z>vkjP{IgiFflYUf)Ha0
z0|P{pp9V;E2`d8wLwOO%B_M8bNfB5iGcP5z0&I2(3j+f~acWMQ1}N;oL~%X?1A~4+
zQD#|UNveKXVv&AYeojhiQL%nfihg-gQeLiUZn2SJl6iVnx`nAlc}`Z9nE?o-=jn&&
z7i1RbX66-_B<AGkx|Ml&8V7)cz&O4vH7_N<NWTCY9{S0Uu+S^0EMWtMX+cV2Nvasg
zL7;$SV1#%96om2dd5O8H@$n^G3=9nM@wxdar8%kb@j)Otu%i*gKsY}L6u6==hqE!3
zaKd6bCBHn6PH`Osipn5RgoCXwO3h8o%*)J62gh>|DD4e!Ab}!F8Wu><*bM@OR1hdu
z2TfdZGcYiKGFUMv5wbCYGfZ$vVsbV-9zkvf=UH(?p5<bQVq!=E7bsE8pqvXbrWBNG
z6-q&=<I%K6DBT35o1t_Ilx~I6ZBV)$N_T+sKgbMF+=BDJJE)w26anCDU(3i)!o*O+
z2r4NhN|?b#0t<*Q0xA}m7;2foLabntk)ei(L9!WCl!6KikT3lp#TO_OmVhkENzDW2
z$byW-;?!cWP;O=(n9j^A0T*hpObkwS;EW1RV&F0^52_F3`^-U*=#)T-4&*roMt(*G
zMh#H>Q739Nz<Ca29wZI(GcYg=nuN^Dz`!66@;b<oY>aG7;0O%JOob<8P=W#{WIjYf
zW(6hWpkNJ9ctKL&^lm6U1xinZ(o>;yzXr%4D2K3OPzpoJ_n<ICBoZ)dK+14X`3<ri
zn(zI<$pl*Aq?MMG7J(`pP%T*kB7#7PI|!6{z=eMhHz?*oAsz%XhXG_5gcu0_fODx0
Zq^7h3H7<&|7#J7?7{!>ySjAYyI00&YE?xit

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/progress/spinner.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/progress/spinner.py
new file mode 100644
index 0000000..4e100ca
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/progress/spinner.py
@@ -0,0 +1,43 @@
+# -*- 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/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/progress/spinner.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/progress/spinner.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..b4de36fed88b83785254b0914861f912722cc6f9
GIT binary patch
literal 2211
zcmZSn%**AGdLky70ScHI7#JKFm>7yDF)%QsFfgPrGUPBY<T5fuF)}cwFfpVsGvqKa
z<T5ivF*7ixurQ=DGo&#xq_8ryFfcSTFhoYNFr=_Cq_TiT+2NwB3@IEiQBJrh8$${g
zOq3fg%Fd9&0~6(ii*hie@G%5y@G~$lWd8sE|Gx$!0|P^e00RR<X<lY>eoAV5PG(7J
zQDRPUCP)S%&B4IH;F*_}nU`6TTEfo2zz|%JnU|MZ1otir0|SE-$h)!(3=F9ZAYZ1i
zGDI<f`~~s~3&{Q`R)(Np4K|QfAft6lL1YY=tO1ky$siFX1_lOD@HvCb(_>&@s9|8p
zVqhp?1T&Zzni(0yY9SnEs89_fgJd%(U>O*K!7ldG0J*4y739mjl+=n6kbya=c_kp*
z3o;UmQ;Wfp<wcn#sTv>~OF$ZmQ*+WvKyJv?0L3GiD9&eKV9+lp$}CGPN!2e)EYeTQ
z&q+xwD%MX*(JxO*%F8v)EjBVtGEc8cw=lIR&&jGXGXR0~JpB;;g3JQl%)H`~#GD*m
zw=xe;;{cEl7{`~T=B4Bp=@%5`rx&Fb7wZ>80#&b|670;<f|SIPR7nN~hGLN07#PJE
z!M*|q6_&sQhinNbs^a7G5_41I<4d?07#QN?bMsS5b5i5ugFwLn_Gd^@X=({K0|P@w
zW=d*&a%oX<eo+u70|Nut#|UB|{2l~~4N;J<L2<>#$i~RV1olWkW-88PCxu9M;JgOO
zVd*TOBp4J72{up?cr<-`DTLkzrME)qEgB&4AW(<}fkFlxScs4Svj!wM_!t-%<Uqjz
z3Kup;aJ2d6=jTx&EG9zzJ_$-sfYOr(Ygm9vEhV(D@X5@>NEe`#11^pfu%-)8>R@C@
zXTwMxeY+qb(6<{(?}5^L2WyCc3T`!|5aD59U<k;pNX<b{9-wjo93&vs&=MLctE8}i
zDxVZKh7@*&bPj01fb>8DVDUaE4b47_*F*X9A@sui5PA`mUJMPu#e+8B1Q{3@v=9O3
zrvWPdz~xMQd|GKqX%VQv1XThhAR-7<DS%6+AW(h`0wu&CP}m27%mEh;2x1_L32?b@
Y11ah4KyE4qr33*+0cJ5yF%}R60B+y;)&Kwi

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/pyparsing.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/pyparsing.py
new file mode 100644
index 0000000..9d6a01d
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/pyparsing.py
@@ -0,0 +1,6493 @@
+#-*- 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`
+ - 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.0"
+__versionTime__ = "07 Apr 2019 18:28 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
+
+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
+except ImportError:
+    # Python 2.7
+    from collections import Iterable
+    from collections import MutableMapping
+
+try:
+    from collections import OrderedDict as _OrderedDict
+except ImportError:
+    try:
+        from ordereddict import OrderedDict as _OrderedDict
+    except ImportError:
+        _OrderedDict = None
+
+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 to be released in pyparsing 2.4
+"""
+__compat__.collect_all_And_tokens = True
+
+
+#~ sys.stderr.write( "testing pyparsing module, version %s, %s\n" % (__version__,__versionTime__ ) )
+
+__all__ = [ '__version__', '__versionTime__', '__author__', '__compat__',
+'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',
+]
+
+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)
+
+class ParseBaseException(Exception):
+    """base exception class for all parsing runtime exceptions"""
+    # Performance tuning: we construct a *lot* of these, so keep this
+    # constructor as small and fast as possible
+    def __init__( self, pstr, loc=0, msg=None, elem=None ):
+        self.loc = loc
+        if msg is None:
+            self.msg = pstr
+            self.pstr = ""
+        else:
+            self.msg = msg
+            self.pstr = pstr
+        self.parserElement = elem
+        self.args = (pstr, loc, msg)
+
+    @classmethod
+    def _from_exception(cls, pe):
+        """
+        internal factory method to simplify creating one type of ParseException
+        from another - avoids having __init__ signature conflicts among subclasses
+        """
+        return cls(pe.pstr, pe.loc, pe.msg, pe.parserElement)
+
+    def __getattr__( self, aname ):
+        """supported attributes by name are:
+           - lineno - returns the line number of the exception text
+           - col - returns the column number of the exception text
+           - line - returns the line containing the exception text
+        """
+        if( aname == "lineno" ):
+            return lineno( self.loc, self.pstr )
+        elif( aname in ("col", "column") ):
+            return col( self.loc, self.pstr )
+        elif( aname == "line" ):
+            return line( self.loc, self.pstr )
+        else:
+            raise AttributeError(aname)
+
+    def __str__( self ):
+        return "%s (at char %d), (line:%d, col:%d)" % \
+                ( self.msg, self.loc, self.lineno, self.column )
+    def __repr__( self ):
+        return _ustr(self)
+    def markInputline( self, markerString = ">!<" ):
+        """Extracts the exception line from the input string, and marks
+           the location of the exception with a special symbol.
+        """
+        line_str = self.line
+        line_column = self.column - 1
+        if markerString:
+            line_str = "".join((line_str[:line_column],
+                                markerString, line_str[line_column:]))
+        return line_str.strip()
+    def __dir__(self):
+        return "lineno col line".split() + dir(type(self))
+
+class ParseException(ParseBaseException):
+    """
+    Exception thrown when parse expressions don't match class;
+    supported attributes by name are:
+    - lineno - returns the line number of the exception text
+    - col - returns the column number of the exception text
+    - line - returns the line containing the exception text
+
+    Example::
+
+        try:
+            Word(nums).setName("integer").parseString("ABC")
+        except ParseException as pe:
+            print(pe)
+            print("column: {}".format(pe.col))
+
+    prints::
+
+       Expected integer (at char 0), (line:1, col:1)
+        column: 1
+
+    """
+
+    @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 ""
+
+        if name in self.__tokdict:
+            if name not in self.__accumNames:
+                return self.__tokdict[name][-1][0]
+            else:
+                return ParseResults([ v[0] for v in self.__tokdict[name] ])
+        else:
+            return ""
+
+    def __add__( self, other ):
+        ret = self.copy()
+        ret += other
+        return ret
+
+    def __iadd__( self, other ):
+        if other.__tokdict:
+            offset = len(self.__toklist)
+            addoffset = lambda a: offset if a<0 else a+offset
+            otheritems = other.__tokdict.items()
+            otherdictitems = [(k, _ParseResultsWithOffset(v[0],addoffset(v[1])) )
+                                for (k,vlist) in otheritems for v in vlist]
+            for k,v in otherdictitems:
+                self[k] = v
+                if isinstance(v[0],ParseResults):
+                    v[0].__parent = wkref(self)
+
+        self.__toklist += other.__toklist
+        self.__accumNames.update( other.__accumNames )
+        return self
+
+    def __radd__(self, other):
+        if isinstance(other,int) and other == 0:
+            # useful for merging many ParseResults using sum() builtin
+            return self.copy()
+        else:
+            # this may raise a TypeError - so be it
+            return other + self
+
+    def __repr__( self ):
+        return "(%s, %s)" % ( repr( self.__toklist ), repr( self.__tokdict ) )
+
+    def __str__( self ):
+        return '[' + ', '.join(_ustr(i) if isinstance(i, ParseResults) else repr(i) for i in self.__toklist) + ']'
+
+    def _asStringList( self, sep='' ):
+        out = []
+        for item in self.__toklist:
+            if out and sep:
+                out.append(sep)
+            if isinstance( item, ParseResults ):
+                out += item._asStringList()
+            else:
+                out.append( _ustr(item) )
+        return out
+
+    def asList( self ):
+        """
+        Returns the parse results as a nested list of matching tokens, all converted to strings.
+
+        Example::
+
+            patt = OneOrMore(Word(alphas))
+            result = patt.parseString("sldkj lsdkj sldkj")
+            # even though the result prints in string-like form, it is actually a pyparsing ParseResults
+            print(type(result), result) # -> <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='', depth=0, full=True):
+        """
+        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'
+        out.append( indent+_ustr(self.asList()) )
+        if full:
+            if self.haskeys():
+                items = sorted((str(k), v) for k,v in self.items())
+                for k,v in items:
+                    if out:
+                        out.append(NL)
+                    out.append( "%s%s- %s: " % (indent,('  '*depth), k) )
+                    if isinstance(v,ParseResults):
+                        if v:
+                            out.append( v.dump(indent,depth+1) )
+                        else:
+                            out.append(_ustr(v))
+                    else:
+                        out.append(repr(v))
+            elif any(isinstance(vv,ParseResults) for vv in self):
+                v = self
+                for i,vv in enumerate(v):
+                    if isinstance(vv,ParseResults):
+                        out.append("\n%s%s[%d]:\n%s%s%s" % (indent,('  '*(depth)),i,indent,('  '*(depth+1)),vv.dump(indent,depth+1) ))
+                    else:
+                        out.append("\n%s%s[%d]:\n%s%s%s" % (indent,('  '*(depth)),i,indent,('  '*(depth+1)),_ustr(vv)))
+
+        return "".join(out)
+
+    def pprint(self, *args, **kwargs):
+        """
+        Pretty-printer for parsed results as a list, using the
+        `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()))
+
+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:
+                        del tb
+
+                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
+
+    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 hasattr(self,"exception"):
+            self.exception.msg = self.errmsg
+        return self
+
+    def setResultsName( self, name, listAllMatches=False ):
+        """
+        Define name for referencing matching tokens as a nested attribute
+        of the returned parse results.
+        NOTE: this returns a *copy* of the original :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")
+        """
+        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
+                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.
+
+        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]
+        """
+        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)
+        """
+        msg = kwargs.get("message", "failed user-defined condition")
+        exc_type = ParseFatalException if kwargs.get("fatal", False) else ParseException
+        for fn in fns:
+            fn = _trim_arity(fn)
+            def pa(s,l,t):
+                if not bool(fn(s,l,t)):
+                    raise exc_type(s,l,msg)
+            self.parseAction.append(pa)
+        self.callDuringTry = self.callDuringTry or kwargs.get("callDuringTry", False)
+        return self
+
+    def setFailAction( self, fn ):
+        """Define action to perform if parsing fails at this expression.
+           Fail acton fn is a callable function that takes the arguments
+           ``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 ):
+        debugging = ( self.debug ) #and doActions )
+
+        if debugging or self.failAction:
+            #~ print ("Match",self,"at loc",loc,"(%d,%d)" % ( lineno(loc,instring), col(loc,instring) ))
+            if (self.debugActions[0] ):
+                self.debugActions[0]( instring, loc, self )
+            if callPreParse and self.callPreparse:
+                preloc = self.preParse( instring, loc )
+            else:
+                preloc = loc
+            tokensStart = preloc
+            try:
+                try:
+                    loc,tokens = self.parseImpl( instring, preloc, doActions )
+                except IndexError:
+                    raise ParseException( instring, len(instring), self.errmsg, self )
+            except ParseBaseException as err:
+                #~ print ("Exception raised:", err)
+                if self.debugActions[2]:
+                    self.debugActions[2]( instring, tokensStart, self, err )
+                if self.failAction:
+                    self.failAction( instring, tokensStart, self, err )
+                raise
+        else:
+            if callPreParse and self.callPreparse:
+                preloc = self.preParse( instring, loc )
+            else:
+                preloc = loc
+            tokensStart = preloc
+            if self.mayIndexError or preloc >= len(instring):
+                try:
+                    loc,tokens = self.parseImpl( instring, preloc, doActions )
+                except IndexError:
+                    raise ParseException( instring, len(instring), self.errmsg, self )
+            else:
+                loc,tokens = self.parseImpl( instring, preloc, doActions )
+
+        tokens = self.postParse( instring, loc, tokens )
+
+        retTokens = ParseResults( tokens, self.resultsName, asList=self.saveAsList, modal=self.modalResults )
+        if self.parseAction and (doActions or self.callDuringTry):
+            if debugging:
+                try:
+                    for fn in self.parseAction:
+                        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 ParseBaseException as err:
+                    #~ print "Exception raised in user parse action:", err
+                    if (self.debugActions[2] ):
+                        self.debugActions[2]( instring, tokensStart, self, err )
+                    raise
+            else:
+                for fn in self.parseAction:
+                    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[1] ):
+                self.debugActions[1]( instring, tokensStart, loc, self, retTokens )
+
+        return loc, retTokens
+
+    def tryParse( self, instring, loc ):
+        try:
+            return self._parse( instring, loc, doActions=False )[0]
+        except ParseFatalException:
+            raise ParseException( instring, loc, self.errmsg, self)
+
+    def canParseNext(self, instring, loc):
+        try:
+            self.tryParse(instring, loc)
+        except (ParseException, IndexError):
+            return False
+        else:
+            return True
+
+    class _UnboundedCache(object):
+        def __init__(self):
+            cache = {}
+            self.not_in_cache = not_in_cache = object()
+
+            def get(self, key):
+                return cache.get(key, not_in_cache)
+
+            def set(self, key, value):
+                cache[key] = value
+
+            def clear(self):
+                cache.clear()
+
+            def cache_len(self):
+                return len(cache)
+
+            self.get = types.MethodType(get, self)
+            self.set = types.MethodType(set, self)
+            self.clear = types.MethodType(clear, self)
+            self.__len__ = types.MethodType(cache_len, self)
+
+    if _OrderedDict is not None:
+        class _FifoCache(object):
+            def __init__(self, size):
+                self.not_in_cache = not_in_cache = object()
+
+                cache = _OrderedDict()
+
+                def get(self, key):
+                    return cache.get(key, not_in_cache)
+
+                def set(self, key, value):
+                    cache[key] = value
+                    while len(cache) > size:
+                        try:
+                            cache.popitem(False)
+                        except KeyError:
+                            pass
+
+                def clear(self):
+                    cache.clear()
+
+                def cache_len(self):
+                    return len(cache)
+
+                self.get = types.MethodType(get, self)
+                self.set = types.MethodType(set, self)
+                self.clear = types.MethodType(clear, self)
+                self.__len__ = types.MethodType(cache_len, self)
+
+    else:
+        class _FifoCache(object):
+            def __init__(self, size):
+                self.not_in_cache = not_in_cache = object()
+
+                cache = {}
+                key_fifo = collections.deque([], size)
+
+                def get(self, key):
+                    return cache.get(key, not_in_cache)
+
+                def set(self, key, value):
+                    cache[key] = value
+                    while len(key_fifo) > size:
+                        cache.pop(key_fifo.popleft(), None)
+                    key_fifo.append(key)
+
+                def clear(self):
+                    cache.clear()
+                    key_fifo.clear()
+
+                def cache_len(self):
+                    return len(cache)
+
+                self.get = types.MethodType(get, self)
+                self.set = types.MethodType(set, self)
+                self.clear = types.MethodType(clear, self)
+                self.__len__ = types.MethodType(cache_len, self)
+
+    # argument cache for optimizing repeated calls when backtracking through recursive expressions
+    packrat_cache = {} # this is set later by enabledPackrat(); this is here so that resetCache() doesn't fail
+    packrat_cache_lock = RLock()
+    packrat_cache_stats = [0, 0]
+
+    # this method gets repeatedly called during backtracking with the same arguments -
+    # we can cache these arguments and save ourselves the trouble of re-parsing the contained expression
+    def _parseCache( self, instring, loc, doActions=True, callPreParse=True ):
+        HIT, MISS = 0, 1
+        lookup = (self, instring, loc, callPreParse, doActions)
+        with ParserElement.packrat_cache_lock:
+            cache = ParserElement.packrat_cache
+            value = cache.get(lookup)
+            if value is cache.not_in_cache:
+                ParserElement.packrat_cache_stats[MISS] += 1
+                try:
+                    value = self._parseNoCache(instring, loc, doActions, callPreParse)
+                except ParseBaseException as pe:
+                    # cache a copy of the exception, without the traceback
+                    cache.set(lookup, pe.__class__(*pe.args))
+                    raise
+                else:
+                    cache.set(lookup, (value[0], value[1].copy()))
+                    return value
+            else:
+                ParserElement.packrat_cache_stats[HIT] += 1
+                if isinstance(value, Exception):
+                    raise value
+                return (value[0], value[1].copy())
+
+    _parse = _parseNoCache
+
+    @staticmethod
+    def resetCache():
+        ParserElement.packrat_cache.clear()
+        ParserElement.packrat_cache_stats[:] = [0] * len(ParserElement.packrat_cache_stats)
+
+    _packratEnabled = False
+    @staticmethod
+    def enablePackrat(cache_size_limit=128):
+        """Enables "packrat" parsing, which adds memoizing to the parsing logic.
+           Repeated parse attempts at the same string location (which happens
+           often in many complex grammars) can immediately return a cached value,
+           instead of re-executing parsing/validating code.  Memoizing is done of
+           both valid results and parsing exceptions.
+
+           Parameters:
+
+           - cache_size_limit - (default= ``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.
+
+        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, clears out pyparsing internal stack trace
+                raise exc
+        else:
+            return tokens
+
+    def scanString( self, instring, maxMatches=_MAX_INT, overlap=False ):
+        """
+        Scan the input string for expression matches.  Each match will return the
+        matching tokens, start location, and end location.  May be called with optional
+        ``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, clears out pyparsing internal stack trace
+                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, clears out pyparsing internal stack trace
+                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, clears out pyparsing internal stack trace
+                raise exc
+
+    def split(self, instring, maxsplit=_MAX_INT, includeSeparators=False):
+        """
+        Generator method to split a string using the given expression as a separator.
+        May be called with optional ``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', '!']
+        """
+        if isinstance( other, basestring ):
+            other = ParserElement._literalStringClass( other )
+        if not isinstance( other, ParserElement ):
+            warnings.warn("Cannot combine element of type %s with ParserElement" % type(other),
+                    SyntaxWarning, stacklevel=2)
+            return None
+        return And( [ self, other ] )
+
+    def __radd__(self, other ):
+        """
+        Implementation of + operator when left operand is not a :class:`ParserElement`
+        """
+        if isinstance( other, basestring ):
+            other = ParserElement._literalStringClass( other )
+        if not isinstance( other, ParserElement ):
+            warnings.warn("Cannot combine element of type %s with ParserElement" % type(other),
+                    SyntaxWarning, stacklevel=2)
+            return None
+        return other + self
+
+    def __sub__(self, other):
+        """
+        Implementation of - operator, returns :class:`And` with error stop
+        """
+        if isinstance( other, basestring ):
+            other = ParserElement._literalStringClass( other )
+        if not isinstance( other, ParserElement ):
+            warnings.warn("Cannot combine element of type %s with ParserElement" % type(other),
+                    SyntaxWarning, stacklevel=2)
+            return None
+        return self + And._ErrorStop() + other
+
+    def __rsub__(self, other ):
+        """
+        Implementation of - operator when left operand is not a :class:`ParserElement`
+        """
+        if isinstance( other, basestring ):
+            other = ParserElement._literalStringClass( other )
+        if not isinstance( other, ParserElement ):
+            warnings.warn("Cannot combine element of type %s with ParserElement" % type(other),
+                    SyntaxWarning, stacklevel=2)
+            return None
+        return other - self
+
+    def __mul__(self,other):
+        """
+        Implementation of * operator, allows use of ``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 isinstance(other,int):
+            minElements, optElements = other,0
+        elif isinstance(other,tuple):
+            other = (other + (None, None))[:2]
+            if other[0] is None:
+                other = (0, other[1])
+            if isinstance(other[0],int) and other[1] is None:
+                if other[0] == 0:
+                    return ZeroOrMore(self)
+                if other[0] == 1:
+                    return OneOrMore(self)
+                else:
+                    return self*other[0] + ZeroOrMore(self)
+            elif isinstance(other[0],int) and isinstance(other[1],int):
+                minElements, optElements = other
+                optElements -= minElements
+            else:
+                raise TypeError("cannot multiply 'ParserElement' and ('%s','%s') objects", type(other[0]),type(other[1]))
+        else:
+            raise TypeError("cannot multiply 'ParserElement' and '%s' objects", type(other))
+
+        if minElements < 0:
+            raise ValueError("cannot multiply ParserElement by negative value")
+        if optElements < 0:
+            raise ValueError("second tuple value must be greater or equal to first tuple value")
+        if minElements == optElements == 0:
+            raise ValueError("cannot multiply ParserElement by 0 or (0,0)")
+
+        if (optElements):
+            def makeOptionalList(n):
+                if n>1:
+                    return Optional(self + makeOptionalList(n-1))
+                else:
+                    return Optional(self)
+            if minElements:
+                if minElements == 1:
+                    ret = self + makeOptionalList(optElements)
+                else:
+                    ret = And([self]*minElements) + makeOptionalList(optElements)
+            else:
+                ret = makeOptionalList(optElements)
+        else:
+            if minElements == 1:
+                ret = self
+            else:
+                ret = And([self]*minElements)
+        return ret
+
+    def __rmul__(self, other):
+        return self.__mul__(other)
+
+    def __or__(self, other ):
+        """
+        Implementation of | operator - returns :class:`MatchFirst`
+        """
+        if isinstance( other, basestring ):
+            other = ParserElement._literalStringClass( other )
+        if not isinstance( other, ParserElement ):
+            warnings.warn("Cannot combine element of type %s with ParserElement" % type(other),
+                    SyntaxWarning, stacklevel=2)
+            return None
+        return MatchFirst( [ self, other ] )
+
+    def __ror__(self, other ):
+        """
+        Implementation of | operator when left operand is not a :class:`ParserElement`
+        """
+        if isinstance( other, basestring ):
+            other = ParserElement._literalStringClass( other )
+        if not isinstance( other, ParserElement ):
+            warnings.warn("Cannot combine element of type %s with ParserElement" % type(other),
+                    SyntaxWarning, stacklevel=2)
+            return None
+        return other | self
+
+    def __xor__(self, other ):
+        """
+        Implementation of ^ operator - returns :class:`Or`
+        """
+        if isinstance( other, basestring ):
+            other = ParserElement._literalStringClass( other )
+        if not isinstance( other, ParserElement ):
+            warnings.warn("Cannot combine element of type %s with ParserElement" % type(other),
+                    SyntaxWarning, stacklevel=2)
+            return None
+        return Or( [ self, other ] )
+
+    def __rxor__(self, other ):
+        """
+        Implementation of ^ operator when left operand is not a :class:`ParserElement`
+        """
+        if isinstance( other, basestring ):
+            other = ParserElement._literalStringClass( other )
+        if not isinstance( other, ParserElement ):
+            warnings.warn("Cannot combine element of type %s with ParserElement" % type(other),
+                    SyntaxWarning, stacklevel=2)
+            return None
+        return other ^ self
+
+    def __and__(self, other ):
+        """
+        Implementation of & operator - returns :class:`Each`
+        """
+        if isinstance( other, basestring ):
+            other = ParserElement._literalStringClass( other )
+        if not isinstance( other, ParserElement ):
+            warnings.warn("Cannot combine element of type %s with ParserElement" % type(other),
+                    SyntaxWarning, stacklevel=2)
+            return None
+        return Each( [ self, other ] )
+
+    def __rand__(self, other ):
+        """
+        Implementation of & operator when left operand is not a :class:`ParserElement`
+        """
+        if isinstance( other, basestring ):
+            other = ParserElement._literalStringClass( other )
+        if not isinstance( other, ParserElement ):
+            warnings.warn("Cannot combine element of type %s with ParserElement" % type(other),
+                    SyntaxWarning, stacklevel=2)
+            return None
+        return other & self
+
+    def __invert__( self ):
+        """
+        Implementation of ~ operator - returns :class:`NotAny`
+        """
+        return NotAny( self )
+
+    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=[] ):
+        """
+        Check defined expressions for valid structure, check for infinite recursive definitions.
+        """
+        self.checkRecursion( [] )
+
+    def parseFile( self, file_or_filename, parseAll=False ):
+        """
+        Execute the parse expression on the given file or filename.
+        If a filename is specified (instead of a file object),
+        the entire file is opened, read, and closed before parsing.
+        """
+        try:
+            file_contents = file_or_filename.read()
+        except AttributeError:
+            with open(file_or_filename, "r") as f:
+                file_contents = f.read()
+        try:
+            return self.parseString(file_contents, parseAll)
+        except ParseBaseException as exc:
+            if ParserElement.verbose_stacktrace:
+                raise
+            else:
+                # catch and re-raise exception from here, clears out pyparsing internal stack trace
+                raise exc
+
+    def __eq__(self,other):
+        if isinstance(other, ParserElement):
+            return self is other or vars(self) == vars(other)
+        elif isinstance(other, basestring):
+            return self.matches(other)
+        else:
+            return super(ParserElement,self)==other
+
+    def __ne__(self,other):
+        return not (self == other)
+
+    def __hash__(self):
+        return hash(id(self))
+
+    def __req__(self,other):
+        return self == other
+
+    def __rne__(self,other):
+        return not (self == other)
+
+    def matches(self, testString, parseAll=True):
+        """
+        Method for quick testing of a parser against a test string. Good for simple
+        inline microtests of sub expressions while building up larger parser.
+
+        Parameters:
+         - testString - to test against this expression for a match
+         - parseAll - (default= ``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):
+        """
+        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
+
+        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)
+        allResults = []
+        comments = []
+        success = True
+        for t in tests:
+            if comment is not None and comment.matches(t, False) or comments and not t:
+                comments.append(t)
+                continue
+            if not t:
+                continue
+            out = ['\n'.join(comments), t]
+            comments = []
+            try:
+                # convert newline marks to actual newlines, and strip leading BOM if present
+                NL = Literal(r'\n').addParseAction(replaceWith('\n')).ignore(quotedString)
+                BOM = '\ufeff'
+                t = NL.transformString(t.lstrip(BOM))
+                result = self.parseString(t, parseAll=parseAll)
+                out.append(result.dump(full=fullDump))
+                success = success and not failureTests
+                if postParse is not None:
+                    try:
+                        pp_value = postParse(t, result)
+                        if pp_value is not None:
+                            out.append(str(pp_value))
+                    except Exception as e:
+                        out.append("{0} failed: {1}: {2}".format(postParse.__name__, type(e).__name__, e))
+            except ParseBaseException as pe:
+                fatal = "(FATAL)" if isinstance(pe, ParseFatalException) else ""
+                if '\n' in t:
+                    out.append(line(pe.loc, t))
+                    out.append(' '*(col(pe.loc,t)-1) + '^' + fatal)
+                else:
+                    out.append(' '*pe.loc + '^' + fatal)
+                out.append("FAIL: " + str(pe))
+                success = success and failureTests
+                result = pe
+            except Exception as exc:
+                out.append("FAIL-EXCEPTION: " + str(exc))
+                success = success and failureTests
+                result = exc
+
+            if printResults:
+                if fullDump:
+                    out.append('')
+                print('\n'.join(out))
+
+            allResults.append((t, result))
+
+        return success, allResults
+
+
+class Token(ParserElement):
+    """Abstract :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: this routine gets called a *lot*
+    # if this is a single character match string  and the first character matches,
+    # short-circuit as quickly as possible, and avoid calling startswith
+    #~ @profile
+    def parseImpl( self, instring, loc, doActions=True ):
+        if (instring[loc] == self.firstMatchChar and
+            (self.matchLen==1 or instring.startswith(self.match,loc)) ):
+            return loc+self.matchLen, self.match
+        raise ParseException(instring, loc, self.errmsg, self)
+_L = Literal
+ParserElement._literalStringClass = Literal
+
+class Keyword(Token):
+    """Token to exactly match a specified string as a keyword, that is,
+    it must be immediately followed by a non-keyword character.  Compare
+    with :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 and
+                (self.matchLen==1 or instring.startswith(self.match,loc)) and
+                (loc >= len(instring)-self.matchLen or instring[loc+self.matchLen] not in self.identChars) and
+                (loc == 0 or instring[loc-1] not in self.identChars) ):
+                return loc+self.matchLen, self.match
+        raise ParseException(instring, loc, self.errmsg, self)
+
+    def copy(self):
+        c = super(Keyword,self).copy()
+        c.identChars = Keyword.DEFAULT_KEYWORD_CHARS
+        return c
+
+    @staticmethod
+    def setDefaultKeywordChars( chars ):
+        """Overrides the default Keyword chars
+        """
+        Keyword.DEFAULT_KEYWORD_CHARS = chars
+
+class CaselessLiteral(Literal):
+    """Token to match a specified string, ignoring case of letters.
+    Note: the matched results will always be in the case of the given
+    match string, NOT the case of the input text.
+
+    Example::
+
+        OneOrMore(CaselessLiteral("CMD")).parseString("cmd CMD Cmd10") # -> ['CMD', 'CMD', 'CMD']
+
+    (Contrast with example for :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], self.match_string)):
+                src,mat = s_m
+                if src != mat:
+                    mismatches.append(match_stringloc)
+                    if len(mismatches) > maxMismatches:
+                        break
+            else:
+                loc = match_stringloc + 1
+                results = ParseResults([instring[start:loc]])
+                results['original'] = self.match_string
+                results['mismatches'] = mismatches
+                return loc, results
+
+        raise ParseException(instring, loc, self.errmsg, self)
+
+
+class Word(Token):
+    """Token for matching words composed of allowed character sets.
+    Defined with string containing all allowed initial characters, an
+    optional string containing allowed body characters (if omitted,
+    defaults to the initial character set), and an optional minimum,
+    maximum, and/or exact length.  The default value for ``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
+
+    def parseImpl( self, instring, loc, doActions=True ):
+        if self.re:
+            result = self.re.match(instring,loc)
+            if not result:
+                raise ParseException(instring, loc, self.errmsg, self)
+
+            loc = result.end()
+            return loc, result.group()
+
+        if 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 Char(Word):
+    """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(self.initCharsOrig)
+        self.re = re.compile( self.reString )
+
+
+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.
+
+    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})")
+    """
+    compiledREtype = type(re.compile("[A-Z]"))
+    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 isinstance(pattern, Regex.compiledREtype):
+            self.re = pattern
+            self.pattern = \
+            self.reString = str(pattern)
+            self.flags = flags
+
+        else:
+            raise ValueError("Regex may only be constructed with a string or a compiled RE object")
+
+        self.name = _ustr(self)
+        self.errmsg = "Expected " + self.name
+        self.mayIndexError = False
+        self.mayReturnEmpty = True
+        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
+        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\00A0': '<NBSP>',
+        'u\1680': '<OGHAM_SPACE_MARK>',
+        'u\180E': '<MONGOLIAN_VOWEL_SEPARATOR>',
+        'u\2000': '<EN_QUAD>',
+        'u\2001': '<EM_QUAD>',
+        'u\2002': '<EN_SPACE>',
+        'u\2003': '<EM_SPACE>',
+        'u\2004': '<THREE-PER-EM_SPACE>',
+        'u\2005': '<FOUR-PER-EM_SPACE>',
+        'u\2006': '<SIX-PER-EM_SPACE>',
+        'u\2007': '<FIGURE_SPACE>',
+        'u\2008': '<PUNCTUATION_SPACE>',
+        'u\2009': '<THIN_SPACE>',
+        'u\200A': '<HAIR_SPACE>',
+        'u\200B': '<ZERO_WIDTH_SPACE>',
+        'u\202F': '<NNBSP>',
+        'u\205F': '<MMSP>',
+        'u\3000': '<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 = [ ParserElement._literalStringClass( exprs ) ]
+        elif isinstance( exprs, Iterable ):
+            exprs = list(exprs)
+            # if sequence of strings provided, wrap with Literal
+            if all(isinstance(expr, basestring) for expr in exprs):
+                exprs = map(ParserElement._literalStringClass, exprs)
+            self.exprs = list(exprs)
+        else:
+            try:
+                self.exprs = list( exprs )
+            except TypeError:
+                self.exprs = [ exprs ]
+        self.callPreparse = False
+
+    def __getitem__( self, i ):
+        return self.exprs[i]
+
+    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=[] ):
+        tmp = validateTrace[:]+[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
+
+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 ):
+        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):
+        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 = ParserElement._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:
+            matches.sort(key=lambda x: -x[0])
+            for _,e in matches:
+                try:
+                    return e._parse( instring, loc, doActions )
+                except ParseException as err:
+                    err.__traceback__ = None
+                    if err.loc > maxExcLoc:
+                        maxException = err
+                        maxExcLoc = err.loc
+
+        if maxException is not None:
+            maxException.msg = self.errmsg
+            raise maxException
+        else:
+            raise ParseException(instring, loc, "no defined alternatives to match", self)
+
+
+    def __ixor__(self, other ):
+        if isinstance( other, basestring ):
+            other = ParserElement._literalStringClass( other )
+        return self.append( other ) #Or( [ self, other ] )
+
+    def __str__( self ):
+        if hasattr(self,"name"):
+            return self.name
+
+        if self.strRepr is None:
+            self.strRepr = "{" + " ^ ".join(_ustr(e) for e in self.exprs) + "}"
+
+        return self.strRepr
+
+    def checkRecursion( self, parseElementList ):
+        subRecCheckList = parseElementList[:] + [ self ]
+        for e in self.exprs:
+            e.checkRecursion( subRecCheckList )
+
+
+class MatchFirst(ParseExpression):
+    """Requires that at least one :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 = ParserElement._literalStringClass( other )
+        return self.append( other ) #MatchFirst( [ self, other ] )
+
+    def __str__( self ):
+        if hasattr(self,"name"):
+            return self.name
+
+        if self.strRepr is None:
+            self.strRepr = "{" + " | ".join(_ustr(e) for e in self.exprs) + "}"
+
+        return self.strRepr
+
+    def checkRecursion( self, parseElementList ):
+        subRecCheckList = parseElementList[:] + [ self ]
+        for e in self.exprs:
+            e.checkRecursion( subRecCheckList )
+
+
+class Each(ParseExpression):
+    """Requires all given :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)]
+            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(ParserElement._literalStringClass, Token):
+                expr = ParserElement._literalStringClass(expr)
+            else:
+                expr = ParserElement._literalStringClass(Literal(expr))
+        self.expr = expr
+        self.strRepr = None
+        if expr is not None:
+            self.mayIndexError = expr.mayIndexError
+            self.mayReturnEmpty = expr.mayReturnEmpty
+            self.setWhitespaceChars( expr.whiteChars )
+            self.skipWhitespace = expr.skipWhitespace
+            self.saveAsList = expr.saveAsList
+            self.callPreparse = expr.callPreparse
+            self.ignoreExprs.extend(expr.ignoreExprs)
+
+    def parseImpl( self, instring, loc, doActions=True ):
+        if self.expr is not None:
+            return self.expr._parse( instring, loc, doActions, callPreParse=False )
+        else:
+            raise ParseException("",loc,self.errmsg,self)
+
+    def leaveWhitespace( self ):
+        self.skipWhitespace = False
+        self.expr = self.expr.copy()
+        if self.expr is not None:
+            self.expr.leaveWhitespace()
+        return self
+
+    def ignore( self, other ):
+        if isinstance( other, Suppress ):
+            if other not in self.ignoreExprs:
+                super( ParseElementEnhance, self).ignore( other )
+                if self.expr is not None:
+                    self.expr.ignore( self.ignoreExprs[-1] )
+        else:
+            super( ParseElementEnhance, self).ignore( other )
+            if self.expr is not None:
+                self.expr.ignore( self.ignoreExprs[-1] )
+        return self
+
+    def streamline( self ):
+        super(ParseElementEnhance,self).streamline()
+        if self.expr is not None:
+            self.expr.streamline()
+        return self
+
+    def checkRecursion( self, parseElementList ):
+        if self in parseElementList:
+            raise RecursiveGrammarException( parseElementList+[self] )
+        subRecCheckList = parseElementList[:] + [ self ]
+        if self.expr is not None:
+            self.expr.checkRecursion( subRecCheckList )
+
+    def validate( self, validateTrace=[] ):
+        tmp = validateTrace[:]+[self]
+        if self.expr is not None:
+            self.expr.validate(tmp)
+        self.checkRecursion( [] )
+
+    def __str__( self ):
+        try:
+            return super(ParseElementEnhance,self).__str__()
+        except Exception:
+            pass
+
+        if self.strRepr is None and self.expr is not None:
+            self.strRepr = "%s:(%s)" % ( self.__class__.__name__, _ustr(self.expr) )
+        return self.strRepr
+
+
+class FollowedBy(ParseElementEnhance):
+    """Lookahead matching of the given parse expression.
+    ``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 ):
+        _, 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
+
+    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[:loc]
+            last_expr = ParseException(instring, loc, self.errmsg)
+            for offset in range(1, min(loc, self.retreat+1)):
+                try:
+                    _, ret = test_expr._parse(instring_slice, loc-offset)
+                except ParseBaseException as pbe:
+                    last_expr = pbe
+                else:
+                    break
+            else:
+                raise last_expr
+        # return empty list of tokens, but preserve any defined results names
+        del ret[:]
+        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 = ParserElement._literalStringClass(ender)
+        self.not_ender = ~ender if ender is not None else None
+
+    def parseImpl( self, instring, loc, doActions=True ):
+        self_expr_parse = self.expr._parse
+        self_skip_ignorables = self._skipIgnorables
+        check_ender = self.not_ender is not None
+        if check_ender:
+            try_not_ender = self.not_ender.tryParse
+
+        # must be at least one (but first see if we are the stopOn sentinel;
+        # if so, fail)
+        if check_ender:
+            try_not_ender(instring, loc)
+        loc, tokens = self_expr_parse( instring, loc, doActions, callPreParse=False )
+        try:
+            hasIgnoreExprs = (not not self.ignoreExprs)
+            while 1:
+                if check_ender:
+                    try_not_ender(instring, loc)
+                if hasIgnoreExprs:
+                    preloc = self_skip_ignorables( instring, loc )
+                else:
+                    preloc = loc
+                loc, tmptokens = self_expr_parse( instring, preloc, doActions )
+                if tmptokens or tmptokens.haskeys():
+                    tokens += tmptokens
+        except (ParseException,IndexError):
+            pass
+
+        return loc, tokens
+
+class OneOrMore(_MultipleMatch):
+    """Repetition of one or more of the given expression.
+
+    Parameters:
+     - expr - expression that must match one or more times
+     - stopOn - (default= ``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 ""
+
+_optionalNotMatched = _NullToken()
+class Optional(ParseElementEnhance):
+    """Optional matching of the given expression.
+
+    Parameters:
+     - expr - expression that must match zero or more times
+     - default (optional) - value to be returned if the optional expression is not found.
+
+    Example::
+
+        # US postal code can be a 5-digit zip, plus optional 4-digit qualifier
+        zip = Combine(Word(nums, exact=5) + Optional('-' + Word(nums, exact=4)))
+        zip.runTests('''
+            # traditional ZIP code
+            12345
+
+            # ZIP+4 form
+            12101-0001
+
+            # invalid ZIP
+            98765-
+            ''')
+
+    prints::
+
+        # traditional ZIP code
+        12345
+        ['12345']
+
+        # ZIP+4 form
+        12101-0001
+        ['12101-0001']
+
+        # invalid ZIP
+        98765-
+             ^
+        FAIL: Expected end of text (at char 5), (line:1, col:6)
+    """
+    def __init__( self, expr, default=_optionalNotMatched ):
+        super(Optional,self).__init__( expr, savelist=False )
+        self.saveAsList = self.expr.saveAsList
+        self.defaultValue = default
+        self.mayReturnEmpty = True
+
+    def parseImpl( self, instring, loc, doActions=True ):
+        try:
+            loc, tokens = self.expr._parse( instring, loc, doActions, callPreParse=False )
+        except (ParseException,IndexError):
+            if self.defaultValue is not _optionalNotMatched:
+                if self.expr.resultsName:
+                    tokens = ParseResults([ self.defaultValue ])
+                    tokens[self.expr.resultsName] = self.defaultValue
+                else:
+                    tokens = [ self.defaultValue ]
+            else:
+                tokens = []
+        return loc, tokens
+
+    def __str__( self ):
+        if hasattr(self,"name"):
+            return self.name
+
+        if self.strRepr is None:
+            self.strRepr = "[" + _ustr(self.expr) + "]"
+
+        return self.strRepr
+
+class SkipTo(ParseElementEnhance):
+    """Token for skipping over all undefined text until the matched
+    expression is found.
+
+    Parameters:
+     - expr - target expression marking the end of the data to be skipped
+     - include - (default= ``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 = ParserElement._literalStringClass(failOn)
+        else:
+            self.failOn = failOn
+        self.errmsg = "No match found for "+_ustr(self.expr)
+
+    def parseImpl( self, instring, loc, doActions=True ):
+        startloc = loc
+        instrlen = len(instring)
+        expr = self.expr
+        expr_parse = self.expr._parse
+        self_failOn_canParseNext = self.failOn.canParseNext if self.failOn is not None else None
+        self_ignoreExpr_tryParse = self.ignoreExpr.tryParse if self.ignoreExpr is not None else None
+
+        tmploc = loc
+        while tmploc <= instrlen:
+            if self_failOn_canParseNext is not None:
+                # break if failOn expression matches
+                if self_failOn_canParseNext(instring, tmploc):
+                    break
+
+            if self_ignoreExpr_tryParse is not None:
+                # advance past ignore expressions
+                while 1:
+                    try:
+                        tmploc = self_ignoreExpr_tryParse(instring, tmploc)
+                    except ParseBaseException:
+                        break
+
+            try:
+                expr_parse(instring, tmploc, doActions=False, callPreParse=False)
+            except (ParseException, IndexError):
+                # no match, advance loc in string
+                tmploc += 1
+            else:
+                # matched skipto expr, done
+                break
+
+        else:
+            # ran off the end of the input string without matching skipto expr, fail
+            raise ParseException(instring, loc, self.errmsg, self)
+
+        # build up return values
+        loc = tmploc
+        skiptext = instring[startloc:loc]
+        skipresult = ParseResults(skiptext)
+
+        if self.includeMatch:
+            loc, mat = expr_parse(instring,loc,doActions,callPreParse=False)
+            skipresult += mat
+
+        return loc, skipresult
+
+class Forward(ParseElementEnhance):
+    """Forward declaration of an expression to be defined later -
+    used for recursive grammars, such as algebraic infix notation.
+    When the expression is known, it is assigned to the ``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 = ParserElement._literalStringClass(other)
+        self.expr = other
+        self.strRepr = None
+        self.mayIndexError = self.expr.mayIndexError
+        self.mayReturnEmpty = self.expr.mayReturnEmpty
+        self.setWhitespaceChars( self.expr.whiteChars )
+        self.skipWhitespace = self.expr.skipWhitespace
+        self.saveAsList = self.expr.saveAsList
+        self.ignoreExprs.extend(self.expr.ignoreExprs)
+        return self
+
+    def __ilshift__(self, other):
+        return self << other
+
+    def leaveWhitespace( self ):
+        self.skipWhitespace = False
+        return self
+
+    def streamline( self ):
+        if not self.streamlined:
+            self.streamlined = True
+            if self.expr is not None:
+                self.expr.streamline()
+        return self
+
+    def validate( self, validateTrace=[] ):
+        if self not in validateTrace:
+            tmp = validateTrace[:]+[self]
+            if self.expr is not None:
+                self.expr.validate(tmp)
+        self.checkRecursion([])
+
+    def __str__( self ):
+        if hasattr(self,"name"):
+            return self.name
+
+        # Avoid infinite recursion by setting a temporary name
+        self.name = self.__class__.__name__ + ": ..."
+
+        # Use the string representation of main expression.
+        try:
+            if self.expr is not None:
+                retString = _ustr(self.expr)
+            else:
+                retString = "None"
+        finally:
+            del self.name
+        return self.__class__.__name__ + ": " + retString
+
+    def copy(self):
+        if self.expr is not None:
+            return super(Forward,self).copy()
+        else:
+            ret = Forward()
+            ret <<= self
+            return ret
+
+class 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 ):
+    """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 if
+       creating a :class:`Regex` raises an exception)
+
+    Example::
+
+        comp_oper = oneOf("< = > <= >= !=")
+        var = Word(alphas)
+        number = Word(nums)
+        term = var | number
+        comparison_expr = term + comp_oper + term
+        print(comparison_expr.searchString("B = 12  AA=23 B<=AA AA>12"))
+
+    prints::
+
+        [['B', '=', '12'], ['AA', '=', '23'], ['B', '<=', 'AA'], ['AA', '>', '12']]
+    """
+    if caseless:
+        isequal = ( lambda a,b: a.upper() == b.upper() )
+        masks = ( lambda a,b: b.upper().startswith(a.upper()) )
+        parseElementClass = CaselessLiteral
+    else:
+        isequal = ( lambda a,b: a == b )
+        masks = ( lambda a,b: b.startswith(a) )
+        parseElementClass = Literal
+
+    symbols = []
+    if isinstance(strs,basestring):
+        symbols = strs.split()
+    elif isinstance(strs, Iterable):
+        symbols = list(strs)
+    else:
+        warnings.warn("Invalid argument to oneOf, expected string or iterable",
+                SyntaxWarning, stacklevel=2)
+    if not symbols:
+        return NoMatch()
+
+    i = 0
+    while i < len(symbols)-1:
+        cur = symbols[i]
+        for j,other in enumerate(symbols[i+1:]):
+            if ( isequal(other, cur) ):
+                del symbols[i+j+1]
+                break
+            elif ( masks(cur, other) ):
+                del symbols[i+j+1]
+                symbols.insert(i,other)
+                cur = other
+                break
+        else:
+            i += 1
+
+    if not caseless and useRegex:
+        #~ print (strs,"->", "|".join( [ _escapeRegexChars(sym) for sym in symbols] ))
+        try:
+            if len(symbols)==len("".join(symbols)):
+                return Regex( "[%s]" % "".join(_escapeRegexRangeChars(sym) for sym in symbols) ).setName(' | '.join(symbols))
+            else:
+                return Regex( "|".join(re.escape(sym) for sym in symbols) ).setName(' | '.join(symbols))
+        except Exception:
+            warnings.warn("Exception creating Regex for oneOf, building MatchFirst",
+                    SyntaxWarning, stacklevel=2)
+
+
+    # last resort, just use MatchFirst
+    return MatchFirst(parseElementClass(sym) for sym in symbols).setName(' | '.join(symbols))
+
+def dictOf( key, value ):
+    """Helper to easily and clearly define a dictionary by specifying
+    the respective patterns for the key and value.  Takes care of
+    defining the :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 + 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 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 < indentStack[-1] and curCol <= indentStack[-2]):
+            raise ParseException(s,l,"not an unindent")
+        indentStack.pop()
+
+    NL = OneOrMore(LineEnd().setWhitespaceChars("\t ").suppress())
+    INDENT = (Empty() + Empty().setParseAction(checkSubIndent)).setName('INDENT')
+    PEER   = Empty().setParseAction(checkPeerIndent).setName('')
+    UNDENT = Empty().setParseAction(checkUnindent).setName('UNINDENT')
+    if indent:
+        smExpr = Group( Optional(NL) +
+            #~ FollowedBy(blockStatementExpr) +
+            INDENT + (OneOrMore( PEER + Group(blockStatementExpr) + Optional(NL) )) + UNDENT)
+    else:
+        smExpr = Group( Optional(NL) +
+            (OneOrMore( PEER + Group(blockStatementExpr) + Optional(NL) )) )
+    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*').setName("real number").setParseAction(convertToFloat)
+    """expression that parses a floating point number and returns a float"""
+
+    sci_real = Regex(r'[+-]?\d+([eE][+-]?\d+|\.\d*([eE][+-]?\d+)?)').setName("real number with scientific notation").setParseAction(convertToFloat)
+    """expression that parses a floating point number with optional
+    scientific notation and returns a float"""
+
+    # streamlining this expression makes the docs nicer-looking
+    number = (sci_real | real | signed_integer).streamline()
+    """any numeric expression, returns the corresponding Python type"""
+
+    fnumber = Regex(r'[+-]?\d+\.?\d*([eE][+-]?\d+)?').setName("fnumber").setParseAction(convertToFloat)
+    """any int or real number, returned as float"""
+
+    identifier = Word(alphas+'_', alphanums+'_').setName("identifier")
+    """typical code identifier (leading alpha or '_', followed by 0 or more alphas, nums, or '_')"""
+
+    ipv4_address = Regex(r'(25[0-5]|2[0-4][0-9]|1?[0-9]{1,2})(\.(25[0-5]|2[0-4][0-9]|1?[0-9]{1,2})){3}').setName("IPv4 address")
+    "IPv4 address (``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, "العربية", pyparsing_unicode.Arabic)
+    setattr(pyparsing_unicode, "中文", pyparsing_unicode.Chinese)
+    setattr(pyparsing_unicode, "кириллица", pyparsing_unicode.Cyrillic)
+    setattr(pyparsing_unicode, "Ελληνικά", pyparsing_unicode.Greek)
+    setattr(pyparsing_unicode, "עִברִית", pyparsing_unicode.Hebrew)
+    setattr(pyparsing_unicode, "日本語", pyparsing_unicode.Japanese)
+    setattr(pyparsing_unicode.Japanese, "漢字", pyparsing_unicode.Japanese.Kanji)
+    setattr(pyparsing_unicode.Japanese, "カタカナ", pyparsing_unicode.Japanese.Katakana)
+    setattr(pyparsing_unicode.Japanese, "ひらがな", pyparsing_unicode.Japanese.Hiragana)
+    setattr(pyparsing_unicode, "한국어", pyparsing_unicode.Korean)
+    setattr(pyparsing_unicode, "ไทย", pyparsing_unicode.Thai)
+    setattr(pyparsing_unicode, "देवनागरी", pyparsing_unicode.Devanagari)
+
+
+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/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/pyparsing.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/pyparsing.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..b6eb2b06fefd55956548557988636d7bac06bc9e
GIT binary patch
literal 277107
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
QI};}}I};D1BqJvi0R89V^#A|>

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/pytoml/__init__.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/pytoml/__init__.py
new file mode 100644
index 0000000..8ed060f
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/pytoml/__init__.py
@@ -0,0 +1,4 @@
+from .core import TomlError
+from .parser import load, loads
+from .test import translate_to_test
+from .writer import dump, dumps
\ No newline at end of file
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/pytoml/__init__.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/pytoml/__init__.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..87d087d0c98151d9c0178e453be1b249b59b865e
GIT binary patch
literal 448
zcmZSn%**AGdLky70ScHH7#JKF7#NBJ7#J8*7#LC*8FCmHav2$-7#SErd?tn*CWc&Q
zhA3u+To#5X7KkV_Lk=rLE*nD>8-&loki*W9%fS%E!H~<z5XH&Bn8L~stii^>z>vwv
zz`&pZB1$+J7#KqGb8}pait>vzKvtKqFfcIW<R_+-utFKd5T$|)3=AbjiFw62i6yD=
zCHe6ssl_D-Eh(kB1z;^8MzNm;7f3nCtmOQn)F6=GN<elOBo-B?76pMU4}x0<GAW1|
zqyeO)yeP9IwI~RrHwfeg4UlF8QJlxXz@T4Hlv$QolB!>pSfrnppOcbWRIHzrqF<hr
zl$UFoTWn;QWS(A?ZeeOso|9E&W&i@|dHNyx1(^l9nR&$}i8(pCZe<>x#sMH9Fpe)v
z%}dEI(l4ki$<NKvkB`sH%PfhH*DI(j;b353u*uC&Da}c>13A4I<W2!bF-8GK06hs`
A1^@s6

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/pytoml/core.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/pytoml/core.py
new file mode 100644
index 0000000..c182734
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/pytoml/core.py
@@ -0,0 +1,13 @@
+class TomlError(RuntimeError):
+    def __init__(self, message, line, col, filename):
+        RuntimeError.__init__(self, message, line, col, filename)
+        self.message = message
+        self.line = line
+        self.col = col
+        self.filename = filename
+
+    def __str__(self):
+        return '{}({}, {}): {}'.format(self.filename, self.line, self.col, self.message)
+
+    def __repr__(self):
+        return 'TomlError({!r}, {!r}, {!r}, {!r})'.format(self.message, self.line, self.col, self.filename)
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/pytoml/core.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/pytoml/core.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..1cadc11131c7a59e9cf4c7a8188e9ddc07534e66
GIT binary patch
literal 1400
zcmZSn%**AGdLky70ScHI7#JKF7#NDB7#J8*7#LC+7}6LSQWzOp7#Nxv7$Tz>8B&-S
zf;B+uN;nx97(()Mb6ksx@{8a`FfuSOIDw2%W&rC4X<-2Ak79xv6vYfOq=kVYiiIHv
zVpcLM0|NsHvoSC*ID>RMGB7ZdFfe2>GSo0I)G#vCFfr6HGt{s!G_x`=g7^#!@l0S*
z28MWMup9$JJPSxg4Ff|wE6DZ18X(8`X@CqZ;bCB42rA7h$;?d!JGg{{fq@}DJ~J<~
zBtE``oq>TNH?_DpF+H_}g@J(~Co?a#1mw%){2Z{#w9K5;yu{p84Uj9rN{Ul+(t<!r
zf<PLAK;l6ln>0XS2_}lO7#JAz3yLz!5=&C`%My$9)ADmtQj3c9lT!4{lalgsO>>Kl
z43o^$tI{n@Ey{DUs>}>PAU#h%M86=jKsPh5xFj(rN7t>)!_znbBm~CsWvO{7`9=B#
zl_mMPIr_=@MX7oPl|f7l3=AM#%ms1+qa-6I7$$>40fa$L1P87XD0UecvKT;t3kl*Z
zCNP^BOtLUEvoHi}fXwnM=3`)BsIJwhuGLYfuGO?ssIG;C0m!du`9-;jC17tOg#sv0
zz(F4b3RZAXfC)N>2RKsW<BLm*;^R3%X$s^Y21W{lLlHUEYg8*1fx-oi)C7l65GaLV
zO(CGj7~rr0xh+1vD7By{J|2`ciXnjmb~re}$H#+`dwhHe7dW5f=BJeAq{hdC6Il=_
zID<eE;CMw4bdKR5a5@J?EhsUvF><nVGW&s(Z4fw!LDC4vfmw8RAvh>)Ac1EGa#JzL
FO#nZuI1~T?

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/pytoml/parser.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/pytoml/parser.py
new file mode 100644
index 0000000..3493aa6
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/pytoml/parser.py
@@ -0,0 +1,341 @@
+import string, re, sys, datetime
+from .core import TomlError
+from .utils import rfc3339_re, parse_rfc3339_re
+
+if sys.version_info[0] == 2:
+    _chr = unichr
+else:
+    _chr = chr
+
+def load(fin, translate=lambda t, x, v: v, object_pairs_hook=dict):
+    return loads(fin.read(), translate=translate, object_pairs_hook=object_pairs_hook, filename=getattr(fin, 'name', repr(fin)))
+
+def loads(s, filename='<string>', translate=lambda t, x, v: v, object_pairs_hook=dict):
+    if isinstance(s, bytes):
+        s = s.decode('utf-8')
+
+    s = s.replace('\r\n', '\n')
+
+    root = object_pairs_hook()
+    tables = object_pairs_hook()
+    scope = root
+
+    src = _Source(s, filename=filename)
+    ast = _p_toml(src, object_pairs_hook=object_pairs_hook)
+
+    def error(msg):
+        raise TomlError(msg, pos[0], pos[1], filename)
+
+    def process_value(v, object_pairs_hook):
+        kind, text, value, pos = v
+        if kind == 'str' and value.startswith('\n'):
+            value = value[1:]
+        if kind == 'array':
+            if value and any(k != value[0][0] for k, t, v, p in value[1:]):
+                error('array-type-mismatch')
+            value = [process_value(item, object_pairs_hook=object_pairs_hook) for item in value]
+        elif kind == 'table':
+            value = object_pairs_hook([(k, process_value(value[k], object_pairs_hook=object_pairs_hook)) for k in value])
+        return translate(kind, text, value)
+
+    for kind, value, pos in ast:
+        if kind == 'kv':
+            k, v = value
+            if k in scope:
+                error('duplicate_keys. Key "{0}" was used more than once.'.format(k))
+            scope[k] = process_value(v, object_pairs_hook=object_pairs_hook)
+        else:
+            is_table_array = (kind == 'table_array')
+            cur = tables
+            for name in value[:-1]:
+                if isinstance(cur.get(name), list):
+                    d, cur = cur[name][-1]
+                else:
+                    d, cur = cur.setdefault(name, (None, object_pairs_hook()))
+
+            scope = object_pairs_hook()
+            name = value[-1]
+            if name not in cur:
+                if is_table_array:
+                    cur[name] = [(scope, object_pairs_hook())]
+                else:
+                    cur[name] = (scope, object_pairs_hook())
+            elif isinstance(cur[name], list):
+                if not is_table_array:
+                    error('table_type_mismatch')
+                cur[name].append((scope, object_pairs_hook()))
+            else:
+                if is_table_array:
+                    error('table_type_mismatch')
+                old_scope, next_table = cur[name]
+                if old_scope is not None:
+                    error('duplicate_tables')
+                cur[name] = (scope, next_table)
+
+    def merge_tables(scope, tables):
+        if scope is None:
+            scope = object_pairs_hook()
+        for k in tables:
+            if k in scope:
+                error('key_table_conflict')
+            v = tables[k]
+            if isinstance(v, list):
+                scope[k] = [merge_tables(sc, tbl) for sc, tbl in v]
+            else:
+                scope[k] = merge_tables(v[0], v[1])
+        return scope
+
+    return merge_tables(root, tables)
+
+class _Source:
+    def __init__(self, s, filename=None):
+        self.s = s
+        self._pos = (1, 1)
+        self._last = None
+        self._filename = filename
+        self.backtrack_stack = []
+
+    def last(self):
+        return self._last
+
+    def pos(self):
+        return self._pos
+
+    def fail(self):
+        return self._expect(None)
+
+    def consume_dot(self):
+        if self.s:
+            self._last = self.s[0]
+            self.s = self[1:]
+            self._advance(self._last)
+            return self._last
+        return None
+
+    def expect_dot(self):
+        return self._expect(self.consume_dot())
+
+    def consume_eof(self):
+        if not self.s:
+            self._last = ''
+            return True
+        return False
+
+    def expect_eof(self):
+        return self._expect(self.consume_eof())
+
+    def consume(self, s):
+        if self.s.startswith(s):
+            self.s = self.s[len(s):]
+            self._last = s
+            self._advance(s)
+            return True
+        return False
+
+    def expect(self, s):
+        return self._expect(self.consume(s))
+
+    def consume_re(self, re):
+        m = re.match(self.s)
+        if m:
+            self.s = self.s[len(m.group(0)):]
+            self._last = m
+            self._advance(m.group(0))
+            return m
+        return None
+
+    def expect_re(self, re):
+        return self._expect(self.consume_re(re))
+
+    def __enter__(self):
+        self.backtrack_stack.append((self.s, self._pos))
+
+    def __exit__(self, type, value, traceback):
+        if type is None:
+            self.backtrack_stack.pop()
+        else:
+            self.s, self._pos = self.backtrack_stack.pop()
+        return type == TomlError
+
+    def commit(self):
+        self.backtrack_stack[-1] = (self.s, self._pos)
+
+    def _expect(self, r):
+        if not r:
+            raise TomlError('msg', self._pos[0], self._pos[1], self._filename)
+        return r
+
+    def _advance(self, s):
+        suffix_pos = s.rfind('\n')
+        if suffix_pos == -1:
+            self._pos = (self._pos[0], self._pos[1] + len(s))
+        else:
+            self._pos = (self._pos[0] + s.count('\n'), len(s) - suffix_pos)
+
+_ews_re = re.compile(r'(?:[ \t]|#[^\n]*\n|#[^\n]*\Z|\n)*')
+def _p_ews(s):
+    s.expect_re(_ews_re)
+
+_ws_re = re.compile(r'[ \t]*')
+def _p_ws(s):
+    s.expect_re(_ws_re)
+
+_escapes = { 'b': '\b', 'n': '\n', 'r': '\r', 't': '\t', '"': '"',
+    '\\': '\\', 'f': '\f' }
+
+_basicstr_re = re.compile(r'[^"\\\000-\037]*')
+_short_uni_re = re.compile(r'u([0-9a-fA-F]{4})')
+_long_uni_re = re.compile(r'U([0-9a-fA-F]{8})')
+_escapes_re = re.compile(r'[btnfr\"\\]')
+_newline_esc_re = re.compile('\n[ \t\n]*')
+def _p_basicstr_content(s, content=_basicstr_re):
+    res = []
+    while True:
+        res.append(s.expect_re(content).group(0))
+        if not s.consume('\\'):
+            break
+        if s.consume_re(_newline_esc_re):
+            pass
+        elif s.consume_re(_short_uni_re) or s.consume_re(_long_uni_re):
+            v = int(s.last().group(1), 16)
+            if 0xd800 <= v < 0xe000:
+                s.fail()
+            res.append(_chr(v))
+        else:
+            s.expect_re(_escapes_re)
+            res.append(_escapes[s.last().group(0)])
+    return ''.join(res)
+
+_key_re = re.compile(r'[0-9a-zA-Z-_]+')
+def _p_key(s):
+    with s:
+        s.expect('"')
+        r = _p_basicstr_content(s, _basicstr_re)
+        s.expect('"')
+        return r
+    if s.consume('\''):
+        if s.consume('\'\''):
+            r = s.expect_re(_litstr_ml_re).group(0)
+            s.expect('\'\'\'')
+        else:
+            r = s.expect_re(_litstr_re).group(0)
+            s.expect('\'')
+        return r
+    return s.expect_re(_key_re).group(0)
+
+_float_re = re.compile(r'[+-]?(?:0|[1-9](?:_?\d)*)(?:\.\d(?:_?\d)*)?(?:[eE][+-]?(?:\d(?:_?\d)*))?')
+
+_basicstr_ml_re = re.compile(r'(?:""?(?!")|[^"\\\000-\011\013-\037])*')
+_litstr_re = re.compile(r"[^'\000\010\012-\037]*")
+_litstr_ml_re = re.compile(r"(?:(?:|'|'')(?:[^'\000-\010\013-\037]))*")
+def _p_value(s, object_pairs_hook):
+    pos = s.pos()
+
+    if s.consume('true'):
+        return 'bool', s.last(), True, pos
+    if s.consume('false'):
+        return 'bool', s.last(), False, pos
+
+    if s.consume('"'):
+        if s.consume('""'):
+            r = _p_basicstr_content(s, _basicstr_ml_re)
+            s.expect('"""')
+        else:
+            r = _p_basicstr_content(s, _basicstr_re)
+            s.expect('"')
+        return 'str', r, r, pos
+
+    if s.consume('\''):
+        if s.consume('\'\''):
+            r = s.expect_re(_litstr_ml_re).group(0)
+            s.expect('\'\'\'')
+        else:
+            r = s.expect_re(_litstr_re).group(0)
+            s.expect('\'')
+        return 'str', r, r, pos
+
+    if s.consume_re(rfc3339_re):
+        m = s.last()
+        return 'datetime', m.group(0), parse_rfc3339_re(m), pos
+
+    if s.consume_re(_float_re):
+        m = s.last().group(0)
+        r = m.replace('_','')
+        if '.' in m or 'e' in m or 'E' in m:
+            return 'float', m, float(r), pos
+        else:
+            return 'int', m, int(r, 10), pos
+
+    if s.consume('['):
+        items = []
+        with s:
+            while True:
+                _p_ews(s)
+                items.append(_p_value(s, object_pairs_hook=object_pairs_hook))
+                s.commit()
+                _p_ews(s)
+                s.expect(',')
+                s.commit()
+        _p_ews(s)
+        s.expect(']')
+        return 'array', None, items, pos
+
+    if s.consume('{'):
+        _p_ws(s)
+        items = object_pairs_hook()
+        if not s.consume('}'):
+            k = _p_key(s)
+            _p_ws(s)
+            s.expect('=')
+            _p_ws(s)
+            items[k] = _p_value(s, object_pairs_hook=object_pairs_hook)
+            _p_ws(s)
+            while s.consume(','):
+                _p_ws(s)
+                k = _p_key(s)
+                _p_ws(s)
+                s.expect('=')
+                _p_ws(s)
+                items[k] = _p_value(s, object_pairs_hook=object_pairs_hook)
+                _p_ws(s)
+            s.expect('}')
+        return 'table', None, items, pos
+
+    s.fail()
+
+def _p_stmt(s, object_pairs_hook):
+    pos = s.pos()
+    if s.consume(   '['):
+        is_array = s.consume('[')
+        _p_ws(s)
+        keys = [_p_key(s)]
+        _p_ws(s)
+        while s.consume('.'):
+            _p_ws(s)
+            keys.append(_p_key(s))
+            _p_ws(s)
+        s.expect(']')
+        if is_array:
+            s.expect(']')
+        return 'table_array' if is_array else 'table', keys, pos
+
+    key = _p_key(s)
+    _p_ws(s)
+    s.expect('=')
+    _p_ws(s)
+    value = _p_value(s, object_pairs_hook=object_pairs_hook)
+    return 'kv', (key, value), pos
+
+_stmtsep_re = re.compile(r'(?:[ \t]*(?:#[^\n]*)?\n)+[ \t]*')
+def _p_toml(s, object_pairs_hook):
+    stmts = []
+    _p_ews(s)
+    with s:
+        stmts.append(_p_stmt(s, object_pairs_hook=object_pairs_hook))
+        while True:
+            s.commit()
+            s.expect_re(_stmtsep_re)
+            stmts.append(_p_stmt(s, object_pairs_hook=object_pairs_hook))
+    _p_ews(s)
+    s.expect_eof()
+    return stmts
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/pytoml/parser.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/pytoml/parser.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..b5c407ef80b7404ae2c7dc68ed1d49ecee4d1803
GIT binary patch
literal 14699
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

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/pytoml/test.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/pytoml/test.py
new file mode 100644
index 0000000..ec8abfc
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/pytoml/test.py
@@ -0,0 +1,30 @@
+import datetime
+from .utils import format_rfc3339
+
+try:
+    _string_types = (str, unicode)
+    _int_types = (int, long)
+except NameError:
+    _string_types = str
+    _int_types = int
+
+def translate_to_test(v):
+    if isinstance(v, dict):
+        return { k: translate_to_test(v) for k, v in v.items() }
+    if isinstance(v, list):
+        a = [translate_to_test(x) for x in v]
+        if v and isinstance(v[0], dict):
+            return a
+        else:
+            return {'type': 'array', 'value': a}
+    if isinstance(v, datetime.datetime):
+        return {'type': 'datetime', 'value': format_rfc3339(v)}
+    if isinstance(v, bool):
+        return {'type': 'bool', 'value': 'true' if v else 'false'}
+    if isinstance(v, _int_types):
+        return {'type': 'integer', 'value': str(v)}
+    if isinstance(v, float):
+        return {'type': 'float', 'value': '{:.17}'.format(v)}
+    if isinstance(v, _string_types):
+        return {'type': 'string', 'value': v}
+    raise RuntimeError('unexpected value: {!r}'.format(v))
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/pytoml/test.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/pytoml/test.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..48dfd68b401691952110aa4976736bc7c82201df
GIT binary patch
literal 1551
zcmZSn%**AGdLky70SZ_d7#JKF7#NCE85kH+7#LC*8FCmHq8J!bm>5!+8FCmIa+w&S
zm>3u<Wf)SK8B$po(wG>cSQ%2;7*g56Yz~I-JXr>oR8EF$E{39T21Z84RA#7>C=P}^
zMuvzK7KRoEhA1wO>A@NxD>MK9|Nq}FlaYaeK?6jT@G&qjq~#aoCYHn(r6n618(SuW
z#F-fw7+4q>7@WaQWMp6{VPL3XU?^c^Xl7z4QU)2=0v5?)VrXVyaA{^_2!<+Q1}kZ1
zNC(Ti#0oLgGBT8~Fw`(IG&3^9F)<WcGSo7GOe@NR8k@qzAPF@(kD-Q%AvhBp2q`QK
zW;IL<DXa`;!Fg~eurg$^f~{D~08+-r08&=M1~Raj5uzCC5_Yh%TVQ4EU}ZH73`Lh1
zQaBj$m>E(yQ51846*Dq|%;W+qF5$#tCKp(lHdq-qSXl}WLl!p{l{{dTK46u+V3jot
zP#bv}Quq*>ni(0I7(r<uSc9K|fx!<Y0)jyipvu6&kO>aXSZRhBCQyLZGJ(U62^6L^
zj0}^R7z)`Kf;B*?3lgz{3=9k<MTvREIf*5y@g@23C8@<F8lZSBVParl&@(6j#d9{8
zEQ9C+X)exUU|`TMD9S8LEJ@WbODxh)%g;$kEh^SeO3^P*O3KSM%`G-EOfpZeO1Chz
zD9_2NGBW^y^gR6#{esK_-ORk=lEj=GUAHn1PvZcP5E#dorRJsN7wH#NmgMK==!0CN
zS5R5Z#lXN|laiTSlANDgV8;vcEy#JCApbHjlz`G~Vo_0IWeF%XmQ)s`f`!Twb4pW7
zI6zq^u_U!5GdC41pOl}U17?&Il|mGzCFT^Tmav1uFRvsuJ+%m|JuN3cv80%dfq|jg
zO3%=|wgkj1E-A{)OD`5<U|=ZCORXqKO)g1IQ2^UyrBJO{RI9-U3Q~}RGmF8V%u9w?
z3vxc#+{}{H++wf;ax#lcf<OTr1af2$C}e{;VcO#}^Gf1Dekm>i#Yb^TQ4q-EU{^r$
zVhM;J4{;GxB@Y7wLr`fR$gi$NMfpYGs0;#!3do)ca6~2!SVV$7%MFS?6_95c`58qR
z`5EOIB^g<mL>Yw`B^db`<rw+Fv@|0>qY$G8NHsWkz+qQfl9^Ks2`CXzK!M_{G%qtb
zKP5E?6er-I%FHW)1aE#`dXO+k87NTw5_40*VFGppA_%}NIwxpwqO{4)PbtkwwF5;=
Zu>b=D0}rDB6Eh<ZqW~i>BO4<Z697KUOVt1X

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/pytoml/utils.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/pytoml/utils.py
new file mode 100644
index 0000000..636a680
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/pytoml/utils.py
@@ -0,0 +1,67 @@
+import datetime
+import re
+
+rfc3339_re = re.compile(r'(\d{4})-(\d{2})-(\d{2})T(\d{2}):(\d{2}):(\d{2})(\.\d+)?(?:Z|([+-]\d{2}):(\d{2}))')
+
+def parse_rfc3339(v):
+    m = rfc3339_re.match(v)
+    if not m or m.group(0) != v:
+        return None
+    return parse_rfc3339_re(m)
+
+def parse_rfc3339_re(m):
+    r = map(int, m.groups()[:6])
+    if m.group(7):
+        micro = float(m.group(7))
+    else:
+        micro = 0
+
+    if m.group(8):
+        g = int(m.group(8), 10) * 60 + int(m.group(9), 10)
+        tz = _TimeZone(datetime.timedelta(0, g * 60))
+    else:
+        tz = _TimeZone(datetime.timedelta(0, 0))
+
+    y, m, d, H, M, S = r
+    return datetime.datetime(y, m, d, H, M, S, int(micro * 1000000), tz)
+
+
+def format_rfc3339(v):
+    offs = v.utcoffset()
+    offs = int(offs.total_seconds()) // 60 if offs is not None else 0
+
+    if offs == 0:
+        suffix = 'Z'
+    else:
+        if offs > 0:
+            suffix = '+'
+        else:
+            suffix = '-'
+            offs = -offs
+        suffix = '{0}{1:02}:{2:02}'.format(suffix, offs // 60, offs % 60)
+
+    if v.microsecond:
+        return v.strftime('%Y-%m-%dT%H:%M:%S.%f') + suffix
+    else:
+        return v.strftime('%Y-%m-%dT%H:%M:%S') + suffix
+
+class _TimeZone(datetime.tzinfo):
+    def __init__(self, offset):
+        self._offset = offset
+
+    def utcoffset(self, dt):
+        return self._offset
+
+    def dst(self, dt):
+        return None
+
+    def tzname(self, dt):
+        m = self._offset.total_seconds() // 60
+        if m < 0:
+            res = '-'
+            m = -m
+        else:
+            res = '+'
+        h = m // 60
+        m = m - h * 60
+        return '{}{:.02}{:.02}'.format(res, h, m)
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/pytoml/utils.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/pytoml/utils.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..c091cf3db727f794930ad2fcae1c1f64cde9fb0f
GIT binary patch
literal 3298
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

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/pytoml/writer.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/pytoml/writer.py
new file mode 100644
index 0000000..73b5089
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/pytoml/writer.py
@@ -0,0 +1,106 @@
+from __future__ import unicode_literals
+import io, datetime, math, string, sys
+
+from .utils import format_rfc3339
+
+if sys.version_info[0] == 3:
+    long = int
+    unicode = str
+
+
+def dumps(obj, sort_keys=False):
+    fout = io.StringIO()
+    dump(obj, fout, sort_keys=sort_keys)
+    return fout.getvalue()
+
+
+_escapes = {'\n': 'n', '\r': 'r', '\\': '\\', '\t': 't', '\b': 'b', '\f': 'f', '"': '"'}
+
+
+def _escape_string(s):
+    res = []
+    start = 0
+
+    def flush():
+        if start != i:
+            res.append(s[start:i])
+        return i + 1
+
+    i = 0
+    while i < len(s):
+        c = s[i]
+        if c in '"\\\n\r\t\b\f':
+            start = flush()
+            res.append('\\' + _escapes[c])
+        elif ord(c) < 0x20:
+            start = flush()
+            res.append('\\u%04x' % ord(c))
+        i += 1
+
+    flush()
+    return '"' + ''.join(res) + '"'
+
+
+_key_chars = string.digits + string.ascii_letters + '-_'
+def _escape_id(s):
+    if any(c not in _key_chars for c in s):
+        return _escape_string(s)
+    return s
+
+
+def _format_value(v):
+    if isinstance(v, bool):
+        return 'true' if v else 'false'
+    if isinstance(v, int) or isinstance(v, long):
+        return unicode(v)
+    if isinstance(v, float):
+        if math.isnan(v) or math.isinf(v):
+            raise ValueError("{0} is not a valid TOML value".format(v))
+        else:
+            return repr(v)
+    elif isinstance(v, unicode) or isinstance(v, bytes):
+        return _escape_string(v)
+    elif isinstance(v, datetime.datetime):
+        return format_rfc3339(v)
+    elif isinstance(v, list):
+        return '[{0}]'.format(', '.join(_format_value(obj) for obj in v))
+    elif isinstance(v, dict):
+        return '{{{0}}}'.format(', '.join('{} = {}'.format(_escape_id(k), _format_value(obj)) for k, obj in v.items()))
+    else:
+        raise RuntimeError(v)
+
+
+def dump(obj, fout, sort_keys=False):
+    tables = [((), obj, False)]
+
+    while tables:
+        name, table, is_array = tables.pop()
+        if name:
+            section_name = '.'.join(_escape_id(c) for c in name)
+            if is_array:
+                fout.write('[[{0}]]\n'.format(section_name))
+            else:
+                fout.write('[{0}]\n'.format(section_name))
+
+        table_keys = sorted(table.keys()) if sort_keys else table.keys()
+        new_tables = []
+        has_kv = False
+        for k in table_keys:
+            v = table[k]
+            if isinstance(v, dict):
+                new_tables.append((name + (k,), v, False))
+            elif isinstance(v, list) and v and all(isinstance(o, dict) for o in v):
+                new_tables.extend((name + (k,), d, True) for d in v)
+            elif v is None:
+                # based on mojombo's comment: https://github.com/toml-lang/toml/issues/146#issuecomment-25019344
+                fout.write(
+                    '#{} = null  # To use: uncomment and replace null with value\n'.format(_escape_id(k)))
+                has_kv = True
+            else:
+                fout.write('{0} = {1}\n'.format(_escape_id(k), _format_value(v)))
+                has_kv = True
+
+        tables.extend(reversed(new_tables))
+
+        if (name or has_kv) and tables:
+            fout.write('\n')
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/pytoml/writer.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/pytoml/writer.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..a1caa60f92df185ca81fb6222c9d8eee1e8e38f4
GIT binary patch
literal 5606
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
W%*e*b$;`uM&dezx!pO<SDFy)8%cWZY

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/requests/__init__.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/requests/__init__.py
new file mode 100644
index 0000000..80c4ce1
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/requests/__init__.py
@@ -0,0 +1,133 @@
+# -*- coding: utf-8 -*-
+
+#   __
+#  /__)  _  _     _   _ _/   _
+# / (   (- (/ (/ (- _)  /  _)
+#          /
+
+"""
+Requests HTTP Library
+~~~~~~~~~~~~~~~~~~~~~
+
+Requests is an HTTP library, written in Python, for human beings. Basic GET
+usage:
+
+   >>> import requests
+   >>> r = requests.get('https://www.python.org')
+   >>> r.status_code
+   200
+   >>> 'Python is a programming language' in r.content
+   True
+
+... or POST:
+
+   >>> payload = dict(key1='value1', key2='value2')
+   >>> r = requests.post('https://httpbin.org/post', data=payload)
+   >>> print(r.text)
+   {
+     ...
+     "form": {
+       "key2": "value2",
+       "key1": "value1"
+     },
+     ...
+   }
+
+The other HTTP methods are supported - see `requests.api`. Full documentation
+is at <http://python-requests.org>.
+
+:copyright: (c) 2017 by Kenneth Reitz.
+:license: Apache 2.0, see LICENSE for more details.
+"""
+
+from pip._vendor import urllib3
+from pip._vendor import chardet
+import warnings
+from .exceptions import RequestsDependencyWarning
+
+
+def check_compatibility(urllib3_version, chardet_version):
+    urllib3_version = urllib3_version.split('.')
+    assert urllib3_version != ['dev']  # Verify urllib3 isn't installed from git.
+
+    # Sometimes, urllib3 only reports its version as 16.1.
+    if len(urllib3_version) == 2:
+        urllib3_version.append('0')
+
+    # Check urllib3 for compatibility.
+    major, minor, patch = urllib3_version  # noqa: F811
+    major, minor, patch = int(major), int(minor), int(patch)
+    # urllib3 >= 1.21.1, <= 1.24
+    assert major == 1
+    assert minor >= 21
+    assert minor <= 24
+
+    # Check chardet for compatibility.
+    major, minor, patch = chardet_version.split('.')[:3]
+    major, minor, patch = int(major), int(minor), int(patch)
+    # chardet >= 3.0.2, < 3.1.0
+    assert major == 3
+    assert minor < 1
+    assert patch >= 2
+
+
+def _check_cryptography(cryptography_version):
+    # cryptography < 1.3.4
+    try:
+        cryptography_version = list(map(int, cryptography_version.split('.')))
+    except ValueError:
+        return
+
+    if cryptography_version < [1, 3, 4]:
+        warning = 'Old version of cryptography ({}) may cause slowdown.'.format(cryptography_version)
+        warnings.warn(warning, RequestsDependencyWarning)
+
+# Check imported dependencies for compatibility.
+try:
+    check_compatibility(urllib3.__version__, chardet.__version__)
+except (AssertionError, ValueError):
+    warnings.warn("urllib3 ({}) or chardet ({}) doesn't match a supported "
+                  "version!".format(urllib3.__version__, chardet.__version__),
+                  RequestsDependencyWarning)
+
+# Attempt to enable urllib3's SNI support, if possible
+from pip._internal.utils.compat import WINDOWS
+if not WINDOWS:
+    try:
+        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
+)
+
+# Set default logging handler to avoid "No handler found" warnings.
+import logging
+from logging import NullHandler
+
+logging.getLogger(__name__).addHandler(NullHandler())
+
+# FileModeWarnings go off per the default.
+warnings.simplefilter('default', FileModeWarning, append=True)
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/requests/__init__.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/requests/__init__.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..0398050f445f1fe4ef50d1e24d41ccfa14f2131b
GIT binary patch
literal 4332
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
Yih=dWFj_H+F$yp`u=6kqFiA240PAo27XSbN

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/requests/__version__.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/requests/__version__.py
new file mode 100644
index 0000000..f5b5d03
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/requests/__version__.py
@@ -0,0 +1,14 @@
+# .-. .-. .-. . . .-. .-. .-. .-.
+# |(  |-  |.| | | |-  `-.  |  `-.
+# ' ' `-' `-`.`-' `-' `-'  '  `-'
+
+__title__ = 'requests'
+__description__ = 'Python HTTP for Humans.'
+__url__ = 'http://python-requests.org'
+__version__ = '2.21.0'
+__build__ = 0x022100
+__author__ = 'Kenneth Reitz'
+__author_email__ = 'me@kennethreitz.org'
+__license__ = 'Apache 2.0'
+__copyright__ = 'Copyright 2018 Kenneth Reitz'
+__cake__ = u'\u2728 \U0001f370 \u2728'
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/requests/__version__.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/requests/__version__.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..e6fff2911b50fab71bebec1e3ac1e1ca1c7ee3dd
GIT binary patch
literal 634
zcmZSn%**AGdLky70SXuy7#JKF7#NB{L<$2#6azyFBSRD;Lkbf^6ca-VGeZ<JLkbH+
z6bnNND?=13Lkb&16dOYdJ3|yZLkb5&6bC~JCqon`Lkbr|um(2+149W10|P@*YGG+=
zaY=EpI0FMiKxIirex8CyNJxM}T7Hp&M`><iUa?-W6axc8MoCG5mA-xfScxu7n_hlV
zdNCUV1A~#Ck)fVJCW9gqLoqJ{1A}*JUS4WRhC)zkW=U1CFarZaZmL5zM6d`X2G+^N
zz`)>GkeHm2s$isNP%Oj1z~G!;P+63jo>8J;WMF8afMQN54+8_kqd6-SKFsgkpzvtU
z3O@~y2_>8i3=Hw{C7C5Tsqyh8{9s;6YH@N=W<g12eqMZh2|HM<v?wP&z69j=`1rEa
zqGE^~M0ZkYW==|cd<n?F`1r)ql8pSK`1le5utq31H8(L6VM0!3a%x^N$VQNd<KvTI
zE{~4~2W@<Oa$<IBe7puI1`$MYF#`jGenC-YSz<}5epzCXep-G`N@`KDeo~5lc~Vkd
zu4!(ukztZ~dR4lGsYQ8CR+X6n2&Cufhv*k%7U*W?6_+ID<mkGUd3YKJfP}y}zAQB_
mCBH}?7B~7xp42O-1iQ&5H$SB`C)JJ>l#+xP7#P?X(IEgr{He?U

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/requests/_internal_utils.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/requests/_internal_utils.py
new file mode 100644
index 0000000..759d9a5
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/requests/_internal_utils.py
@@ -0,0 +1,42 @@
+# -*- coding: utf-8 -*-
+
+"""
+requests._internal_utils
+~~~~~~~~~~~~~~
+
+Provides utility functions that are consumed internally by Requests
+which depend on extremely few external helpers (such as compat)
+"""
+
+from .compat import is_py2, builtin_str, str
+
+
+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.
+    """
+    if isinstance(string, builtin_str):
+        out = string
+    else:
+        if is_py2:
+            out = string.encode(encoding)
+        else:
+            out = string.decode(encoding)
+
+    return out
+
+
+def unicode_is_ascii(u_string):
+    """Determine if unicode string only contains ASCII characters.
+
+    :param str u_string: unicode string to check. Must be unicode
+        and not Python 2 `str`.
+    :rtype: bool
+    """
+    assert isinstance(u_string, str)
+    try:
+        u_string.encode('ascii')
+        return True
+    except UnicodeEncodeError:
+        return False
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/requests/_internal_utils.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/requests/_internal_utils.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..65903f3b630a1f680cd4efd738c0f9a72e731f8e
GIT binary patch
literal 1676
zcmZSn%**AGdLky70ScHH7#JKF7#NDJ85kH+7#N}$7*ZG+QkWQW7#VVz7^0XMa+w*T
zm>F_e7@}Ah7*m)TQdk&T7#X5i8B$moS{N9j*cejS7=ks}L58ejU|`@XN-Zo+EiNh6
zi_gp}NiE7t%!w~8$;>I{szU)>TmeP-Wtl0d#R?$l%#uolw9>rflFa<PVug~7#1e(X
zqEv<C{Ji4Q+|(2Wm{~cM3Q3g;K~Oum$}=*PGZa!%3sUn^6!P;FQY%V|Qgc&tDizXF
z%RxM_0~9h+a|%+6iWM}9OOrDc5{ng*^K%OlOEkGM85tNDG?*C}7)sa}7#K2(;|nT{
zO1K#q7?Mgeb4oJv;)_d)N<i`;nw5cpA+b0)Gcy?!ZXi(*b_RJJM3gWv)G#oVFfueV
zF%(IF*tJXydFl)$ObkT^AZ`{jLk%NCGa~~?oF6R0f)J@;VhGj%xu^Iv0|SG5W?5>U
zLZU)(Nl|8Ax<Y<ZR%&vIjzUptdSX#ZPHJ(nLVlV;No7GQNUWr^D6d!{QK2ZcpeVIC
zHLoNQ6pjk{X<P~l3Xsr*nv<EQP?C|Vke67JS(XYj9AZprUUGg4$gae^6or&jD5pFl
zwI~&AOkQeoYH@L5QKg<jNJeI{LSiu}YKj#cgPlD+6-x8Kjw;E|Nm0lz$w)0K&n!;W
z18dX(g<A<1ID9knic1pnl2d~~9t{GeLU6!??M?+V!8WHN;soOG5)K9i2C%BkymWAc
z<d>Fcfb@fj;&KKC2K|Df%(BFiRQ<BVBK@@doRrj}V*R8P{qm%wyj;`VVk5&O^Yp58
z3sZ~ooUAG{0}x2h(+|-v$SlwWJ1i$h*R9OM(>MSm1jg}Ysd*{+Mf$K*t&f(f^$IFW
z1VG6rKOPdMpahedm(B-D6g(jJvGOx=GO;lVG4V4cgFFqwpa21-m|_rtoNS6kL8+yQ
zk)cu)oIIF8*|C|Cfw6>zAviowh=HYql_8spp~#Mbk&&^4jUhN91(a++>9BYU0|SFg
zYDsEQZf0JpLS~vmX<lY>ehNIA^Yd~lK{=`<F*6SqZOIvlMTyBJsYS(lT;RyEDo89!
z%mt+kg;J<rtk4ZA$yZ3uNKMYxQ}8V<E>TEIg((1=07`P8B$St5q7YD7l98XMV5E>x
zTvC((Ne)&;p!8;?kd&XF1J)1(a=jn82nk|gU|<LW<*pJ?2s#!Qrxt;dvTIRMeo+u8
z*h)YuLW)XLON1C07(yXFbOj~dRIs8FkRrFloZ?h)UIM2Zm`A`#1xyThdVxkwd}eVx
zxI~eIrx$inMrKA{Mh-?^Mo5^HfXdeR_>}zQ_;_#*ffQcg%mc|rpzsO;<*y)6QUrSt
fK@6x@LAll@H$SB`C)JJ<<V8>^%f=+b%p(8*eUZr@

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/requests/adapters.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/requests/adapters.py
new file mode 100644
index 0000000..c30e7c9
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/requests/adapters.py
@@ -0,0 +1,533 @@
+# -*- coding: utf-8 -*-
+
+"""
+requests.adapters
+~~~~~~~~~~~~~~~~~
+
+This module contains the transport adapters that Requests uses to define
+and maintain connections.
+"""
+
+import os.path
+import socket
+
+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 HTTPError as _HTTPError
+from pip._vendor.urllib3.exceptions import MaxRetryError
+from pip._vendor.urllib3.exceptions import NewConnectionError
+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 SSLError as _SSLError
+from pip._vendor.urllib3.exceptions import ResponseError
+from pip._vendor.urllib3.exceptions import LocationValueError
+
+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
+
+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):
+    """The Base Transport Adapter"""
+
+    def __init__(self):
+        super(BaseAdapter, self).__init__()
+
+    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.
+        :param stream: (optional) Whether to stream the request content.
+        :param timeout: (optional) How long to wait for the server to send
+            data before giving up, as a float, or a :ref:`(connect timeout,
+            read timeout) <timeouts>` tuple.
+        :type timeout: float or tuple
+        :param verify: (optional) Either a boolean, in which case it controls whether we verify
+            the server's TLS certificate, or a string, in which case it must be a path
+            to a CA bundle to use
+        :param cert: (optional) Any user-provided SSL certificate to be trusted.
+        :param proxies: (optional) The proxies dictionary to apply to the request.
+        """
+        raise NotImplementedError
+
+    def close(self):
+        """Cleans up adapter specific items."""
+        raise NotImplementedError
+
+
+class HTTPAdapter(BaseAdapter):
+    """The built-in HTTP Adapter for urllib3.
+
+    Provides a general-case interface for Requests sessions to contact HTTP and
+    HTTPS urls by implementing the Transport Adapter interface. This class will
+    usually be created by the :class:`Session <Session>` class under the
+    covers.
+
+    :param pool_connections: The number of urllib3 connection pools to cache.
+    :param pool_maxsize: The maximum number of connections to save in the pool.
+    :param max_retries: The maximum number of retries each connection
+        should attempt. Note, this applies only to failed DNS lookups, socket
+        connections and connection timeouts, never to requests where data has
+        made it to the server. By default, Requests does not retry failed
+        connections. If you need granular control over the conditions under
+        which we retry a request, import urllib3's ``Retry`` class and pass
+        that instead.
+    :param pool_block: Whether the connection pool should block for connections.
+
+    Usage::
+
+      >>> import requests
+      >>> s = requests.Session()
+      >>> a = requests.adapters.HTTPAdapter(max_retries=3)
+      >>> s.mount('http://', a)
+    """
+    __attrs__ = ['max_retries', 'config', '_pool_connections', '_pool_maxsize',
+                 '_pool_block']
+
+    def __init__(self, pool_connections=DEFAULT_POOLSIZE,
+                 pool_maxsize=DEFAULT_POOLSIZE, max_retries=DEFAULT_RETRIES,
+                 pool_block=DEFAULT_POOLBLOCK):
+        if max_retries == DEFAULT_RETRIES:
+            self.max_retries = Retry(0, read=False)
+        else:
+            self.max_retries = Retry.from_int(max_retries)
+        self.config = {}
+        self.proxy_manager = {}
+
+        super(HTTPAdapter, self).__init__()
+
+        self._pool_connections = pool_connections
+        self._pool_maxsize = pool_maxsize
+        self._pool_block = pool_block
+
+        self.init_poolmanager(pool_connections, pool_maxsize, block=pool_block)
+
+    def __getstate__(self):
+        return {attr: getattr(self, attr, None) for attr in self.__attrs__}
+
+    def __setstate__(self, state):
+        # Can't handle by adding 'proxy_manager' to self.__attrs__ because
+        # self.poolmanager uses a lambda function, which isn't pickleable.
+        self.proxy_manager = {}
+        self.config = {}
+
+        for attr, value in state.items():
+            setattr(self, attr, value)
+
+        self.init_poolmanager(self._pool_connections, self._pool_maxsize,
+                              block=self._pool_block)
+
+    def init_poolmanager(self, connections, maxsize, block=DEFAULT_POOLBLOCK, **pool_kwargs):
+        """Initializes a urllib3 PoolManager.
+
+        This method should not be called from user code, and is only
+        exposed for use when subclassing the
+        :class:`HTTPAdapter <requests.adapters.HTTPAdapter>`.
+
+        :param connections: The number of urllib3 connection pools to cache.
+        :param maxsize: The maximum number of connections to save in the pool.
+        :param block: Block when no free connections are available.
+        :param pool_kwargs: Extra keyword arguments used to initialize the Pool Manager.
+        """
+        # save these values for pickling
+        self._pool_connections = connections
+        self._pool_maxsize = maxsize
+        self._pool_block = block
+
+        self.poolmanager = PoolManager(num_pools=connections, maxsize=maxsize,
+                                       block=block, strict=True, **pool_kwargs)
+
+    def proxy_manager_for(self, proxy, **proxy_kwargs):
+        """Return urllib3 ProxyManager for the given proxy.
+
+        This method should not be called from user code, and is only
+        exposed for use when subclassing the
+        :class:`HTTPAdapter <requests.adapters.HTTPAdapter>`.
+
+        :param proxy: The proxy to return a urllib3 ProxyManager for.
+        :param proxy_kwargs: Extra keyword arguments used to configure the Proxy Manager.
+        :returns: ProxyManager
+        :rtype: urllib3.ProxyManager
+        """
+        if proxy in self.proxy_manager:
+            manager = self.proxy_manager[proxy]
+        elif proxy.lower().startswith('socks'):
+            username, password = get_auth_from_url(proxy)
+            manager = self.proxy_manager[proxy] = SOCKSProxyManager(
+                proxy,
+                username=username,
+                password=password,
+                num_pools=self._pool_connections,
+                maxsize=self._pool_maxsize,
+                block=self._pool_block,
+                **proxy_kwargs
+            )
+        else:
+            proxy_headers = self.proxy_headers(proxy)
+            manager = self.proxy_manager[proxy] = proxy_from_url(
+                proxy,
+                proxy_headers=proxy_headers,
+                num_pools=self._pool_connections,
+                maxsize=self._pool_maxsize,
+                block=self._pool_block,
+                **proxy_kwargs)
+
+        return manager
+
+    def cert_verify(self, conn, url, verify, cert):
+        """Verify a SSL certificate. This method should not be called from user
+        code, and is only exposed for use when subclassing the
+        :class:`HTTPAdapter <requests.adapters.HTTPAdapter>`.
+
+        :param conn: The urllib3 connection object associated with the cert.
+        :param url: The requested URL.
+        :param verify: Either a boolean, in which case it controls whether we verify
+            the server's TLS certificate, or a string, in which case it must be a path
+            to a CA bundle to use
+        :param cert: The SSL certificate to verify.
+        """
+        if url.lower().startswith('https') and verify:
+
+            cert_loc = None
+
+            # Allow self-specified cert location.
+            if verify is not True:
+                cert_loc = verify
+
+            if not cert_loc:
+                cert_loc = extract_zipped_paths(DEFAULT_CA_BUNDLE_PATH)
+
+            if not cert_loc or not os.path.exists(cert_loc):
+                raise IOError("Could not find a suitable TLS CA certificate bundle, "
+                              "invalid path: {}".format(cert_loc))
+
+            conn.cert_reqs = 'CERT_REQUIRED'
+
+            if not os.path.isdir(cert_loc):
+                conn.ca_certs = cert_loc
+            else:
+                conn.ca_cert_dir = cert_loc
+        else:
+            conn.cert_reqs = 'CERT_NONE'
+            conn.ca_certs = None
+            conn.ca_cert_dir = None
+
+        if cert:
+            if not isinstance(cert, basestring):
+                conn.cert_file = cert[0]
+                conn.key_file = cert[1]
+            else:
+                conn.cert_file = cert
+                conn.key_file = None
+            if conn.cert_file and not os.path.exists(conn.cert_file):
+                raise IOError("Could not find the TLS certificate file, "
+                              "invalid path: {}".format(conn.cert_file))
+            if conn.key_file and not os.path.exists(conn.key_file):
+                raise IOError("Could not find the TLS key file, "
+                              "invalid path: {}".format(conn.key_file))
+
+    def build_response(self, req, resp):
+        """Builds a :class:`Response <requests.Response>` object from a urllib3
+        response. This should not be called from user code, and is only exposed
+        for use when subclassing the
+        :class:`HTTPAdapter <requests.adapters.HTTPAdapter>`
+
+        :param req: The :class:`PreparedRequest <PreparedRequest>` used to generate the response.
+        :param resp: The urllib3 response object.
+        :rtype: requests.Response
+        """
+        response = Response()
+
+        # Fallback to None if there's no status_code, for whatever reason.
+        response.status_code = getattr(resp, 'status', None)
+
+        # Make headers case-insensitive.
+        response.headers = CaseInsensitiveDict(getattr(resp, 'headers', {}))
+
+        # Set encoding.
+        response.encoding = get_encoding_from_headers(response.headers)
+        response.raw = resp
+        response.reason = response.raw.reason
+
+        if isinstance(req.url, bytes):
+            response.url = req.url.decode('utf-8')
+        else:
+            response.url = req.url
+
+        # Add new cookies from the server.
+        extract_cookies_to_jar(response.cookies, req, resp)
+
+        # Give the Response some context.
+        response.request = req
+        response.connection = self
+
+        return response
+
+    def get_connection(self, url, proxies=None):
+        """Returns a urllib3 connection for the given URL. This should not be
+        called from user code, and is only exposed for use when subclassing the
+        :class:`HTTPAdapter <requests.adapters.HTTPAdapter>`.
+
+        :param url: The URL to connect to.
+        :param proxies: (optional) A Requests-style dictionary of proxies used on this request.
+        :rtype: urllib3.ConnectionPool
+        """
+        proxy = select_proxy(url, proxies)
+
+        if proxy:
+            proxy = prepend_scheme_if_needed(proxy, 'http')
+            proxy_url = parse_url(proxy)
+            if not proxy_url.host:
+                raise InvalidProxyURL("Please check proxy URL. It is malformed"
+                                      " and could be missing the host.")
+            proxy_manager = self.proxy_manager_for(proxy)
+            conn = proxy_manager.connection_from_url(url)
+        else:
+            # Only scheme should be lower case
+            parsed = urlparse(url)
+            url = parsed.geturl()
+            conn = self.poolmanager.connection_from_url(url)
+
+        return conn
+
+    def close(self):
+        """Disposes of any internal state.
+
+        Currently, this closes the PoolManager and any active ProxyManager,
+        which closes any pooled connections.
+        """
+        self.poolmanager.clear()
+        for proxy in self.proxy_manager.values():
+            proxy.clear()
+
+    def request_url(self, request, proxies):
+        """Obtain the url to use when making the final request.
+
+        If the message is being sent through a HTTP proxy, the full URL has to
+        be used. Otherwise, we should only use the path portion of the URL.
+
+        This should not be called from user code, and is only exposed for use
+        when subclassing the
+        :class:`HTTPAdapter <requests.adapters.HTTPAdapter>`.
+
+        :param request: The :class:`PreparedRequest <PreparedRequest>` being sent.
+        :param proxies: A dictionary of schemes or schemes and hosts to proxy URLs.
+        :rtype: str
+        """
+        proxy = select_proxy(request.url, proxies)
+        scheme = urlparse(request.url).scheme
+
+        is_proxied_http_request = (proxy and scheme != 'https')
+        using_socks_proxy = False
+        if proxy:
+            proxy_scheme = urlparse(proxy).scheme.lower()
+            using_socks_proxy = proxy_scheme.startswith('socks')
+
+        url = request.path_url
+        if is_proxied_http_request and not using_socks_proxy:
+            url = urldefragauth(request.url)
+
+        return url
+
+    def add_headers(self, request, **kwargs):
+        """Add any headers needed by the connection. As of v2.0 this does
+        nothing by default, but is left for overriding by users that subclass
+        the :class:`HTTPAdapter <requests.adapters.HTTPAdapter>`.
+
+        This should not be called from user code, and is only exposed for use
+        when subclassing the
+        :class:`HTTPAdapter <requests.adapters.HTTPAdapter>`.
+
+        :param request: The :class:`PreparedRequest <PreparedRequest>` to add headers to.
+        :param kwargs: The keyword arguments from the call to send().
+        """
+        pass
+
+    def proxy_headers(self, proxy):
+        """Returns a dictionary of the headers to add to any request sent
+        through a proxy. This works with urllib3 magic to ensure that they are
+        correctly sent to the proxy, rather than in a tunnelled request if
+        CONNECT is being used.
+
+        This should not be called from user code, and is only exposed for use
+        when subclassing the
+        :class:`HTTPAdapter <requests.adapters.HTTPAdapter>`.
+
+        :param proxy: The url of the proxy being used for this request.
+        :rtype: dict
+        """
+        headers = {}
+        username, password = get_auth_from_url(proxy)
+
+        if username:
+            headers['Proxy-Authorization'] = _basic_auth_str(username,
+                                                             password)
+
+        return headers
+
+    def send(self, request, stream=False, timeout=None, verify=True, cert=None, proxies=None):
+        """Sends PreparedRequest object. Returns Response object.
+
+        :param request: The :class:`PreparedRequest <PreparedRequest>` being sent.
+        :param stream: (optional) Whether to stream the request content.
+        :param timeout: (optional) How long to wait for the server to send
+            data before giving up, as a float, or a :ref:`(connect timeout,
+            read timeout) <timeouts>` tuple.
+        :type timeout: float or tuple or urllib3 Timeout object
+        :param verify: (optional) Either a boolean, in which case it controls whether
+            we verify the server's TLS certificate, or a string, in which case it
+            must be a path to a CA bundle to use
+        :param cert: (optional) Any user-provided SSL certificate to be trusted.
+        :param proxies: (optional) The proxies dictionary to apply to the request.
+        :rtype: requests.Response
+        """
+
+        try:
+            conn = self.get_connection(request.url, proxies)
+        except LocationValueError as e:
+            raise InvalidURL(e, request=request)
+
+        self.cert_verify(conn, request.url, verify, cert)
+        url = self.request_url(request, proxies)
+        self.add_headers(request, stream=stream, timeout=timeout, verify=verify, cert=cert, proxies=proxies)
+
+        chunked = not (request.body is None or 'Content-Length' in request.headers)
+
+        if isinstance(timeout, tuple):
+            try:
+                connect, read = timeout
+                timeout = TimeoutSauce(connect=connect, read=read)
+            except ValueError as e:
+                # this may raise a string formatting error.
+                err = ("Invalid timeout {}. Pass a (connect, read) "
+                       "timeout tuple, or a single float to set "
+                       "both timeouts to the same value".format(timeout))
+                raise ValueError(err)
+        elif isinstance(timeout, TimeoutSauce):
+            pass
+        else:
+            timeout = TimeoutSauce(connect=timeout, read=timeout)
+
+        try:
+            if not chunked:
+                resp = conn.urlopen(
+                    method=request.method,
+                    url=url,
+                    body=request.body,
+                    headers=request.headers,
+                    redirect=False,
+                    assert_same_host=False,
+                    preload_content=False,
+                    decode_content=False,
+                    retries=self.max_retries,
+                    timeout=timeout
+                )
+
+            # Send the request.
+            else:
+                if hasattr(conn, 'proxy_pool'):
+                    conn = conn.proxy_pool
+
+                low_conn = conn._get_conn(timeout=DEFAULT_POOL_TIMEOUT)
+
+                try:
+                    low_conn.putrequest(request.method,
+                                        url,
+                                        skip_accept_encoding=True)
+
+                    for header, value in request.headers.items():
+                        low_conn.putheader(header, value)
+
+                    low_conn.endheaders()
+
+                    for i in request.body:
+                        low_conn.send(hex(len(i))[2:].encode('utf-8'))
+                        low_conn.send(b'\r\n')
+                        low_conn.send(i)
+                        low_conn.send(b'\r\n')
+                    low_conn.send(b'0\r\n\r\n')
+
+                    # Receive the response from the server
+                    try:
+                        # For Python 2.7, use buffering of HTTP responses
+                        r = low_conn.getresponse(buffering=True)
+                    except TypeError:
+                        # For compatibility with Python 3.3+
+                        r = low_conn.getresponse()
+
+                    resp = HTTPResponse.from_httplib(
+                        r,
+                        pool=conn,
+                        connection=low_conn,
+                        preload_content=False,
+                        decode_content=False
+                    )
+                except:
+                    # If we hit any problems here, clean up the connection.
+                    # Then, reraise so that we can handle the actual exception.
+                    low_conn.close()
+                    raise
+
+        except (ProtocolError, socket.error) as err:
+            raise ConnectionError(err, request=request)
+
+        except MaxRetryError as e:
+            if isinstance(e.reason, ConnectTimeoutError):
+                # TODO: Remove this in 3.0.0: see #2811
+                if not isinstance(e.reason, NewConnectionError):
+                    raise ConnectTimeout(e, request=request)
+
+            if isinstance(e.reason, ResponseError):
+                raise RetryError(e, request=request)
+
+            if isinstance(e.reason, _ProxyError):
+                raise ProxyError(e, request=request)
+
+            if isinstance(e.reason, _SSLError):
+                # This branch is for urllib3 v1.22 and later.
+                raise SSLError(e, request=request)
+
+            raise ConnectionError(e, request=request)
+
+        except ClosedPoolError as e:
+            raise ConnectionError(e, request=request)
+
+        except _ProxyError as e:
+            raise ProxyError(e)
+
+        except (_SSLError, _HTTPError) as e:
+            if isinstance(e, _SSLError):
+                # This branch is for urllib3 versions earlier than v1.22
+                raise SSLError(e, request=request)
+            elif isinstance(e, ReadTimeoutError):
+                raise ReadTimeout(e, request=request)
+            else:
+                raise
+
+        return self.build_response(request, resp)
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/requests/adapters.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/requests/adapters.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..275bc1004c5c817aa28d6384df1c58984d82244e
GIT binary patch
literal 20399
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

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/requests/api.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/requests/api.py
new file mode 100644
index 0000000..abada96
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/requests/api.py
@@ -0,0 +1,158 @@
+# -*- coding: utf-8 -*-
+
+"""
+requests.api
+~~~~~~~~~~~~
+
+This module implements the Requests API.
+
+:copyright: (c) 2012 by Kenneth Reitz.
+:license: Apache2, see LICENSE for more details.
+"""
+
+from . import sessions
+
+
+def request(method, url, **kwargs):
+    """Constructs and sends a :class:`Request <Request>`.
+
+    :param method: method for the new :class:`Request` object.
+    :param url: URL for the new :class:`Request` object.
+    :param params: (optional) Dictionary, list of tuples or bytes to send
+        in the body of the :class:`Request`.
+    :param data: (optional) Dictionary, list of tuples, bytes, or file-like
+        object to send in the body of the :class:`Request`.
+    :param json: (optional) A JSON serializable Python object to send in the body of the :class:`Request`.
+    :param headers: (optional) Dictionary of HTTP Headers to send with the :class:`Request`.
+    :param cookies: (optional) Dict or CookieJar object to send with the :class:`Request`.
+    :param files: (optional) Dictionary of ``'name': file-like-objects`` (or ``{'name': file-tuple}``) for multipart encoding upload.
+        ``file-tuple`` can be a 2-tuple ``('filename', fileobj)``, 3-tuple ``('filename', fileobj, 'content_type')``
+        or a 4-tuple ``('filename', fileobj, 'content_type', custom_headers)``, where ``'content-type'`` is a string
+        defining the content type of the given file and ``custom_headers`` a dict-like object containing additional headers
+        to add for the file.
+    :param auth: (optional) Auth tuple to enable Basic/Digest/Custom HTTP Auth.
+    :param timeout: (optional) How many seconds to wait for the server to send data
+        before giving up, as a float, or a :ref:`(connect timeout, read
+        timeout) <timeouts>` tuple.
+    :type timeout: float or tuple
+    :param allow_redirects: (optional) Boolean. Enable/disable GET/OPTIONS/POST/PUT/PATCH/DELETE/HEAD redirection. Defaults to ``True``.
+    :type allow_redirects: bool
+    :param proxies: (optional) Dictionary mapping protocol to the URL of the proxy.
+    :param verify: (optional) Either a boolean, in which case it controls whether we verify
+            the server's TLS certificate, or a string, in which case it must be a path
+            to a CA bundle to use. Defaults to ``True``.
+    :param stream: (optional) if ``False``, the response content will be immediately downloaded.
+    :param cert: (optional) if String, path to ssl client cert file (.pem). If Tuple, ('cert', 'key') pair.
+    :return: :class:`Response <Response>` object
+    :rtype: requests.Response
+
+    Usage::
+
+      >>> import requests
+      >>> req = requests.request('GET', 'https://httpbin.org/get')
+      <Response [200]>
+    """
+
+    # By using the 'with' statement we are sure the session is closed, thus we
+    # avoid leaving sockets open which can trigger a ResourceWarning in some
+    # cases, and look like a memory leak in others.
+    with sessions.Session() as session:
+        return session.request(method=method, url=url, **kwargs)
+
+
+def get(url, params=None, **kwargs):
+    r"""Sends a GET request.
+
+    :param url: URL for the new :class:`Request` object.
+    :param params: (optional) Dictionary, list of tuples or bytes to send
+        in the body of the :class:`Request`.
+    :param \*\*kwargs: Optional arguments that ``request`` takes.
+    :return: :class:`Response <Response>` object
+    :rtype: requests.Response
+    """
+
+    kwargs.setdefault('allow_redirects', True)
+    return request('get', url, params=params, **kwargs)
+
+
+def options(url, **kwargs):
+    r"""Sends an OPTIONS request.
+
+    :param url: URL for the new :class:`Request` object.
+    :param \*\*kwargs: Optional arguments that ``request`` takes.
+    :return: :class:`Response <Response>` object
+    :rtype: requests.Response
+    """
+
+    kwargs.setdefault('allow_redirects', True)
+    return request('options', url, **kwargs)
+
+
+def head(url, **kwargs):
+    r"""Sends a HEAD request.
+
+    :param url: URL for the new :class:`Request` object.
+    :param \*\*kwargs: Optional arguments that ``request`` takes.
+    :return: :class:`Response <Response>` object
+    :rtype: requests.Response
+    """
+
+    kwargs.setdefault('allow_redirects', False)
+    return request('head', url, **kwargs)
+
+
+def post(url, data=None, json=None, **kwargs):
+    r"""Sends a POST request.
+
+    :param url: URL for the new :class:`Request` object.
+    :param data: (optional) Dictionary, list of tuples, bytes, or file-like
+        object to send in the body of the :class:`Request`.
+    :param json: (optional) json data to send in the body of the :class:`Request`.
+    :param \*\*kwargs: Optional arguments that ``request`` takes.
+    :return: :class:`Response <Response>` object
+    :rtype: requests.Response
+    """
+
+    return request('post', url, data=data, json=json, **kwargs)
+
+
+def put(url, data=None, **kwargs):
+    r"""Sends a PUT request.
+
+    :param url: URL for the new :class:`Request` object.
+    :param data: (optional) Dictionary, list of tuples, bytes, or file-like
+        object to send in the body of the :class:`Request`.
+    :param json: (optional) json data to send in the body of the :class:`Request`.
+    :param \*\*kwargs: Optional arguments that ``request`` takes.
+    :return: :class:`Response <Response>` object
+    :rtype: requests.Response
+    """
+
+    return request('put', url, data=data, **kwargs)
+
+
+def patch(url, data=None, **kwargs):
+    r"""Sends a PATCH request.
+
+    :param url: URL for the new :class:`Request` object.
+    :param data: (optional) Dictionary, list of tuples, bytes, or file-like
+        object to send in the body of the :class:`Request`.
+    :param json: (optional) json data to send in the body of the :class:`Request`.
+    :param \*\*kwargs: Optional arguments that ``request`` takes.
+    :return: :class:`Response <Response>` object
+    :rtype: requests.Response
+    """
+
+    return request('patch', url, data=data, **kwargs)
+
+
+def delete(url, **kwargs):
+    r"""Sends a DELETE request.
+
+    :param url: URL for the new :class:`Request` object.
+    :param \*\*kwargs: Optional arguments that ``request`` takes.
+    :return: :class:`Response <Response>` object
+    :rtype: requests.Response
+    """
+
+    return request('delete', url, **kwargs)
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/requests/api.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/requests/api.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..995ff7acb8c6a1fd4af0edb1db524aea8ce11f74
GIT binary patch
literal 7499
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
XkBv!ynNy#KpOcr9m!F@9pNAg+wK$z&

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/requests/auth.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/requests/auth.py
new file mode 100644
index 0000000..bdde51c
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/requests/auth.py
@@ -0,0 +1,305 @@
+# -*- coding: utf-8 -*-
+
+"""
+requests.auth
+~~~~~~~~~~~~~
+
+This module contains the authentication handlers for Requests.
+"""
+
+import os
+import re
+import time
+import hashlib
+import threading
+import warnings
+
+from base64 import b64encode
+
+from .compat import urlparse, str, basestring
+from .cookies import extract_cookies_to_jar
+from ._internal_utils import to_native_string
+from .utils import parse_dict_header
+
+CONTENT_TYPE_FORM_URLENCODED = 'application/x-www-form-urlencoded'
+CONTENT_TYPE_MULTI_PART = 'multipart/form-data'
+
+
+def _basic_auth_str(username, password):
+    """Returns a Basic Auth string."""
+
+    # "I want us to put a big-ol' comment on top of it that
+    # says that this behaviour is dumb but we need to preserve
+    # it because people are relying on it."
+    #    - Lukasa
+    #
+    # These are here solely to maintain backwards compatibility
+    # for things like ints. This will be removed in 3.0.0.
+    if not isinstance(username, basestring):
+        warnings.warn(
+            "Non-string usernames will no longer be supported in Requests "
+            "3.0.0. Please convert the object you've passed in ({!r}) to "
+            "a string or bytes object in the near future to avoid "
+            "problems.".format(username),
+            category=DeprecationWarning,
+        )
+        username = str(username)
+
+    if not isinstance(password, basestring):
+        warnings.warn(
+            "Non-string passwords will no longer be supported in Requests "
+            "3.0.0. Please convert the object you've passed in ({!r}) to "
+            "a string or bytes object in the near future to avoid "
+            "problems.".format(password),
+            category=DeprecationWarning,
+        )
+        password = str(password)
+    # -- End Removal --
+
+    if isinstance(username, str):
+        username = username.encode('latin1')
+
+    if isinstance(password, str):
+        password = password.encode('latin1')
+
+    authstr = 'Basic ' + to_native_string(
+        b64encode(b':'.join((username, password))).strip()
+    )
+
+    return authstr
+
+
+class AuthBase(object):
+    """Base class that all auth implementations derive from"""
+
+    def __call__(self, r):
+        raise NotImplementedError('Auth hooks must be callable.')
+
+
+class HTTPBasicAuth(AuthBase):
+    """Attaches HTTP Basic Authentication to the given Request object."""
+
+    def __init__(self, username, password):
+        self.username = username
+        self.password = password
+
+    def __eq__(self, other):
+        return all([
+            self.username == getattr(other, 'username', None),
+            self.password == getattr(other, 'password', None)
+        ])
+
+    def __ne__(self, other):
+        return not self == other
+
+    def __call__(self, r):
+        r.headers['Authorization'] = _basic_auth_str(self.username, self.password)
+        return r
+
+
+class HTTPProxyAuth(HTTPBasicAuth):
+    """Attaches HTTP Proxy Authentication to a given Request object."""
+
+    def __call__(self, r):
+        r.headers['Proxy-Authorization'] = _basic_auth_str(self.username, self.password)
+        return r
+
+
+class HTTPDigestAuth(AuthBase):
+    """Attaches HTTP Digest Authentication to the given Request object."""
+
+    def __init__(self, username, password):
+        self.username = username
+        self.password = password
+        # Keep state in per-thread local storage
+        self._thread_local = threading.local()
+
+    def init_per_thread_state(self):
+        # Ensure state is initialized just once per-thread
+        if not hasattr(self._thread_local, 'init'):
+            self._thread_local.init = True
+            self._thread_local.last_nonce = ''
+            self._thread_local.nonce_count = 0
+            self._thread_local.chal = {}
+            self._thread_local.pos = None
+            self._thread_local.num_401_calls = None
+
+    def build_digest_header(self, method, url):
+        """
+        :rtype: str
+        """
+
+        realm = self._thread_local.chal['realm']
+        nonce = self._thread_local.chal['nonce']
+        qop = self._thread_local.chal.get('qop')
+        algorithm = self._thread_local.chal.get('algorithm')
+        opaque = self._thread_local.chal.get('opaque')
+        hash_utf8 = None
+
+        if algorithm is None:
+            _algorithm = 'MD5'
+        else:
+            _algorithm = algorithm.upper()
+        # lambdas assume digest modules are imported at the top level
+        if _algorithm == 'MD5' or _algorithm == 'MD5-SESS':
+            def md5_utf8(x):
+                if isinstance(x, str):
+                    x = x.encode('utf-8')
+                return hashlib.md5(x).hexdigest()
+            hash_utf8 = md5_utf8
+        elif _algorithm == 'SHA':
+            def sha_utf8(x):
+                if isinstance(x, str):
+                    x = x.encode('utf-8')
+                return hashlib.sha1(x).hexdigest()
+            hash_utf8 = sha_utf8
+        elif _algorithm == 'SHA-256':
+            def sha256_utf8(x):
+                if isinstance(x, str):
+                    x = x.encode('utf-8')
+                return hashlib.sha256(x).hexdigest()
+            hash_utf8 = sha256_utf8
+        elif _algorithm == 'SHA-512':
+            def sha512_utf8(x):
+                if isinstance(x, str):
+                    x = x.encode('utf-8')
+                return hashlib.sha512(x).hexdigest()
+            hash_utf8 = sha512_utf8
+
+        KD = lambda s, d: hash_utf8("%s:%s" % (s, d))
+
+        if hash_utf8 is None:
+            return None
+
+        # XXX not implemented yet
+        entdig = None
+        p_parsed = urlparse(url)
+        #: path is request-uri defined in RFC 2616 which should not be empty
+        path = p_parsed.path or "/"
+        if p_parsed.query:
+            path += '?' + p_parsed.query
+
+        A1 = '%s:%s:%s' % (self.username, realm, self.password)
+        A2 = '%s:%s' % (method, path)
+
+        HA1 = hash_utf8(A1)
+        HA2 = hash_utf8(A2)
+
+        if nonce == self._thread_local.last_nonce:
+            self._thread_local.nonce_count += 1
+        else:
+            self._thread_local.nonce_count = 1
+        ncvalue = '%08x' % self._thread_local.nonce_count
+        s = str(self._thread_local.nonce_count).encode('utf-8')
+        s += nonce.encode('utf-8')
+        s += time.ctime().encode('utf-8')
+        s += os.urandom(8)
+
+        cnonce = (hashlib.sha1(s).hexdigest()[:16])
+        if _algorithm == 'MD5-SESS':
+            HA1 = hash_utf8('%s:%s:%s' % (HA1, nonce, cnonce))
+
+        if not qop:
+            respdig = KD(HA1, "%s:%s" % (nonce, HA2))
+        elif qop == 'auth' or 'auth' in qop.split(','):
+            noncebit = "%s:%s:%s:%s:%s" % (
+                nonce, ncvalue, cnonce, 'auth', HA2
+            )
+            respdig = KD(HA1, noncebit)
+        else:
+            # XXX handle auth-int.
+            return None
+
+        self._thread_local.last_nonce = nonce
+
+        # XXX should the partial digests be encoded too?
+        base = 'username="%s", realm="%s", nonce="%s", uri="%s", ' \
+               'response="%s"' % (self.username, realm, nonce, path, respdig)
+        if opaque:
+            base += ', opaque="%s"' % opaque
+        if algorithm:
+            base += ', algorithm="%s"' % algorithm
+        if entdig:
+            base += ', digest="%s"' % entdig
+        if qop:
+            base += ', qop="auth", nc=%s, cnonce="%s"' % (ncvalue, cnonce)
+
+        return 'Digest %s' % (base)
+
+    def handle_redirect(self, r, **kwargs):
+        """Reset num_401_calls counter on redirects."""
+        if r.is_redirect:
+            self._thread_local.num_401_calls = 1
+
+    def handle_401(self, r, **kwargs):
+        """
+        Takes the given response and tries digest-auth, if needed.
+
+        :rtype: requests.Response
+        """
+
+        # If response is not 4xx, do not auth
+        # See https://github.com/requests/requests/issues/3772
+        if not 400 <= r.status_code < 500:
+            self._thread_local.num_401_calls = 1
+            return r
+
+        if self._thread_local.pos is not None:
+            # Rewind the file position indicator of the body to where
+            # it was to resend the request.
+            r.request.body.seek(self._thread_local.pos)
+        s_auth = r.headers.get('www-authenticate', '')
+
+        if 'digest' in s_auth.lower() and self._thread_local.num_401_calls < 2:
+
+            self._thread_local.num_401_calls += 1
+            pat = re.compile(r'digest ', flags=re.IGNORECASE)
+            self._thread_local.chal = parse_dict_header(pat.sub('', s_auth, count=1))
+
+            # Consume content and release the original connection
+            # to allow our new request to reuse the same one.
+            r.content
+            r.close()
+            prep = r.request.copy()
+            extract_cookies_to_jar(prep._cookies, r.request, r.raw)
+            prep.prepare_cookies(prep._cookies)
+
+            prep.headers['Authorization'] = self.build_digest_header(
+                prep.method, prep.url)
+            _r = r.connection.send(prep, **kwargs)
+            _r.history.append(r)
+            _r.request = prep
+
+            return _r
+
+        self._thread_local.num_401_calls = 1
+        return r
+
+    def __call__(self, r):
+        # Initialize per-thread state, if needed
+        self.init_per_thread_state()
+        # If we have a saved nonce, skip the 401
+        if self._thread_local.last_nonce:
+            r.headers['Authorization'] = self.build_digest_header(r.method, r.url)
+        try:
+            self._thread_local.pos = r.body.tell()
+        except AttributeError:
+            # In the case of HTTPDigestAuth being reused and the body of
+            # the previous request was a file-like object, pos has the
+            # file position of the previous body. Ensure it's set to
+            # None.
+            self._thread_local.pos = None
+        r.register_hook('response', self.handle_401)
+        r.register_hook('response', self.handle_redirect)
+        self._thread_local.num_401_calls = 1
+
+        return r
+
+    def __eq__(self, other):
+        return all([
+            self.username == getattr(other, 'username', None),
+            self.password == getattr(other, 'password', None)
+        ])
+
+    def __ne__(self, other):
+        return not self == other
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/requests/auth.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/requests/auth.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..411da986b50944428ff2e64c925a78e30eaa306c
GIT binary patch
literal 11699
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
J*u_M}H~?@|9$f$c

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/requests/certs.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/requests/certs.py
new file mode 100644
index 0000000..06a594e
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/requests/certs.py
@@ -0,0 +1,18 @@
+#!/usr/bin/env python
+# -*- coding: utf-8 -*-
+
+"""
+requests.certs
+~~~~~~~~~~~~~~
+
+This module returns the preferred default CA certificate bundle. There is
+only one — the one from the certifi package.
+
+If you are packaging Requests, e.g., for a Linux distribution or a managed
+environment, you can change the definition of where() to return a separately
+packaged CA bundle.
+"""
+from pip._vendor.certifi import where
+
+if __name__ == '__main__':
+    print(where())
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/requests/certs.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/requests/certs.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..f76857493ccadc4972c73fbd2b91f49820677fed
GIT binary patch
literal 665
zcmZSn%**AGdLky70ScHH7#JKF7#NBT85kH+7#N}$7*ZG+QkWQW7#VVz7^0XM7*m-U
zQkWUCnHY+68B&=Tni&|}J@ObBQdk&*HCRDf-541dxQbE>OH+$WiuICHi%N>Q>QDd|
zS4c)?u|jTsN@-52LQ!f-X;EIWLP<udLP1e#T53^IYKlTiYFc7xPKkoEqXNi?%(Tqp
z#FA8nq|&^UoK!u9kc`x#RE5l9uKc{5N`?HqRE0+kQ@}=m*l9)ixnK@dt3p9ya&}^R
zsvZ}YXPQD~eyKuYQ7Tk0GcR2s2<loLg;c$CJspL#{33-!1)t2k(h7x?%;J)w%%swi
z%=|nBuy}4_USfJ`3Rh}gS!PjwUT$h$i4NG%<itFM<c!3;^i;6rDXD3hd6^J>X$s{a
z7i(xLl;lHwtdOWsoLZ1rlvt9QQ^^H&VG78@P)~AY{{R2~zXl@%149WYWWgqsa4;}1
z#K-3*X6D7m`)RO%B-z12Df!9q@g>3x3=9RC1$yyisd*{+Md0wyOv?-cMKDxvUSe))
ze7puo1VI$%GB7ac7ZhcdC6=V>mn9bIr{(9Qq!tzHC#C3@Cne?On&uW8877&hSEXB+
zT9oHxRhb!pKzg2jh<-t4fo^7AaY<rMj;>poho^A>NC=Ff4$+6D2z^kT6zdgKf?Z>i
W3r+-fe4v!W#=yY9#wftV!w3M^ZOIq_

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/requests/compat.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/requests/compat.py
new file mode 100644
index 0000000..6a86893
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/requests/compat.py
@@ -0,0 +1,74 @@
+# -*- coding: utf-8 -*-
+
+"""
+requests.compat
+~~~~~~~~~~~~~~~
+
+This module handles import compatibility issues between Python 2 and
+Python 3.
+"""
+
+from pip._vendor import chardet
+
+import sys
+
+# -------
+# Pythons
+# -------
+
+# Syntax sugar.
+_ver = sys.version_info
+
+#: Python 2.x?
+is_py2 = (_ver[0] == 2)
+
+#: Python 3.x?
+is_py3 = (_ver[0] == 3)
+
+# 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
+
+# ---------
+# 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
+    from collections import Callable, Mapping, MutableMapping, OrderedDict
+
+
+    builtin_str = str
+    bytes = str
+    str = unicode
+    basestring = basestring
+    numeric_types = (int, long, float)
+    integer_types = (int, long)
+
+elif is_py3:
+    from urllib.parse import urlparse, urlunparse, urljoin, urlsplit, urlencode, quote, unquote, quote_plus, unquote_plus, urldefrag
+    from urllib.request import parse_http_list, getproxies, proxy_bypass, proxy_bypass_environment, getproxies_environment
+    from http import cookiejar as cookielib
+    from http.cookies import Morsel
+    from io import StringIO
+    from collections import OrderedDict
+    from collections.abc import Callable, Mapping, MutableMapping
+
+    builtin_str = str
+    str = str
+    bytes = bytes
+    basestring = (str, bytes)
+    numeric_types = (int, float)
+    integer_types = (int,)
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/requests/compat.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/requests/compat.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..511fd88c8e14da3cd39d466307f226e6f36532de
GIT binary patch
literal 2003
zcmZSn%**AGdLky70ScHI7#JKF7#NC^nHU&S7#N}$7*ZG+QkWQW7#VVz7^0XM7(sky
zh8$*wC}xIKW`-;lhA38sR91!*76!=_R)%aQhA1{TpAF1s2OGl7ki)?c#leuu#!wUq
zHin%chm#?fiy?}OA(xvWikl&qharlGA(xjSikBgmk0FYWA(x*aik~4@fFVkNAy<$g
zN{}H}h#^V{;tURk9ASoBVTLGShFlSbC=rHSQHCf{hFmd*C^3dyafT>yh&oP&90`V8
zNros%2%niDM~Wdz3hXK_h8$^zTp5Na8HgM=Lyjy%t}H{8EQHU)kR!*CE6)%m&ycIY
z5T(G7tH=<g$dIeV5T(Sxn5xVWrNRIrRT)y%7^0LJQq>uv)EQDW7*aJEQneV;m>Ht9
zq1-ekhA16|JT}Huc7~#OCQv}~GUVvu_5maWaD@-Te|!u%dQku24KIF%9DRmd1CZCj
z;m^g8V~FN=BV@k|fc*~fDaf^g3^~SF!U8E2lo?W08KP7{A(E=f0P-*-EVRIEa6qIn
zf<u9UA%&SCSVIVu*a{gK7`Td33rkarON#Z9^K%OlOStM#0T)+DMrN@>ZhlH>PO3si
zVqQv4YOz9QZb5!gi2_7RW>RKOW=W+&W^r+8YOz96YDsx&YMw$sWl2VUo`R7=VqOXt
zlw+*NmHGew|Nk0{3=9k<><kPH$r*`7DXArXnV_7I$;80GkO|5R8k`^ntPBhcg{Ao=
zsbHn0c@Q=iOf<eAr?j|)hk=0sDg_Y$X)P_vNzF^nPf0BSsZLKVDJaUX$V`Q(2C*yS
zlPU`mi;GJn7#J9k1>#fl$})@c^Kw)3N=n2S7#I+mk)<?1ZY$vc*<F-VkXTd<v8l8u
zr!)`31^KSDC?_jFGY_V&xF9F9qy*}|l+?7M#B@kV@PixyG9*5uq@*A|C$qQ&BEiPM
zz~Gx-RGgXv;e#v;E-A{)OZW8GU;%{@NW?iYCnqr}2NF!ai3J6jdFds5Ag!e(AaR%w
zHv<EMe^E+mQEG}yW^#!JC~Shj1V|<b6p}%_3=9lGAkPJX;wT6dBSD}T2?E&`1Tqxt
z^&pUwgFwy;0(mqD<cuJY&misuv6A!ivolk(5{tk>L81%{3>sjQK#4C%7-WwKNX!J}
z4Ui%6@hSPq@$n@f#}s51=*5?%=B4Bp1%Z-A2}oygB_smNQj3Z+^Yh{}^V0H5K<<h!
zOD!q^IVQ6>zM#?w!88U-XBFq?fyGLTa&j`0u=)(_WsnhQ{=phPpkRQcNw9%N;Lrd^
zEX30}nMq*#oWVg5BmnZOAjq2_uO;W_<fJB-Waj4;2cZT9IE)}ZEhz#ALsDsGPDy57
zd~r!p3CM*>l_jag5S#Nd;psamu{gCDoGQSYGxJKo-p<L-O9$&p%gIkHDFMZ7UTJP>
zQD$;{No7H5F<2xsuOu}+wFoK#N&=8T(u1U8kWZlk(2@ddG$@${fpP~p`+<0R5T6&9
zfKp6mehDajAo)};F)3LC6p;v`IFEsWLBF6Vvn;VBRlh8;NIxw<CndG0SU)L6zdR`^
zFV{4;*vK%+JiRL2!qlQXC#%ZL00h$W^h5LuG7EGw^NLFnb8>Xu$~-)c13*Gx3{5xs
zPzM+5L&_<=f=X~kw8;e*W_F-7TI|BWz`({Nz{JDO$t=Juz{$hL#^}JT!6?AU!zjQg
hz^KH`#t4D@jQmV&jBbn|IgpG1qYM*7hKG@d5dc#gu6O_d

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/requests/cookies.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/requests/cookies.py
new file mode 100644
index 0000000..56fccd9
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/requests/cookies.py
@@ -0,0 +1,549 @@
+# -*- coding: utf-8 -*-
+
+"""
+requests.cookies
+~~~~~~~~~~~~~~~~
+
+Compatibility code to be able to use `cookielib.CookieJar` with requests.
+
+requests.utils imports from here, so be careful with imports.
+"""
+
+import copy
+import time
+import calendar
+
+from ._internal_utils import to_native_string
+from .compat import cookielib, urlparse, urlunparse, Morsel, MutableMapping
+
+try:
+    import threading
+except ImportError:
+    import dummy_threading as threading
+
+
+class MockRequest(object):
+    """Wraps a `requests.Request` to mimic a `urllib2.Request`.
+
+    The code in `cookielib.CookieJar` expects this interface in order to correctly
+    manage cookie policies, i.e., determine whether a cookie can be set, given the
+    domains of the request and the cookie.
+
+    The original request object is read-only. The client is responsible for collecting
+    the new headers via `get_new_headers()` and interpreting them appropriately. You
+    probably want `get_cookie_header`, defined below.
+    """
+
+    def __init__(self, request):
+        self._r = request
+        self._new_headers = {}
+        self.type = urlparse(self._r.url).scheme
+
+    def get_type(self):
+        return self.type
+
+    def get_host(self):
+        return urlparse(self._r.url).netloc
+
+    def get_origin_req_host(self):
+        return self.get_host()
+
+    def get_full_url(self):
+        # Only return the response's URL if the user hadn't set the Host
+        # header
+        if not self._r.headers.get('Host'):
+            return self._r.url
+        # If they did set it, retrieve it and reconstruct the expected domain
+        host = to_native_string(self._r.headers['Host'], encoding='utf-8')
+        parsed = urlparse(self._r.url)
+        # Reconstruct the URL as we expect it
+        return urlunparse([
+            parsed.scheme, host, parsed.path, parsed.params, parsed.query,
+            parsed.fragment
+        ])
+
+    def is_unverifiable(self):
+        return True
+
+    def has_header(self, name):
+        return name in self._r.headers or name in self._new_headers
+
+    def get_header(self, name, default=None):
+        return self._r.headers.get(name, self._new_headers.get(name, default))
+
+    def add_header(self, key, val):
+        """cookielib has no legitimate use for this method; add it back if you find one."""
+        raise NotImplementedError("Cookie headers should be added with add_unredirected_header()")
+
+    def add_unredirected_header(self, name, value):
+        self._new_headers[name] = value
+
+    def get_new_headers(self):
+        return self._new_headers
+
+    @property
+    def unverifiable(self):
+        return self.is_unverifiable()
+
+    @property
+    def origin_req_host(self):
+        return self.get_origin_req_host()
+
+    @property
+    def host(self):
+        return self.get_host()
+
+
+class MockResponse(object):
+    """Wraps a `httplib.HTTPMessage` to mimic a `urllib.addinfourl`.
+
+    ...what? Basically, expose the parsed HTTP headers from the server response
+    the way `cookielib` expects to see them.
+    """
+
+    def __init__(self, headers):
+        """Make a MockResponse for `cookielib` to read.
+
+        :param headers: a httplib.HTTPMessage or analogous carrying the headers
+        """
+        self._headers = headers
+
+    def info(self):
+        return self._headers
+
+    def getheaders(self, name):
+        self._headers.getheaders(name)
+
+
+def extract_cookies_to_jar(jar, request, response):
+    """Extract the cookies from the response into a CookieJar.
+
+    :param jar: cookielib.CookieJar (not necessarily a RequestsCookieJar)
+    :param request: our own requests.Request object
+    :param response: urllib3.HTTPResponse object
+    """
+    if not (hasattr(response, '_original_response') and
+            response._original_response):
+        return
+    # the _original_response field is the wrapped httplib.HTTPResponse object,
+    req = MockRequest(request)
+    # pull out the HTTPMessage with the headers and put it in the mock:
+    res = MockResponse(response._original_response.msg)
+    jar.extract_cookies(res, req)
+
+
+def get_cookie_header(jar, request):
+    """
+    Produce an appropriate Cookie header string to be sent with `request`, or None.
+
+    :rtype: str
+    """
+    r = MockRequest(request)
+    jar.add_cookie_header(r)
+    return r.get_new_headers().get('Cookie')
+
+
+def remove_cookie_by_name(cookiejar, name, domain=None, path=None):
+    """Unsets a cookie by name, by default over all domains and paths.
+
+    Wraps CookieJar.clear(), is O(n).
+    """
+    clearables = []
+    for cookie in cookiejar:
+        if cookie.name != name:
+            continue
+        if domain is not None and domain != cookie.domain:
+            continue
+        if path is not None and path != cookie.path:
+            continue
+        clearables.append((cookie.domain, cookie.path, cookie.name))
+
+    for domain, path, name in clearables:
+        cookiejar.clear(domain, path, name)
+
+
+class CookieConflictError(RuntimeError):
+    """There are two cookies that meet the criteria specified in the cookie jar.
+    Use .get and .set and include domain and path args in order to be more specific.
+    """
+
+
+class RequestsCookieJar(cookielib.CookieJar, MutableMapping):
+    """Compatibility class; is a cookielib.CookieJar, but exposes a dict
+    interface.
+
+    This is the CookieJar we create by default for requests and sessions that
+    don't specify one, since some clients may expect response.cookies and
+    session.cookies to support dict operations.
+
+    Requests does not use the dict interface internally; it's just for
+    compatibility with external client code. All requests code should work
+    out of the box with externally provided instances of ``CookieJar``, e.g.
+    ``LWPCookieJar`` and ``FileCookieJar``.
+
+    Unlike a regular CookieJar, this class is pickleable.
+
+    .. warning:: dictionary operations that are normally O(1) may be O(n).
+    """
+
+    def get(self, name, default=None, domain=None, path=None):
+        """Dict-like get() that also supports optional domain and path args in
+        order to resolve naming collisions from using one cookie jar over
+        multiple domains.
+
+        .. warning:: operation is O(n), not O(1).
+        """
+        try:
+            return self._find_no_duplicates(name, domain, path)
+        except KeyError:
+            return default
+
+    def set(self, name, value, **kwargs):
+        """Dict-like set() that also supports optional domain and path args in
+        order to resolve naming collisions from using one cookie jar over
+        multiple domains.
+        """
+        # support client code that unsets cookies by assignment of a None value:
+        if value is None:
+            remove_cookie_by_name(self, name, domain=kwargs.get('domain'), path=kwargs.get('path'))
+            return
+
+        if isinstance(value, Morsel):
+            c = morsel_to_cookie(value)
+        else:
+            c = create_cookie(name, value, **kwargs)
+        self.set_cookie(c)
+        return c
+
+    def iterkeys(self):
+        """Dict-like iterkeys() that returns an iterator of names of cookies
+        from the jar.
+
+        .. seealso:: itervalues() and iteritems().
+        """
+        for cookie in iter(self):
+            yield cookie.name
+
+    def keys(self):
+        """Dict-like keys() that returns a list of names of cookies from the
+        jar.
+
+        .. seealso:: values() and items().
+        """
+        return list(self.iterkeys())
+
+    def itervalues(self):
+        """Dict-like itervalues() that returns an iterator of values of cookies
+        from the jar.
+
+        .. seealso:: iterkeys() and iteritems().
+        """
+        for cookie in iter(self):
+            yield cookie.value
+
+    def values(self):
+        """Dict-like values() that returns a list of values of cookies from the
+        jar.
+
+        .. seealso:: keys() and items().
+        """
+        return list(self.itervalues())
+
+    def iteritems(self):
+        """Dict-like iteritems() that returns an iterator of name-value tuples
+        from the jar.
+
+        .. seealso:: iterkeys() and itervalues().
+        """
+        for cookie in iter(self):
+            yield cookie.name, cookie.value
+
+    def items(self):
+        """Dict-like items() that returns a list of name-value tuples from the
+        jar. Allows client-code to call ``dict(RequestsCookieJar)`` and get a
+        vanilla python dict of key value pairs.
+
+        .. seealso:: keys() and values().
+        """
+        return list(self.iteritems())
+
+    def list_domains(self):
+        """Utility method to list all the domains in the jar."""
+        domains = []
+        for cookie in iter(self):
+            if cookie.domain not in domains:
+                domains.append(cookie.domain)
+        return domains
+
+    def list_paths(self):
+        """Utility method to list all the paths in the jar."""
+        paths = []
+        for cookie in iter(self):
+            if cookie.path not in paths:
+                paths.append(cookie.path)
+        return paths
+
+    def multiple_domains(self):
+        """Returns True if there are multiple domains in the jar.
+        Returns False otherwise.
+
+        :rtype: bool
+        """
+        domains = []
+        for cookie in iter(self):
+            if cookie.domain is not None and cookie.domain in domains:
+                return True
+            domains.append(cookie.domain)
+        return False  # there is only one domain in jar
+
+    def get_dict(self, domain=None, path=None):
+        """Takes as an argument an optional domain and path and returns a plain
+        old Python dict of name-value pairs of cookies that meet the
+        requirements.
+
+        :rtype: dict
+        """
+        dictionary = {}
+        for cookie in iter(self):
+            if (
+                (domain is None or cookie.domain == domain) and
+                (path is None or cookie.path == path)
+            ):
+                dictionary[cookie.name] = cookie.value
+        return dictionary
+
+    def __contains__(self, name):
+        try:
+            return super(RequestsCookieJar, self).__contains__(name)
+        except CookieConflictError:
+            return True
+
+    def __getitem__(self, name):
+        """Dict-like __getitem__() for compatibility with client code. Throws
+        exception if there are more than one cookie with name. In that case,
+        use the more explicit get() method instead.
+
+        .. warning:: operation is O(n), not O(1).
+        """
+        return self._find_no_duplicates(name)
+
+    def __setitem__(self, name, value):
+        """Dict-like __setitem__ for compatibility with client code. Throws
+        exception if there is already a cookie of that name in the jar. In that
+        case, use the more explicit set() method instead.
+        """
+        self.set(name, value)
+
+    def __delitem__(self, name):
+        """Deletes a cookie given a name. Wraps ``cookielib.CookieJar``'s
+        ``remove_cookie_by_name()``.
+        """
+        remove_cookie_by_name(self, name)
+
+    def set_cookie(self, cookie, *args, **kwargs):
+        if hasattr(cookie.value, 'startswith') and cookie.value.startswith('"') and cookie.value.endswith('"'):
+            cookie.value = cookie.value.replace('\\"', '')
+        return super(RequestsCookieJar, self).set_cookie(cookie, *args, **kwargs)
+
+    def update(self, other):
+        """Updates this jar with cookies from another CookieJar or dict-like"""
+        if isinstance(other, cookielib.CookieJar):
+            for cookie in other:
+                self.set_cookie(copy.copy(cookie))
+        else:
+            super(RequestsCookieJar, self).update(other)
+
+    def _find(self, name, domain=None, path=None):
+        """Requests uses this method internally to get cookie values.
+
+        If there are conflicting cookies, _find arbitrarily chooses one.
+        See _find_no_duplicates if you want an exception thrown if there are
+        conflicting cookies.
+
+        :param name: a string containing name of cookie
+        :param domain: (optional) string containing domain of cookie
+        :param path: (optional) string containing path of cookie
+        :return: cookie.value
+        """
+        for cookie in iter(self):
+            if cookie.name == name:
+                if domain is None or cookie.domain == domain:
+                    if path is None or cookie.path == path:
+                        return cookie.value
+
+        raise KeyError('name=%r, domain=%r, path=%r' % (name, domain, path))
+
+    def _find_no_duplicates(self, name, domain=None, path=None):
+        """Both ``__get_item__`` and ``get`` call this function: it's never
+        used elsewhere in Requests.
+
+        :param name: a string containing name of cookie
+        :param domain: (optional) string containing domain of cookie
+        :param path: (optional) string containing path of cookie
+        :raises KeyError: if cookie is not found
+        :raises CookieConflictError: if there are multiple cookies
+            that match name and optionally domain and path
+        :return: cookie.value
+        """
+        toReturn = None
+        for cookie in iter(self):
+            if cookie.name == name:
+                if domain is None or cookie.domain == domain:
+                    if path is None or cookie.path == path:
+                        if toReturn is not None:  # if there are multiple cookies that meet passed in criteria
+                            raise CookieConflictError('There are multiple cookies with name, %r' % (name))
+                        toReturn = cookie.value  # we will eventually return this as long as no cookie conflict
+
+        if toReturn:
+            return toReturn
+        raise KeyError('name=%r, domain=%r, path=%r' % (name, domain, path))
+
+    def __getstate__(self):
+        """Unlike a normal CookieJar, this class is pickleable."""
+        state = self.__dict__.copy()
+        # remove the unpickleable RLock object
+        state.pop('_cookies_lock')
+        return state
+
+    def __setstate__(self, state):
+        """Unlike a normal CookieJar, this class is pickleable."""
+        self.__dict__.update(state)
+        if '_cookies_lock' not in self.__dict__:
+            self._cookies_lock = threading.RLock()
+
+    def copy(self):
+        """Return a copy of this RequestsCookieJar."""
+        new_cj = RequestsCookieJar()
+        new_cj.set_policy(self.get_policy())
+        new_cj.update(self)
+        return new_cj
+
+    def get_policy(self):
+        """Return the CookiePolicy instance used."""
+        return self._policy
+
+
+def _copy_cookie_jar(jar):
+    if jar is None:
+        return None
+
+    if hasattr(jar, 'copy'):
+        # We're dealing with an instance of RequestsCookieJar
+        return jar.copy()
+    # We're dealing with a generic CookieJar instance
+    new_jar = copy.copy(jar)
+    new_jar.clear()
+    for cookie in jar:
+        new_jar.set_cookie(copy.copy(cookie))
+    return new_jar
+
+
+def create_cookie(name, value, **kwargs):
+    """Make a cookie from underspecified parameters.
+
+    By default, the pair of `name` and `value` will be set for the domain ''
+    and sent on every request (this is sometimes called a "supercookie").
+    """
+    result = {
+        'version': 0,
+        'name': name,
+        'value': value,
+        'port': None,
+        'domain': '',
+        'path': '/',
+        'secure': False,
+        'expires': None,
+        'discard': True,
+        'comment': None,
+        'comment_url': None,
+        'rest': {'HttpOnly': None},
+        'rfc2109': False,
+    }
+
+    badargs = set(kwargs) - set(result)
+    if badargs:
+        err = 'create_cookie() got unexpected keyword arguments: %s'
+        raise TypeError(err % list(badargs))
+
+    result.update(kwargs)
+    result['port_specified'] = bool(result['port'])
+    result['domain_specified'] = bool(result['domain'])
+    result['domain_initial_dot'] = result['domain'].startswith('.')
+    result['path_specified'] = bool(result['path'])
+
+    return cookielib.Cookie(**result)
+
+
+def morsel_to_cookie(morsel):
+    """Convert a Morsel object into a Cookie containing the one k/v pair."""
+
+    expires = None
+    if morsel['max-age']:
+        try:
+            expires = int(time.time() + int(morsel['max-age']))
+        except ValueError:
+            raise TypeError('max-age: %s must be integer' % morsel['max-age'])
+    elif morsel['expires']:
+        time_template = '%a, %d-%b-%Y %H:%M:%S GMT'
+        expires = calendar.timegm(
+            time.strptime(morsel['expires'], time_template)
+        )
+    return create_cookie(
+        comment=morsel['comment'],
+        comment_url=bool(morsel['comment']),
+        discard=False,
+        domain=morsel['domain'],
+        expires=expires,
+        name=morsel.key,
+        path=morsel['path'],
+        port=None,
+        rest={'HttpOnly': morsel['httponly']},
+        rfc2109=False,
+        secure=bool(morsel['secure']),
+        value=morsel.value,
+        version=morsel['version'] or 0,
+    )
+
+
+def cookiejar_from_dict(cookie_dict, cookiejar=None, overwrite=True):
+    """Returns a CookieJar from a key/value dictionary.
+
+    :param cookie_dict: Dict of key/values to insert into CookieJar.
+    :param cookiejar: (optional) A cookiejar to add the cookies to.
+    :param overwrite: (optional) If False, will not replace cookies
+        already in the jar with new ones.
+    :rtype: CookieJar
+    """
+    if cookiejar is None:
+        cookiejar = RequestsCookieJar()
+
+    if cookie_dict is not None:
+        names_from_jar = [cookie.name for cookie in cookiejar]
+        for name in cookie_dict:
+            if overwrite or (name not in names_from_jar):
+                cookiejar.set_cookie(create_cookie(name, cookie_dict[name]))
+
+    return cookiejar
+
+
+def merge_cookies(cookiejar, cookies):
+    """Add cookies to cookiejar and returns a merged CookieJar.
+
+    :param cookiejar: CookieJar object to add the cookies to.
+    :param cookies: Dictionary or CookieJar object to be added.
+    :rtype: CookieJar
+    """
+    if not isinstance(cookiejar, cookielib.CookieJar):
+        raise ValueError('You can only merge into CookieJar')
+
+    if isinstance(cookies, dict):
+        cookiejar = cookiejar_from_dict(
+            cookies, cookiejar=cookiejar, overwrite=False)
+    elif isinstance(cookies, cookielib.CookieJar):
+        try:
+            cookiejar.update(cookies)
+        except AttributeError:
+            for cookie_in_jar in cookies:
+                cookiejar.set_cookie(cookie_in_jar)
+
+    return cookiejar
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/requests/cookies.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/requests/cookies.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..c6e163a6cde80277aee1ea7c5044623b0742e25e
GIT binary patch
literal 25235
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

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/requests/exceptions.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/requests/exceptions.py
new file mode 100644
index 0000000..a91e1fd
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/requests/exceptions.py
@@ -0,0 +1,126 @@
+# -*- coding: utf-8 -*-
+
+"""
+requests.exceptions
+~~~~~~~~~~~~~~~~~~~
+
+This module contains the set of Requests' exceptions.
+"""
+from pip._vendor.urllib3.exceptions import HTTPError as BaseHTTPError
+
+
+class RequestException(IOError):
+    """There was an ambiguous exception that occurred while handling your
+    request.
+    """
+
+    def __init__(self, *args, **kwargs):
+        """Initialize RequestException with `request` and `response` objects."""
+        response = kwargs.pop('response', None)
+        self.response = response
+        self.request = kwargs.pop('request', None)
+        if (response is not None and not self.request and
+                hasattr(response, 'request')):
+            self.request = self.response.request
+        super(RequestException, self).__init__(*args, **kwargs)
+
+
+class HTTPError(RequestException):
+    """An HTTP error occurred."""
+
+
+class ConnectionError(RequestException):
+    """A Connection error occurred."""
+
+
+class ProxyError(ConnectionError):
+    """A proxy error occurred."""
+
+
+class SSLError(ConnectionError):
+    """An SSL error occurred."""
+
+
+class Timeout(RequestException):
+    """The request timed out.
+
+    Catching this error will catch both
+    :exc:`~requests.exceptions.ConnectTimeout` and
+    :exc:`~requests.exceptions.ReadTimeout` errors.
+    """
+
+
+class ConnectTimeout(ConnectionError, Timeout):
+    """The request timed out while trying to connect to the remote server.
+
+    Requests that produced this error are safe to retry.
+    """
+
+
+class ReadTimeout(Timeout):
+    """The server did not send any data in the allotted amount of time."""
+
+
+class URLRequired(RequestException):
+    """A valid URL is required to make a request."""
+
+
+class TooManyRedirects(RequestException):
+    """Too many redirects."""
+
+
+class MissingSchema(RequestException, ValueError):
+    """The URL schema (e.g. http or https) is missing."""
+
+
+class InvalidSchema(RequestException, ValueError):
+    """See defaults.py for valid schemas."""
+
+
+class InvalidURL(RequestException, ValueError):
+    """The URL provided was somehow invalid."""
+
+
+class InvalidHeader(RequestException, ValueError):
+    """The header value provided was somehow invalid."""
+
+
+class InvalidProxyURL(InvalidURL):
+    """The proxy URL provided is invalid."""
+
+
+class ChunkedEncodingError(RequestException):
+    """The server declared chunked encoding but sent an invalid chunk."""
+
+
+class ContentDecodingError(RequestException, BaseHTTPError):
+    """Failed to decode response content"""
+
+
+class StreamConsumedError(RequestException, TypeError):
+    """The content for this response was already consumed"""
+
+
+class RetryError(RequestException):
+    """Custom retries logic failed"""
+
+
+class UnrewindableBodyError(RequestException):
+    """Requests encountered an error when trying to rewind a body"""
+
+# Warnings
+
+
+class RequestsWarning(Warning):
+    """Base warning for Requests."""
+    pass
+
+
+class FileModeWarning(RequestsWarning, DeprecationWarning):
+    """A file was opened in text mode, but Requests determined its binary length."""
+    pass
+
+
+class RequestsDependencyWarning(RequestsWarning):
+    """An imported dependency doesn't match the expected version range."""
+    pass
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/requests/exceptions.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/requests/exceptions.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..91e8628c9fb0c55744f05e3a96f8ad6696e5907c
GIT binary patch
literal 8345
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
LBE}}hD#;1}NHrQ~

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/requests/help.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/requests/help.py
new file mode 100644
index 0000000..3c3072b
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/requests/help.py
@@ -0,0 +1,119 @@
+"""Module containing bug report helper(s)."""
+from __future__ import print_function
+
+import json
+import platform
+import sys
+import ssl
+
+from pip._vendor import idna
+from pip._vendor import urllib3
+from pip._vendor import chardet
+
+from . import __version__ as requests_version
+
+try:
+    from pip._vendor.urllib3.contrib import pyopenssl
+except ImportError:
+    pyopenssl = None
+    OpenSSL = None
+    cryptography = None
+else:
+    import OpenSSL
+    import cryptography
+
+
+def _implementation():
+    """Return a dict with the Python implementation and version.
+
+    Provide both the name and the version of the Python implementation
+    currently running. For example, on CPython 2.7.5 it will return
+    {'name': 'CPython', 'version': '2.7.5'}.
+
+    This function works best on CPython and PyPy: in particular, it probably
+    doesn't work for Jython or IronPython. Future investigation should be done
+    to work out the correct shape of the code for those platforms.
+    """
+    implementation = platform.python_implementation()
+
+    if implementation == 'CPython':
+        implementation_version = platform.python_version()
+    elif implementation == 'PyPy':
+        implementation_version = '%s.%s.%s' % (sys.pypy_version_info.major,
+                                               sys.pypy_version_info.minor,
+                                               sys.pypy_version_info.micro)
+        if sys.pypy_version_info.releaselevel != 'final':
+            implementation_version = ''.join([
+                implementation_version, sys.pypy_version_info.releaselevel
+            ])
+    elif implementation == 'Jython':
+        implementation_version = platform.python_version()  # Complete Guess
+    elif implementation == 'IronPython':
+        implementation_version = platform.python_version()  # Complete Guess
+    else:
+        implementation_version = 'Unknown'
+
+    return {'name': implementation, 'version': implementation_version}
+
+
+def info():
+    """Generate information for a bug report."""
+    try:
+        platform_info = {
+            'system': platform.system(),
+            'release': platform.release(),
+        }
+    except IOError:
+        platform_info = {
+            'system': 'Unknown',
+            'release': 'Unknown',
+        }
+
+    implementation_info = _implementation()
+    urllib3_info = {'version': urllib3.__version__}
+    chardet_info = {'version': chardet.__version__}
+
+    pyopenssl_info = {
+        'version': None,
+        'openssl_version': '',
+    }
+    if OpenSSL:
+        pyopenssl_info = {
+            'version': OpenSSL.__version__,
+            'openssl_version': '%x' % OpenSSL.SSL.OPENSSL_VERSION_NUMBER,
+        }
+    cryptography_info = {
+        'version': getattr(cryptography, '__version__', ''),
+    }
+    idna_info = {
+        'version': getattr(idna, '__version__', ''),
+    }
+
+    system_ssl = ssl.OPENSSL_VERSION_NUMBER
+    system_ssl_info = {
+        'version': '%x' % system_ssl if system_ssl is not None else ''
+    }
+
+    return {
+        'platform': platform_info,
+        'implementation': implementation_info,
+        'system_ssl': system_ssl_info,
+        'using_pyopenssl': pyopenssl is not None,
+        'pyOpenSSL': pyopenssl_info,
+        'urllib3': urllib3_info,
+        'chardet': chardet_info,
+        'cryptography': cryptography_info,
+        'idna': idna_info,
+        'requests': {
+            'version': requests_version,
+        },
+    }
+
+
+def main():
+    """Pretty-print the bug information as JSON."""
+    print(json.dumps(info(), sort_keys=True, indent=2))
+
+
+if __name__ == '__main__':
+    main()
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/requests/help.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/requests/help.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..c197b0501524006ead28876fd8c3c0d7ad6260d8
GIT binary patch
literal 3572
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

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/requests/hooks.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/requests/hooks.py
new file mode 100644
index 0000000..7a51f21
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/requests/hooks.py
@@ -0,0 +1,34 @@
+# -*- coding: utf-8 -*-
+
+"""
+requests.hooks
+~~~~~~~~~~~~~~
+
+This module provides the capabilities for the Requests hooks system.
+
+Available hooks:
+
+``response``:
+    The response generated from a Request.
+"""
+HOOKS = ['response']
+
+
+def default_hooks():
+    return {event: [] for event in HOOKS}
+
+# TODO: response is the only one
+
+
+def dispatch_hook(key, hooks, hook_data, **kwargs):
+    """Dispatches a hook dictionary on a given piece of data."""
+    hooks = hooks or {}
+    hooks = hooks.get(key)
+    if hooks:
+        if hasattr(hooks, '__call__'):
+            hooks = [hooks]
+        for hook in hooks:
+            _hook_data = hook(hook_data, **kwargs)
+            if _hook_data is not None:
+                hook_data = _hook_data
+    return hook_data
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/requests/hooks.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/requests/hooks.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..91f5c1b7e01586bc0f56d00cca1ae4a338932fbf
GIT binary patch
literal 1398
zcmZSn%**AGdLky70SXuy7#JKF7#NCG85kH+7#N}$7*ZG+(is_|7#UKS7+M$@qL>&`
zn86HYh7=ZtU=3D~@{J4(3|vL2g{7&*CB=Ff`T5z!Ty-dbiz_4}vsfWFKczG$RiU6L
zzbrE)wOFAfBUK?eu^=%iGbghoGqqSDEx!mX7z8y;0c@B;ab<ByYOWp^mt$FCW=>*K
zPAWvgii;~Dp(wSuAV04-H6g)@OF=<FAtWPJ0Vbx9o|>0hlvt9QqL5aUpR16l05w^U
ztAvArfdQrt9t2Db3=GZ;3=GA5pderbd9{Rr!KImzAy@+>=a&o$BoK>*fq@|yq*9WB
zfgzKDp@xAWmY<=Pks+Odp@xxRG801~8$+-LC}<%BNK*-j&@(6j1zT!aYF-IM3Z$qw
zmw|ynzo00yEU_e2zbvsxKP^8eCAFwnKPg4OJSizJ*EF}-$S}z~y(-<p)S^5mtIEs(
z1k&^LL-Y$W3v@H{ic1o6a&+CwJUop9Ktf;~UzVDel3%0`iy(b)nCcZ&7IQH$FxaGI
zCYL1V=N8xrfjk3pA18wb$dh14dieW$BYR?CTw1~lijCB?#L}FSc(C&YVUA^BOlD?a
zU|?flU;xF4H%PpK0UQMdoS=BAWdub>7C3^M89@<L!^lun!cYPhPhn(eW@0F^0jWs`
z%jPjKRG5OeF0on+wJZ!ZEDSYF3^mLQy^IXCtPC}*psbM1$x!4BV%IV;6gq=Ycpd{t
zU9bkoHN|EO3=A%r#RZ8a$r-7|3W?z4ssIY=%>2B>qDqDQJcUGs^vtr<JcWYH)Z|o!
z{4|A>#F9ikaI%b#PfpCqiI4XKn^pocGCj4Vgq?wbAtSLkv81G^1ms!2{Jc~Rkk7#?
zvQsO;Q3ej55>AlX{QT^Akf|jgMcL(vMd`(0jUXi@px6foCRoWpCPYZ|LW2wJBymtQ
zihvRu6AvRlBO4<>BM&1lm=s|2(*SuM92)WQDf!9q@j;*v3Id4+@iQ<mAp8Pm(LZN_
XBhe-oT-w=z(rz&*0@xTinK{`2Q0QYi

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/requests/models.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/requests/models.py
new file mode 100644
index 0000000..0839957
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/requests/models.py
@@ -0,0 +1,953 @@
+# -*- coding: utf-8 -*-
+
+"""
+requests.models
+~~~~~~~~~~~~~~~
+
+This module contains the primary objects that power Requests.
+"""
+
+import datetime
+import sys
+
+# Import encoding now, to avoid implicit import later.
+# Implicit import within threads may cause LookupError when standard library is in a ZIP,
+# such as in Embedded Python. See https://github.com/requests/requests/issues/3578.
+import encodings.idna
+
+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 .compat import (
+    Callable, Mapping,
+    cookielib, urlunparse, urlsplit, urlencode, str, bytes,
+    is_py2, chardet, builtin_str, basestring)
+from .compat import json as complexjson
+from .status_codes import codes
+
+#: The set of HTTP status codes that indicate an automatically
+#: processable redirect.
+REDIRECT_STATI = (
+    codes.moved,               # 301
+    codes.found,               # 302
+    codes.other,               # 303
+    codes.temporary_redirect,  # 307
+    codes.permanent_redirect,  # 308
+)
+
+DEFAULT_REDIRECT_LIMIT = 30
+CONTENT_CHUNK_SIZE = 10 * 1024
+ITER_CHUNK_SIZE = 512
+
+
+class RequestEncodingMixin(object):
+    @property
+    def path_url(self):
+        """Build the path URL to use."""
+
+        url = []
+
+        p = urlsplit(self.url)
+
+        path = p.path
+        if not path:
+            path = '/'
+
+        url.append(path)
+
+        query = p.query
+        if query:
+            url.append('?')
+            url.append(query)
+
+        return ''.join(url)
+
+    @staticmethod
+    def _encode_params(data):
+        """Encode parameters in a piece of data.
+
+        Will successfully encode parameters when passed as a dict or a list of
+        2-tuples. Order is retained if data is a list of 2-tuples but arbitrary
+        if parameters are supplied as a dict.
+        """
+
+        if isinstance(data, (str, bytes)):
+            return data
+        elif hasattr(data, 'read'):
+            return data
+        elif hasattr(data, '__iter__'):
+            result = []
+            for k, vs in to_key_val_list(data):
+                if isinstance(vs, basestring) or not hasattr(vs, '__iter__'):
+                    vs = [vs]
+                for v in vs:
+                    if v is not None:
+                        result.append(
+                            (k.encode('utf-8') if isinstance(k, str) else k,
+                             v.encode('utf-8') if isinstance(v, str) else v))
+            return urlencode(result, doseq=True)
+        else:
+            return data
+
+    @staticmethod
+    def _encode_files(files, data):
+        """Build the body for a multipart/form-data request.
+
+        Will successfully encode files when passed as a dict or a list of
+        tuples. Order is retained if data is a list of tuples but arbitrary
+        if parameters are supplied as a dict.
+        The tuples may be 2-tuples (filename, fileobj), 3-tuples (filename, fileobj, contentype)
+        or 4-tuples (filename, fileobj, contentype, custom_headers).
+        """
+        if (not files):
+            raise ValueError("Files must be provided.")
+        elif isinstance(data, basestring):
+            raise ValueError("Data must not be a string.")
+
+        new_fields = []
+        fields = to_key_val_list(data or {})
+        files = to_key_val_list(files or {})
+
+        for field, val in fields:
+            if isinstance(val, basestring) or not hasattr(val, '__iter__'):
+                val = [val]
+            for v in val:
+                if v is not None:
+                    # Don't call str() on bytestrings: in Py3 it all goes wrong.
+                    if not isinstance(v, bytes):
+                        v = str(v)
+
+                    new_fields.append(
+                        (field.decode('utf-8') if isinstance(field, bytes) else field,
+                         v.encode('utf-8') if isinstance(v, str) else v))
+
+        for (k, v) in files:
+            # support for explicit filename
+            ft = None
+            fh = None
+            if isinstance(v, (tuple, list)):
+                if len(v) == 2:
+                    fn, fp = v
+                elif len(v) == 3:
+                    fn, fp, ft = v
+                else:
+                    fn, fp, ft, fh = v
+            else:
+                fn = guess_filename(v) or k
+                fp = v
+
+            if isinstance(fp, (str, bytes, bytearray)):
+                fdata = fp
+            elif hasattr(fp, 'read'):
+                fdata = fp.read()
+            elif fp is None:
+                continue
+            else:
+                fdata = fp
+
+            rf = RequestField(name=k, data=fdata, filename=fn, headers=fh)
+            rf.make_multipart(content_type=ft)
+            new_fields.append(rf)
+
+        body, content_type = encode_multipart_formdata(new_fields)
+
+        return body, content_type
+
+
+class RequestHooksMixin(object):
+    def register_hook(self, event, hook):
+        """Properly register a hook."""
+
+        if event not in self.hooks:
+            raise ValueError('Unsupported event specified, with event name "%s"' % (event))
+
+        if isinstance(hook, Callable):
+            self.hooks[event].append(hook)
+        elif hasattr(hook, '__iter__'):
+            self.hooks[event].extend(h for h in hook if isinstance(h, Callable))
+
+    def deregister_hook(self, event, hook):
+        """Deregister a previously registered hook.
+        Returns True if the hook existed, False if not.
+        """
+
+        try:
+            self.hooks[event].remove(hook)
+            return True
+        except ValueError:
+            return False
+
+
+class Request(RequestHooksMixin):
+    """A user-created :class:`Request <Request>` object.
+
+    Used to prepare a :class:`PreparedRequest <PreparedRequest>`, which is sent to the server.
+
+    :param method: HTTP method to use.
+    :param url: URL to send.
+    :param headers: dictionary of headers to send.
+    :param files: dictionary of {filename: fileobject} files to multipart upload.
+    :param data: the body to attach to the request. If a dictionary or
+        list of tuples ``[(key, value)]`` is provided, form-encoding will
+        take place.
+    :param json: json for the body to attach to the request (if files or data is not specified).
+    :param params: URL parameters to append to the URL. If a dictionary or
+        list of tuples ``[(key, value)]`` is provided, form-encoding will
+        take place.
+    :param auth: Auth handler or (user, pass) tuple.
+    :param cookies: dictionary or CookieJar of cookies to attach to this request.
+    :param hooks: dictionary of callback hooks, for internal usage.
+
+    Usage::
+
+      >>> import requests
+      >>> req = requests.Request('GET', 'https://httpbin.org/get')
+      >>> req.prepare()
+      <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):
+
+        # Default empty dicts for dict params.
+        data = [] if data is None else data
+        files = [] if files is None else files
+        headers = {} if headers is None else headers
+        params = {} if params is None else params
+        hooks = {} if hooks is None else hooks
+
+        self.hooks = default_hooks()
+        for (k, v) in list(hooks.items()):
+            self.register_hook(event=k, hook=v)
+
+        self.method = method
+        self.url = url
+        self.headers = headers
+        self.files = files
+        self.data = data
+        self.json = json
+        self.params = params
+        self.auth = auth
+        self.cookies = cookies
+
+    def __repr__(self):
+        return '<Request [%s]>' % (self.method)
+
+    def prepare(self):
+        """Constructs a :class:`PreparedRequest <PreparedRequest>` for transmission and returns it."""
+        p = PreparedRequest()
+        p.prepare(
+            method=self.method,
+            url=self.url,
+            headers=self.headers,
+            files=self.files,
+            data=self.data,
+            json=self.json,
+            params=self.params,
+            auth=self.auth,
+            cookies=self.cookies,
+            hooks=self.hooks,
+        )
+        return p
+
+
+class PreparedRequest(RequestEncodingMixin, RequestHooksMixin):
+    """The fully mutable :class:`PreparedRequest <PreparedRequest>` object,
+    containing the exact bytes that will be sent to the server.
+
+    Generated from either a :class:`Request <Request>` object or manually.
+
+    Usage::
+
+      >>> import requests
+      >>> req = requests.Request('GET', 'https://httpbin.org/get')
+      >>> r = req.prepare()
+      <PreparedRequest [GET]>
+
+      >>> s = requests.Session()
+      >>> s.send(r)
+      <Response [200]>
+    """
+
+    def __init__(self):
+        #: HTTP verb to send to the server.
+        self.method = None
+        #: HTTP URL to send the request to.
+        self.url = None
+        #: dictionary of HTTP headers.
+        self.headers = None
+        # The `CookieJar` used to create the Cookie header will be stored here
+        # after prepare_cookies is called
+        self._cookies = None
+        #: request body to send to the server.
+        self.body = None
+        #: dictionary of callback hooks, for internal usage.
+        self.hooks = default_hooks()
+        #: integer denoting starting position of a readable file-like body.
+        self._body_position = None
+
+    def prepare(self,
+            method=None, url=None, headers=None, files=None, data=None,
+            params=None, auth=None, cookies=None, hooks=None, json=None):
+        """Prepares the entire request with the given parameters."""
+
+        self.prepare_method(method)
+        self.prepare_url(url, params)
+        self.prepare_headers(headers)
+        self.prepare_cookies(cookies)
+        self.prepare_body(data, files, json)
+        self.prepare_auth(auth, url)
+
+        # Note that prepare_auth must be last to enable authentication schemes
+        # such as OAuth to work on a fully prepared request.
+
+        # This MUST go after prepare_auth. Authenticators could add a hook
+        self.prepare_hooks(hooks)
+
+    def __repr__(self):
+        return '<PreparedRequest [%s]>' % (self.method)
+
+    def copy(self):
+        p = PreparedRequest()
+        p.method = self.method
+        p.url = self.url
+        p.headers = self.headers.copy() if self.headers is not None else None
+        p._cookies = _copy_cookie_jar(self._cookies)
+        p.body = self.body
+        p.hooks = self.hooks
+        p._body_position = self._body_position
+        return p
+
+    def prepare_method(self, method):
+        """Prepares the given HTTP method."""
+        self.method = method
+        if self.method is not None:
+            self.method = to_native_string(self.method.upper())
+
+    @staticmethod
+    def _get_idna_encoded_host(host):
+        from pip._vendor import idna
+
+        try:
+            host = idna.encode(host, uts46=True).decode('utf-8')
+        except idna.IDNAError:
+            raise UnicodeError
+        return host
+
+    def prepare_url(self, url, params):
+        """Prepares the given HTTP URL."""
+        #: Accept objects that have string representations.
+        #: We're unable to blindly call unicode/str functions
+        #: as this will include the bytestring indicator (b'')
+        #: on python 3.x.
+        #: https://github.com/requests/requests/pull/2238
+        if isinstance(url, bytes):
+            url = url.decode('utf8')
+        else:
+            url = unicode(url) if is_py2 else str(url)
+
+        # Remove leading whitespaces from url
+        url = url.lstrip()
+
+        # Don't do any URL preparation for non-HTTP schemes like `mailto`,
+        # `data` etc to work around exceptions from `url_parse`, which
+        # handles RFC 3986 only.
+        if ':' in url and not url.lower().startswith('http'):
+            self.url = url
+            return
+
+        # Support for unicode domain names and paths.
+        try:
+            scheme, auth, host, port, path, query, fragment = parse_url(url)
+        except LocationParseError as e:
+            raise InvalidURL(*e.args)
+
+        if not scheme:
+            error = ("Invalid URL {0!r}: No schema supplied. Perhaps you meant http://{0}?")
+            error = error.format(to_native_string(url, 'utf8'))
+
+            raise MissingSchema(error)
+
+        if not host:
+            raise InvalidURL("Invalid URL %r: No host supplied" % url)
+
+        # In general, we want to try IDNA encoding the hostname if the string contains
+        # non-ASCII characters. This allows users to automatically get the correct IDNA
+        # behaviour. For strings containing only ASCII characters, we need to also verify
+        # it doesn't start with a wildcard (*), before allowing the unencoded hostname.
+        if not unicode_is_ascii(host):
+            try:
+                host = self._get_idna_encoded_host(host)
+            except UnicodeError:
+                raise InvalidURL('URL has an invalid label.')
+        elif host.startswith(u'*'):
+            raise InvalidURL('URL has an invalid label.')
+
+        # Carefully reconstruct the network location
+        netloc = auth or ''
+        if netloc:
+            netloc += '@'
+        netloc += host
+        if port:
+            netloc += ':' + str(port)
+
+        # Bare domains aren't valid URLs.
+        if not path:
+            path = '/'
+
+        if is_py2:
+            if isinstance(scheme, str):
+                scheme = scheme.encode('utf-8')
+            if isinstance(netloc, str):
+                netloc = netloc.encode('utf-8')
+            if isinstance(path, str):
+                path = path.encode('utf-8')
+            if isinstance(query, str):
+                query = query.encode('utf-8')
+            if isinstance(fragment, str):
+                fragment = fragment.encode('utf-8')
+
+        if isinstance(params, (str, bytes)):
+            params = to_native_string(params)
+
+        enc_params = self._encode_params(params)
+        if enc_params:
+            if query:
+                query = '%s&%s' % (query, enc_params)
+            else:
+                query = enc_params
+
+        url = requote_uri(urlunparse([scheme, netloc, path, None, query, fragment]))
+        self.url = url
+
+    def prepare_headers(self, headers):
+        """Prepares the given HTTP headers."""
+
+        self.headers = CaseInsensitiveDict()
+        if headers:
+            for header in headers.items():
+                # Raise exception on invalid header value.
+                check_header_validity(header)
+                name, value = header
+                self.headers[to_native_string(name)] = value
+
+    def prepare_body(self, data, files, json=None):
+        """Prepares the given HTTP body data."""
+
+        # Check if file, fo, generator, iterator.
+        # If not, run through normal process.
+
+        # Nottin' on you.
+        body = None
+        content_type = None
+
+        if not data and json is not None:
+            # urllib3 requires a bytes-like body. Python 2's json.dumps
+            # provides this natively, but Python 3 gives a Unicode string.
+            content_type = 'application/json'
+            body = complexjson.dumps(json)
+            if not isinstance(body, bytes):
+                body = body.encode('utf-8')
+
+        is_stream = all([
+            hasattr(data, '__iter__'),
+            not isinstance(data, (basestring, list, tuple, Mapping))
+        ])
+
+        try:
+            length = super_len(data)
+        except (TypeError, AttributeError, UnsupportedOperation):
+            length = None
+
+        if is_stream:
+            body = data
+
+            if getattr(body, 'tell', None) is not None:
+                # Record the current file position before reading.
+                # This will allow us to rewind a file in the event
+                # of a redirect.
+                try:
+                    self._body_position = body.tell()
+                except (IOError, OSError):
+                    # This differentiates from None, allowing us to catch
+                    # a failed `tell()` later when trying to rewind the body
+                    self._body_position = object()
+
+            if files:
+                raise NotImplementedError('Streamed bodies and files are mutually exclusive.')
+
+            if length:
+                self.headers['Content-Length'] = builtin_str(length)
+            else:
+                self.headers['Transfer-Encoding'] = 'chunked'
+        else:
+            # Multi-part file uploads.
+            if files:
+                (body, content_type) = self._encode_files(files, data)
+            else:
+                if data:
+                    body = self._encode_params(data)
+                    if isinstance(data, basestring) or hasattr(data, 'read'):
+                        content_type = None
+                    else:
+                        content_type = 'application/x-www-form-urlencoded'
+
+            self.prepare_content_length(body)
+
+            # Add content-type if it wasn't explicitly provided.
+            if content_type and ('content-type' not in self.headers):
+                self.headers['Content-Type'] = content_type
+
+        self.body = body
+
+    def prepare_content_length(self, body):
+        """Prepare Content-Length header based on request method and body"""
+        if body is not None:
+            length = super_len(body)
+            if length:
+                # If length exists, set it. Otherwise, we fallback
+                # to Transfer-Encoding: chunked.
+                self.headers['Content-Length'] = builtin_str(length)
+        elif self.method not in ('GET', 'HEAD') and self.headers.get('Content-Length') is None:
+            # Set Content-Length to 0 for methods that can have a body
+            # but don't provide one. (i.e. not GET or HEAD)
+            self.headers['Content-Length'] = '0'
+
+    def prepare_auth(self, auth, url=''):
+        """Prepares the given HTTP auth data."""
+
+        # If no Auth is explicitly provided, extract it from the URL first.
+        if auth is None:
+            url_auth = get_auth_from_url(self.url)
+            auth = url_auth if any(url_auth) else None
+
+        if auth:
+            if isinstance(auth, tuple) and len(auth) == 2:
+                # special-case basic HTTP auth
+                auth = HTTPBasicAuth(*auth)
+
+            # Allow auth to make its changes.
+            r = auth(self)
+
+            # Update self to reflect the auth changes.
+            self.__dict__.update(r.__dict__)
+
+            # Recompute Content-Length
+            self.prepare_content_length(self.body)
+
+    def prepare_cookies(self, cookies):
+        """Prepares the given HTTP cookie data.
+
+        This function eventually generates a ``Cookie`` header from the
+        given cookies using cookielib. Due to cookielib's design, the header
+        will not be regenerated if it already exists, meaning this function
+        can only be called once for the life of the
+        :class:`PreparedRequest <PreparedRequest>` object. Any subsequent calls
+        to ``prepare_cookies`` will have no actual effect, unless the "Cookie"
+        header is removed beforehand.
+        """
+        if isinstance(cookies, cookielib.CookieJar):
+            self._cookies = cookies
+        else:
+            self._cookies = cookiejar_from_dict(cookies)
+
+        cookie_header = get_cookie_header(self._cookies, self)
+        if cookie_header is not None:
+            self.headers['Cookie'] = cookie_header
+
+    def prepare_hooks(self, hooks):
+        """Prepares the given hooks."""
+        # hooks can be passed as None to the prepare method and to this
+        # method. To prevent iterating over None, simply use an empty list
+        # if hooks is False-y
+        hooks = hooks or []
+        for event in hooks:
+            self.register_hook(event, hooks[event])
+
+
+class Response(object):
+    """The :class:`Response <Response>` object, which contains a
+    server's response to an HTTP request.
+    """
+
+    __attrs__ = [
+        '_content', 'status_code', 'headers', 'url', 'history',
+        'encoding', 'reason', 'cookies', 'elapsed', 'request'
+    ]
+
+    def __init__(self):
+        self._content = False
+        self._content_consumed = False
+        self._next = None
+
+        #: Integer Code of responded HTTP Status, e.g. 404 or 200.
+        self.status_code = None
+
+        #: Case-insensitive Dictionary of Response Headers.
+        #: For example, ``headers['content-encoding']`` will return the
+        #: value of a ``'Content-Encoding'`` response header.
+        self.headers = CaseInsensitiveDict()
+
+        #: File-like object representation of response (for advanced usage).
+        #: Use of ``raw`` requires that ``stream=True`` be set on the request.
+        # This requirement does not apply for use internally to Requests.
+        self.raw = None
+
+        #: Final URL location of Response.
+        self.url = None
+
+        #: Encoding to decode with when accessing r.text.
+        self.encoding = None
+
+        #: A list of :class:`Response <Response>` objects from
+        #: the history of the Request. Any redirect responses will end
+        #: up here. The list is sorted from the oldest to the most recent request.
+        self.history = []
+
+        #: Textual reason of responded HTTP Status, e.g. "Not Found" or "OK".
+        self.reason = None
+
+        #: A CookieJar of Cookies the server sent back.
+        self.cookies = cookiejar_from_dict({})
+
+        #: The amount of time elapsed between sending the request
+        #: and the arrival of the response (as a timedelta).
+        #: This property specifically measures the time taken between sending
+        #: the first byte of the request and finishing parsing the headers. It
+        #: is therefore unaffected by consuming the response content or the
+        #: value of the ``stream`` keyword argument.
+        self.elapsed = datetime.timedelta(0)
+
+        #: The :class:`PreparedRequest <PreparedRequest>` object to which this
+        #: is a response.
+        self.request = None
+
+    def __enter__(self):
+        return self
+
+    def __exit__(self, *args):
+        self.close()
+
+    def __getstate__(self):
+        # Consume everything; accessing the content attribute makes
+        # sure the content has been fully read.
+        if not self._content_consumed:
+            self.content
+
+        return {attr: getattr(self, attr, None) for attr in self.__attrs__}
+
+    def __setstate__(self, state):
+        for name, value in state.items():
+            setattr(self, name, value)
+
+        # pickled objects do not have .raw
+        setattr(self, '_content_consumed', True)
+        setattr(self, 'raw', None)
+
+    def __repr__(self):
+        return '<Response [%s]>' % (self.status_code)
+
+    def __bool__(self):
+        """Returns True if :attr:`status_code` is less than 400.
+
+        This attribute checks if the status code of the response is between
+        400 and 600 to see if there was a client error or a server error. If
+        the status code, is between 200 and 400, this will return True. This
+        is **not** a check to see if the response code is ``200 OK``.
+        """
+        return self.ok
+
+    def __nonzero__(self):
+        """Returns True if :attr:`status_code` is less than 400.
+
+        This attribute checks if the status code of the response is between
+        400 and 600 to see if there was a client error or a server error. If
+        the status code, is between 200 and 400, this will return True. This
+        is **not** a check to see if the response code is ``200 OK``.
+        """
+        return self.ok
+
+    def __iter__(self):
+        """Allows you to use a response as an iterator."""
+        return self.iter_content(128)
+
+    @property
+    def ok(self):
+        """Returns True if :attr:`status_code` is less than 400, False if not.
+
+        This attribute checks if the status code of the response is between
+        400 and 600 to see if there was a client error or a server error. If
+        the status code is between 200 and 400, this will return True. This
+        is **not** a check to see if the response code is ``200 OK``.
+        """
+        try:
+            self.raise_for_status()
+        except HTTPError:
+            return False
+        return True
+
+    @property
+    def is_redirect(self):
+        """True if this Response is a well-formed HTTP redirect that could have
+        been processed automatically (by :meth:`Session.resolve_redirects`).
+        """
+        return ('location' in self.headers and self.status_code in REDIRECT_STATI)
+
+    @property
+    def is_permanent_redirect(self):
+        """True if this Response one of the permanent versions of redirect."""
+        return ('location' in self.headers and self.status_code in (codes.moved_permanently, codes.permanent_redirect))
+
+    @property
+    def next(self):
+        """Returns a PreparedRequest for the next request in a redirect chain, if there is one."""
+        return self._next
+
+    @property
+    def apparent_encoding(self):
+        """The apparent encoding, provided by the chardet library."""
+        return chardet.detect(self.content)['encoding']
+
+    def iter_content(self, chunk_size=1, decode_unicode=False):
+        """Iterates over the response data.  When stream=True is set on the
+        request, this avoids reading the content at once into memory for
+        large responses.  The chunk size is the number of bytes it should
+        read into memory.  This is not necessarily the length of each item
+        returned as decoding can take place.
+
+        chunk_size must be of type int or None. A value of None will
+        function differently depending on the value of `stream`.
+        stream=True will read data as it arrives in whatever size the
+        chunks are received. If stream=False, data is returned as
+        a single chunk.
+
+        If decode_unicode is True, content will be decoded using the best
+        available encoding based on the response.
+        """
+
+        def generate():
+            # Special case for urllib3.
+            if hasattr(self.raw, 'stream'):
+                try:
+                    for chunk in self.raw.stream(chunk_size, decode_content=True):
+                        yield chunk
+                except ProtocolError as e:
+                    raise ChunkedEncodingError(e)
+                except DecodeError as e:
+                    raise ContentDecodingError(e)
+                except ReadTimeoutError as e:
+                    raise ConnectionError(e)
+            else:
+                # Standard file-like object.
+                while True:
+                    chunk = self.raw.read(chunk_size)
+                    if not chunk:
+                        break
+                    yield chunk
+
+            self._content_consumed = True
+
+        if self._content_consumed and isinstance(self._content, bool):
+            raise StreamConsumedError()
+        elif chunk_size is not None and not isinstance(chunk_size, int):
+            raise TypeError("chunk_size must be an int, it is instead a %s." % type(chunk_size))
+        # simulate reading small chunks of the content
+        reused_chunks = iter_slices(self._content, chunk_size)
+
+        stream_chunks = generate()
+
+        chunks = reused_chunks if self._content_consumed else stream_chunks
+
+        if decode_unicode:
+            chunks = stream_decode_response_unicode(chunks, self)
+
+        return chunks
+
+    def iter_lines(self, chunk_size=ITER_CHUNK_SIZE, decode_unicode=False, delimiter=None):
+        """Iterates over the response data, one line at a time.  When
+        stream=True is set on the request, this avoids reading the
+        content at once into memory for large responses.
+
+        .. note:: This method is not reentrant safe.
+        """
+
+        pending = None
+
+        for chunk in self.iter_content(chunk_size=chunk_size, decode_unicode=decode_unicode):
+
+            if pending is not None:
+                chunk = pending + chunk
+
+            if delimiter:
+                lines = chunk.split(delimiter)
+            else:
+                lines = chunk.splitlines()
+
+            if lines and lines[-1] and chunk and lines[-1][-1] == chunk[-1]:
+                pending = lines.pop()
+            else:
+                pending = None
+
+            for line in lines:
+                yield line
+
+        if pending is not None:
+            yield pending
+
+    @property
+    def content(self):
+        """Content of the response, in bytes."""
+
+        if self._content is False:
+            # Read the contents.
+            if self._content_consumed:
+                raise RuntimeError(
+                    'The content for this response was already consumed')
+
+            if self.status_code == 0 or self.raw is None:
+                self._content = None
+            else:
+                self._content = b''.join(self.iter_content(CONTENT_CHUNK_SIZE)) or b''
+
+        self._content_consumed = True
+        # don't need to release the connection; that's been handled by urllib3
+        # since we exhausted the data.
+        return self._content
+
+    @property
+    def text(self):
+        """Content of the response, in unicode.
+
+        If Response.encoding is None, encoding will be guessed using
+        ``chardet``.
+
+        The encoding of the response content is determined based solely on HTTP
+        headers, following RFC 2616 to the letter. If you can take advantage of
+        non-HTTP knowledge to make a better guess at the encoding, you should
+        set ``r.encoding`` appropriately before accessing this property.
+        """
+
+        # Try charset from content-type
+        content = None
+        encoding = self.encoding
+
+        if not self.content:
+            return str('')
+
+        # Fallback to auto-detected encoding.
+        if self.encoding is None:
+            encoding = self.apparent_encoding
+
+        # Decode unicode from given encoding.
+        try:
+            content = str(self.content, encoding, errors='replace')
+        except (LookupError, TypeError):
+            # A LookupError is raised if the encoding was not found which could
+            # indicate a misspelling or similar mistake.
+            #
+            # A TypeError can be raised if encoding is None
+            #
+            # So we try blindly encoding.
+            content = str(self.content, errors='replace')
+
+        return content
+
+    def json(self, **kwargs):
+        r"""Returns the json-encoded content of a response, if any.
+
+        :param \*\*kwargs: Optional arguments that ``json.loads`` takes.
+        :raises ValueError: 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
+            # a best guess).
+            encoding = guess_json_utf(self.content)
+            if encoding is not None:
+                try:
+                    return complexjson.loads(
+                        self.content.decode(encoding), **kwargs
+                    )
+                except UnicodeDecodeError:
+                    # Wrong UTF codec detected; usually because it's not UTF-8
+                    # but some other 8-bit codec.  This is an RFC violation,
+                    # and the server didn't bother to tell us what codec *was*
+                    # used.
+                    pass
+        return complexjson.loads(self.text, **kwargs)
+
+    @property
+    def links(self):
+        """Returns the parsed header links of the response, if any."""
+
+        header = self.headers.get('link')
+
+        # l = MultiDict()
+        l = {}
+
+        if header:
+            links = parse_header_links(header)
+
+            for link in links:
+                key = link.get('rel') or link.get('url')
+                l[key] = link
+
+        return l
+
+    def raise_for_status(self):
+        """Raises stored :class:`HTTPError`, if one occurred."""
+
+        http_error_msg = ''
+        if isinstance(self.reason, bytes):
+            # We attempt to decode utf-8 first because some servers
+            # choose to localize their reason strings. If the string
+            # isn't utf-8, we fall back to iso-8859-1 for all other
+            # encodings. (See PR #3538)
+            try:
+                reason = self.reason.decode('utf-8')
+            except UnicodeDecodeError:
+                reason = self.reason.decode('iso-8859-1')
+        else:
+            reason = self.reason
+
+        if 400 <= self.status_code < 500:
+            http_error_msg = u'%s Client Error: %s for url: %s' % (self.status_code, reason, self.url)
+
+        elif 500 <= self.status_code < 600:
+            http_error_msg = u'%s Server Error: %s for url: %s' % (self.status_code, reason, self.url)
+
+        if http_error_msg:
+            raise HTTPError(http_error_msg, response=self)
+
+    def close(self):
+        """Releases the connection back to the pool. Once this method has been
+        called the underlying ``raw`` object must not be accessed again.
+
+        *Note: Should not normally need to be called explicitly.*
+        """
+        if not self._content_consumed:
+            self.raw.close()
+
+        release_conn = getattr(self.raw, 'release_conn', None)
+        if release_conn is not None:
+            release_conn()
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/requests/models.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/requests/models.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..7f78300589391fad7330eb6c6987361aa39d7938
GIT binary patch
literal 31863
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

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/requests/packages.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/requests/packages.py
new file mode 100644
index 0000000..9582fa7
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/requests/packages.py
@@ -0,0 +1,16 @@
+import sys
+
+# This code exists for backwards compatibility reasons.
+# I don't like it either. Just look the other way. :)
+
+for package in ('urllib3', 'idna', 'chardet'):
+    vendored_package = "pip._vendor." + package
+    locals()[package] = __import__(vendored_package)
+    # This traversal is apparently necessary such that the identities are
+    # preserved (requests.packages.urllib3.* is urllib3.*)
+    for mod in list(sys.modules):
+        if mod == vendored_package or mod.startswith(vendored_package + '.'):
+            unprefixed_mod = mod[len("pip._vendor."):]
+            sys.modules['pip._vendor.requests.packages.' + unprefixed_mod] = sys.modules[mod]
+
+# Kinda cool, though, right?
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/requests/packages.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/requests/packages.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..cd07134a21d96812018a43aaed422ccedb99ed5d
GIT binary patch
literal 643
zcmZSn%**AGdLky70Sed{7#JKF7#NBdF)%QsFfgPrGUPBYL@_W_^fRPzFu26FGej{m
zq_8riGBSuqF)^evGo&&xG&3@!vM@9=fJAL75*boi8B!S-ve-ZpF0la&QS1z<>>!2N
zObo@@Aa)i9h?~O3Al}T#P~-*@O63HZ+sw!yAH@aLp32T32{9;zogtNrLENU$jiJzu
zA-qtSAv}eVAy|Wxfq^0O|NsC0{Yuyw7#K>6a&j`0j7wNR!YO%)V8P^!#G;hcl42eP
z28M#n0=@XM)V!4ZBE1qu1_lPbVmUP7qSV6D)Z&t2y@JH#?8NlcVm%FJP>3LzUko$9
z7$gWaUxS;0fuRJfw6Yj%G1Pz(0R{#Jh@Gh^@i0Ly1_p-s_{`jb{GyWh_!3aS=j10R
z<`jb+pOaZ!0yZNzKczG$wHRz}ZhlG$NLz79Vo^zPd1grlSU4v&uY?ce`MiRn)U?cs
z)Rg$#{1gpPj3S8Q0tN;K{eq&*vc!^9{j$U&{j~g?l+>bP{iGEA@}#7^T+`fQBf})~
z^s00VQ;YJPtSU1D5J=C{5795kEYQu&D=taQ$<cKy^YAnd011IHG&J>L!KM%OV6k37
iWeEoZ1A`633wEH;E(W=ihn1I+i&2<aj8UFZfDr)T+?}uh

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/requests/sessions.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/requests/sessions.py
new file mode 100644
index 0000000..d73d700
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/requests/sessions.py
@@ -0,0 +1,770 @@
+# -*- coding: utf-8 -*-
+
+"""
+requests.session
+~~~~~~~~~~~~~~~~
+
+This module provides a Session object to manage and persist settings across
+requests (cookies, auth, proxies).
+"""
+import os
+import sys
+import time
+from datetime import timedelta
+
+from .auth import _basic_auth_str
+from .compat import cookielib, is_py3, OrderedDict, urljoin, urlparse, Mapping
+from .cookies import (
+    cookiejar_from_dict, extract_cookies_to_jar, RequestsCookieJar, merge_cookies)
+from .models import Request, PreparedRequest, DEFAULT_REDIRECT_LIMIT
+from .hooks import default_hooks, dispatch_hook
+from ._internal_utils import to_native_string
+from .utils import to_key_val_list, default_headers, DEFAULT_PORTS
+from .exceptions import (
+    TooManyRedirects, InvalidSchema, ChunkedEncodingError, ContentDecodingError)
+
+from .structures import CaseInsensitiveDict
+from .adapters import HTTPAdapter
+
+from .utils import (
+    requote_uri, get_environ_proxies, get_netrc_auth, should_bypass_proxies,
+    get_auth_from_url, rewind_body
+)
+
+from .status_codes import codes
+
+# formerly defined here, reexposed here for backward compatibility
+from .models import REDIRECT_STATI
+
+# Preferred clock, based on which one is more accurate on a given system.
+if sys.platform == 'win32':
+    try:  # Python 3.4+
+        preferred_clock = time.perf_counter
+    except AttributeError:  # Earlier than Python 3.
+        preferred_clock = time.clock
+else:
+    preferred_clock = time.time
+
+
+def merge_setting(request_setting, session_setting, dict_class=OrderedDict):
+    """Determines appropriate setting for a given request, taking into account
+    the explicit setting on that request, and the setting in the session. If a
+    setting is a dictionary, they will be merged together using `dict_class`
+    """
+
+    if session_setting is None:
+        return request_setting
+
+    if request_setting is None:
+        return session_setting
+
+    # Bypass if not a dictionary (e.g. verify)
+    if not (
+            isinstance(session_setting, Mapping) and
+            isinstance(request_setting, Mapping)
+    ):
+        return request_setting
+
+    merged_setting = dict_class(to_key_val_list(session_setting))
+    merged_setting.update(to_key_val_list(request_setting))
+
+    # Remove keys that are set to None. Extract keys first to avoid altering
+    # the dictionary during iteration.
+    none_keys = [k for (k, v) in merged_setting.items() if v is None]
+    for key in none_keys:
+        del merged_setting[key]
+
+    return merged_setting
+
+
+def merge_hooks(request_hooks, session_hooks, dict_class=OrderedDict):
+    """Properly merges both requests and session hooks.
+
+    This is necessary because when request_hooks == {'response': []}, the
+    merge breaks Session hooks entirely.
+    """
+    if session_hooks is None or session_hooks.get('response') == []:
+        return request_hooks
+
+    if request_hooks is None or request_hooks.get('response') == []:
+        return session_hooks
+
+    return merge_setting(request_hooks, session_hooks, dict_class)
+
+
+class SessionRedirectMixin(object):
+
+    def get_redirect_target(self, resp):
+        """Receives a Response. Returns a redirect URI or ``None``"""
+        # Due to the nature of how requests processes redirects this method will
+        # be called at least once upon the original response and at least twice
+        # on each subsequent redirect response (if any).
+        # If a custom mixin is used to handle this logic, it may be advantageous
+        # to cache the redirect location onto the response object as a private
+        # attribute.
+        if resp.is_redirect:
+            location = resp.headers['location']
+            # Currently the underlying http module on py3 decode headers
+            # in latin1, but empirical evidence suggests that latin1 is very
+            # rarely used with non-ASCII characters in HTTP headers.
+            # It is more likely to get UTF8 header rather than latin1.
+            # This causes incorrect handling of UTF8 encoded location headers.
+            # To solve this, we re-encode the location in latin1.
+            if is_py3:
+                location = location.encode('latin1')
+            return to_native_string(location, 'utf8')
+        return None
+
+    def should_strip_auth(self, old_url, new_url):
+        """Decide whether Authorization header should be removed when redirecting"""
+        old_parsed = urlparse(old_url)
+        new_parsed = urlparse(new_url)
+        if old_parsed.hostname != new_parsed.hostname:
+            return True
+        # Special case: allow http -> https redirect when using the standard
+        # ports. This isn't specified by RFC 7235, but is kept to avoid
+        # breaking backwards compatibility with older versions of requests
+        # that allowed any redirects on the same host.
+        if (old_parsed.scheme == 'http' and old_parsed.port in (80, None)
+                and new_parsed.scheme == 'https' and new_parsed.port in (443, None)):
+            return False
+
+        # Handle default port usage corresponding to scheme.
+        changed_port = old_parsed.port != new_parsed.port
+        changed_scheme = old_parsed.scheme != new_parsed.scheme
+        default_port = (DEFAULT_PORTS.get(old_parsed.scheme, None), None)
+        if (not changed_scheme and old_parsed.port in default_port
+                and new_parsed.port in default_port):
+            return False
+
+        # Standard case: root URI must match
+        return changed_port or changed_scheme
+
+    def resolve_redirects(self, resp, req, stream=False, timeout=None,
+                          verify=True, cert=None, proxies=None, yield_requests=False, **adapter_kwargs):
+        """Receives a Response. Returns a generator of Responses or Requests."""
+
+        hist = []  # keep track of history
+
+        url = self.get_redirect_target(resp)
+        previous_fragment = urlparse(req.url).fragment
+        while url:
+            prepared_request = req.copy()
+
+            # Update history and keep track of redirects.
+            # resp.history must ignore the original request in this loop
+            hist.append(resp)
+            resp.history = hist[1:]
+
+            try:
+                resp.content  # Consume socket so it can be released
+            except (ChunkedEncodingError, ContentDecodingError, RuntimeError):
+                resp.raw.read(decode_content=False)
+
+            if len(resp.history) >= self.max_redirects:
+                raise TooManyRedirects('Exceeded %s redirects.' % self.max_redirects, response=resp)
+
+            # Release the connection back into the pool.
+            resp.close()
+
+            # Handle redirection without scheme (see: RFC 1808 Section 4)
+            if url.startswith('//'):
+                parsed_rurl = urlparse(resp.url)
+                url = '%s:%s' % (to_native_string(parsed_rurl.scheme), url)
+
+            # Normalize url case and attach previous fragment if needed (RFC 7231 7.1.2)
+            parsed = urlparse(url)
+            if parsed.fragment == '' and previous_fragment:
+                parsed = parsed._replace(fragment=previous_fragment)
+            elif parsed.fragment:
+                previous_fragment = parsed.fragment
+            url = parsed.geturl()
+
+            # Facilitate relative 'location' headers, as allowed by RFC 7231.
+            # (e.g. '/path/to/resource' instead of 'http://domain.tld/path/to/resource')
+            # Compliant with RFC3986, we percent encode the url.
+            if not parsed.netloc:
+                url = urljoin(resp.url, requote_uri(url))
+            else:
+                url = requote_uri(url)
+
+            prepared_request.url = to_native_string(url)
+
+            self.rebuild_method(prepared_request, resp)
+
+            # https://github.com/requests/requests/issues/1084
+            if resp.status_code not in (codes.temporary_redirect, codes.permanent_redirect):
+                # https://github.com/requests/requests/issues/3490
+                purged_headers = ('Content-Length', 'Content-Type', 'Transfer-Encoding')
+                for header in purged_headers:
+                    prepared_request.headers.pop(header, None)
+                prepared_request.body = None
+
+            headers = prepared_request.headers
+            try:
+                del headers['Cookie']
+            except KeyError:
+                pass
+
+            # Extract any cookies sent on the response to the cookiejar
+            # in the new request. Because we've mutated our copied prepared
+            # request, use the old one that we haven't yet touched.
+            extract_cookies_to_jar(prepared_request._cookies, req, resp.raw)
+            merge_cookies(prepared_request._cookies, self.cookies)
+            prepared_request.prepare_cookies(prepared_request._cookies)
+
+            # Rebuild auth and proxy information.
+            proxies = self.rebuild_proxies(prepared_request, proxies)
+            self.rebuild_auth(prepared_request, resp)
+
+            # A failed tell() sets `_body_position` to `object()`. This non-None
+            # value ensures `rewindable` will be True, allowing us to raise an
+            # UnrewindableBodyError, instead of hanging the connection.
+            rewindable = (
+                prepared_request._body_position is not None and
+                ('Content-Length' in headers or 'Transfer-Encoding' in headers)
+            )
+
+            # Attempt to rewind consumed file-like object.
+            if rewindable:
+                rewind_body(prepared_request)
+
+            # Override the original request.
+            req = prepared_request
+
+            if yield_requests:
+                yield req
+            else:
+
+                resp = self.send(
+                    req,
+                    stream=stream,
+                    timeout=timeout,
+                    verify=verify,
+                    cert=cert,
+                    proxies=proxies,
+                    allow_redirects=False,
+                    **adapter_kwargs
+                )
+
+                extract_cookies_to_jar(self.cookies, prepared_request, resp.raw)
+
+                # extract redirect url, if any, for the next loop
+                url = self.get_redirect_target(resp)
+                yield resp
+
+    def rebuild_auth(self, prepared_request, response):
+        """When being redirected we may want to strip authentication from the
+        request to avoid leaking credentials. This method intelligently removes
+        and reapplies authentication where possible to avoid credential loss.
+        """
+        headers = prepared_request.headers
+        url = prepared_request.url
+
+        if 'Authorization' in headers and self.should_strip_auth(response.request.url, url):
+            # If we get redirected to a new host, we should strip out any
+            # authentication headers.
+            del headers['Authorization']
+
+        # .netrc might have more auth for us on our new host.
+        new_auth = get_netrc_auth(url) if self.trust_env else None
+        if new_auth is not None:
+            prepared_request.prepare_auth(new_auth)
+
+        return
+
+    def rebuild_proxies(self, prepared_request, proxies):
+        """This method re-evaluates the proxy configuration by considering the
+        environment variables. If we are redirected to a URL covered by
+        NO_PROXY, we strip the proxy configuration. Otherwise, we set missing
+        proxy keys for this URL (in case they were stripped by a previous
+        redirect).
+
+        This method also replaces the Proxy-Authorization header where
+        necessary.
+
+        :rtype: dict
+        """
+        proxies = proxies if proxies is not None else {}
+        headers = prepared_request.headers
+        url = prepared_request.url
+        scheme = urlparse(url).scheme
+        new_proxies = proxies.copy()
+        no_proxy = proxies.get('no_proxy')
+
+        bypass_proxy = should_bypass_proxies(url, no_proxy=no_proxy)
+        if self.trust_env and not bypass_proxy:
+            environ_proxies = get_environ_proxies(url, no_proxy=no_proxy)
+
+            proxy = environ_proxies.get(scheme, environ_proxies.get('all'))
+
+            if proxy:
+                new_proxies.setdefault(scheme, proxy)
+
+        if 'Proxy-Authorization' in headers:
+            del headers['Proxy-Authorization']
+
+        try:
+            username, password = get_auth_from_url(new_proxies[scheme])
+        except KeyError:
+            username, password = None, None
+
+        if username and password:
+            headers['Proxy-Authorization'] = _basic_auth_str(username, password)
+
+        return new_proxies
+
+    def rebuild_method(self, prepared_request, response):
+        """When being redirected we may want to change the method of the request
+        based on certain specs or browser behavior.
+        """
+        method = prepared_request.method
+
+        # https://tools.ietf.org/html/rfc7231#section-6.4.4
+        if response.status_code == codes.see_other and method != 'HEAD':
+            method = 'GET'
+
+        # Do what the browsers do, despite standards...
+        # First, turn 302s into GETs.
+        if response.status_code == codes.found and method != 'HEAD':
+            method = 'GET'
+
+        # Second, if a POST is responded to with a 301, turn it into a GET.
+        # This bizarre behaviour is explained in Issue 1704.
+        if response.status_code == codes.moved and method == 'POST':
+            method = 'GET'
+
+        prepared_request.method = method
+
+
+class Session(SessionRedirectMixin):
+    """A Requests session.
+
+    Provides cookie persistence, connection-pooling, and configuration.
+
+    Basic Usage::
+
+      >>> import requests
+      >>> s = requests.Session()
+      >>> s.get('https://httpbin.org/get')
+      <Response [200]>
+
+    Or as a context manager::
+
+      >>> with requests.Session() as s:
+      >>>     s.get('https://httpbin.org/get')
+      <Response [200]>
+    """
+
+    __attrs__ = [
+        'headers', 'cookies', 'auth', 'proxies', 'hooks', 'params', 'verify',
+        'cert', 'prefetch', 'adapters', 'stream', 'trust_env',
+        'max_redirects',
+    ]
+
+    def __init__(self):
+
+        #: A case-insensitive dictionary of headers to be sent on each
+        #: :class:`Request <Request>` sent from this
+        #: :class:`Session <Session>`.
+        self.headers = default_headers()
+
+        #: Default Authentication tuple or object to attach to
+        #: :class:`Request <Request>`.
+        self.auth = None
+
+        #: Dictionary mapping protocol or protocol and host to the URL of the proxy
+        #: (e.g. {'http': 'foo.bar:3128', 'http://host.name': 'foo.bar:4012'}) to
+        #: be used on each :class:`Request <Request>`.
+        self.proxies = {}
+
+        #: Event-handling hooks.
+        self.hooks = default_hooks()
+
+        #: Dictionary of querystring data to attach to each
+        #: :class:`Request <Request>`. The dictionary values may be lists for
+        #: representing multivalued query parameters.
+        self.params = {}
+
+        #: Stream response content default.
+        self.stream = False
+
+        #: SSL Verification default.
+        self.verify = True
+
+        #: SSL client certificate default, if String, path to ssl client
+        #: cert file (.pem). If Tuple, ('cert', 'key') pair.
+        self.cert = None
+
+        #: Maximum number of redirects allowed. If the request exceeds this
+        #: limit, a :class:`TooManyRedirects` exception is raised.
+        #: This defaults to requests.models.DEFAULT_REDIRECT_LIMIT, which is
+        #: 30.
+        self.max_redirects = DEFAULT_REDIRECT_LIMIT
+
+        #: Trust environment settings for proxy configuration, default
+        #: authentication and similar.
+        self.trust_env = True
+
+        #: A CookieJar containing all currently outstanding cookies set on this
+        #: session. By default it is a
+        #: :class:`RequestsCookieJar <requests.cookies.RequestsCookieJar>`, but
+        #: may be any other ``cookielib.CookieJar`` compatible object.
+        self.cookies = cookiejar_from_dict({})
+
+        # Default connection adapters.
+        self.adapters = OrderedDict()
+        self.mount('https://', HTTPAdapter())
+        self.mount('http://', HTTPAdapter())
+
+    def __enter__(self):
+        return self
+
+    def __exit__(self, *args):
+        self.close()
+
+    def prepare_request(self, request):
+        """Constructs a :class:`PreparedRequest <PreparedRequest>` for
+        transmission and returns it. The :class:`PreparedRequest` has settings
+        merged from the :class:`Request <Request>` instance and those of the
+        :class:`Session`.
+
+        :param request: :class:`Request` instance to prepare with this
+            session's settings.
+        :rtype: requests.PreparedRequest
+        """
+        cookies = request.cookies or {}
+
+        # Bootstrap CookieJar.
+        if not isinstance(cookies, cookielib.CookieJar):
+            cookies = cookiejar_from_dict(cookies)
+
+        # Merge with session cookies
+        merged_cookies = merge_cookies(
+            merge_cookies(RequestsCookieJar(), self.cookies), cookies)
+
+        # Set environment's basic authentication if not explicitly set.
+        auth = request.auth
+        if self.trust_env and not auth and not self.auth:
+            auth = get_netrc_auth(request.url)
+
+        p = PreparedRequest()
+        p.prepare(
+            method=request.method.upper(),
+            url=request.url,
+            files=request.files,
+            data=request.data,
+            json=request.json,
+            headers=merge_setting(request.headers, self.headers, dict_class=CaseInsensitiveDict),
+            params=merge_setting(request.params, self.params),
+            auth=merge_setting(auth, self.auth),
+            cookies=merged_cookies,
+            hooks=merge_hooks(request.hooks, self.hooks),
+        )
+        return p
+
+    def request(self, method, url,
+            params=None, data=None, headers=None, cookies=None, files=None,
+            auth=None, timeout=None, allow_redirects=True, proxies=None,
+            hooks=None, stream=None, verify=None, cert=None, json=None):
+        """Constructs a :class:`Request <Request>`, prepares it and sends it.
+        Returns :class:`Response <Response>` object.
+
+        :param method: method for the new :class:`Request` object.
+        :param url: URL for the new :class:`Request` object.
+        :param params: (optional) Dictionary or bytes to be sent in the query
+            string for the :class:`Request`.
+        :param data: (optional) Dictionary, list of tuples, bytes, or file-like
+            object to send in the body of the :class:`Request`.
+        :param json: (optional) json to send in the body of the
+            :class:`Request`.
+        :param headers: (optional) Dictionary of HTTP Headers to send with the
+            :class:`Request`.
+        :param cookies: (optional) Dict or CookieJar object to send with the
+            :class:`Request`.
+        :param files: (optional) Dictionary of ``'filename': file-like-objects``
+            for multipart encoding upload.
+        :param auth: (optional) Auth tuple or callable to enable
+            Basic/Digest/Custom HTTP Auth.
+        :param timeout: (optional) How long to wait for the server to send
+            data before giving up, as a float, or a :ref:`(connect timeout,
+            read timeout) <timeouts>` tuple.
+        :type timeout: float or tuple
+        :param allow_redirects: (optional) Set to True by default.
+        :type allow_redirects: bool
+        :param proxies: (optional) Dictionary mapping protocol or protocol and
+            hostname to the URL of the proxy.
+        :param stream: (optional) whether to immediately download the response
+            content. Defaults to ``False``.
+        :param verify: (optional) Either a boolean, in which case it controls whether we verify
+            the server's TLS certificate, or a string, in which case it must be a path
+            to a CA bundle to use. Defaults to ``True``.
+        :param cert: (optional) if String, path to ssl client cert file (.pem).
+            If Tuple, ('cert', 'key') pair.
+        :rtype: requests.Response
+        """
+        # Create the Request.
+        req = Request(
+            method=method.upper(),
+            url=url,
+            headers=headers,
+            files=files,
+            data=data or {},
+            json=json,
+            params=params or {},
+            auth=auth,
+            cookies=cookies,
+            hooks=hooks,
+        )
+        prep = self.prepare_request(req)
+
+        proxies = proxies or {}
+
+        settings = self.merge_environment_settings(
+            prep.url, proxies, stream, verify, cert
+        )
+
+        # Send the request.
+        send_kwargs = {
+            'timeout': timeout,
+            'allow_redirects': allow_redirects,
+        }
+        send_kwargs.update(settings)
+        resp = self.send(prep, **send_kwargs)
+
+        return resp
+
+    def get(self, url, **kwargs):
+        r"""Sends a GET request. Returns :class:`Response` object.
+
+        :param url: URL for the new :class:`Request` object.
+        :param \*\*kwargs: Optional arguments that ``request`` takes.
+        :rtype: requests.Response
+        """
+
+        kwargs.setdefault('allow_redirects', True)
+        return self.request('GET', url, **kwargs)
+
+    def options(self, url, **kwargs):
+        r"""Sends a OPTIONS request. Returns :class:`Response` object.
+
+        :param url: URL for the new :class:`Request` object.
+        :param \*\*kwargs: Optional arguments that ``request`` takes.
+        :rtype: requests.Response
+        """
+
+        kwargs.setdefault('allow_redirects', True)
+        return self.request('OPTIONS', url, **kwargs)
+
+    def head(self, url, **kwargs):
+        r"""Sends a HEAD request. Returns :class:`Response` object.
+
+        :param url: URL for the new :class:`Request` object.
+        :param \*\*kwargs: Optional arguments that ``request`` takes.
+        :rtype: requests.Response
+        """
+
+        kwargs.setdefault('allow_redirects', False)
+        return self.request('HEAD', url, **kwargs)
+
+    def post(self, url, data=None, json=None, **kwargs):
+        r"""Sends a POST request. Returns :class:`Response` object.
+
+        :param url: URL for the new :class:`Request` object.
+        :param data: (optional) Dictionary, list of tuples, bytes, or file-like
+            object to send in the body of the :class:`Request`.
+        :param json: (optional) json to send in the body of the :class:`Request`.
+        :param \*\*kwargs: Optional arguments that ``request`` takes.
+        :rtype: requests.Response
+        """
+
+        return self.request('POST', url, data=data, json=json, **kwargs)
+
+    def put(self, url, data=None, **kwargs):
+        r"""Sends a PUT request. Returns :class:`Response` object.
+
+        :param url: URL for the new :class:`Request` object.
+        :param data: (optional) Dictionary, list of tuples, bytes, or file-like
+            object to send in the body of the :class:`Request`.
+        :param \*\*kwargs: Optional arguments that ``request`` takes.
+        :rtype: requests.Response
+        """
+
+        return self.request('PUT', url, data=data, **kwargs)
+
+    def patch(self, url, data=None, **kwargs):
+        r"""Sends a PATCH request. Returns :class:`Response` object.
+
+        :param url: URL for the new :class:`Request` object.
+        :param data: (optional) Dictionary, list of tuples, bytes, or file-like
+            object to send in the body of the :class:`Request`.
+        :param \*\*kwargs: Optional arguments that ``request`` takes.
+        :rtype: requests.Response
+        """
+
+        return self.request('PATCH', url, data=data, **kwargs)
+
+    def delete(self, url, **kwargs):
+        r"""Sends a DELETE request. Returns :class:`Response` object.
+
+        :param url: URL for the new :class:`Request` object.
+        :param \*\*kwargs: Optional arguments that ``request`` takes.
+        :rtype: requests.Response
+        """
+
+        return self.request('DELETE', url, **kwargs)
+
+    def send(self, request, **kwargs):
+        """Send a given PreparedRequest.
+
+        :rtype: requests.Response
+        """
+        # Set defaults that the hooks can utilize to ensure they always have
+        # the correct parameters to reproduce the previous request.
+        kwargs.setdefault('stream', self.stream)
+        kwargs.setdefault('verify', self.verify)
+        kwargs.setdefault('cert', self.cert)
+        kwargs.setdefault('proxies', self.proxies)
+
+        # It's possible that users might accidentally send a Request object.
+        # Guard against that specific failure case.
+        if isinstance(request, Request):
+            raise ValueError('You can only send PreparedRequests.')
+
+        # Set up variables needed for resolve_redirects and dispatching of hooks
+        allow_redirects = kwargs.pop('allow_redirects', True)
+        stream = kwargs.get('stream')
+        hooks = request.hooks
+
+        # Get the appropriate adapter to use
+        adapter = self.get_adapter(url=request.url)
+
+        # Start time (approximately) of the request
+        start = preferred_clock()
+
+        # Send the request
+        r = adapter.send(request, **kwargs)
+
+        # Total elapsed time of the request (approximately)
+        elapsed = preferred_clock() - start
+        r.elapsed = timedelta(seconds=elapsed)
+
+        # Response manipulation hooks
+        r = dispatch_hook('response', hooks, r, **kwargs)
+
+        # Persist cookies
+        if r.history:
+
+            # If the hooks create history then we want those cookies too
+            for resp in r.history:
+                extract_cookies_to_jar(self.cookies, resp.request, resp.raw)
+
+        extract_cookies_to_jar(self.cookies, request, r.raw)
+
+        # Redirect resolving generator.
+        gen = self.resolve_redirects(r, request, **kwargs)
+
+        # Resolve redirects if allowed.
+        history = [resp for resp in gen] if allow_redirects else []
+
+        # Shuffle things around if there's history.
+        if history:
+            # Insert the first (original) request at the start
+            history.insert(0, r)
+            # Get the last request made
+            r = history.pop()
+            r.history = history
+
+        # If redirects aren't being followed, store the response on the Request for Response.next().
+        if not allow_redirects:
+            try:
+                r._next = next(self.resolve_redirects(r, request, yield_requests=True, **kwargs))
+            except StopIteration:
+                pass
+
+        if not stream:
+            r.content
+
+        return r
+
+    def merge_environment_settings(self, url, proxies, stream, verify, cert):
+        """
+        Check the environment and merge it with some settings.
+
+        :rtype: dict
+        """
+        # Gather clues from the surrounding environment.
+        if self.trust_env:
+            # Set environment's proxies.
+            no_proxy = proxies.get('no_proxy') if proxies is not None else None
+            env_proxies = get_environ_proxies(url, no_proxy=no_proxy)
+            for (k, v) in env_proxies.items():
+                proxies.setdefault(k, v)
+
+            # Look for requests environment configuration and be compatible
+            # with cURL.
+            if verify is True or verify is None:
+                verify = (os.environ.get('REQUESTS_CA_BUNDLE') or
+                          os.environ.get('CURL_CA_BUNDLE'))
+
+        # Merge all the kwargs.
+        proxies = merge_setting(proxies, self.proxies)
+        stream = merge_setting(stream, self.stream)
+        verify = merge_setting(verify, self.verify)
+        cert = merge_setting(cert, self.cert)
+
+        return {'verify': verify, 'proxies': proxies, 'stream': stream,
+                'cert': cert}
+
+    def get_adapter(self, url):
+        """
+        Returns the appropriate connection adapter for the given URL.
+
+        :rtype: requests.adapters.BaseAdapter
+        """
+        for (prefix, adapter) in self.adapters.items():
+
+            if url.lower().startswith(prefix.lower()):
+                return adapter
+
+        # Nothing matches :-/
+        raise InvalidSchema("No connection adapters were found for '%s'" % url)
+
+    def close(self):
+        """Closes all adapters and as such the session"""
+        for v in self.adapters.values():
+            v.close()
+
+    def mount(self, prefix, adapter):
+        """Registers a connection adapter to a prefix.
+
+        Adapters are sorted in descending order by prefix length.
+        """
+        self.adapters[prefix] = adapter
+        keys_to_move = [k for k in self.adapters if len(k) < len(prefix)]
+
+        for key in keys_to_move:
+            self.adapters[key] = self.adapters.pop(key)
+
+    def __getstate__(self):
+        state = {attr: getattr(self, attr, None) for attr in self.__attrs__}
+        return state
+
+    def __setstate__(self, state):
+        for attr, value in state.items():
+            setattr(self, attr, value)
+
+
+def session():
+    """
+    Returns a :class:`Session` for context-management.
+
+    .. deprecated:: 1.0.0
+
+        This method has been deprecated since version 1.0.0 and is only kept for
+        backwards compatibility. New code should use :class:`~requests.sessions.Session`
+        to create a session. This may be removed at a future date.
+
+    :rtype: Session
+    """
+    return Session()
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/requests/sessions.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/requests/sessions.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..2fd7ac432b2e2ee46fdab3f440fcae792b92dfcd
GIT binary patch
literal 24341
zcmZSn%**AGdLky70SZ_d7#JKF7#ND>m>3vR7#N}$7*ZG+QkWQW7#X4%VQeObC?*)2
znIVc9%w}fDVPVK+Wr$*BU`%0QNMU8jVPnW;XNY2l@Yxu0I2dv{8KO8Da=93yxEOM|
z8KSrua(Nh{co=ed8KQU@a`_md_#mp;8FKg;as?Qo1Q>D!8KMLka)lV8gcx##8KQ(C
zDmWN&L>O{K8KOiPa>W>;#29kL8KT4?a-0k~5)8SL3{jE{xl#;KQV>xth8$^zTp5Na
z83>=7AxD-WSB@b{jv-f`AxfShSAii)0V2o4kfX?utHcnc#E`4Z5T(qJtHKba!jP-V
z5Ty!H!OM`N#*nMd5Ty>`^D*RTFyv}7L}^0!{9x0y7^1Woa<v(vv>9@B7@~9-a&;M^
zbQyB>7^3tTa`hRa^dYJR7;+34at#@x3?Y0$u<wi*qKp_AQ<)gDj2Tjd7_yldijFW=
z@-n0{Gh~@CM42*#=SeZJq?$2gb1@VhU}R)u1j(3#WbzmpBJw!FDw#q2RBnb8VTKk)
zhA0aL5L*Pywq!^VWk|JRNMmG35o2g!U}$Dwh>WskND*g9wFZkyz(s8sQY1l~C|gj1
z2-c7SrIX1F3=CXFsfDGf#U;gh#i_-`nfZBKb!dQ#D<mVcSRpq*r8Fm1p`a+gEHfpw
zSRqj%7@|QTKPf9UxkRBPUm-U!FEKq;Au%sSp&+%WIJ3A!p*XdqBr`9)SRpaFD8INE
zZk>Wga(;exW@@pHLSku2h7QQ!ip<nvO+Bv6|NsC0_tRixU|=ZW1QD6JsVS*BC5f3J
zA&59X0|P^RQetstay&?Td~r#U1{+8%NCU*=oXn&WkWglEd_kpg2{!`+gMU#<YEf#6
zOJ;IO2|EJ=LupY?R(@t)2?vB-kXTfl3YPFqEGWp#OV?ll87a)bzyL8aE3qg(ttdY?
zJ_Tfg7y|=CYDGy=Vsc45M7}t_BtJeYv8Y6lfq@|i8nDh_e|jYrmGCk!Fyy8drKiG_
zYcPY%2e|~QxCG>{fTGlb#G=#`m>9?&7gsmOP@j<aAXgX9AXn#*cppz+&kzkJkbaP{
zDXD3Rr8y<>8Tt9y#bAq4GK&imOOi9dLXbcc0IAN8&r2-HEK3Ci8OV!ZCxEOi$&b%Y
zt&A^A%!$v*EG_{%1#WC=VoGWe#9)|H0{nwQf*~OUGB_kZ-#0O@GAK1AvnVyW1fte6
zuPiYqGbK1VBQ-a%M1+BX!8xNeFFQ5GH7_|oB{MJGwWuh+2qKZ6SCX1n;*yFa0dY1c
z{GAhvQ$6#FQ}c>5L5>H-AVd-rtsWsE0gfq&1tqD_L;w;5rR)5X)cDe(%o30Z>8U00
zsd;6YMfrL01x5Lwv{u5$z`y_!&r2;Sf+VC8QBcOn$S=)FiBGC5NGvXfD+a|WNHI9Q
zfm1<gQ4Tm+6{VJE=B30Z<)>6a90e+glk-zjiy>T)HSmZF4si_eECHz~&&)G6N(O~L
zDE)zwnls4qEes3{HQ?epn}eZ9fT4zgA-D!yl!N#RAi3ZYMi5oP#L&#dkZ;WZ;xaHm
zxW!Ho9ZU=*%pgV0j10|;47JP*HOvfIEMP$fkVrEl17kV^Sd<l1a=66GF~l%2)Uq(t
zvNF`Lf~p0OeI*PvEDUi>422~OwQLL(q6{@`3@)*}47Kbatu^cnwuSQ<!fTirg29Qg
z_yq$4gG*{jYEf=x9;lQkC@9J=D9TJMNre>!3TgR83W*BonPsVY3ZPg@EiTbfC`ruD
z%u83u%qz)PNK8)7FU>3AQczG(D9K1wNUbQy$xP0K7bXh%c?u;Ni6sc#pb`h95?b0Q
zWP%icYy=l+dJ3Lt3W;Fj;0izm7$_HK=I13ARqBB3sZ=P>%*jzmN>u=7(iDY~{Pfh4
zjMO59(qfR?5<u$XlXDV_ixa?x`9X>tP|W$|=cSf#F)%P>7H8%amn7yTrv`!ZwGb%J
zfr_Ehf|SIPRB*&+mZatuYk(phoXMbJ5D#@5SPWVi!^J>GBdiA}T!<s#DnMmpb_s|q
z1DBe4`FW|J3|(9TN@3Zll^URC0+=W+U|?X-FDS|^ODsv%FH0=aPs`5%<!}9@6#ep~
zq`X|y++ricB=hvDbPH39@|>(HGXoGv&(jalFUTy=1^Y24N7t>)!_znbBm~CsWvO{7
z`9=Cr9~J9Ey-}=JPzf%Sz;1>)*$|Z4K@|}L8xJE36AvQ`3qK=26AP0NqcDphBQGO2
z6F7H(+z$$4aPEkL<_;!?Yz~HEMNkUQ0%w+HMuv0-a4o9}$p8$XnhvDM4a7%R<OR|h
zT*3sBt6^lQVPa?orD2d=#VZ*Y7y^p&3sQ@6Dj{j1SRpCDBm<V-iWNZV4eB=qaFMIW
z1x^v*nliIkAulyKwYWI3s8S&*H94`gI8~uM1CiRnMRKu%t*t_}dQoa|L4ICws=Adz
zbZjj+9fC~)hm=B6QEFm#F}$V)TcwbiSCUzjnp3F<RtT=VV5aziYm^`rP@)5QB|Wty
z$bf-?0W1uT0cg}foB$Sq`U4^oqy<tvz$pb(e1rWDaZ>;&op6EN#HPr|!UV$L8Uxz?
zfYms@nH8CN@WwDG^ErVuf^?@cfE&OJ;1&?L_1nS#YWk+KFr=_Cq_TlX5Q7DjWLnrj
z&E6Dduwo8|6c#Xp6VxaM>EdDt3f2Ibo(!sdL4gdy;IwHENt;;=3`N$U<ONA{lC?~r
zqPa*9l*qD}K~{hYWG03@28I$AkYEZks2mSYVPOc?096dd=HTW-a%yH7s0dXEf~FBY
zg`m`u(xN<2*;NFsXB9$&JQebb6cQ3ZMNmQlI636xCnuI<=I4RiKRJmdnR$jKpd3_M
zl4b!dv_N5;SsV{D2Hfh&fYkCqAP<4Hrh;ne)F4pJ2ToIvWCSv)I5j5?Y$Pb<1%ccP
zE?L0Dz!WdAIv(bu_>#n;^wg3>P#WL?B_0k=MqYL{Mj=LCMsTqLDt|#f1xMWjP>uoD
zyP&vXW+-6*MGT0|0;=b-7(vxw79&G8GeeOcC^~~d)hW311Zvplffa#MQ#KnzQ65+|
zGeZh9xIlt%Sr}5-86dJHYz$!iEMRpkAX7n=E;B<GGgyQfEW*Z6!p@Mz0XCW$l>C~R
zKx7&dxbkIV;3>KWmSbV4ff#%ZtQm<5wuhCW;6A9<4hGja#ctpVIyo~1Tqc35H^<VF
zjQpa^DsY-nfTRM2VsIk}R2vqh=H{2Brof6YNc%1`FC85J86_nJnV>uduGv7m;>_KQ
z3=DqY<^Wg*%7lo5+UG%_`VgE@GxCc|@)C1X!A6A?m8OD|T`{P+2oWpDFDd~iJ+Sd^
zi8;loL7--2kP)by0!3kvEhy?h88Sa7B_7ly1F`c`%fW0=u>leXH|<lvH8e;H$_1s1
z<c!3;^wgAikWJuv6(#_61xO9784OYbPU2u<VA44#GeY79+=4Fv_kYSjsayt>%9(f=
zc^HKlSy<&5<rrC*g&2hxr5VK-`59T5lR;q*3OrD2KO3aOl9>TiY1VRqYQZdc^5+IO
zD47_tm_QB1EM|sU9)=2T<{EB>A`|8sCQvi7nSr5}m!XD>A&V7M(t#S2HC&)JqkIh`
zLp&QpB{xVoi=BZnJWrQ_rGx|2l`G+5NMi<fcPB6~GBVaMGGuWxWbuGX#1dYHW(Gz^
zP{+4~53H39WOoe%Ll!?nHY-EXQHBx$P=11lh^4TA6g4w4HZg+AQIJuBpjIqn4L3uU
z5Gb28Gcpu$GJ;yhj8Ko%@`1|v5@CiKK87q2u<_gsX-o`awcH>xKuWnmqP6@CHT<Bg
z2+FTa3`O>gH9TOFpCL<>A%%mXh6m)>T7HH+QK-tI5JrfWS{{&5AhsCDIknti1>y|F
zEsP}+ASY)rF_cI$)POB&W?}$Y&4UoB<z@i64=h{5%Mi~5ju<J18eWjzW+n!3ph+{7
z$S`Edf=M}$53<=AiWrzuL>OuX7%CJQY6KWuVkH@B1ws0<<QcLQ7-|GTBM2Y^3a>MU
zrwD^&;+4Q|<z>i{XQ&kdN0|^q3J-&Ac%C2wONlZ#rqr1jq0yoO(vzhMDi=Y)%?)ZW
zF_x&oL>U;e)Irr4V+}7umIhQ5oGus`vNS>b8g`I8sN=xEkfj9{VFZbQb!da!m(9tL
zznm$Blc7ckR8kf!XG-CQvTKDIYJ?ez_A-^|fOLWk&SL<vYMB^nI2ej9GSx6KgfSLs
zfkR9e<jNFYQ1O_;2Pzd)_`!V|0Z>7hA_yulQ-l~wco}Lq8G0GnY8e?yRKOb5K}I6H
z2TE;7*`kIKVg)DwgEhciMNk_fC>3v2ot~PPT9jClU!;(q2CvJDL6tVNhhMA*9@zkw
zJ}IF7FKB=O+#4<i_5EEdl2cPtQd1OEixptCTd`gcxcLlfgXrrQgIW!$#a61tC7?0@
zT(qVYC8p=5=9LtKdY{ga&b6*jYF>ItMlq;Ng9(LH7Niz~3YCze#Ju9P)FNG2-yB>P
zLq;#a%;J)w)WlqHOQ9q)H#NVs1T0*ZT9lbq2`<5tQ;Q%2E3ghWsH92E$;mH=H#CYN
zO;qw-rJ)CE9D$lzkZJ@}g_joP1O<Ys0Z`K<IlrJ1?6Aawg4DbeuzNEyi%as0D#7ez
zNLU1kgUpct=>i2uP-z~>Q;_ipkeNk^<zPP*r6#5XfhtXKKPo3R58P<ZO{_q8DF~Dj
zz!g+-PJS_@A6Q(HSX5G6o>`IsX+F7tECSV6@kOZxIf==Tnl2sGp34EdHZQd#CqFp|
z6q7;HAjP0~D@si&&CE%O&rL1K$WH+eHWZg6mXsF9gN7G^6hZ2QKtyV8L4HwUQ6=0_
zB_QE~)S}$PywtoBxNwj)NHxfR1^ES#iWL-QprH$Js_{;(1P4J7sICBuz{aYAKrKdS
z0D=eZ!2Q$$$XFFj5m*f7Xjmcu1usktG<X6|=it$j_=0@Ucusy^kOIhAAeR)U=A~$W
zDk*Ti9%Kg+2RXMWwJ<0c6k{PEA{0b~frxOB0#Hy@W~Sz(#6!C`#b7%UA!9=E+2x5v
z>BZpK1SN!^NRS>-k}oJqEz8U=Eslp}mJ-lN7SvC0!@$7~X)(kXff^W~<_m-mwx*!8
z2-JXpw3~{-kqKc#0-KA0fdMi?l$ey03T`=oiGgcA6r~pD=ai+w6Gd@9s4-9jDmqx$
znD`lm7&#evSa=zEnV1>58O0dInIsrxn7Nqw8TlDyn0XjQ8AU-V7<pJZ8Ks$cnE06l
zn5CK67<n1R8F`pE89};u8Ch7x7=;-Hn1vVx*!USGSlAeOnc0}w7&(~P7?B|}BPX*M
zGe4wJ4hmXObb}k^)$sllX!weeA&U_-Je9%-D%L>_X$NqT%>*jzvzS4$H7ua|q{soJ
zAcc{^7F0tpfSM~sp$sLgpn9O0ks%M<1p~FWSwSt2Y)*!va!~D>#SW?>pcP9B6GJe#
zw^RI*fq@|$)Ok-z1q}kh3SdxsI8`Axu~MNtF%LZWU0hO>SpXi)26fOO9WVvZI3Z|k
z3EWi&jb}j<C}^}iu`E9`MIk2@GV+yNl$rw4n3z+nrvM&DfMj~mkXUL?PG)*)UP(@+
zLJ_zzUJN%6G!jvinpjYflL_i8mX>6I41wBSo{?IVs!)($T%4JdlZvntVV6QqesM8m
zAOYk$aM|XF+#T=(_Zq+{8Jur|{6Lup)WnAR1U%SOQdC+D9$pQS1!YR`_yZ{0L$eaN
zjS3ztgXC&Z#DeQDgt_3d2GleMl@Q?k0VW0{lLQrmvH~LmLouj0U|{8B<YZD|=3<s+
z<Y5$mj7fpU+(AV(IGvg@f_sZ8EDWH;Bm_#2dCUx%3=E*Q2_)Hqhhnq9!>gcSSr$+`
zGYc}*$^>ddgWA(<AdOjUpjI@f<H-){{?)L6xS*C3BV#QGIK6W)6zvB!d3cKUgBsN+
zDmXz6nk+U@LayOt0GS1D!h;%`T%guENGBUZ78h6n7bvqZ7VZbN0#m@_!=Oxc6`XmP
z!I`I0ilKxX)MTn*Wsq!U1dk7MgL(tud9n;FB|P93A|Gh#Duopx32MZH`U-~NcC#TP
zsF}qLZZtDN&9(t$Og4sKaFQtAz{tRWoZyR6byLd{b4n9SQj0-(2Rt=YsgRtXmzJ4c
zS_J8(CV>TtGgDHFK-sb+BNd({pribt#*ac-Vo@fj*ewQ+0hgyLBo?K@8&RpCAzp<<
zh0q`$h2;D)(A1DZQYG9RKmYiEApeL+9fk5#1xW4&jWL6&HL&Ff*XSwugF4dXnZ>CP
z#i=C<xtYbqnR)4O(;(WiQ!9(X1K=f~IW>^Q8ku<t$%)0OAfHw$l!G!X*sg-q6osTp
zg+v8dB?UJLRs?B62OU8f7diYAbBgm7psfr@00tE0S5)ev<ZD<rA6!Jhjn0FOTOt{4
zRa8=0kZPp>8h(Z=gk;xz@Z?A(xMh@>lT!>DgTZ1KWB|a=PXkm>gBu-)d=GBK1%X;e
zL7<^saKAoC4pfM=fCx~Z7TjwuPA!4<!h_^N5_up3G}^5J%8E$E3aCMVWIV`Za0L!3
zTR?G;nOYpw4l2Vy<rC5rPbIkR0!=$$e`Tf?gBx`qU6o)DmlmfM<$;DPKn*$2<WPBj
zQ3|-60uuvMSQRlaFo=K(E6~s_1CInFCnF~#KO+w#Ka&un0HY8SsA?8t;$h@sVrG<L
z<Yg3K;$akn6l0(k7pMyXF2=f1s#_*dg<8S{>IZ{HxD3Eq7cu~50ID}@nL*_SXf%Kk
zG#-}40v_rLM^YA!O&Kd#SshpzWOS?!Ng249jAsB1x<ZFSn~1G`A;UJHT%-W4IP=rM
zJZL=yPr6Bo#i=QvDI`#DB{4Hkp|~J58QdL9D#|Y}PAyVMO3g?t%girAsuw{4<>Bh+
z0#54gt|8#YWPpEg2y{3V)NX-T8<Yu3nc$W=s1045ni`)EDjdK`DJ{P=F9pm352=A?
zPm$6ts7n_Fnw1A9ConNEX)1$(fx#A(rUXDWAqyw793v+S6f^m0fV%>qJP;ob$`0}I
z;4B&+p9@|i5FZ}|?w)~K3gDg-B+G-+SWqJ<a6r{-5GdIOf$RZ$6G04&hs{9i2|%r2
zP!Yw(#3{-t$;K#Jz$wD13GVYi=NjPC3!siIsOw)W!^pq@pI(5ktVv-8CE*lS(1244
zJ7~-(g_9wLiy?&@G{BO=%aG0sntw>)1J5n6Fr@H<8LSK`0$>IkLy91n!OoDPhy|r`
zVi8OcVrbz5EzSY06=49a&q)yh8^QxxC<2<h;DzZDV`yOlE!P1VE)HHy!Vi{`0J8;P
zi$w$(Ql!8p2r;BcgBijMDKcP&2t$f2m?6rLA_r!OF{H?Y8R85n3Sfo=XsSdB6sir3
z3=ED6u;C5`=#&$*k_mt<DS<4afGr(K%}Y+z0oD3>smY+p4BdkK{G80ZbRF>Q8%k>c
zYLF9XJ%~bRabkL^l@(+{PC>!W&Q2i{)H{Yx7sDFQAemwXTllP=9yF3QG@)e$Sb<)8
zYKewAcwpN~Umrv#W#;MS7p3c`r<SP0l-j`NXcVH23=CrJAh!D#DI^vvB!WCql3Gy$
zT_00~>NwCC0TwrabQW77xdc?r7nA84kX}fo2%7o@7ha%tb`Yqt1Q$o(nMH8dwIH!5
zF}FAf-opl0d<8|RX{ja28DI{yTU`w4kAth}B+wEWP;Cst@c!FUP&Er)mQ=&Q5YGr&
zlLlgdo5mmp3#e1p%m8ZD#<PLi%OF8^h7u022q!}c7ns2f)5rrJv14F}=YvV{gGPlj
z!Rr}7dIcFugh0ctAhs|_Z<YwC`CK9j5(Eu?g2wYiK=lnmD1`yq)AK6^m1v*{F1FIw
zF9vmSKpZQ5eGSkkTo9;n0|`S=_a<l-s3Zf0Ul6D)2$~Jz&H)jiu_8#&fJ;1hKn8(|
zmLO0_1%bm1WLpp@I)XrzOVB(}V1c?6xuCTVL7;hY@ahq8^)SH2BRJaQ<1_OzOXA~m
zLG=QtUB<x5!@|kR$;`vb$;`>j$->D7!u-rUjKYk`po9R!pl~P#c@ngg1?(w5h=)K5
z28I7PLB)T3YF<fdQGEOokOx7nA_j;zKunNJ-9aT8C=x-b2%M}L!HEYX2U)Hb1gamv
z6JKCoLGoEqdNIVepsI90YBy-~rB;BVZ#k0hKt2PtTtGvi;7HN}^<)_tvKSZ&ct9Dl
zmI*o)1ZfC1Gcgn!Kqsw1T~x>%HY+F_m#~5I7&K(SLo%RFC%8SA#SR*_0ZDN%6g7iJ
zVR%3k149-&1Bg|^2_Amo0`-Y&SwOAI5^j)TkRck-{178p0WU)qA4oif3C!gJPX{rA
zCWs)jL0JNzc^}Z=y&$OGEfE4MgOmfppvl(~5r$?a#uN@vDFIR@3N9i<LEYdKPOu;g
zSOh#zk-`OTqjEEph=I)!2TO^A6gM+)G1jm$1Z(hsQbac+1A}vZUU5lLX>tjuw6_8;
z5wc1^TgRthgC<~?0O|=sOLzr^643ZNxYwAU2d?6ZK!d}1#R{1vpaG#&1svukC}boS
z!xmS;>NW+)x|J0802Ev|v=UaZfimn86u_%_@{%D7H%l_|i&H@}706v`nAOl4G67oQ
zf~plOaD@S@z^u^iK{CB0AJmrxEp1c)*Lk2WFx>YbqoB<Kb%bvaEpS*b6xy0E)<X+S
zxIy6dGkB;9T(PBP=A=S~ep3=l62Un#t2jRoQjmjsOhMp68(f-$3u910t^t}BfRxRu
zpduZVPr&0`kl7Hg#G)W@=?!WJ2Z6?SA+-UxSeFH90F5vQfjXw(#v^nT4D2$nqe=@3
zQj3C?fK-C&$e?8)7HFLg#95LcF4$S7AQsp~plk{*RDzm8Vj!o22cN;~WKv+`?_hU;
z7l9QFbeRLH6`>x7jmobA6+NIZXW-&z7GmUQW@eOT=46y&6k>w(SwSQSOEZcx3Nf;Q
zda0mcdQkNXnqmPLQO7~`BzQR_C<`;f3Irx_X}}6<cGs|j%K;XK0$orUmcj;_5KRHE
zS1hmxi*SI(&p^|RY@kLtcsiF0G+W95nklXk1Q$d?ph?<-e2{w3EG`46BU~c{8ceR?
z22T?5fu?qwSs7}D88Vqb<8CS33}&E7a2^J;S`mgC5zx3^jWEbCMo{6$2AavN5n<?M
zWT+Kos1aod1`k~nGjiZ4KcE>DDW`%~NrTr0g9-(383CFu0dWu+1-3*8mSy1$Q+N~A
zE<pjZWE(RVL%Oh5upTsMr6y>|D=)PiGhf5Z0Oec|h86^+MLAaB5jAo&gUga)D+P`G
z0#K7bF-KDYwA2@}NE0+;np6oM6wC*$ODRsxD}k-_EG$heLX6yjoC6v}%S#89u;5Vu
zL~wwYyC)z54C-!B@qoi(9R<*WXmFWWT95-;vJQ5J4#+{E@<lf%GaE7d2(la!HlP7_
zPz1po37TaCo05Sj%%PEt=^juih2kEN03H+J1t7?Ng1&`JP~i^gGzHM2Y6TC-iZHmf
z&~h8qvji=J^y@G!1BD;FM1`hF3atV~2c|`^^pmELkf07y0vfeYw^9Hx!I7s6iLl}X
z$iiMw5P~o$3FnsPlw=kp7L_P~SHpn@n@bCF@)J`qQV^&|g%V?+0at|*P?7=pG&wOR
z2Q(B7@?mNoh=mem;LfYQOJ;g%af!ZjX>mz@E+h^>reN3wnybz)EkUu)BfnfBCqFM8
zWI=giW(hp)7pE4Lr51sNL8%eNR#2)}NJ>r1FG>Zi$cFe%2h{gWR7lIoPb>i^@<auz
zqSQ321dZhUJWy|30cyPtidmqUa+r*!f(=wnv0VZr43PX#Qdy7+Q)vaU2NXi!pn@9-
z&6jA)2T*(*oC=<K11%f_jg><Oh|w*=Fd->FKL_0!&>(MSD$b;n3)v6?nu;jNPtMN)
zIk%uFAHq(|OMx2)N;a@nZJ-bb6`!DCe&}E%$QtOvU64wsA0aC%P`p;20a<!plCO}N
zo12;fT0x&vsgROio(D>N;4%%g_7b#q7{zkv@&-Kx7s!^7Vvs8m62MF65-^Jy$m$Ig
zt6eie<CO}D3ZQUGP0Z5)m0#r<naLTDiHgh;@PI~9eoirHO(0ltd8z`$Bow!RJP%2H
z>ct8nKEVp0A=k{b%;dz9RA|D26w_F&$So}{0hRKJ3I&NJ8K}nQD<mp7J1QiV=A}TU
zHA{<A(LD@G6j=NVasi5OGt(4;OF(l-I$(=Hp;cU*qmZ1F394Q|%E85if`(o}YOW?C
zZGocCGfg1`l)ZHnG}J*V)pZoqvr{Y8H5CdHGm(amF&eM1N*V4gaN7{vYK1fb(b|UK
z#vp1NH3+;AA_BAw5;Rm11nP?ffmW^utpT-=q~Lpvpi>&4=`h&J`(lVqYM_>6DaZs+
z3k%Y^1dTpJWWjcVo2Q^PBaqfG*jZqAz-<SQAwh;e!0R&*;~n5uEofyTxYZ463xYeM
z&}|OI;8__^fdpNj0bc7dz^ztr<N6Z3nX1Xg$OB!g0HQ&djggaypNWTwjZuPynUS55
zi;0&}hzY(H95l+|4eAvtgC<j$Kt1UcMo=FbHu}T_8hwInIOv71F?h<rz!038mjdcN
zy1RzJI#Y=C-iRs|vReRm3yz}ZSBzGS7G$xEm4ZLC1*VW#lwJx-JfNw>#1e&s1ZWp5
zApx{$ClzV+01?R?lwN}-f|49)lrX3hlmbD`dT_vl7hFJ+A*cfd9*%@KXP}dX5d#B*
zBohMzcod6)Lx7RO2nQ`Hfkn7~K!~TmU+^%GbZ|!)>QzWQ<Bj{Eji59F8ZiS${lE;H
zfyz}#N2FMVijn^eDYt{>6o+}t2TcG)B_g|n$Hzf~7?5NDTD}jda0Ww^gUWAE-$)-N
zzCog(p?T1t54d!f2bJy&(9#{WSra_s30Xu_!@|(Z#01$HTYQ2MQL=-kiw7*OK@EMB
zb`PRoJtVrf7~>C!mKd}VP5a7g5~#KUw}?PZ8}LL1q}~Fh4Me>a1XnUBN-<F4Eyyn}
zu>vJ&&`2f&H+cUONE|e(2u{$TAxF?46>MM)G{z2It<}rK2wezSiky@~2d<Ga*itgh
z(;axtNkC`_I9(y7I#2|nr@FyVhJuRvg3=OqczWX^E4`H?r#HtCXOGdclU^kqc#<Lj
z6y`%E&4Ef_@NpNxNU07~*ntuwD5HQ&IbpPFyM~DY+zA6I1fN_0Ym>XU`nZO;4p@St
zeUSnx_#vJ|Do{XSg;bynhOz|Y&Xm-g)RNSAc*JsmJ71vLHBbW`9I+fs;1$?ekm`#8
zv~&^N;f8d;nZQ%G;KMQ)K?@ccz;i|5866~5EMQgO9R!S^%>s-JpgC<OhN3LcLhKY)
z&_oV&w;>Z~TW$&)X!$jCmYWH*s5%95)CLQ9zL*<)js^pGe<M3s1iZzumW`nVJc|w5
z2ge4QyoL@2Ff!C~K&5Kf86;{sK}%aen+-WZn+<C?7~;XJTR^i`tf1*DP}*e%>8ash
z$P#8KGGwgK1&L<~Gq}XcGt_c1l!$<RBnn#ioh1e)#lf5Q3b`4>L7UIv@{C}O5J^xg
zKmx>vx(mEVv4)wUs2Y4+2seXEtPsfb8ZPj$AeoGL%-}twJfIccMe9LpzOy93(`p=`
zxpFX{12jtqTE5N$GB{osG{;}V%uxJ=u~LJfL<;Oon4KxypkM|0j)}1u?67!ghVa5K
zj4UNG;PvJoK<mv5zc5CC7Ll_s6tggaLO_;*5ya<!&B}X1J6Z6PM$qPqk>|dk3!I_j
z8pV2;qjP8@TcBk>#h?+M$ox`;<itFM{Jfk>1<+WQ0-80&dO_eJ5Ab*fD7hA=Cg<m+
z6oYp^fL4k!1eJrjN8lCD;2tp+tAfCj&^(}FJuU_YhOoq((p1PUtsGE`6g++c8leD>
z!hwg?z~|IJc0YmpR^YYG;6+?TMX4$A$vOGS*+HO@zaUT-8{9Wf%}FdMPE83C02vtr
zB0!5`Aj5v3-da#RNDQ=o6Fe@HnO6+j><21Z^HM8Hz%@oZm<7t1!6o?xo+Y4NkD2*-
zL9rkof`lQ33)nPJ;Q|R7u!li&++b%w7ngy}1Mi^&&t?||9RS%5-wl?Ynim9eBY1EC
zObo~f0XPUVK?M_NEhq!KFe4a(jxhnvZ!>Z-i!yUE3o-LD3V~Syj0#L*%%aSy%xp}c
zRoFbtY>do|8jQS*>`ZKoTujNJ;tmwWpkM_>Yq2nBK@Pa1S+p9oJtTz#yvIZZ#Lfbr
zWC7jL!~r^<2eh>Wd>Bd%X!kT@EjvSn7HF?)77Hi?y2Q$WH)(J%)N+FLL&_0Oa5gRU
zWC*We0Tp?mBU2hdt8_qiaWE9E1{Hr<9H6Q36!316f<;Io%%EbimW82kH7HYqmhv!x
zvom;e326BcCukWBs8Hbs*;C65&fP3vH9TMu7O)5_ScDfW!pe{dJ{ci}g~6-_eCB~!
z4Krv-j~VD(B6bF|U=2{(ERF-6Uj`b72Vv)o)Z}dNv<T9GH+YU5yhK7Fvjnp0q&Pn}
z6~0;qODTY|%>lAgKnRrfTmwU0gF}MjogL$yLj7EPT*1pPoI`_r5JHeulc3T8vH%dY
zLlL^`0lYQ@yl@blQ)NI#s)Gn{rU%7!38)p4UkuI#P%nVbZh;K2gL4UdY+Zv3q!lrA
zg0K><1mbki3YFBnGT45GARUlCT~K}mW&8omIcpgh7&d`&4k#oT*g2UL8HE@n8AVtm
z7=;)mz~>eSF$ytBKt@_Y`2o~A0fkdBC@3my!0822(=#x*#A<_+HWT=uE69d_aQzOd
z?wLS|A9Ngm04OO27YZ<hmq4~vF*1lXGcq(Wg2v>bz1%wFG!+D0fd!h!N<=!z3OWs%
z30kNHDP`evt&n4_LW6v;BrSLa11;o=^_&umQ=uo9!KZ?XK`UhZ@<DTKpt)8gONt@e
zgTR{zz!s{j7OVS#kBk8?9}NN}C~(P{lV6@%6qEvrY|zvW(mn%lMFc8lK(#?;MbObf
zkQVkaFfg14r3KLV8UvdQlQbg-Gk66lC`*7aINm|26?D1*xH!xLul#X|6=0}^tPTXn
zG9xH*Qy5`~k!gbtoC9siE>=j)$x(m>JGfK;t(hxL&H$Gf(1mA^t?A&P1lMt(O=zjb
zXp1_721D)vtuws~3NcW|U|<qMY@P*mgutPd59;eML32qBBZCd-us3kfxx}h~vI*$C
z3vlTTVt`w&*$fOt;-EYNI`2&!v}m(J9aIs3+mnz28nQwP+!h9v=?tKagf@j94B?1C
z2eoH{QqwbwOHzwK6Ixg@3+RkD&|1K>%nGDz0?i1;;5~Z9`9&qEDWI9>l+@zn)I88(
zfeQJc^BX}k{gA|~kOMx>05KAX6oEmYgMWfR?IZ9eLrBZxJSaneQardEEa72bU;u5%
z1D)Ck+K&^YKL|3zd<F)FN1&($X9iYYMiVAp#5!b9W&jn0#h_(|?F`^kJ{cL>7#KPr
zQ43m?3(gOa<M{mGxd@cyLEYbCP+Kw+yyiYu8kBcRz<NPr*bJb~K@B6rWG03}(B@3Y
zx@M4#;5rF(m{Lhe5qL8Xc#Si-!qPJU&+aCcloUaFlAuZnlv5c7q(xTD#lXN|1FFN5
z^K%RA-hl!V<O5Cyu<O8!IOF3%t}Tv_2m1n?GQfo<=wt=x{(O+v!4d=F32?%Uk55l6
z0Xr!^{w>HG;H=IliKr0aSsk=(4AjsAFWhbh)rOFU9=J9H<!*52xP}=Nzl?>v4B;uD
zJr5v1LUv|C>J3Qmqy!W;NcF`vP?os@>Uw~z1DA;4*aZ^<89K%A(D{fQI({0Uq3odP
zAZO12IUD4y`1q9k<oNiYt02(@AYvhiSPUXSt0ll`ItWy3g2(eAn@~4{WI=~<25kkg
zwu6YBAYwO&0C%21jhG-%?FFtQf<Rd}=sHOD7D_=faA6fRlYxOD1hk$3)aqmtWMdX(
z<Y(k$<}?Ry+0X=S6P0k`<OV^0ULGDE9!@S!Pfl4*K2BCnZcY|ZJp*beGJp~bD15-%
zVoJc9AA-R-syK>~fdSlhfi;#A;ZrrR)#Bi`3V2;oMTsutj9}1$0%*~%r>BsTT2Pb<
zS`?IGWu;)KXP{>Q**^tp*CX$21}$_?N=?l}(x6bB30k>c20CsyKM$fAT)$@)Lwe=e
zsRiJba9}rr3`|N)1}!Q`DOLa#5s4+4NtrpBC6#&#eyQaOpkq~FN1v4zBbI5_!P{=o
zwn8y%w-{o@U`f70a#1Siq|-$B4mapY4vC<HAfabBq$nhoC?qPRm6ntir7D091%(C#
zZ21H<*uV}3hcP%7!HEb#3{2JoWhQ6<d;{e=P|?c3qXFud2i*oG{L`Q;2d<zhA*=2|
zs{p~ven1`talj)E;C1RjphN|3Xh9+(2xM9iNHb(d6sW*~Y!3%n3mJ(3Rf^!VX&}q)
zLERg$3Ay<xsX4`vMNqsThwy<2(5M1rdlqO^13U;4p9$LJlb4tiUs{rxQw%<w2VD9?
zxZtiHsGbC$G6&w)np%;Z3SJ9S3_j;42-KiPIy?we;Xw9&loq8H2Z2i;&|WU^4leLX
zK0%-^4&-1A@GuW(@)&a94X6PED&nE%`4oc>^a)Y|g(1kJ1v!Z&Y57ID;QF8-wJ0qf
zd@gQkQP6&n5|9@iOG=6|lS)e<<3V7LKn8cfy9q$s2f)DtS>751+T{vPOhI=BNdW~;
z8a9x9!*<|Ky%hrk18CV5=o~u%CILo0MkOX0MlnVKMj1vWW&uV4COuXGW&vh?MrKA{
U@NRZaW*&JSezC7&{}~no02mRM`v3p{

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/requests/status_codes.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/requests/status_codes.py
new file mode 100644
index 0000000..813e8c4
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/requests/status_codes.py
@@ -0,0 +1,120 @@
+# -*- coding: utf-8 -*-
+
+r"""
+The ``codes`` object defines a mapping from common names for HTTP statuses
+to their numerical codes, accessible either as attributes or as dictionary
+items.
+
+>>> requests.codes['temporary_redirect']
+307
+>>> requests.codes.teapot
+418
+>>> requests.codes['\o/']
+200
+
+Some codes have multiple names, and both upper- and lower-case versions of
+the names are allowed. For example, ``codes.ok``, ``codes.OK``, and
+``codes.okay`` all correspond to the HTTP status code 200.
+"""
+
+from .structures import LookupDict
+
+_codes = {
+
+    # Informational.
+    100: ('continue',),
+    101: ('switching_protocols',),
+    102: ('processing',),
+    103: ('checkpoint',),
+    122: ('uri_too_long', 'request_uri_too_long'),
+    200: ('ok', 'okay', 'all_ok', 'all_okay', 'all_good', '\\o/', '✓'),
+    201: ('created',),
+    202: ('accepted',),
+    203: ('non_authoritative_info', 'non_authoritative_information'),
+    204: ('no_content',),
+    205: ('reset_content', 'reset'),
+    206: ('partial_content', 'partial'),
+    207: ('multi_status', 'multiple_status', 'multi_stati', 'multiple_stati'),
+    208: ('already_reported',),
+    226: ('im_used',),
+
+    # Redirection.
+    300: ('multiple_choices',),
+    301: ('moved_permanently', 'moved', '\\o-'),
+    302: ('found',),
+    303: ('see_other', 'other'),
+    304: ('not_modified',),
+    305: ('use_proxy',),
+    306: ('switch_proxy',),
+    307: ('temporary_redirect', 'temporary_moved', 'temporary'),
+    308: ('permanent_redirect',
+          'resume_incomplete', 'resume',),  # These 2 to be removed in 3.0
+
+    # Client Error.
+    400: ('bad_request', 'bad'),
+    401: ('unauthorized',),
+    402: ('payment_required', 'payment'),
+    403: ('forbidden',),
+    404: ('not_found', '-o-'),
+    405: ('method_not_allowed', 'not_allowed'),
+    406: ('not_acceptable',),
+    407: ('proxy_authentication_required', 'proxy_auth', 'proxy_authentication'),
+    408: ('request_timeout', 'timeout'),
+    409: ('conflict',),
+    410: ('gone',),
+    411: ('length_required',),
+    412: ('precondition_failed', 'precondition'),
+    413: ('request_entity_too_large',),
+    414: ('request_uri_too_large',),
+    415: ('unsupported_media_type', 'unsupported_media', 'media_type'),
+    416: ('requested_range_not_satisfiable', 'requested_range', 'range_not_satisfiable'),
+    417: ('expectation_failed',),
+    418: ('im_a_teapot', 'teapot', 'i_am_a_teapot'),
+    421: ('misdirected_request',),
+    422: ('unprocessable_entity', 'unprocessable'),
+    423: ('locked',),
+    424: ('failed_dependency', 'dependency'),
+    425: ('unordered_collection', 'unordered'),
+    426: ('upgrade_required', 'upgrade'),
+    428: ('precondition_required', 'precondition'),
+    429: ('too_many_requests', 'too_many'),
+    431: ('header_fields_too_large', 'fields_too_large'),
+    444: ('no_response', 'none'),
+    449: ('retry_with', 'retry'),
+    450: ('blocked_by_windows_parental_controls', 'parental_controls'),
+    451: ('unavailable_for_legal_reasons', 'legal_reasons'),
+    499: ('client_closed_request',),
+
+    # Server Error.
+    500: ('internal_server_error', 'server_error', '/o\\', '✗'),
+    501: ('not_implemented',),
+    502: ('bad_gateway',),
+    503: ('service_unavailable', 'unavailable'),
+    504: ('gateway_timeout',),
+    505: ('http_version_not_supported', 'http_version'),
+    506: ('variant_also_negotiates',),
+    507: ('insufficient_storage',),
+    509: ('bandwidth_limit_exceeded', 'bandwidth'),
+    510: ('not_extended',),
+    511: ('network_authentication_required', 'network_auth', 'network_authentication'),
+}
+
+codes = LookupDict(name='status_codes')
+
+def _init():
+    for code, titles in _codes.items():
+        for title in titles:
+            setattr(codes, title, code)
+            if not title.startswith(('\\', '/')):
+                setattr(codes, title.upper(), code)
+
+    def doc(code):
+        names = ', '.join('``%s``' % n for n in _codes[code])
+        return '* %d: %s' % (code, names)
+
+    global __doc__
+    __doc__ = (__doc__ + '\n' +
+               '\n'.join(doc(code) for code in sorted(_codes))
+               if __doc__ is not None else None)
+
+_init()
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/requests/status_codes.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/requests/status_codes.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..0b59a325d6e0cff83f58e95c41454fbdf07de8d3
GIT binary patch
literal 7881
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

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/requests/structures.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/requests/structures.py
new file mode 100644
index 0000000..da930e2
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/requests/structures.py
@@ -0,0 +1,103 @@
+# -*- coding: utf-8 -*-
+
+"""
+requests.structures
+~~~~~~~~~~~~~~~~~~~
+
+Data structures that power Requests.
+"""
+
+from .compat import OrderedDict, Mapping, MutableMapping
+
+
+class CaseInsensitiveDict(MutableMapping):
+    """A case-insensitive ``dict``-like object.
+
+    Implements all methods and operations of
+    ``MutableMapping`` as well as dict's ``copy``. Also
+    provides ``lower_items``.
+
+    All keys are expected to be strings. The structure remembers the
+    case of the last key to be set, and ``iter(instance)``,
+    ``keys()``, ``items()``, ``iterkeys()``, and ``iteritems()``
+    will contain case-sensitive keys. However, querying and contains
+    testing is case insensitive::
+
+        cid = CaseInsensitiveDict()
+        cid['Accept'] = 'application/json'
+        cid['aCCEPT'] == 'application/json'  # True
+        list(cid) == ['Accept']  # True
+
+    For example, ``headers['content-encoding']`` will return the
+    value of a ``'Content-Encoding'`` response header, regardless
+    of how the header name was originally stored.
+
+    If the constructor, ``.update``, or equality comparison
+    operations are given keys that have equal ``.lower()``s, the
+    behavior is undefined.
+    """
+
+    def __init__(self, data=None, **kwargs):
+        self._store = OrderedDict()
+        if data is None:
+            data = {}
+        self.update(data, **kwargs)
+
+    def __setitem__(self, key, value):
+        # Use the lowercased key for lookups, but store the actual
+        # key alongside the value.
+        self._store[key.lower()] = (key, value)
+
+    def __getitem__(self, key):
+        return self._store[key.lower()][1]
+
+    def __delitem__(self, key):
+        del self._store[key.lower()]
+
+    def __iter__(self):
+        return (casedkey for casedkey, mappedvalue in self._store.values())
+
+    def __len__(self):
+        return len(self._store)
+
+    def lower_items(self):
+        """Like iteritems(), but with all lowercase keys."""
+        return (
+            (lowerkey, keyval[1])
+            for (lowerkey, keyval)
+            in self._store.items()
+        )
+
+    def __eq__(self, other):
+        if isinstance(other, Mapping):
+            other = CaseInsensitiveDict(other)
+        else:
+            return NotImplemented
+        # Compare insensitively
+        return dict(self.lower_items()) == dict(other.lower_items())
+
+    # Copy is required
+    def copy(self):
+        return CaseInsensitiveDict(self._store.values())
+
+    def __repr__(self):
+        return str(dict(self.items()))
+
+
+class LookupDict(dict):
+    """Dictionary lookup object."""
+
+    def __init__(self, name=None):
+        self.name = name
+        super(LookupDict, self).__init__()
+
+    def __repr__(self):
+        return '<lookup \'%s\'>' % (self.name)
+
+    def __getitem__(self, key):
+        # We allow fall-through here, so values default to None
+
+        return self.__dict__.get(key, None)
+
+    def get(self, key, default=None):
+        return self.__dict__.get(key, default)
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/requests/structures.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/requests/structures.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..9e186857b3d212ce69e7017e7333c2de80c174df
GIT binary patch
literal 6281
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

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/requests/utils.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/requests/utils.py
new file mode 100644
index 0000000..8170a8d
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/requests/utils.py
@@ -0,0 +1,977 @@
+# -*- coding: utf-8 -*-
+
+"""
+requests.utils
+~~~~~~~~~~~~~~
+
+This module provides utility functions that are used within Requests
+that are also useful for external consumption.
+"""
+
+import codecs
+import contextlib
+import io
+import os
+import re
+import socket
+import struct
+import sys
+import tempfile
+import warnings
+import zipfile
+
+from .__version__ import __version__
+from . import certs
+# to_native_string is unused here, but imported here for backwards compatibility
+from ._internal_utils import to_native_string
+from .compat import parse_http_list as _parse_list_header
+from .compat import (
+    quote, urlparse, bytes, str, OrderedDict, unquote, getproxies,
+    proxy_bypass, urlunparse, basestring, integer_types, is_py3,
+    proxy_bypass_environment, getproxies_environment, Mapping)
+from .cookies import cookiejar_from_dict
+from .structures import CaseInsensitiveDict
+from .exceptions import (
+    InvalidURL, InvalidHeader, FileModeWarning, UnrewindableBodyError)
+
+NETRC_FILES = ('.netrc', '_netrc')
+
+DEFAULT_CA_BUNDLE_PATH = certs.where()
+
+DEFAULT_PORTS = {'http': 80, 'https': 443}
+
+
+if sys.platform == 'win32':
+    # provide a proxy_bypass version on Windows without DNS lookups
+
+    def proxy_bypass_registry(host):
+        try:
+            if is_py3:
+                import winreg
+            else:
+                import _winreg as winreg
+        except ImportError:
+            return False
+
+        try:
+            internetSettings = winreg.OpenKey(winreg.HKEY_CURRENT_USER,
+                r'Software\Microsoft\Windows\CurrentVersion\Internet Settings')
+            # ProxyEnable could be REG_SZ or REG_DWORD, normalizing it
+            proxyEnable = int(winreg.QueryValueEx(internetSettings,
+                                              'ProxyEnable')[0])
+            # ProxyOverride is almost always a string
+            proxyOverride = winreg.QueryValueEx(internetSettings,
+                                                'ProxyOverride')[0]
+        except OSError:
+            return False
+        if not proxyEnable or not proxyOverride:
+            return False
+
+        # make a check value list from the registry entry: replace the
+        # '<local>' string by the localhost entry and the corresponding
+        # canonical entry.
+        proxyOverride = proxyOverride.split(';')
+        # now check if we match one of the registry values.
+        for test in proxyOverride:
+            if test == '<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
+            if re.match(test, host, re.I):
+                return True
+        return False
+
+    def proxy_bypass(host):  # noqa
+        """Return True, if the host should be bypassed.
+
+        Checks proxy settings gathered from the environment, if specified,
+        or the registry.
+        """
+        if getproxies_environment():
+            return proxy_bypass_environment(host)
+        else:
+            return proxy_bypass_registry(host)
+
+
+def dict_to_sequence(d):
+    """Returns an internal sequence dictionary update."""
+
+    if hasattr(d, 'items'):
+        d = d.items()
+
+    return d
+
+
+def super_len(o):
+    total_length = None
+    current_position = 0
+
+    if hasattr(o, '__len__'):
+        total_length = len(o)
+
+    elif hasattr(o, 'len'):
+        total_length = o.len
+
+    elif hasattr(o, 'fileno'):
+        try:
+            fileno = o.fileno()
+        except io.UnsupportedOperation:
+            pass
+        else:
+            total_length = os.fstat(fileno).st_size
+
+            # Having used fstat to determine the file length, we need to
+            # confirm that this file was opened up in binary mode.
+            if 'b' not in o.mode:
+                warnings.warn((
+                    "Requests has determined the content-length for this "
+                    "request using the binary size of the file: however, the "
+                    "file has been opened in text mode (i.e. without the 'b' "
+                    "flag in the mode). This may lead to an incorrect "
+                    "content-length. In Requests 3.0, support will be removed "
+                    "for files in text mode."),
+                    FileModeWarning
+                )
+
+    if hasattr(o, 'tell'):
+        try:
+            current_position = o.tell()
+        except (OSError, IOError):
+            # This can happen in some weird situations, such as when the file
+            # is actually a special file descriptor like stdin. In this
+            # instance, we don't know what the length is, so set it to zero and
+            # let requests chunk it instead.
+            if total_length is not None:
+                current_position = total_length
+        else:
+            if hasattr(o, 'seek') and total_length is None:
+                # StringIO and BytesIO have seek but no useable fileno
+                try:
+                    # seek to end of file
+                    o.seek(0, 2)
+                    total_length = o.tell()
+
+                    # seek back to current position to support
+                    # partially read file-like objects
+                    o.seek(current_position or 0)
+                except (OSError, IOError):
+                    total_length = 0
+
+    if total_length is None:
+        total_length = 0
+
+    return max(0, total_length - current_position)
+
+
+def get_netrc_auth(url, raise_errors=False):
+    """Returns the Requests tuple auth for a given url from netrc."""
+
+    try:
+        from netrc import netrc, NetrcParseError
+
+        netrc_path = None
+
+        for f in NETRC_FILES:
+            try:
+                loc = os.path.expanduser('~/{}'.format(f))
+            except KeyError:
+                # os.path.expanduser can fail when $HOME is undefined and
+                # getpwuid fails. See https://bugs.python.org/issue20164 &
+                # https://github.com/requests/requests/issues/1846
+                return
+
+            if os.path.exists(loc):
+                netrc_path = loc
+                break
+
+        # Abort early if there isn't one.
+        if netrc_path is None:
+            return
+
+        ri = urlparse(url)
+
+        # Strip port numbers from netloc. This weird `if...encode`` dance is
+        # used for Python 3.2, which doesn't support unicode literals.
+        splitstr = b':'
+        if isinstance(url, str):
+            splitstr = splitstr.decode('ascii')
+        host = ri.netloc.split(splitstr)[0]
+
+        try:
+            _netrc = netrc(netrc_path).authenticators(host)
+            if _netrc:
+                # Return with login / password
+                login_i = (0 if _netrc[0] else 1)
+                return (_netrc[login_i], _netrc[2])
+        except (NetrcParseError, IOError):
+            # If there was a parsing error or a permissions issue reading the file,
+            # we'll just skip netrc auth unless explicitly asked to raise errors.
+            if raise_errors:
+                raise
+
+    # AppEngine hackiness.
+    except (ImportError, AttributeError):
+        pass
+
+
+def guess_filename(obj):
+    """Tries to guess the filename of the given object."""
+    name = getattr(obj, 'name', None)
+    if (name and isinstance(name, basestring) and name[0] != '<' and
+            name[-1] != '>'):
+        return os.path.basename(name)
+
+
+def extract_zipped_paths(path):
+    """Replace nonexistent paths that look like they refer to a member of a zip
+    archive with the location of an extracted copy of the target, or else
+    just return the provided path unchanged.
+    """
+    if os.path.exists(path):
+        # this is already a valid path, no need to do anything further
+        return path
+
+    # find the first valid part of the provided path and treat that as a zip archive
+    # assume the rest of the path is the name of a member in the archive
+    archive, member = os.path.split(path)
+    while archive and not os.path.exists(archive):
+        archive, prefix = os.path.split(archive)
+        member = '/'.join([prefix, member])
+
+    if not zipfile.is_zipfile(archive):
+        return path
+
+    zip_file = zipfile.ZipFile(archive)
+    if member not in zip_file.namelist():
+        return path
+
+    # we have a valid zip archive and a valid member of that archive
+    tmp = tempfile.gettempdir()
+    extracted_path = os.path.join(tmp, *member.split('/'))
+    if not os.path.exists(extracted_path):
+        extracted_path = zip_file.extract(member, path=tmp)
+
+    return extracted_path
+
+
+def from_key_val_list(value):
+    """Take an object and test to see if it can be represented as a
+    dictionary. Unless it can not be represented as such, return an
+    OrderedDict, e.g.,
+
+    ::
+
+        >>> from_key_val_list([('key', 'val')])
+        OrderedDict([('key', 'val')])
+        >>> from_key_val_list('string')
+        ValueError: cannot encode objects that are not 2-tuples
+        >>> from_key_val_list({'key': 'val'})
+        OrderedDict([('key', 'val')])
+
+    :rtype: OrderedDict
+    """
+    if value is None:
+        return None
+
+    if isinstance(value, (str, bytes, bool, int)):
+        raise ValueError('cannot encode objects that are not 2-tuples')
+
+    return OrderedDict(value)
+
+
+def to_key_val_list(value):
+    """Take an object and test to see if it can be represented as a
+    dictionary. If it can be, return a list of tuples, e.g.,
+
+    ::
+
+        >>> to_key_val_list([('key', 'val')])
+        [('key', 'val')]
+        >>> to_key_val_list({'key': 'val'})
+        [('key', 'val')]
+        >>> to_key_val_list('string')
+        ValueError: cannot encode objects that are not 2-tuples.
+
+    :rtype: list
+    """
+    if value is None:
+        return None
+
+    if isinstance(value, (str, bytes, bool, int)):
+        raise ValueError('cannot encode objects that are not 2-tuples')
+
+    if isinstance(value, Mapping):
+        value = value.items()
+
+    return list(value)
+
+
+# From mitsuhiko/werkzeug (used with permission).
+def parse_list_header(value):
+    """Parse lists as described by RFC 2068 Section 2.
+
+    In particular, parse comma-separated lists where the elements of
+    the list may include quoted-strings.  A quoted-string could
+    contain a comma.  A non-quoted string could have quotes in the
+    middle.  Quotes are removed automatically after parsing.
+
+    It basically works like :func:`parse_set_header` just that items
+    may appear multiple times and case sensitivity is preserved.
+
+    The return value is a standard :class:`list`:
+
+    >>> parse_list_header('token, "quoted value"')
+    ['token', 'quoted value']
+
+    To create a header from the :class:`list` again, use the
+    :func:`dump_header` function.
+
+    :param value: a string with a list header.
+    :return: :class:`list`
+    :rtype: list
+    """
+    result = []
+    for item in _parse_list_header(value):
+        if item[:1] == item[-1:] == '"':
+            item = unquote_header_value(item[1:-1])
+        result.append(item)
+    return result
+
+
+# From mitsuhiko/werkzeug (used with permission).
+def parse_dict_header(value):
+    """Parse lists of key, value pairs as described by RFC 2068 Section 2 and
+    convert them into a python dict:
+
+    >>> d = parse_dict_header('foo="is a fish", bar="as well"')
+    >>> type(d) is dict
+    True
+    >>> sorted(d.items())
+    [('bar', 'as well'), ('foo', 'is a fish')]
+
+    If there is no value for a key it will be `None`:
+
+    >>> parse_dict_header('key_without_value')
+    {'key_without_value': None}
+
+    To create a header from the :class:`dict` again, use the
+    :func:`dump_header` function.
+
+    :param value: a string with a dict header.
+    :return: :class:`dict`
+    :rtype: dict
+    """
+    result = {}
+    for item in _parse_list_header(value):
+        if '=' not in item:
+            result[item] = None
+            continue
+        name, value = item.split('=', 1)
+        if value[:1] == value[-1:] == '"':
+            value = unquote_header_value(value[1:-1])
+        result[name] = value
+    return result
+
+
+# From mitsuhiko/werkzeug (used with permission).
+def unquote_header_value(value, is_filename=False):
+    r"""Unquotes a header value.  (Reversal of :func:`quote_header_value`).
+    This does not use the real unquoting but what browsers are actually
+    using for quoting.
+
+    :param value: the header value to unquote.
+    :rtype: str
+    """
+    if value and value[0] == value[-1] == '"':
+        # this is not the real unquoting, but fixing this so that the
+        # RFC is met will result in bugs with internet explorer and
+        # probably some other browsers as well.  IE for example is
+        # uploading files with "C:\foo\bar.txt" as filename
+        value = value[1:-1]
+
+        # if this is a filename and the starting characters look like
+        # a UNC path, then just return the value without quotes.  Using the
+        # replace sequence below on a UNC path has the effect of turning
+        # the leading double slash into a single slash and then
+        # _fix_ie_filename() doesn't work correctly.  See #458.
+        if not is_filename or value[:2] != '\\\\':
+            return value.replace('\\\\', '\\').replace('\\"', '"')
+    return value
+
+
+def dict_from_cookiejar(cj):
+    """Returns a key/value dictionary from a CookieJar.
+
+    :param cj: CookieJar object to extract cookies from.
+    :rtype: dict
+    """
+
+    cookie_dict = {}
+
+    for cookie in cj:
+        cookie_dict[cookie.name] = cookie.value
+
+    return cookie_dict
+
+
+def add_dict_to_cookiejar(cj, cookie_dict):
+    """Returns a CookieJar from a key/value dictionary.
+
+    :param cj: CookieJar to insert cookies into.
+    :param cookie_dict: Dict of key/values to insert into CookieJar.
+    :rtype: CookieJar
+    """
+
+    return cookiejar_from_dict(cookie_dict, cj)
+
+
+def get_encodings_from_content(content):
+    """Returns encodings from given content string.
+
+    :param content: bytestring to extract encodings from.
+    """
+    warnings.warn((
+        'In requests 3.0, get_encodings_from_content will be removed. For '
+        'more information, please see the discussion on issue #2266. (This'
+        ' warning should only appear once.)'),
+        DeprecationWarning)
+
+    charset_re = re.compile(r'<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))
+
+
+def _parse_content_type_header(header):
+    """Returns content type and parameters from given header
+
+    :param header: string
+    :return: tuple containing content type and dictionary of
+         parameters
+    """
+
+    tokens = header.split(';')
+    content_type, params = tokens[0].strip(), tokens[1:]
+    params_dict = {}
+    items_to_strip = "\"' "
+
+    for param in params:
+        param = param.strip()
+        if param:
+            key, value = param, True
+            index_of_equals = param.find("=")
+            if index_of_equals != -1:
+                key = param[:index_of_equals].strip(items_to_strip)
+                value = param[index_of_equals + 1:].strip(items_to_strip)
+            params_dict[key.lower()] = value
+    return content_type, params_dict
+
+
+def get_encoding_from_headers(headers):
+    """Returns encodings from given HTTP Header Dict.
+
+    :param headers: dictionary to extract encoding from.
+    :rtype: str
+    """
+
+    content_type = headers.get('content-type')
+
+    if not content_type:
+        return None
+
+    content_type, params = _parse_content_type_header(content_type)
+
+    if 'charset' in params:
+        return params['charset'].strip("'\"")
+
+    if 'text' in content_type:
+        return 'ISO-8859-1'
+
+
+def stream_decode_response_unicode(iterator, r):
+    """Stream decodes a iterator."""
+
+    if r.encoding is None:
+        for item in iterator:
+            yield item
+        return
+
+    decoder = codecs.getincrementaldecoder(r.encoding)(errors='replace')
+    for chunk in iterator:
+        rv = decoder.decode(chunk)
+        if rv:
+            yield rv
+    rv = decoder.decode(b'', final=True)
+    if rv:
+        yield rv
+
+
+def iter_slices(string, slice_length):
+    """Iterate over slices of a string."""
+    pos = 0
+    if slice_length is None or slice_length <= 0:
+        slice_length = len(string)
+    while pos < len(string):
+        yield string[pos:pos + slice_length]
+        pos += slice_length
+
+
+def get_unicode_from_response(r):
+    """Returns the requested content back in unicode.
+
+    :param r: Response object to get unicode content from.
+
+    Tried:
+
+    1. charset from content-type
+    2. fall back and replace all unicode characters
+
+    :rtype: str
+    """
+    warnings.warn((
+        'In requests 3.0, get_unicode_from_response will be removed. For '
+        'more information, please see the discussion on issue #2266. (This'
+        ' warning should only appear once.)'),
+        DeprecationWarning)
+
+    tried_encodings = []
+
+    # Try charset from content-type
+    encoding = get_encoding_from_headers(r.headers)
+
+    if encoding:
+        try:
+            return str(r.content, encoding)
+        except UnicodeError:
+            tried_encodings.append(encoding)
+
+    # Fall back:
+    try:
+        return str(r.content, encoding, errors='replace')
+    except TypeError:
+        return r.content
+
+
+# The unreserved URI characters (RFC 3986)
+UNRESERVED_SET = frozenset(
+    "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz" + "0123456789-._~")
+
+
+def unquote_unreserved(uri):
+    """Un-escape any percent-escape sequences in a URI that are unreserved
+    characters. This leaves all reserved, illegal and non-ASCII bytes encoded.
+
+    :rtype: str
+    """
+    parts = uri.split('%')
+    for i in range(1, len(parts)):
+        h = parts[i][0:2]
+        if len(h) == 2 and h.isalnum():
+            try:
+                c = chr(int(h, 16))
+            except ValueError:
+                raise InvalidURL("Invalid percent-escape sequence: '%s'" % h)
+
+            if c in UNRESERVED_SET:
+                parts[i] = c + parts[i][2:]
+            else:
+                parts[i] = '%' + parts[i]
+        else:
+            parts[i] = '%' + parts[i]
+    return ''.join(parts)
+
+
+def requote_uri(uri):
+    """Re-quote the given URI.
+
+    This function passes the given URI through an unquote/quote cycle to
+    ensure that it is fully and consistently quoted.
+
+    :rtype: str
+    """
+    safe_with_percent = "!#$%&'()*+,/:;=?@[]~"
+    safe_without_percent = "!#$&'()*+,/:;=?@[]~"
+    try:
+        # Unquote only the unreserved characters
+        # Then quote only illegal characters (do not quote reserved,
+        # unreserved, or '%')
+        return quote(unquote_unreserved(uri), safe=safe_with_percent)
+    except InvalidURL:
+        # We couldn't unquote the given URI, so let's try quoting it, but
+        # there may be unquoted '%'s in the URI. We need to make sure they're
+        # properly quoted so they do not cause issues elsewhere.
+        return quote(uri, safe=safe_without_percent)
+
+
+def address_in_network(ip, net):
+    """This function allows you to check if an IP belongs to a network subnet
+
+    Example: returns True if ip = 192.168.1.1 and net = 192.168.1.0/24
+             returns False if ip = 192.168.1.1 and net = 192.168.100.0/24
+
+    :rtype: bool
+    """
+    ipaddr = struct.unpack('=L', socket.inet_aton(ip))[0]
+    netaddr, bits = net.split('/')
+    netmask = struct.unpack('=L', socket.inet_aton(dotted_netmask(int(bits))))[0]
+    network = struct.unpack('=L', socket.inet_aton(netaddr))[0] & netmask
+    return (ipaddr & netmask) == (network & netmask)
+
+
+def dotted_netmask(mask):
+    """Converts mask from /xx format to xxx.xxx.xxx.xxx
+
+    Example: if mask is 24 function returns 255.255.255.0
+
+    :rtype: str
+    """
+    bits = 0xffffffff ^ (1 << 32 - mask) - 1
+    return socket.inet_ntoa(struct.pack('>I', bits))
+
+
+def is_ipv4_address(string_ip):
+    """
+    :rtype: bool
+    """
+    try:
+        socket.inet_aton(string_ip)
+    except socket.error:
+        return False
+    return True
+
+
+def is_valid_cidr(string_network):
+    """
+    Very simple check of the cidr format in no_proxy variable.
+
+    :rtype: bool
+    """
+    if string_network.count('/') == 1:
+        try:
+            mask = int(string_network.split('/')[1])
+        except ValueError:
+            return False
+
+        if mask < 1 or mask > 32:
+            return False
+
+        try:
+            socket.inet_aton(string_network.split('/')[0])
+        except socket.error:
+            return False
+    else:
+        return False
+    return True
+
+
+@contextlib.contextmanager
+def set_environ(env_name, value):
+    """Set the environment variable 'env_name' to 'value'
+
+    Save previous value, yield, and then restore the previous value stored in
+    the environment variable 'env_name'.
+
+    If 'value' is None, do nothing"""
+    value_changed = value is not None
+    if value_changed:
+        old_value = os.environ.get(env_name)
+        os.environ[env_name] = value
+    try:
+        yield
+    finally:
+        if value_changed:
+            if old_value is None:
+                del os.environ[env_name]
+            else:
+                os.environ[env_name] = old_value
+
+
+def should_bypass_proxies(url, no_proxy):
+    """
+    Returns whether we should bypass proxies or not.
+
+    :rtype: bool
+    """
+    # Prioritize lowercase environment variables over uppercase
+    # to keep a consistent behaviour with other http projects (curl, wget).
+    get_proxy = lambda k: os.environ.get(k) or os.environ.get(k.upper())
+
+    # First check whether no_proxy is defined. If it is, check that the URL
+    # we're getting isn't in the no_proxy list.
+    no_proxy_arg = no_proxy
+    if no_proxy is None:
+        no_proxy = get_proxy('no_proxy')
+    parsed = urlparse(url)
+
+    if parsed.hostname is None:
+        # URLs don't always have hostnames, e.g. file:/// urls.
+        return True
+
+    if no_proxy:
+        # We need to check whether we match here. We need to see if we match
+        # the end of the hostname, both with and without the port.
+        no_proxy = (
+            host for host in no_proxy.replace(' ', '').split(',') if host
+        )
+
+        if is_ipv4_address(parsed.hostname):
+            for proxy_ip in no_proxy:
+                if is_valid_cidr(proxy_ip):
+                    if address_in_network(parsed.hostname, proxy_ip):
+                        return True
+                elif parsed.hostname == proxy_ip:
+                    # If no_proxy ip was defined in plain IP notation instead of cidr notation &
+                    # matches the IP of the index
+                    return True
+        else:
+            host_with_port = parsed.hostname
+            if parsed.port:
+                host_with_port += ':{}'.format(parsed.port)
+
+            for host in no_proxy:
+                if parsed.hostname.endswith(host) or host_with_port.endswith(host):
+                    # The URL does match something in no_proxy, so we don't want
+                    # to apply the proxies on this URL.
+                    return True
+
+    with set_environ('no_proxy', no_proxy_arg):
+        # parsed.hostname can be `None` in cases such as a file URI.
+        try:
+            bypass = proxy_bypass(parsed.hostname)
+        except (TypeError, socket.gaierror):
+            bypass = False
+
+    if bypass:
+        return True
+
+    return False
+
+
+def get_environ_proxies(url, no_proxy=None):
+    """
+    Return a dict of environment proxies.
+
+    :rtype: dict
+    """
+    if should_bypass_proxies(url, no_proxy=no_proxy):
+        return {}
+    else:
+        return getproxies()
+
+
+def select_proxy(url, proxies):
+    """Select a proxy for the url, if applicable.
+
+    :param url: The url being for the request
+    :param proxies: A dictionary of schemes or schemes and hosts to proxy URLs
+    """
+    proxies = proxies or {}
+    urlparts = urlparse(url)
+    if urlparts.hostname is None:
+        return proxies.get(urlparts.scheme, proxies.get('all'))
+
+    proxy_keys = [
+        urlparts.scheme + '://' + urlparts.hostname,
+        urlparts.scheme,
+        'all://' + urlparts.hostname,
+        'all',
+    ]
+    proxy = None
+    for proxy_key in proxy_keys:
+        if proxy_key in proxies:
+            proxy = proxies[proxy_key]
+            break
+
+    return proxy
+
+
+def default_user_agent(name="python-requests"):
+    """
+    Return a string representing the default user agent.
+
+    :rtype: str
+    """
+    return '%s/%s' % (name, __version__)
+
+
+def default_headers():
+    """
+    :rtype: requests.structures.CaseInsensitiveDict
+    """
+    return CaseInsensitiveDict({
+        'User-Agent': default_user_agent(),
+        'Accept-Encoding': ', '.join(('gzip', 'deflate')),
+        'Accept': '*/*',
+        'Connection': 'keep-alive',
+    })
+
+
+def parse_header_links(value):
+    """Return a list of parsed link headers proxies.
+
+    i.e. Link: <http:/.../front.jpeg>; rel=front; type="image/jpeg",<http://.../back.jpeg>; rel=back;type="image/jpeg"
+
+    :rtype: list
+    """
+
+    links = []
+
+    replace_chars = ' \'"'
+
+    value = value.strip(replace_chars)
+    if not value:
+        return links
+
+    for val in re.split(', *<', value):
+        try:
+            url, params = val.split(';', 1)
+        except ValueError:
+            url, params = val, ''
+
+        link = {'url': url.strip('<> \'"')}
+
+        for param in params.split(';'):
+            try:
+                key, value = param.split('=')
+            except ValueError:
+                break
+
+            link[key.strip(replace_chars)] = value.strip(replace_chars)
+
+        links.append(link)
+
+    return links
+
+
+# Null bytes; no need to recreate these on each call to guess_json_utf
+_null = '\x00'.encode('ascii')  # encoding to ASCII for Python 3
+_null2 = _null * 2
+_null3 = _null * 3
+
+
+def guess_json_utf(data):
+    """
+    :rtype: str
+    """
+    # JSON always starts with two ASCII characters, so detection is as
+    # easy as counting the nulls and from their location and count
+    # determine the encoding. Also detect a BOM, if present.
+    sample = data[:4]
+    if sample in (codecs.BOM_UTF32_LE, codecs.BOM_UTF32_BE):
+        return 'utf-32'     # BOM included
+    if sample[:3] == codecs.BOM_UTF8:
+        return 'utf-8-sig'  # BOM included, MS style (discouraged)
+    if sample[:2] in (codecs.BOM_UTF16_LE, codecs.BOM_UTF16_BE):
+        return 'utf-16'     # BOM included
+    nullcount = sample.count(_null)
+    if nullcount == 0:
+        return 'utf-8'
+    if nullcount == 2:
+        if sample[::2] == _null2:   # 1st and 3rd are null
+            return 'utf-16-be'
+        if sample[1::2] == _null2:  # 2nd and 4th are null
+            return 'utf-16-le'
+        # Did not detect 2 valid UTF-16 ascii-range characters
+    if nullcount == 3:
+        if sample[:3] == _null3:
+            return 'utf-32-be'
+        if sample[1:] == _null3:
+            return 'utf-32-le'
+        # Did not detect a valid UTF-32 ascii-range character
+    return None
+
+
+def prepend_scheme_if_needed(url, new_scheme):
+    """Given a URL that may or may not have a scheme, prepend the given scheme.
+    Does not replace a present scheme with the one provided as an argument.
+
+    :rtype: str
+    """
+    scheme, netloc, path, params, query, fragment = urlparse(url, new_scheme)
+
+    # urlparse is a finicky beast, and sometimes decides that there isn't a
+    # netloc present. Assume that it's being over-cautious, and switch netloc
+    # and path if urlparse decided there was no netloc.
+    if not netloc:
+        netloc, path = path, netloc
+
+    return urlunparse((scheme, netloc, path, params, query, fragment))
+
+
+def get_auth_from_url(url):
+    """Given a url with authentication components, extract them into a tuple of
+    username,password.
+
+    :rtype: (str,str)
+    """
+    parsed = urlparse(url)
+
+    try:
+        auth = (unquote(parsed.username), unquote(parsed.password))
+    except (AttributeError, TypeError):
+        auth = ('', '')
+
+    return auth
+
+
+# Moved outside of function to avoid recompile every call
+_CLEAN_HEADER_REGEX_BYTE = re.compile(b'^\\S[^\\r\\n]*$|^$')
+_CLEAN_HEADER_REGEX_STR = re.compile(r'^\S[^\r\n]*$|^$')
+
+
+def check_header_validity(header):
+    """Verifies that header value is a string which doesn't contain
+    leading whitespace or return characters. This prevents unintended
+    header injection.
+
+    :param header: tuple, in the format (name, value).
+    """
+    name, value = header
+
+    if isinstance(value, bytes):
+        pat = _CLEAN_HEADER_REGEX_BYTE
+    else:
+        pat = _CLEAN_HEADER_REGEX_STR
+    try:
+        if not pat.match(value):
+            raise InvalidHeader("Invalid return character or leading space in header: %s" % name)
+    except TypeError:
+        raise InvalidHeader("Value for header {%s: %s} must be of type str or "
+                            "bytes, not %s" % (name, value, type(value)))
+
+
+def urldefragauth(url):
+    """
+    Given a url remove the fragment and the authentication part.
+
+    :rtype: str
+    """
+    scheme, netloc, path, params, query, fragment = urlparse(url)
+
+    # see func:`prepend_scheme_if_needed`
+    if not netloc:
+        netloc, path = path, netloc
+
+    netloc = netloc.rsplit('@', 1)[-1]
+
+    return urlunparse((scheme, netloc, path, params, query, ''))
+
+
+def rewind_body(prepared_request):
+    """Move file pointer back to its recorded starting position
+    so it can be read again on redirect.
+    """
+    body_seek = getattr(prepared_request.body, 'seek', None)
+    if body_seek is not None and isinstance(prepared_request._body_position, integer_types):
+        try:
+            body_seek(prepared_request._body_position)
+        except (IOError, OSError):
+            raise UnrewindableBodyError("An error occurred when rewinding request "
+                                        "body for redirect.")
+    else:
+        raise UnrewindableBodyError("Unable to rewind request body for redirect.")
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/requests/utils.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/requests/utils.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..64aa7549518ccf5db86871d1680f86e1522b4bc9
GIT binary patch
literal 29364
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
DZdh9h

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/retrying.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/retrying.py
new file mode 100644
index 0000000..6d1e627
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/retrying.py
@@ -0,0 +1,267 @@
+## Copyright 2013-2014 Ray Holder
+##
+## 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 random
+from pip._vendor import six
+import sys
+import time
+import traceback
+
+
+# sys.maxint / 2, since Python 3.2 doesn't have a sys.maxint...
+MAX_WAIT = 1073741823
+
+
+def retry(*dargs, **dkw):
+    """
+    Decorator function that instantiates the 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]):
+        def wrap_simple(f):
+
+            @six.wraps(f)
+            def wrapped_f(*args, **kw):
+                return Retrying().call(f, *args, **kw)
+
+            return wrapped_f
+
+        return wrap_simple(dargs[0])
+
+    else:
+        def wrap(f):
+
+            @six.wraps(f)
+            def wrapped_f(*args, **kw):
+                return Retrying(*dargs, **dkw).call(f, *args, **kw)
+
+            return wrapped_f
+
+        return wrap
+
+
+class Retrying(object):
+
+    def __init__(self,
+                 stop=None, wait=None,
+                 stop_max_attempt_number=None,
+                 stop_max_delay=None,
+                 wait_fixed=None,
+                 wait_random_min=None, wait_random_max=None,
+                 wait_incrementing_start=None, wait_incrementing_increment=None,
+                 wait_exponential_multiplier=None, wait_exponential_max=None,
+                 retry_on_exception=None,
+                 retry_on_result=None,
+                 wrap_exception=False,
+                 stop_func=None,
+                 wait_func=None,
+                 wait_jitter_max=None):
+
+        self._stop_max_attempt_number = 5 if stop_max_attempt_number is None else stop_max_attempt_number
+        self._stop_max_delay = 100 if stop_max_delay is None else stop_max_delay
+        self._wait_fixed = 1000 if wait_fixed is None else wait_fixed
+        self._wait_random_min = 0 if wait_random_min is None else wait_random_min
+        self._wait_random_max = 1000 if wait_random_max is None else wait_random_max
+        self._wait_incrementing_start = 0 if wait_incrementing_start is None else wait_incrementing_start
+        self._wait_incrementing_increment = 100 if wait_incrementing_increment is None else wait_incrementing_increment
+        self._wait_exponential_multiplier = 1 if wait_exponential_multiplier is None else wait_exponential_multiplier
+        self._wait_exponential_max = MAX_WAIT if wait_exponential_max is None else wait_exponential_max
+        self._wait_jitter_max = 0 if wait_jitter_max is None else wait_jitter_max
+
+        # TODO add chaining of stop behaviors
+        # stop behavior
+        stop_funcs = []
+        if stop_max_attempt_number is not None:
+            stop_funcs.append(self.stop_after_attempt)
+
+        if stop_max_delay is not None:
+            stop_funcs.append(self.stop_after_delay)
+
+        if stop_func is not None:
+            self.stop = stop_func
+
+        elif stop is None:
+            self.stop = lambda attempts, delay: any(f(attempts, delay) for f in stop_funcs)
+
+        else:
+            self.stop = getattr(self, stop)
+
+        # TODO add chaining of wait behaviors
+        # wait behavior
+        wait_funcs = [lambda *args, **kwargs: 0]
+        if wait_fixed is not None:
+            wait_funcs.append(self.fixed_sleep)
+
+        if wait_random_min is not None or wait_random_max is not None:
+            wait_funcs.append(self.random_sleep)
+
+        if wait_incrementing_start is not None or wait_incrementing_increment is not None:
+            wait_funcs.append(self.incrementing_sleep)
+
+        if wait_exponential_multiplier is not None or wait_exponential_max is not None:
+            wait_funcs.append(self.exponential_sleep)
+
+        if wait_func is not None:
+            self.wait = wait_func
+
+        elif wait is None:
+            self.wait = lambda attempts, delay: max(f(attempts, delay) for f in wait_funcs)
+
+        else:
+            self.wait = getattr(self, wait)
+
+        # retry on exception filter
+        if retry_on_exception is None:
+            self._retry_on_exception = self.always_reject
+        else:
+            self._retry_on_exception = retry_on_exception
+
+        # TODO simplify retrying by Exception types
+        # retry on result filter
+        if retry_on_result is None:
+            self._retry_on_result = self.never_reject
+        else:
+            self._retry_on_result = retry_on_result
+
+        self._wrap_exception = wrap_exception
+
+    def stop_after_attempt(self, previous_attempt_number, delay_since_first_attempt_ms):
+        """Stop after the previous attempt >= stop_max_attempt_number."""
+        return previous_attempt_number >= self._stop_max_attempt_number
+
+    def stop_after_delay(self, previous_attempt_number, delay_since_first_attempt_ms):
+        """Stop after the time from the first attempt >= stop_max_delay."""
+        return delay_since_first_attempt_ms >= self._stop_max_delay
+
+    def no_sleep(self, previous_attempt_number, delay_since_first_attempt_ms):
+        """Don't sleep at all before retrying."""
+        return 0
+
+    def fixed_sleep(self, previous_attempt_number, delay_since_first_attempt_ms):
+        """Sleep a fixed amount of time between each retry."""
+        return self._wait_fixed
+
+    def random_sleep(self, previous_attempt_number, delay_since_first_attempt_ms):
+        """Sleep a random amount of time between wait_random_min and wait_random_max"""
+        return random.randint(self._wait_random_min, self._wait_random_max)
+
+    def incrementing_sleep(self, previous_attempt_number, delay_since_first_attempt_ms):
+        """
+        Sleep an incremental amount of time after each attempt, starting at
+        wait_incrementing_start and incrementing by wait_incrementing_increment
+        """
+        result = self._wait_incrementing_start + (self._wait_incrementing_increment * (previous_attempt_number - 1))
+        if result < 0:
+            result = 0
+        return result
+
+    def exponential_sleep(self, previous_attempt_number, delay_since_first_attempt_ms):
+        exp = 2 ** previous_attempt_number
+        result = self._wait_exponential_multiplier * exp
+        if result > self._wait_exponential_max:
+            result = self._wait_exponential_max
+        if result < 0:
+            result = 0
+        return result
+
+    def never_reject(self, result):
+        return False
+
+    def always_reject(self, result):
+        return True
+
+    def should_reject(self, attempt):
+        reject = False
+        if attempt.has_exception:
+            reject |= self._retry_on_exception(attempt.value[1])
+        else:
+            reject |= self._retry_on_result(attempt.value)
+
+        return reject
+
+    def call(self, fn, *args, **kwargs):
+        start_time = int(round(time.time() * 1000))
+        attempt_number = 1
+        while True:
+            try:
+                attempt = Attempt(fn(*args, **kwargs), attempt_number, False)
+            except:
+                tb = sys.exc_info()
+                attempt = Attempt(tb, attempt_number, True)
+
+            if not self.should_reject(attempt):
+                return attempt.get(self._wrap_exception)
+
+            delay_since_first_attempt_ms = int(round(time.time() * 1000)) - start_time
+            if self.stop(attempt_number, delay_since_first_attempt_ms):
+                if not self._wrap_exception and attempt.has_exception:
+                    # get() on an attempt with an exception should cause it to be raised, but raise just in case
+                    raise attempt.get()
+                else:
+                    raise RetryError(attempt)
+            else:
+                sleep = self.wait(attempt_number, delay_since_first_attempt_ms)
+                if self._wait_jitter_max:
+                    jitter = random.random() * self._wait_jitter_max
+                    sleep = sleep + max(0, jitter)
+                time.sleep(sleep / 1000.0)
+
+            attempt_number += 1
+
+
+class Attempt(object):
+    """
+    An Attempt encapsulates a call to a target function that may end as a
+    normal return value from the function or an Exception depending on what
+    occurred during the execution.
+    """
+
+    def __init__(self, value, attempt_number, has_exception):
+        self.value = value
+        self.attempt_number = attempt_number
+        self.has_exception = has_exception
+
+    def get(self, wrap_exception=False):
+        """
+        Return the return value of this Attempt instance or raise an Exception.
+        If wrap_exception is true, this Attempt is wrapped inside of a
+        RetryError before being raised.
+        """
+        if self.has_exception:
+            if wrap_exception:
+                raise RetryError(self)
+            else:
+                six.reraise(self.value[0], self.value[1], self.value[2])
+        else:
+            return self.value
+
+    def __repr__(self):
+        if self.has_exception:
+            return "Attempts: {0}, Error:\n{1}".format(self.attempt_number, "".join(traceback.format_tb(self.value[2])))
+        else:
+            return "Attempts: {0}, Value: {1}".format(self.attempt_number, self.value)
+
+
+class RetryError(Exception):
+    """
+    A RetryError encapsulates the last Attempt instance right before giving up.
+    """
+
+    def __init__(self, last_attempt):
+        self.last_attempt = last_attempt
+
+    def __str__(self):
+        return "RetryError[{0}]".format(self.last_attempt)
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/retrying.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/retrying.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..0476a0871670217101061b56da37cdfb5ad7ca4f
GIT binary patch
literal 11662
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
LIpxGwiYWpBABLIj

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/six.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/six.py
new file mode 100644
index 0000000..89b2188
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/six.py
@@ -0,0 +1,952 @@
+# Copyright (c) 2010-2018 Benjamin Peterson
+#
+# Permission is hereby granted, free of charge, to any person obtaining a copy
+# of this software and associated documentation files (the "Software"), to deal
+# in the Software without restriction, including without limitation the rights
+# to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
+# copies of the Software, and to permit persons to whom the Software is
+# furnished to do so, subject to the following conditions:
+#
+# The above copyright notice and this permission notice shall be included in all
+# copies or substantial portions of the Software.
+#
+# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
+# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
+# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
+# AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
+# LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
+# OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
+# SOFTWARE.
+
+"""Utilities for writing code that runs on Python 2 and 3"""
+
+from __future__ import absolute_import
+
+import functools
+import itertools
+import operator
+import sys
+import types
+
+__author__ = "Benjamin Peterson <benjamin@python.org>"
+__version__ = "1.12.0"
+
+
+# Useful for very coarse version differentiation.
+PY2 = sys.version_info[0] == 2
+PY3 = sys.version_info[0] == 3
+PY34 = sys.version_info[0:2] >= (3, 4)
+
+if PY3:
+    string_types = str,
+    integer_types = int,
+    class_types = type,
+    text_type = str
+    binary_type = bytes
+
+    MAXSIZE = sys.maxsize
+else:
+    string_types = basestring,
+    integer_types = (int, long)
+    class_types = (type, types.ClassType)
+    text_type = unicode
+    binary_type = str
+
+    if sys.platform.startswith("java"):
+        # Jython always uses 32 bits.
+        MAXSIZE = int((1 << 31) - 1)
+    else:
+        # It's possible to have sizeof(long) != sizeof(Py_ssize_t).
+        class X(object):
+
+            def __len__(self):
+                return 1 << 31
+        try:
+            len(X())
+        except OverflowError:
+            # 32-bit
+            MAXSIZE = int((1 << 31) - 1)
+        else:
+            # 64-bit
+            MAXSIZE = int((1 << 63) - 1)
+        del X
+
+
+def _add_doc(func, doc):
+    """Add documentation to a function."""
+    func.__doc__ = doc
+
+
+def _import_module(name):
+    """Import module, returning the module after the last dot."""
+    __import__(name)
+    return sys.modules[name]
+
+
+class _LazyDescr(object):
+
+    def __init__(self, name):
+        self.name = name
+
+    def __get__(self, obj, tp):
+        result = self._resolve()
+        setattr(obj, self.name, result)  # Invokes __set__.
+        try:
+            # This is a bit ugly, but it avoids running this again by
+            # removing this descriptor.
+            delattr(obj.__class__, self.name)
+        except AttributeError:
+            pass
+        return result
+
+
+class MovedModule(_LazyDescr):
+
+    def __init__(self, name, old, new=None):
+        super(MovedModule, self).__init__(name)
+        if PY3:
+            if new is None:
+                new = name
+            self.mod = new
+        else:
+            self.mod = old
+
+    def _resolve(self):
+        return _import_module(self.mod)
+
+    def __getattr__(self, attr):
+        _module = self._resolve()
+        value = getattr(_module, attr)
+        setattr(self, attr, value)
+        return value
+
+
+class _LazyModule(types.ModuleType):
+
+    def __init__(self, name):
+        super(_LazyModule, self).__init__(name)
+        self.__doc__ = self.__class__.__doc__
+
+    def __dir__(self):
+        attrs = ["__doc__", "__name__"]
+        attrs += [attr.name for attr in self._moved_attributes]
+        return attrs
+
+    # Subclasses should override this
+    _moved_attributes = []
+
+
+class MovedAttribute(_LazyDescr):
+
+    def __init__(self, name, old_mod, new_mod, old_attr=None, new_attr=None):
+        super(MovedAttribute, self).__init__(name)
+        if PY3:
+            if new_mod is None:
+                new_mod = name
+            self.mod = new_mod
+            if new_attr is None:
+                if old_attr is None:
+                    new_attr = name
+                else:
+                    new_attr = old_attr
+            self.attr = new_attr
+        else:
+            self.mod = old_mod
+            if old_attr is None:
+                old_attr = name
+            self.attr = old_attr
+
+    def _resolve(self):
+        module = _import_module(self.mod)
+        return getattr(module, self.attr)
+
+
+class _SixMetaPathImporter(object):
+
+    """
+    A meta path importer to import six.moves and its submodules.
+
+    This class implements a PEP302 finder and loader. It should be compatible
+    with Python 2.5 and all existing versions of Python3
+    """
+
+    def __init__(self, six_module_name):
+        self.name = six_module_name
+        self.known_modules = {}
+
+    def _add_module(self, mod, *fullnames):
+        for fullname in fullnames:
+            self.known_modules[self.name + "." + fullname] = mod
+
+    def _get_module(self, fullname):
+        return self.known_modules[self.name + "." + fullname]
+
+    def find_module(self, fullname, path=None):
+        if fullname in self.known_modules:
+            return self
+        return None
+
+    def __get_module(self, fullname):
+        try:
+            return self.known_modules[fullname]
+        except KeyError:
+            raise ImportError("This loader does not know module " + fullname)
+
+    def load_module(self, fullname):
+        try:
+            # in case of a reload
+            return sys.modules[fullname]
+        except KeyError:
+            pass
+        mod = self.__get_module(fullname)
+        if isinstance(mod, MovedModule):
+            mod = mod._resolve()
+        else:
+            mod.__loader__ = self
+        sys.modules[fullname] = mod
+        return mod
+
+    def is_package(self, fullname):
+        """
+        Return true, if the named module is a package.
+
+        We need this method to get correct spec objects with
+        Python 3.4 (see PEP451)
+        """
+        return hasattr(self.__get_module(fullname), "__path__")
+
+    def get_code(self, fullname):
+        """Return None
+
+        Required, if is_package is implemented"""
+        self.__get_module(fullname)  # eventually raises ImportError
+        return None
+    get_source = get_code  # same as get_code
+
+_importer = _SixMetaPathImporter(__name__)
+
+
+class _MovedItems(_LazyModule):
+
+    """Lazy loading of moved objects"""
+    __path__ = []  # mark as package
+
+
+_moved_attributes = [
+    MovedAttribute("cStringIO", "cStringIO", "io", "StringIO"),
+    MovedAttribute("filter", "itertools", "builtins", "ifilter", "filter"),
+    MovedAttribute("filterfalse", "itertools", "itertools", "ifilterfalse", "filterfalse"),
+    MovedAttribute("input", "__builtin__", "builtins", "raw_input", "input"),
+    MovedAttribute("intern", "__builtin__", "sys"),
+    MovedAttribute("map", "itertools", "builtins", "imap", "map"),
+    MovedAttribute("getcwd", "os", "os", "getcwdu", "getcwd"),
+    MovedAttribute("getcwdb", "os", "os", "getcwd", "getcwdb"),
+    MovedAttribute("getoutput", "commands", "subprocess"),
+    MovedAttribute("range", "__builtin__", "builtins", "xrange", "range"),
+    MovedAttribute("reload_module", "__builtin__", "importlib" if PY34 else "imp", "reload"),
+    MovedAttribute("reduce", "__builtin__", "functools"),
+    MovedAttribute("shlex_quote", "pipes", "shlex", "quote"),
+    MovedAttribute("StringIO", "StringIO", "io"),
+    MovedAttribute("UserDict", "UserDict", "collections"),
+    MovedAttribute("UserList", "UserList", "collections"),
+    MovedAttribute("UserString", "UserString", "collections"),
+    MovedAttribute("xrange", "__builtin__", "builtins", "xrange", "range"),
+    MovedAttribute("zip", "itertools", "builtins", "izip", "zip"),
+    MovedAttribute("zip_longest", "itertools", "itertools", "izip_longest", "zip_longest"),
+    MovedModule("builtins", "__builtin__"),
+    MovedModule("configparser", "ConfigParser"),
+    MovedModule("copyreg", "copy_reg"),
+    MovedModule("dbm_gnu", "gdbm", "dbm.gnu"),
+    MovedModule("_dummy_thread", "dummy_thread", "_dummy_thread"),
+    MovedModule("http_cookiejar", "cookielib", "http.cookiejar"),
+    MovedModule("http_cookies", "Cookie", "http.cookies"),
+    MovedModule("html_entities", "htmlentitydefs", "html.entities"),
+    MovedModule("html_parser", "HTMLParser", "html.parser"),
+    MovedModule("http_client", "httplib", "http.client"),
+    MovedModule("email_mime_base", "email.MIMEBase", "email.mime.base"),
+    MovedModule("email_mime_image", "email.MIMEImage", "email.mime.image"),
+    MovedModule("email_mime_multipart", "email.MIMEMultipart", "email.mime.multipart"),
+    MovedModule("email_mime_nonmultipart", "email.MIMENonMultipart", "email.mime.nonmultipart"),
+    MovedModule("email_mime_text", "email.MIMEText", "email.mime.text"),
+    MovedModule("BaseHTTPServer", "BaseHTTPServer", "http.server"),
+    MovedModule("CGIHTTPServer", "CGIHTTPServer", "http.server"),
+    MovedModule("SimpleHTTPServer", "SimpleHTTPServer", "http.server"),
+    MovedModule("cPickle", "cPickle", "pickle"),
+    MovedModule("queue", "Queue"),
+    MovedModule("reprlib", "repr"),
+    MovedModule("socketserver", "SocketServer"),
+    MovedModule("_thread", "thread", "_thread"),
+    MovedModule("tkinter", "Tkinter"),
+    MovedModule("tkinter_dialog", "Dialog", "tkinter.dialog"),
+    MovedModule("tkinter_filedialog", "FileDialog", "tkinter.filedialog"),
+    MovedModule("tkinter_scrolledtext", "ScrolledText", "tkinter.scrolledtext"),
+    MovedModule("tkinter_simpledialog", "SimpleDialog", "tkinter.simpledialog"),
+    MovedModule("tkinter_tix", "Tix", "tkinter.tix"),
+    MovedModule("tkinter_ttk", "ttk", "tkinter.ttk"),
+    MovedModule("tkinter_constants", "Tkconstants", "tkinter.constants"),
+    MovedModule("tkinter_dnd", "Tkdnd", "tkinter.dnd"),
+    MovedModule("tkinter_colorchooser", "tkColorChooser",
+                "tkinter.colorchooser"),
+    MovedModule("tkinter_commondialog", "tkCommonDialog",
+                "tkinter.commondialog"),
+    MovedModule("tkinter_tkfiledialog", "tkFileDialog", "tkinter.filedialog"),
+    MovedModule("tkinter_font", "tkFont", "tkinter.font"),
+    MovedModule("tkinter_messagebox", "tkMessageBox", "tkinter.messagebox"),
+    MovedModule("tkinter_tksimpledialog", "tkSimpleDialog",
+                "tkinter.simpledialog"),
+    MovedModule("urllib_parse", __name__ + ".moves.urllib_parse", "urllib.parse"),
+    MovedModule("urllib_error", __name__ + ".moves.urllib_error", "urllib.error"),
+    MovedModule("urllib", __name__ + ".moves.urllib", __name__ + ".moves.urllib"),
+    MovedModule("urllib_robotparser", "robotparser", "urllib.robotparser"),
+    MovedModule("xmlrpc_client", "xmlrpclib", "xmlrpc.client"),
+    MovedModule("xmlrpc_server", "SimpleXMLRPCServer", "xmlrpc.server"),
+]
+# Add windows specific modules.
+if sys.platform == "win32":
+    _moved_attributes += [
+        MovedModule("winreg", "_winreg"),
+    ]
+
+for attr in _moved_attributes:
+    setattr(_MovedItems, attr.name, attr)
+    if isinstance(attr, MovedModule):
+        _importer._add_module(attr, "moves." + attr.name)
+del attr
+
+_MovedItems._moved_attributes = _moved_attributes
+
+moves = _MovedItems(__name__ + ".moves")
+_importer._add_module(moves, "moves")
+
+
+class Module_six_moves_urllib_parse(_LazyModule):
+
+    """Lazy loading of moved objects in six.moves.urllib_parse"""
+
+
+_urllib_parse_moved_attributes = [
+    MovedAttribute("ParseResult", "urlparse", "urllib.parse"),
+    MovedAttribute("SplitResult", "urlparse", "urllib.parse"),
+    MovedAttribute("parse_qs", "urlparse", "urllib.parse"),
+    MovedAttribute("parse_qsl", "urlparse", "urllib.parse"),
+    MovedAttribute("urldefrag", "urlparse", "urllib.parse"),
+    MovedAttribute("urljoin", "urlparse", "urllib.parse"),
+    MovedAttribute("urlparse", "urlparse", "urllib.parse"),
+    MovedAttribute("urlsplit", "urlparse", "urllib.parse"),
+    MovedAttribute("urlunparse", "urlparse", "urllib.parse"),
+    MovedAttribute("urlunsplit", "urlparse", "urllib.parse"),
+    MovedAttribute("quote", "urllib", "urllib.parse"),
+    MovedAttribute("quote_plus", "urllib", "urllib.parse"),
+    MovedAttribute("unquote", "urllib", "urllib.parse"),
+    MovedAttribute("unquote_plus", "urllib", "urllib.parse"),
+    MovedAttribute("unquote_to_bytes", "urllib", "urllib.parse", "unquote", "unquote_to_bytes"),
+    MovedAttribute("urlencode", "urllib", "urllib.parse"),
+    MovedAttribute("splitquery", "urllib", "urllib.parse"),
+    MovedAttribute("splittag", "urllib", "urllib.parse"),
+    MovedAttribute("splituser", "urllib", "urllib.parse"),
+    MovedAttribute("splitvalue", "urllib", "urllib.parse"),
+    MovedAttribute("uses_fragment", "urlparse", "urllib.parse"),
+    MovedAttribute("uses_netloc", "urlparse", "urllib.parse"),
+    MovedAttribute("uses_params", "urlparse", "urllib.parse"),
+    MovedAttribute("uses_query", "urlparse", "urllib.parse"),
+    MovedAttribute("uses_relative", "urlparse", "urllib.parse"),
+]
+for attr in _urllib_parse_moved_attributes:
+    setattr(Module_six_moves_urllib_parse, attr.name, attr)
+del attr
+
+Module_six_moves_urllib_parse._moved_attributes = _urllib_parse_moved_attributes
+
+_importer._add_module(Module_six_moves_urllib_parse(__name__ + ".moves.urllib_parse"),
+                      "moves.urllib_parse", "moves.urllib.parse")
+
+
+class Module_six_moves_urllib_error(_LazyModule):
+
+    """Lazy loading of moved objects in six.moves.urllib_error"""
+
+
+_urllib_error_moved_attributes = [
+    MovedAttribute("URLError", "urllib2", "urllib.error"),
+    MovedAttribute("HTTPError", "urllib2", "urllib.error"),
+    MovedAttribute("ContentTooShortError", "urllib", "urllib.error"),
+]
+for attr in _urllib_error_moved_attributes:
+    setattr(Module_six_moves_urllib_error, attr.name, attr)
+del attr
+
+Module_six_moves_urllib_error._moved_attributes = _urllib_error_moved_attributes
+
+_importer._add_module(Module_six_moves_urllib_error(__name__ + ".moves.urllib.error"),
+                      "moves.urllib_error", "moves.urllib.error")
+
+
+class Module_six_moves_urllib_request(_LazyModule):
+
+    """Lazy loading of moved objects in six.moves.urllib_request"""
+
+
+_urllib_request_moved_attributes = [
+    MovedAttribute("urlopen", "urllib2", "urllib.request"),
+    MovedAttribute("install_opener", "urllib2", "urllib.request"),
+    MovedAttribute("build_opener", "urllib2", "urllib.request"),
+    MovedAttribute("pathname2url", "urllib", "urllib.request"),
+    MovedAttribute("url2pathname", "urllib", "urllib.request"),
+    MovedAttribute("getproxies", "urllib", "urllib.request"),
+    MovedAttribute("Request", "urllib2", "urllib.request"),
+    MovedAttribute("OpenerDirector", "urllib2", "urllib.request"),
+    MovedAttribute("HTTPDefaultErrorHandler", "urllib2", "urllib.request"),
+    MovedAttribute("HTTPRedirectHandler", "urllib2", "urllib.request"),
+    MovedAttribute("HTTPCookieProcessor", "urllib2", "urllib.request"),
+    MovedAttribute("ProxyHandler", "urllib2", "urllib.request"),
+    MovedAttribute("BaseHandler", "urllib2", "urllib.request"),
+    MovedAttribute("HTTPPasswordMgr", "urllib2", "urllib.request"),
+    MovedAttribute("HTTPPasswordMgrWithDefaultRealm", "urllib2", "urllib.request"),
+    MovedAttribute("AbstractBasicAuthHandler", "urllib2", "urllib.request"),
+    MovedAttribute("HTTPBasicAuthHandler", "urllib2", "urllib.request"),
+    MovedAttribute("ProxyBasicAuthHandler", "urllib2", "urllib.request"),
+    MovedAttribute("AbstractDigestAuthHandler", "urllib2", "urllib.request"),
+    MovedAttribute("HTTPDigestAuthHandler", "urllib2", "urllib.request"),
+    MovedAttribute("ProxyDigestAuthHandler", "urllib2", "urllib.request"),
+    MovedAttribute("HTTPHandler", "urllib2", "urllib.request"),
+    MovedAttribute("HTTPSHandler", "urllib2", "urllib.request"),
+    MovedAttribute("FileHandler", "urllib2", "urllib.request"),
+    MovedAttribute("FTPHandler", "urllib2", "urllib.request"),
+    MovedAttribute("CacheFTPHandler", "urllib2", "urllib.request"),
+    MovedAttribute("UnknownHandler", "urllib2", "urllib.request"),
+    MovedAttribute("HTTPErrorProcessor", "urllib2", "urllib.request"),
+    MovedAttribute("urlretrieve", "urllib", "urllib.request"),
+    MovedAttribute("urlcleanup", "urllib", "urllib.request"),
+    MovedAttribute("URLopener", "urllib", "urllib.request"),
+    MovedAttribute("FancyURLopener", "urllib", "urllib.request"),
+    MovedAttribute("proxy_bypass", "urllib", "urllib.request"),
+    MovedAttribute("parse_http_list", "urllib2", "urllib.request"),
+    MovedAttribute("parse_keqv_list", "urllib2", "urllib.request"),
+]
+for attr in _urllib_request_moved_attributes:
+    setattr(Module_six_moves_urllib_request, attr.name, attr)
+del attr
+
+Module_six_moves_urllib_request._moved_attributes = _urllib_request_moved_attributes
+
+_importer._add_module(Module_six_moves_urllib_request(__name__ + ".moves.urllib.request"),
+                      "moves.urllib_request", "moves.urllib.request")
+
+
+class Module_six_moves_urllib_response(_LazyModule):
+
+    """Lazy loading of moved objects in six.moves.urllib_response"""
+
+
+_urllib_response_moved_attributes = [
+    MovedAttribute("addbase", "urllib", "urllib.response"),
+    MovedAttribute("addclosehook", "urllib", "urllib.response"),
+    MovedAttribute("addinfo", "urllib", "urllib.response"),
+    MovedAttribute("addinfourl", "urllib", "urllib.response"),
+]
+for attr in _urllib_response_moved_attributes:
+    setattr(Module_six_moves_urllib_response, attr.name, attr)
+del attr
+
+Module_six_moves_urllib_response._moved_attributes = _urllib_response_moved_attributes
+
+_importer._add_module(Module_six_moves_urllib_response(__name__ + ".moves.urllib.response"),
+                      "moves.urllib_response", "moves.urllib.response")
+
+
+class Module_six_moves_urllib_robotparser(_LazyModule):
+
+    """Lazy loading of moved objects in six.moves.urllib_robotparser"""
+
+
+_urllib_robotparser_moved_attributes = [
+    MovedAttribute("RobotFileParser", "robotparser", "urllib.robotparser"),
+]
+for attr in _urllib_robotparser_moved_attributes:
+    setattr(Module_six_moves_urllib_robotparser, attr.name, attr)
+del attr
+
+Module_six_moves_urllib_robotparser._moved_attributes = _urllib_robotparser_moved_attributes
+
+_importer._add_module(Module_six_moves_urllib_robotparser(__name__ + ".moves.urllib.robotparser"),
+                      "moves.urllib_robotparser", "moves.urllib.robotparser")
+
+
+class Module_six_moves_urllib(types.ModuleType):
+
+    """Create a six.moves.urllib namespace that resembles the Python 3 namespace"""
+    __path__ = []  # mark as package
+    parse = _importer._get_module("moves.urllib_parse")
+    error = _importer._get_module("moves.urllib_error")
+    request = _importer._get_module("moves.urllib_request")
+    response = _importer._get_module("moves.urllib_response")
+    robotparser = _importer._get_module("moves.urllib_robotparser")
+
+    def __dir__(self):
+        return ['parse', 'error', 'request', 'response', 'robotparser']
+
+_importer._add_module(Module_six_moves_urllib(__name__ + ".moves.urllib"),
+                      "moves.urllib")
+
+
+def add_move(move):
+    """Add an item to six.moves."""
+    setattr(_MovedItems, move.name, move)
+
+
+def remove_move(name):
+    """Remove item from six.moves."""
+    try:
+        delattr(_MovedItems, name)
+    except AttributeError:
+        try:
+            del moves.__dict__[name]
+        except KeyError:
+            raise AttributeError("no such move, %r" % (name,))
+
+
+if PY3:
+    _meth_func = "__func__"
+    _meth_self = "__self__"
+
+    _func_closure = "__closure__"
+    _func_code = "__code__"
+    _func_defaults = "__defaults__"
+    _func_globals = "__globals__"
+else:
+    _meth_func = "im_func"
+    _meth_self = "im_self"
+
+    _func_closure = "func_closure"
+    _func_code = "func_code"
+    _func_defaults = "func_defaults"
+    _func_globals = "func_globals"
+
+
+try:
+    advance_iterator = next
+except NameError:
+    def advance_iterator(it):
+        return it.next()
+next = advance_iterator
+
+
+try:
+    callable = callable
+except NameError:
+    def callable(obj):
+        return any("__call__" in klass.__dict__ for klass in type(obj).__mro__)
+
+
+if PY3:
+    def get_unbound_function(unbound):
+        return unbound
+
+    create_bound_method = types.MethodType
+
+    def create_unbound_method(func, cls):
+        return func
+
+    Iterator = object
+else:
+    def get_unbound_function(unbound):
+        return unbound.im_func
+
+    def create_bound_method(func, obj):
+        return types.MethodType(func, obj, obj.__class__)
+
+    def create_unbound_method(func, cls):
+        return types.MethodType(func, None, cls)
+
+    class Iterator(object):
+
+        def next(self):
+            return type(self).__next__(self)
+
+    callable = callable
+_add_doc(get_unbound_function,
+         """Get the function out of a possibly unbound function""")
+
+
+get_method_function = operator.attrgetter(_meth_func)
+get_method_self = operator.attrgetter(_meth_self)
+get_function_closure = operator.attrgetter(_func_closure)
+get_function_code = operator.attrgetter(_func_code)
+get_function_defaults = operator.attrgetter(_func_defaults)
+get_function_globals = operator.attrgetter(_func_globals)
+
+
+if PY3:
+    def iterkeys(d, **kw):
+        return iter(d.keys(**kw))
+
+    def itervalues(d, **kw):
+        return iter(d.values(**kw))
+
+    def iteritems(d, **kw):
+        return iter(d.items(**kw))
+
+    def iterlists(d, **kw):
+        return iter(d.lists(**kw))
+
+    viewkeys = operator.methodcaller("keys")
+
+    viewvalues = operator.methodcaller("values")
+
+    viewitems = operator.methodcaller("items")
+else:
+    def iterkeys(d, **kw):
+        return d.iterkeys(**kw)
+
+    def itervalues(d, **kw):
+        return d.itervalues(**kw)
+
+    def iteritems(d, **kw):
+        return d.iteritems(**kw)
+
+    def iterlists(d, **kw):
+        return d.iterlists(**kw)
+
+    viewkeys = operator.methodcaller("viewkeys")
+
+    viewvalues = operator.methodcaller("viewvalues")
+
+    viewitems = operator.methodcaller("viewitems")
+
+_add_doc(iterkeys, "Return an iterator over the keys of a dictionary.")
+_add_doc(itervalues, "Return an iterator over the values of a dictionary.")
+_add_doc(iteritems,
+         "Return an iterator over the (key, value) pairs of a dictionary.")
+_add_doc(iterlists,
+         "Return an iterator over the (key, [values]) pairs of a dictionary.")
+
+
+if PY3:
+    def b(s):
+        return s.encode("latin-1")
+
+    def u(s):
+        return s
+    unichr = chr
+    import struct
+    int2byte = struct.Struct(">B").pack
+    del struct
+    byte2int = operator.itemgetter(0)
+    indexbytes = operator.getitem
+    iterbytes = iter
+    import io
+    StringIO = io.StringIO
+    BytesIO = io.BytesIO
+    _assertCountEqual = "assertCountEqual"
+    if sys.version_info[1] <= 1:
+        _assertRaisesRegex = "assertRaisesRegexp"
+        _assertRegex = "assertRegexpMatches"
+    else:
+        _assertRaisesRegex = "assertRaisesRegex"
+        _assertRegex = "assertRegex"
+else:
+    def b(s):
+        return s
+    # Workaround for standalone backslash
+
+    def u(s):
+        return unicode(s.replace(r'\\', r'\\\\'), "unicode_escape")
+    unichr = unichr
+    int2byte = chr
+
+    def byte2int(bs):
+        return ord(bs[0])
+
+    def indexbytes(buf, i):
+        return ord(buf[i])
+    iterbytes = functools.partial(itertools.imap, ord)
+    import StringIO
+    StringIO = BytesIO = StringIO.StringIO
+    _assertCountEqual = "assertItemsEqual"
+    _assertRaisesRegex = "assertRaisesRegexp"
+    _assertRegex = "assertRegexpMatches"
+_add_doc(b, """Byte literal""")
+_add_doc(u, """Text literal""")
+
+
+def assertCountEqual(self, *args, **kwargs):
+    return getattr(self, _assertCountEqual)(*args, **kwargs)
+
+
+def assertRaisesRegex(self, *args, **kwargs):
+    return getattr(self, _assertRaisesRegex)(*args, **kwargs)
+
+
+def assertRegex(self, *args, **kwargs):
+    return getattr(self, _assertRegex)(*args, **kwargs)
+
+
+if PY3:
+    exec_ = getattr(moves.builtins, "exec")
+
+    def reraise(tp, value, tb=None):
+        try:
+            if value is None:
+                value = tp()
+            if value.__traceback__ is not tb:
+                raise value.with_traceback(tb)
+            raise value
+        finally:
+            value = None
+            tb = None
+
+else:
+    def exec_(_code_, _globs_=None, _locs_=None):
+        """Execute code in a namespace."""
+        if _globs_ is None:
+            frame = sys._getframe(1)
+            _globs_ = frame.f_globals
+            if _locs_ is None:
+                _locs_ = frame.f_locals
+            del frame
+        elif _locs_ is None:
+            _locs_ = _globs_
+        exec("""exec _code_ in _globs_, _locs_""")
+
+    exec_("""def reraise(tp, value, tb=None):
+    try:
+        raise tp, value, tb
+    finally:
+        tb = None
+""")
+
+
+if sys.version_info[:2] == (3, 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):
+    exec_("""def raise_from(value, from_value):
+    try:
+        raise value from from_value
+    finally:
+        value = None
+""")
+else:
+    def raise_from(value, from_value):
+        raise value
+
+
+print_ = getattr(moves.builtins, "print", None)
+if print_ is None:
+    def print_(*args, **kwargs):
+        """The new-style print function for Python 2.4 and 2.5."""
+        fp = kwargs.pop("file", sys.stdout)
+        if fp is None:
+            return
+
+        def write(data):
+            if not isinstance(data, basestring):
+                data = str(data)
+            # If the file has an encoding, encode unicode with it.
+            if (isinstance(fp, file) and
+                    isinstance(data, unicode) and
+                    fp.encoding is not None):
+                errors = getattr(fp, "errors", None)
+                if errors is None:
+                    errors = "strict"
+                data = data.encode(fp.encoding, errors)
+            fp.write(data)
+        want_unicode = False
+        sep = kwargs.pop("sep", None)
+        if sep is not None:
+            if isinstance(sep, unicode):
+                want_unicode = True
+            elif not isinstance(sep, str):
+                raise TypeError("sep must be None or a string")
+        end = kwargs.pop("end", None)
+        if end is not None:
+            if isinstance(end, unicode):
+                want_unicode = True
+            elif not isinstance(end, str):
+                raise TypeError("end must be None or a string")
+        if kwargs:
+            raise TypeError("invalid keyword arguments to print()")
+        if not want_unicode:
+            for arg in args:
+                if isinstance(arg, unicode):
+                    want_unicode = True
+                    break
+        if want_unicode:
+            newline = unicode("\n")
+            space = unicode(" ")
+        else:
+            newline = "\n"
+            space = " "
+        if sep is None:
+            sep = space
+        if end is None:
+            end = newline
+        for i, arg in enumerate(args):
+            if i:
+                write(sep)
+            write(arg)
+        write(end)
+if sys.version_info[:2] < (3, 3):
+    _print = print_
+
+    def print_(*args, **kwargs):
+        fp = kwargs.get("file", sys.stdout)
+        flush = kwargs.pop("flush", False)
+        _print(*args, **kwargs)
+        if flush and fp is not None:
+            fp.flush()
+
+_add_doc(reraise, """Reraise an exception.""")
+
+if sys.version_info[0:2] < (3, 4):
+    def wraps(wrapped, assigned=functools.WRAPPER_ASSIGNMENTS,
+              updated=functools.WRAPPER_UPDATES):
+        def wrapper(f):
+            f = functools.wraps(wrapped, assigned, updated)(f)
+            f.__wrapped__ = wrapped
+            return f
+        return wrapper
+else:
+    wraps = functools.wraps
+
+
+def with_metaclass(meta, *bases):
+    """Create a base class with a metaclass."""
+    # This requires a bit of explanation: the basic idea is to make a dummy
+    # metaclass for one level of class instantiation that replaces itself with
+    # the actual metaclass.
+    class metaclass(type):
+
+        def __new__(cls, name, this_bases, d):
+            return meta(name, bases, d)
+
+        @classmethod
+        def __prepare__(cls, name, this_bases):
+            return meta.__prepare__(name, bases)
+    return type.__new__(metaclass, 'temporary_class', (), {})
+
+
+def add_metaclass(metaclass):
+    """Class decorator for creating a class with a metaclass."""
+    def wrapper(cls):
+        orig_vars = cls.__dict__.copy()
+        slots = orig_vars.get('__slots__')
+        if slots is not None:
+            if isinstance(slots, str):
+                slots = [slots]
+            for slots_var in slots:
+                orig_vars.pop(slots_var)
+        orig_vars.pop('__dict__', None)
+        orig_vars.pop('__weakref__', None)
+        if hasattr(cls, '__qualname__'):
+            orig_vars['__qualname__'] = cls.__qualname__
+        return metaclass(cls.__name__, cls.__bases__, orig_vars)
+    return wrapper
+
+
+def ensure_binary(s, encoding='utf-8', errors='strict'):
+    """Coerce **s** to six.binary_type.
+
+    For Python 2:
+      - `unicode` -> encoded to `str`
+      - `str` -> `str`
+
+    For Python 3:
+      - `str` -> encoded to `bytes`
+      - `bytes` -> `bytes`
+    """
+    if isinstance(s, text_type):
+        return s.encode(encoding, errors)
+    elif isinstance(s, binary_type):
+        return s
+    else:
+        raise TypeError("not expecting type '%s'" % type(s))
+
+
+def ensure_str(s, encoding='utf-8', errors='strict'):
+    """Coerce *s* to `str`.
+
+    For Python 2:
+      - `unicode` -> encoded to `str`
+      - `str` -> `str`
+
+    For Python 3:
+      - `str` -> `str`
+      - `bytes` -> decoded to `str`
+    """
+    if not isinstance(s, (text_type, binary_type)):
+        raise TypeError("not expecting type '%s'" % type(s))
+    if PY2 and isinstance(s, text_type):
+        s = s.encode(encoding, errors)
+    elif PY3 and isinstance(s, binary_type):
+        s = s.decode(encoding, errors)
+    return s
+
+
+def ensure_text(s, encoding='utf-8', errors='strict'):
+    """Coerce *s* to six.text_type.
+
+    For Python 2:
+      - `unicode` -> `unicode`
+      - `str` -> `unicode`
+
+    For Python 3:
+      - `str` -> `str`
+      - `bytes` -> decoded to `str`
+    """
+    if isinstance(s, binary_type):
+        return s.decode(encoding, errors)
+    elif isinstance(s, text_type):
+        return s
+    else:
+        raise TypeError("not expecting type '%s'" % type(s))
+
+
+
+def python_2_unicode_compatible(klass):
+    """
+    A decorator that defines __unicode__ and __str__ methods under Python 2.
+    Under Python 3 it does nothing.
+
+    To support Python 2 and 3 with a single code base, define a __str__ method
+    returning text and apply this decorator to the class.
+    """
+    if PY2:
+        if '__str__' not in klass.__dict__:
+            raise ValueError("@python_2_unicode_compatible cannot be applied "
+                             "to %s because it doesn't define __str__()." %
+                             klass.__name__)
+        klass.__unicode__ = klass.__str__
+        klass.__str__ = lambda self: self.__unicode__().encode('utf-8')
+    return klass
+
+
+# Complete the moves implementation.
+# This code is at the end of this module to speed up module loading.
+# Turn this module into a package.
+__path__ = []  # required for PEP 302 and PEP 451
+__package__ = __name__  # see PEP 366 @ReservedAssignment
+if globals().get("__spec__") is not None:
+    __spec__.submodule_search_locations = []  # PEP 451 @UndefinedVariable
+# Remove other six meta path importers, since they cause problems. This can
+# happen if six is removed from sys.modules and then reloaded. (Setuptools does
+# this for some reason.)
+if sys.meta_path:
+    for i, importer in enumerate(sys.meta_path):
+        # Here's some real nastiness: Another "instance" of the six module might
+        # be floating around. Therefore, we can't use isinstance() to check for
+        # the six meta path importer, since the other six instance will have
+        # inserted an importer with different class.
+        if (type(importer).__name__ == "_SixMetaPathImporter" and
+                importer.name == __name__):
+            del sys.meta_path[i]
+            break
+    del i, importer
+# Finally, add the importer to the meta path import hook.
+sys.meta_path.append(_importer)
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/six.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/six.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..c11762e443b0969c8bbde53e7667725d0f350ec1
GIT binary patch
literal 37306
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
Vl3?Uv;bfFy1;rs3BL^cV69BLe@lyZ*

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/__init__.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/__init__.py
new file mode 100644
index 0000000..148a9c3
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/__init__.py
@@ -0,0 +1,92 @@
+"""
+urllib3 - Thread-safe connection pooling and re-using.
+"""
+
+from __future__ import absolute_import
+import warnings
+
+from .connectionpool import (
+    HTTPConnectionPool,
+    HTTPSConnectionPool,
+    connection_from_url
+)
+
+from . import exceptions
+from .filepost import encode_multipart_formdata
+from .poolmanager import PoolManager, ProxyManager, proxy_from_url
+from .response import HTTPResponse
+from .util.request import make_headers
+from .util.url import get_host
+from .util.timeout import Timeout
+from .util.retry import Retry
+
+
+# Set default logging handler to avoid "No handler found" warnings.
+import logging
+from logging import NullHandler
+
+__author__ = 'Andrey Petrov (andrey.petrov@shazow.net)'
+__license__ = 'MIT'
+__version__ = '1.24.1'
+
+__all__ = (
+    'HTTPConnectionPool',
+    'HTTPSConnectionPool',
+    'PoolManager',
+    'ProxyManager',
+    'HTTPResponse',
+    'Retry',
+    'Timeout',
+    'add_stderr_logger',
+    'connection_from_url',
+    'disable_warnings',
+    'encode_multipart_formdata',
+    'get_host',
+    'make_headers',
+    'proxy_from_url',
+)
+
+logging.getLogger(__name__).addHandler(NullHandler())
+
+
+def add_stderr_logger(level=logging.DEBUG):
+    """
+    Helper for quickly adding a StreamHandler to the logger. Useful for
+    debugging.
+
+    Returns the handler after adding it.
+    """
+    # This method needs to be in this __init__.py to get the __name__ correct
+    # even if urllib3 is vendored within another package.
+    logger = logging.getLogger(__name__)
+    handler = logging.StreamHandler()
+    handler.setFormatter(logging.Formatter('%(asctime)s %(levelname)s %(message)s'))
+    logger.addHandler(handler)
+    logger.setLevel(level)
+    logger.debug('Added a stderr logging handler to logger: %s', __name__)
+    return handler
+
+
+# ... Clean up.
+del NullHandler
+
+
+# All warning filters *must* be appended unless you're really certain that they
+# shouldn't be: otherwise, it's very hard for users to use most Python
+# mechanisms to silence them.
+# SecurityWarning's always go off by default.
+warnings.simplefilter('always', exceptions.SecurityWarning, append=True)
+# SubjectAltNameWarning's should go off once per host
+warnings.simplefilter('default', exceptions.SubjectAltNameWarning, append=True)
+# InsecurePlatformWarning's don't vary between requests, so we keep it default.
+warnings.simplefilter('default', exceptions.InsecurePlatformWarning,
+                      append=True)
+# SNIMissingWarnings should go off only once.
+warnings.simplefilter('default', exceptions.SNIMissingWarning, append=True)
+
+
+def disable_warnings(category=exceptions.HTTPWarning):
+    """
+    Helper for quickly disabling all urllib3 warnings.
+    """
+    warnings.simplefilter('ignore', category)
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/__init__.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/__init__.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..7ea724834415f01661545716bbf749bd58949993
GIT binary patch
literal 3012
zcmZSn%**AGdLky70SfpS7#JKJ7#NBdFfuTtFfc?hFr+Xtq%bk$Ff!yaF+?#jFoO8Z
z3^~jUQOpb}EDR~E3^^<exvUIPtPHtq3{h+hx$F#4><o+`IW~qI4u)J#hA2)5pPeCx
ziy@brA&MKq=U~X;VaVlWh~j0)<ztBAW60%ah~kIHaWdoxFysm{L<vIpTnsrv47tJ#
zQNj>DH$#pHL#`-8lqiJH!;mA!kSop*B@W^9GUP}w<VrF`Ny6PM#SkS0_75LJjub<#
zG((g$17iw5LzE0diU32DEJKPQLzEmtiYh~tJVUA!LzV(Vsv<)(BSV%FL#i}GGXsdt
z2$E1{NKs&DVPuF>VThJyNM&ZoQe{X{WJu*?$WmiSQDR6{XJ}?(WQ0m6gC#U@NoeAd
z&_b5rWXRHHNKpaXs>6`N%n+=h#=yW(Y{9_5z*Sn5larZbte~q9l2MeJn4(*pn3k%L
zoS&DMnp~2ZpQliepP!SNm#&bQm!eRVs#{u|nU}7|l?jS=4MqkAh7x`T28P6>;{2S_
zlGOOj+=Bd~62DB4j0Q7ET8M#x!6PIjz!`32Kz@Esi7-?+7>hW<_V~1-{M`7`q8x}-
zTnr2hsTIko1t6CdL&PLOVtL8=DXH<fr8y;;1&Ku^@oD)*xhaVyi4Z4nGcYiKEcH#y
zOH5BKD&Ya~i}EWfVFIAUTL2P3vk#;Y<o2M{;)49V;#7!@Ako~!?9}*-)Wnq3BB(n!
z7#JARQ%mAA@{3C#>ev|=7(z00Q}auq0;~)S3_+<SMU@bFkhA<sb8<Wq^HOp^<}ffY
zIOe4krB*5gq?Q!rmnmo@g1LGHV6H=PMq*Wdxn5psiDn5XY<)dLirE+#7!37{O!N$c
zKw%!l1hNAp7zDCDh!e!+1rZ=umk5I5DkUYpxFjXDs3<-sKRrFQC<tU$i2wrwLrP|G
zVp2|Oe0gF~US?i;aS+(WAa@3Vf<6f3$7GN-ARQp=49fBGplD`b$YNwDVFIP|T1JKv
z28JwVP_nOOVyIza$YKGDu!6EsGb2b1V+|ui78^*enUMj^VP~j;<Pwk!2dLx#na0Gx
zSi{5+435X*Hc*09P*70tNX;ooEmBC!FH$Hh%}mbDsZ>ZzNdc!)h2WB+)Wlq9m@1Uy
zE0koUDnLA{rx044npT<v(#QoeCnYthG(8=hpuzm0)RNMoykfAH3`ndfB&L<57Qu|q
zEYSliELLS;U{KXaEKV-T%uUrSR#4T*Ni9pw$xDRta#M?o6Vp>Qi;HzYv6_;Snxc@X
z010-mYe0^LSy7S?7D_F$Qcx|{07Y2|DDps#&df_M0STn1miT}ps{|AW@$n#w;^Rv|
zF^l41aM~_TEpf{)%1taONi72FM({w<n3$3R4IZ#z#i=DeAh(x*A{!hc;Lrwh!JaAs
zB`1($Qj5Uuf;w9RTm*oK;(P`M2K|Df%(BFiRQ<BVBK@@d98k{CPfF1*PfE(mHO(zH
zGE6d0uS&NtwJ6WYsxmVGf%H865dDJ80^Q8K;*!Li99_3E4^QI&kPsNhm!;;V<QM5f
z3n~5h_{_Y_lK6PNg32IJdNlzRW1!5-z{$_Z!zjkc%gD<pzzBA5VorHtWif<VP>`CJ
z0(N^!YFc7xP6;>>!xAz$5sSbRaS9_iC4wp}c*?WElky;$1{9x(IXMbYrz*g*5G1{T
zospTImtU0Xrvb{M;E;!@fkawnZb43JT4qj3Y7wM-0L652Vo7Rxeo^HB2R5kOhyVpP
z$n6X)8lW&Q#$K`)<0#pSLB&Wwetr(L&@BcPNCBWi7g+$gv@HfDNN{;s49X7BqO=&~
zmPGV23~VcwdZQSWOdv6YDAtPc))~d1aEF!TU{@j+_QfEtqtz9<ptJ*WVtjl`esX+#
z2`HDv$ETH+loqAN#|MG(NRSdp5lAz_m7uB>sniA)s3l;vEFiTYXQXB3q!#2Cmw*f6
z5>N<&^yEV7u^>>sgcS22wcsRG1g)vS1wS}lm6l}Y=oO_FmZlb$fJ<?(I<RPIQBDxZ
zOoTd6X_jAF5(J7HurI*sia>Q%5U8vP0>ya{$QNMQ`1r)ql8pSK_;|3};^T8NlT-7G
zQ{nuw)S}|d{Ji*haOR7TPt3`Qj}HQ+kRVWo3z7hN6co)au1=xu;5;3q3=-pKU|<MN
zO)f3UEU65K)J7$sPzfn2O)U`xNtPyMr6!j+=9Ks)=BC1wh%+!Sc;*#@G^PgRB$j~M
z0WdjGx(W94^vx^=HDO?)Ape6B9h4sgQiaHDVAensZ{SF>$<0qG%}KQbC5&P}1_lN;
zCILnsCK)yXMgc|{Mi2?cEIf<?Ol*v7jBLydjJO~hvm`UWFf+R(lO&T6BRi8MGXPV6
B-(&y)

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/_collections.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/_collections.py
new file mode 100644
index 0000000..34f2381
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/_collections.py
@@ -0,0 +1,329 @@
+from __future__ import absolute_import
+try:
+    from collections.abc import Mapping, MutableMapping
+except ImportError:
+    from collections import Mapping, MutableMapping
+try:
+    from threading import RLock
+except ImportError:  # Platform-specific: No threads available
+    class RLock:
+        def __enter__(self):
+            pass
+
+        def __exit__(self, exc_type, exc_value, traceback):
+            pass
+
+
+from collections import OrderedDict
+from .exceptions import InvalidHeader
+from .packages.six import iterkeys, itervalues, PY3
+
+
+__all__ = ['RecentlyUsedContainer', 'HTTPHeaderDict']
+
+
+_Null = object()
+
+
+class RecentlyUsedContainer(MutableMapping):
+    """
+    Provides a thread-safe dict-like container which maintains up to
+    ``maxsize`` keys while throwing away the least-recently-used keys beyond
+    ``maxsize``.
+
+    :param maxsize:
+        Maximum number of recent elements to retain.
+
+    :param dispose_func:
+        Every time an item is evicted from the container,
+        ``dispose_func(value)`` is called.  Callback which will get called
+    """
+
+    ContainerCls = OrderedDict
+
+    def __init__(self, maxsize=10, dispose_func=None):
+        self._maxsize = maxsize
+        self.dispose_func = dispose_func
+
+        self._container = self.ContainerCls()
+        self.lock = RLock()
+
+    def __getitem__(self, key):
+        # Re-insert the item, moving it to the end of the eviction line.
+        with self.lock:
+            item = self._container.pop(key)
+            self._container[key] = item
+            return item
+
+    def __setitem__(self, key, value):
+        evicted_value = _Null
+        with self.lock:
+            # Possibly evict the existing value of 'key'
+            evicted_value = self._container.get(key, _Null)
+            self._container[key] = value
+
+            # If we didn't evict an existing value, we might have to evict the
+            # least recently used item from the beginning of the container.
+            if len(self._container) > self._maxsize:
+                _key, evicted_value = self._container.popitem(last=False)
+
+        if self.dispose_func and evicted_value is not _Null:
+            self.dispose_func(evicted_value)
+
+    def __delitem__(self, key):
+        with self.lock:
+            value = self._container.pop(key)
+
+        if self.dispose_func:
+            self.dispose_func(value)
+
+    def __len__(self):
+        with self.lock:
+            return len(self._container)
+
+    def __iter__(self):
+        raise NotImplementedError('Iteration over this class is unlikely to be threadsafe.')
+
+    def clear(self):
+        with self.lock:
+            # Copy pointers to all values, then wipe the mapping
+            values = list(itervalues(self._container))
+            self._container.clear()
+
+        if self.dispose_func:
+            for value in values:
+                self.dispose_func(value)
+
+    def keys(self):
+        with self.lock:
+            return list(iterkeys(self._container))
+
+
+class HTTPHeaderDict(MutableMapping):
+    """
+    :param headers:
+        An iterable of field-value pairs. Must not contain multiple field names
+        when compared case-insensitively.
+
+    :param kwargs:
+        Additional field-value pairs to pass in to ``dict.update``.
+
+    A ``dict`` like container for storing HTTP Headers.
+
+    Field names are stored and compared case-insensitively in compliance with
+    RFC 7230. Iteration provides the first case-sensitive key seen for each
+    case-insensitive pair.
+
+    Using ``__setitem__`` syntax overwrites fields that compare equal
+    case-insensitively in order to maintain ``dict``'s api. For fields that
+    compare equal, instead create a new ``HTTPHeaderDict`` and use ``.add``
+    in a loop.
+
+    If multiple fields that are equal case-insensitively are passed to the
+    constructor or ``.update``, the behavior is undefined and some will be
+    lost.
+
+    >>> headers = HTTPHeaderDict()
+    >>> headers.add('Set-Cookie', 'foo=bar')
+    >>> headers.add('set-cookie', 'baz=quxx')
+    >>> headers['content-length'] = '7'
+    >>> headers['SET-cookie']
+    'foo=bar, baz=quxx'
+    >>> headers['Content-Length']
+    '7'
+    """
+
+    def __init__(self, headers=None, **kwargs):
+        super(HTTPHeaderDict, self).__init__()
+        self._container = OrderedDict()
+        if headers is not None:
+            if isinstance(headers, HTTPHeaderDict):
+                self._copy_from(headers)
+            else:
+                self.extend(headers)
+        if kwargs:
+            self.extend(kwargs)
+
+    def __setitem__(self, key, val):
+        self._container[key.lower()] = [key, val]
+        return self._container[key.lower()]
+
+    def __getitem__(self, key):
+        val = self._container[key.lower()]
+        return ', '.join(val[1:])
+
+    def __delitem__(self, key):
+        del self._container[key.lower()]
+
+    def __contains__(self, key):
+        return key.lower() in self._container
+
+    def __eq__(self, other):
+        if not isinstance(other, Mapping) and not hasattr(other, 'keys'):
+            return False
+        if not isinstance(other, type(self)):
+            other = type(self)(other)
+        return (dict((k.lower(), v) for k, v in self.itermerged()) ==
+                dict((k.lower(), v) for k, v in other.itermerged()))
+
+    def __ne__(self, other):
+        return not self.__eq__(other)
+
+    if not PY3:  # Python 2
+        iterkeys = MutableMapping.iterkeys
+        itervalues = MutableMapping.itervalues
+
+    __marker = object()
+
+    def __len__(self):
+        return len(self._container)
+
+    def __iter__(self):
+        # Only provide the originally cased names
+        for vals in self._container.values():
+            yield vals[0]
+
+    def pop(self, key, default=__marker):
+        '''D.pop(k[,d]) -> v, remove specified key and return the corresponding value.
+          If key is not found, d is returned if given, otherwise KeyError is raised.
+        '''
+        # Using the MutableMapping function directly fails due to the private marker.
+        # Using ordinary dict.pop would expose the internal structures.
+        # So let's reinvent the wheel.
+        try:
+            value = self[key]
+        except KeyError:
+            if default is self.__marker:
+                raise
+            return default
+        else:
+            del self[key]
+            return value
+
+    def discard(self, key):
+        try:
+            del self[key]
+        except KeyError:
+            pass
+
+    def add(self, key, val):
+        """Adds a (name, value) pair, doesn't overwrite the value if it already
+        exists.
+
+        >>> headers = HTTPHeaderDict(foo='bar')
+        >>> headers.add('Foo', 'baz')
+        >>> headers['foo']
+        'bar, baz'
+        """
+        key_lower = key.lower()
+        new_vals = [key, val]
+        # Keep the common case aka no item present as fast as possible
+        vals = self._container.setdefault(key_lower, new_vals)
+        if new_vals is not vals:
+            vals.append(val)
+
+    def extend(self, *args, **kwargs):
+        """Generic import function for any type of header-like object.
+        Adapted version of MutableMapping.update in order to insert items
+        with self.add instead of self.__setitem__
+        """
+        if len(args) > 1:
+            raise TypeError("extend() takes at most 1 positional "
+                            "arguments ({0} given)".format(len(args)))
+        other = args[0] if len(args) >= 1 else ()
+
+        if isinstance(other, HTTPHeaderDict):
+            for key, val in other.iteritems():
+                self.add(key, val)
+        elif isinstance(other, Mapping):
+            for key in other:
+                self.add(key, other[key])
+        elif hasattr(other, "keys"):
+            for key in other.keys():
+                self.add(key, other[key])
+        else:
+            for key, value in other:
+                self.add(key, value)
+
+        for key, value in kwargs.items():
+            self.add(key, value)
+
+    def getlist(self, key, default=__marker):
+        """Returns a list of all the values for the named field. Returns an
+        empty list if the key doesn't exist."""
+        try:
+            vals = self._container[key.lower()]
+        except KeyError:
+            if default is self.__marker:
+                return []
+            return default
+        else:
+            return vals[1:]
+
+    # Backwards compatibility for httplib
+    getheaders = getlist
+    getallmatchingheaders = getlist
+    iget = getlist
+
+    # Backwards compatibility for http.cookiejar
+    get_all = getlist
+
+    def __repr__(self):
+        return "%s(%s)" % (type(self).__name__, dict(self.itermerged()))
+
+    def _copy_from(self, other):
+        for key in other:
+            val = other.getlist(key)
+            if isinstance(val, list):
+                # Don't need to convert tuples
+                val = list(val)
+            self._container[key.lower()] = [key] + val
+
+    def copy(self):
+        clone = type(self)()
+        clone._copy_from(self)
+        return clone
+
+    def iteritems(self):
+        """Iterate over all header lines, including duplicate ones."""
+        for key in self:
+            vals = self._container[key.lower()]
+            for val in vals[1:]:
+                yield vals[0], val
+
+    def itermerged(self):
+        """Iterate over all headers, merging duplicate ones together."""
+        for key in self:
+            val = self._container[key.lower()]
+            yield val[0], ', '.join(val[1:])
+
+    def items(self):
+        return list(self.iteritems())
+
+    @classmethod
+    def from_httplib(cls, message):  # Python 2
+        """Read headers from a Python 2 httplib message object."""
+        # python2.7 does not expose a proper API for exporting multiheaders
+        # efficiently. This function re-reads raw lines from the message
+        # object and extracts the multiheaders properly.
+        obs_fold_continued_leaders = (' ', '\t')
+        headers = []
+
+        for line in message.headers:
+            if line.startswith(obs_fold_continued_leaders):
+                if not headers:
+                    # We received a header line that starts with OWS as described
+                    # in RFC-7230 S3.2.4. This indicates a multiline header, but
+                    # there exists no previous header to which we can attach it.
+                    raise InvalidHeader(
+                        'Header continuation with no previous header: %s' % line
+                    )
+                else:
+                    key, value = headers[-1]
+                    headers[-1] = (key, value + ' ' + line.strip())
+                    continue
+
+            key, value = line.split(':', 1)
+            headers.append((key, value.strip()))
+
+        return cls(headers)
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/_collections.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/_collections.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..5cd36e6a0a5aa9d68d0b5d1e79d3d0abdc0c0850
GIT binary patch
literal 15104
zcmZSn%**AGdLky70SZ_d7#JKJ7#NBL7#SE+7#LC*8FCmHav2$-7#SEVrNBZ=3^_~;
zxy%ev%nZ3K3{fl$jNy6e3@oXv4B1=^MZpY=jEo?iObj_}sLJvf86ql0z-BNr<ghd3
zaxg@3fOM<Cb@zdFvoNIaGo-LGv@kF<GcZI(aWH_if(&H?8_LNL#mT^!!p@Mw!H~nn
zkju>w#SP(eGUV_u<nl5^@iOG{F+}k(<nl8_@iQ={a51ECGo&*yL<umY3W7|H5@JZ<
zVn}6SNMmG3;elHv3{nRb<%NriFr@G?1ZxN|Ffe3-LP~>?fq|ifpMilPF{wB|r?ezB
zJ~Ou<zo<lm2_(VJz`)>}SWu9emtMjLVwaXACgr3;g&>+iAsytCpPU`U%)r0^j{uOt
zPM`>oVqjoMWdMbH3IoU;QB0u7Xkh>adr&ago@9_>7<L9}VqpNsS}@oOKMjOaK@!EO
zIcX3fka%%10|SG8K~ZK|Vo9ogSz?iXT7FJSYEiL%Qi^_gQc_;7X>PHRVUl@zRl0?#
zMR`tEm6-tur03~}=oe%b=w{{>mn7!o=(?48cp3+QgupnyEHy7BzevBdC?_W~$yh%=
zIX@>SHMt}+Kd)G?pt6LMfq@}DJ~gi-wJ1KGi-Ccm7!+m<jL9H3f-uNOIDG?B5CkGh
zI6whZksM!AS&#}gG_@i*zAQ1P6v8VhN=!~oN=(ik1YQO?H9kJIBC{kuo)_U`4Y)tz
z<MR@8Q{&@HK;aP|pPQdjnv)tI9|TS$pa4U70?Zny$OETUkb8<jPG@7}WCo|S5^e?t
z2LGaz)S}cBm(1jnOi&a;WI*2a%qvUG$xQJ`O-xBG(f}oQaO7o{q!wkTRu+Rj4dQ?!
zueb!HARyAXM3jMnAt*IDHLoP6GPF1~#W_E(Br!8DwFsQ2JVHVOASQxrgy$cSW^n#V
z0woVv{)u8@NM!~URVj?1T%W?k(89zJ#m11r49;5Y3@I#N1_!j%iQ;5PVFQbBF{H4A
z8Qh@429*7H7*aUFBD@Si!5Sc+7f)nlVBk_vP*4ac$}h`INi9}LR4B<PN=;1BElx~J
zRY=K9F44`&%uZEEhWSCEJR>tXLm@XY6YQyCh0+3rl6<fs2?@E06~&oVsR;=Rpzr}H
z%}E6rm|vcmm#&alo>-|+l98&AlbTpuqFV$FBHhyB)D(z@q}0m%ycBf9^tiwxRt1Sg
ziMa|;JFLKBAh-J_R%GUu<|^cs<|d^UDdeXqKulIh%}LEo%_}KZD9KkSN(Ds$s!1uC
z#Rd7rsqty0dC3UlT+336DiumHb5j)(^As{mQganDixpDKGLuVEQxwvQ@^is{fCq>U
z+#v}G$R=ulQ-x+i0!VvuVopwKik^akb7D>oD073tCOJc)JToUpAw9K30ipnGR3<1d
zC4<rf2!qNPaG_$zz`#($$WX(;5YNC+!vto4xmir0Y5^q9%uvDtW3z&)D_D8T1}faa
znHd^-B|M-47s>x%0eC`n&VeNEc(^aY8K?x5d2;fTv%z@*QksFP45*<&A`A=+;A{>i
z1}d+E^Jsj0W*(^2(gBrPAfGcZax!u<@iQia0u&UmAcunk)*KYD3=CNe4E-7mj5Q1l
zS&R%>OrWrCW@M;kf`)Y#BS^%ihKV6KJcWTFFd~J40T#R<<ATINxn2wu&>(I>egRS-
zfkd)XE5YFhN>SkO0TTljNTB>5AD^CD0&-7$yfHkSn79~)7<n1N2@q6_!^3Gh$Zre`
zwalQTm&M4?9}5XBCWb6#P}r0(Ff=oPrNN045`;D-EMVnK49$#S1}j503qw%`n9anH
z#Rh5|l&~{2Gcd+5G1Rhv^ye`!K!O+)7aR;llNoB58A=!!vN^$Q28JvSkVrEl17jYv
z*#L@EKXCBoBo>!waDto)a(ujBX-*DW)TF1DfQ#y!)Vv^JkV23T3-Sv<0Z{_d<d&FI
zoC-<IATBta2T6leg1F#pT>`2epk)HI?gr(J`0Uh5aI}Jn0gl^ZSln8H;uh2dWME`t
z<YE$K<YkdyRACZD<ONXq0L}~ch`b;UiCxsZfQT1nh9YZlBr=0C2y$G2>QFy$69EzM
zL7-M4BuGJd0THA@DubiU;08DDQc`n3sUSYy6BJ~SVuOoOf{Bw6-eiRbl_Dajgcul0
z7{P%7PUiRu2#~HIP$>a!Wq`v0oL0cZfF&4E4v3G>NzIFo4*>Zbl$IG7xe&ev<u7mo
z0VSgnaQCX2k)eqZQptd1{fa^5sAoxPQ6i|ttdL)pTBJ~tky)&eoRe5w45|c6^FU3B
zoJxg~e1#-%yC5|&1=P;a0|!P4C^P!ymw4tDKq~Ik6xX7n{35XAU<oNunuw1FHTvS?
zLqI_V@;d`0pg<`b6q4Y8N<btJb#U@1fs~5Opn?!ou|N_GGeZ`*%4S65ELMi17={Wt
zP?72qD-5oI7#OlxVcD$Ei6I<T>_M^`C`p2|8l(WsEG`KG_3*&S3|yck=cFbUq2<03
zkS=gpRy;`ZV2~~Y14B3{OnE^4Ja9=R%)|+*i$MMaVR-1OBSKdKTj*kDK~Rzg2T~BI
zNe~3;-GT#XP^B)ABS9_aL{KPzIG{}ErvY{>7pQ#!DyB+6p%5RRlAjzO9|Q`jAW(+`
z9QS_td8t8?Ace9Z0u)L?ppqp>6U5a95uiX0(nl$DK`Iyqs_Y38WME*B0r?lydSv5a
zV`5|CXXj++<mY7PWZ`7y<brpRKv@mkMG|8~8e#yAFNlF!5iN}1juI2NkHZS<BC)}`
zNbImK5(lh{#0l#naWSNFGZbesr1CIifrnr~4DcvS9s@%vKd4C^B>?M23BtNjLJX+_
zpiUXcUhwD(sFNiE9g~R?Wk>-J!$gUJmGLovl!-H>iZet>fJsR(DFr5_LE}as?J^80
z0$}&cGNcHC8FCCMLSTkGLy9n%p}>$L0%j;Oq$)9_h=SP7j0{oApl%(g6<S=t0`1mW
zLAp#C;0|mtqL1SU?${K8#&$scrL@e{oD^MfVW3cum|0Y;r{G&!T%wSdUjpm+Ddd*s
zlw=m<q$+?FD}cKF#o+D=s0&t}k(#HFoS$2eSd^NgkepbY3L0cd%`46<$t+9FsYLB}
zWtS%wr6ap0B_$J7XC&r83`ceesIDjg*B^NxCa8;*T%uQ6kdj!EnveiB*HHl?o{*pb
zs$pPmPAyVM%P&$WF3B$fbw5EJZv{xtyBMm`4dii%UlbCHQo%}7Qxp>OQt<gkArs=+
zoXo_$<Wz<7%#sXnNCde#E0`M@8|Wz@s=)$S#~Re{P0K7Q26gp{Q+11BfdlIJDio)t
z=7HUsnwShR3q1_M@d9;qXfen;2?_D>@FreDf<kd+UP)pFxZW)<$}CAOh6HA@LP<s<
zC>p_$qmWuynwSH2ExHXkl^}oRg9bxDAr0%`!-H16SRt_>Q%}JyzX;i6h*^-RhnTLT
z02*LRO-xZpE=o--NmWQx$V)9(NJs!h03`fDBOeI~;BYQ2PE|-q&`V57Nk{;jm6@lI
zsF0JNUjX&3XBt}CgZc;*Utr&0NpIlD1SOl)6p&v^GE%`tC+FuCmlTyIm*f{I<QIXg
zg(V~%aGyRYH6yVsGrtJZSV>7u%glqOhT{BOP(<hCC?r9Q%E>P-fjZF6&Q1ZE!xU^4
zP(7)k3APwX3CO1!>cOccy3YCe*_o;8ItuD(`T4d<iACx-6c?wK=qAGzCnZ+d7M502
zV5*K*2X)s|^GbAcQuESFGSp)gY!%ea)zO_0tsd+e0y8ldEDLjjjso0xusD*#qt!vf
z10d6Vpr(UWz|4pDt3j<GZ_t=-38=@!zyN6(H#33y)XfYGj3vyV@)R^&!2)XHq(J(0
zQ4A$)AZ`gGs1sS_1#V5VgG4}Gi^3={p999v1CM|d6~IKn&2D&S5Y$reL-YZQOAAtq
zf`mYoAGm4+SDBzDco1kv1u}?N3`(+~+zjT%C+8Pb#)F1>z^$azijvg46r}Dvr~-z@
zI9LIsKm%8!U}C`PQjq^TKy@jona;o{%*eyY!^qDlz$C!P2I<j*Vh4o5ZB#8#D~b`+
zuuNwH2PJrfDT@&lK{lYyHxgeGHrN5Gg~2T+aMLm;zZ^O=3T~l8y2&65$`W(HVF4xv
zEI>dlpvj;Bfi$Kh5nW!88^M79>VTsAwH7>Q0UE(zVn|_PkZ)#W2nNT$A9&1PM*%WW
z3^D^86hRiCv<|W(D?c+2tP&9%L6#`3tpN)QP?HcehEoi3Cn#}%vn(h&K^Pnspe7hv
zSlA+sbAi+${0pASL3k4!(O_c0d<e3AHYm114rPGEHHZnqVE=)7m^F-`p}uAYaDr!K
z$Yz5N<AIccV-oDgLFYa25N$kcNVYgWejXODg5nnJ)fP~S1m|B!k;+q~!T{=mGJ=}Q
z%}fknJ~Kmb2}BJGC^(wIg>SJRXc)PM0n|~gVFZ!2j0|}U3?;0fywCy(I5toj;R4dY
z2$lfPM}UGBSt6T>As9Rm<Ol9?fX7fkc?N`wK~)4Od)6>8#L6;&2LB+Vt?=k!Vn}0R
z2xBZ{h72-5N_7wkjw5g;D*;8Bo<RvnG#gBofzkkE5PG1JVKFBI1A|R^YF=tZL6O}u
zSR}DAP~ZPSHlSL~7DU($ib4j}@5>Q>*8tU-L7-9QAW&q1`>+{_#fc>)MM27-qzX#7
z;2BX612pdhu8BbdExD;h>8UA*><F%R@=G#Oiv~Wf!PS3!d}?8Q{6dgtdB7tV3XCj_
zqKu-9(CP-1NI@8!FF}2IcoEyo$iM@uS3$uN<N}ICkXlH&>I~w7j0F31pb|9HlX<D}
z@hd@|1i247<OOmxhzs@_XiOYboPcLgz*Qzl+7A+QgL2>#JT9^c%}*fzfJ&%jSP503
z04f}_Al_nNaEaw-sAU8-MN=3VB*PdB1;Eo4kfjZNkYyGiGr+Y-kRB)s!CX+n29MH|
zCFT@s40x;tfrf*&g8UA07z2|Sq=5+HfTlUXG3w61z);Bt@_h{>gJdl;19-s<Xex$_
zp~xJx<fR7EaAai2=3po?W@usn)fAvfvWOaR#bR5-%n+OcYCeI&pcs^XT=YPbW7*L<
zDY2Rgx^@a>ItoRpx%p+O3dIGf$(d=HklA2x@31Jfq_ijx+&N3mFDgncF38VI0rh^t
zgB5z<9tdavLP5bZ4cwE?EC!ESq~(|9rRXT6fO>KeGg4C&GSd{&Gs{x*bQHj)M|oy(
zs)BcFC3uh-tS~XNI5h=fC?w^ArxRhyN<iZ)@u+>g`1st!qU_Wna7_ovx8TVlP>Gk4
znwD6aQ!-daSV6NeyFgJ6?jNu-Gx9O=GV(LBF|snTBbrO_=m!<dmE6$iw++t|WMF~D
zy&Nd+p=+B^3NTQLfn<14LIQUO20p2SYnznJ;^f4ll+z&ZgGTWg7?~NlL4(Vnybc-+
z2hreE?+fV`Wq}uQfu=iQU8GtTP*^~xhnX2_SU`Q%T2>IFh7~+L>B&&T3Z4!{^hn`p
z{}BTNgJVhxXpMyiX!uM=0i1|66+lC7ItnTIsl|EfC5QnWaH<C@0j1o`5{1MZ(8`QT
zc%o0O$Sf{_4P}9H0a9-rb0h*Z$e@lGWk6F88J2L%&j*c1BqdfsM;FjkMT5o()FDF#
zASsY};2{IZ7z0QMI`aqW5Cw^WDt0bVfTxx~a{{<7Nh~M;b*Mpsj>s?IZW4GsRCa1*
zJh)#8&U$&N<)9hX;vhFrNjl)gCV1*NF(u_9$Xg)4F>vxQ@-T@q@<1kmK)D{2f&4+W
zM=T=)XyO{uicVn!PkkGJMnqD;!y%x`65POsw4<9K&1`VF*$i%{XR|UC`G9L0W(LVT
zX3)TOEi*$2Gidr7wA6!%p=csQ#R(8Mixu1=kCg#8rCAt2$&vvyzh1)vN|Vh@42*?&
z4B>gRVcOY2iMQwkLq#V@yGyJTX!ae{GGPO!XK?bC1Z!K)5T2L9Py(KGPXVX-B38zV
zAdt2!PKd3zH9rB@85JrZ)h-Cvv4L|E#40wBOBf4z7{e>HK!XukTo6OyUcsW+k}*7m
zl_411tSmmjz`)?1nwMIXnXCX=&Zq!d(*qh)29K&H=2a?y+LoZPZpgR|WKmOoQdVkm
z38KJvOi3&NE%GT#Eh^5;&jTs<MOgs}9e73=D9y|(PAw_{FBC!=5YH^hPynr41m!FE
zcxZkaL=0)*7M_{GBMQZ!p#tb|lcqvRVm4?+R*6DxesPI{p+Z4EXgobXFEK|Uu_(P1
zvbIU1+MpIvt!aXr9^jr9bOj}7wkQbH@B(M6kjjEoa9sz^gK7Cixrrr^7CC5a46Fpy
z+y+g67YF%+`V^q%TM%eT0N7A)yBjPE4s~$O1-EBFqxnIg+20^gdlg*fgERABsr5`5
z7#JRcva1rP^k5ZY<YW|ORAS<1lw=fV<Y(k%lxE~-6lRoW5@r-(lEl&s@&+}7#K9>R
zoH-#QWRUidDg#Ri6L<l!9jH!(wuhL(?IA0MbOwfCNNb20)bExLP62g^K{ZWrE+~Y-
z%^OgSkds+l0!nX*IXQ@OzZjf)K{E%S`XWUEJoTcd5Cqee2TwhzxdkPa3SdJr)4&E~
zr&hwN6mUhM2Tozo;u%yjgS*i|pb9(415~tvD{L?UYQ6-4mOu=aG8a^+rl*#G{P!Ca
zk$j+tWM*a*2RC0>7+IOXeQQv91$h8mi-Q_3DU9Ia7d(`a#Rwk%U;tIm&0vu<CI&HR
ztGyUh7pWF&s1|ENnsE-G*Z~#qL5?7n6DWW{#)DJ+AZXEmS}^hPMX3cv@$vkOh_%R|
zRyHUIKo}ehF$@e06``Oy#3j}jyqEwyz)}Nlpnxh9Mo`II!UQUVi>$yw1YV+0%M5MF
zr-K!UgK7rwQXj~A1)D;4Xs-tpDt;QEDlaG$6jb0oK6s8Dp2#3U3UU%!2{G^i8Dzr1
zz#s$)Ku}~efYTE{Xqh0$TcE%MVQ@eyfEqL4!7os4%>eBJf|dn>6BA<%sG$ea1?e^f
zfm0C3bVPF)T!JR&<maUhyvM;MH)x(i3gmfE@@D{-h2V??iYgEWcY%FCDaaL6`nkl~
zg1rr1ED0Ly1J4vl)-o|vD1s{P6h;PlmsnBI8onCvz`0}%GjtG7n;{&WVwj;Lg2kW)
zB4nC072M=i0F``@%2^>NGcUCmG>w>?Qwr|wrIZ%rWF~{=67%y?iy<W$xVD3aHMW!n
zF2q1>MsQs;@Btna#K6EH4+?Bh-eq9oWfW!<gtQq!^#LdYfrA?~1XN)Q32svy!3_#s
zMg~bpD-y(E2G3DI#!EpNlZ7D|oF$7vYyWTrbFq#BXlM=8n??;^g_8XARM7aE9ypAV
zr#$??!>-_lJ*4^onGX>Ir58lqKM2AbRA#Gz!W*2p!Ql-~+@L%P&()xgFsK<08{9!3
zwgMMqpqLv>>x6=W85kIJKwbm+13J+Gsv|*h04}VygO+!*gNplf@QU4vd7v5~i-Ex<
zb~3n~&jMQI45<W)DnK<ru?wi|PXRak#UN|@3c(U7EDVyM(Ro&eS~gHmq6WNVSG<M=
zT9JyUF@f}_urSyZih=747SNiu6jo4grI`ub9f9a&2CrgcWvF3;YE1)ILX3rC4B?>B
zB5=JEtO3d%#h`*S2(*R(QX~{Z7TzZ+1XPw}<mV|EDP)wC6y#(kDdeUW7bm8tDnQ%v
z;7I_5Vo)4&7K4^KK^7c<mxN^Il|t4gf>vxO<mD?A6s4AB=9d;jr|+#4REsnJ|Ns9V
zY={-Oy#y(|BSDQ0u$da5#1v!(stZ6BMsZ1EQAsh#ydd!CCny&emlS0dfQ$O#f}G5f
zAW-=UZZU(qj>$R2;Nb|UyGuYrGWkix@t{pi;JKa5ywcQ^_#DWR9f(b!Xa$vtkn9DT
zupId8Rl>u-zyO*ekB7#DJ}5nce8a%T#>mDb02)_fVP+Iy7GRWPWMh(Glx6bM0J%K~
z6mUV{zKH>-!2p_thb&qHO$P;mrYRwd)~rFYpyDvd6~qE%)gVxUhb-O$EpY_*WFRpQ
zZo`7dbHM|fkOjwHAbsGj45$wPZl8ds6~M(CXj4xyc(YD=Dri4gZemGtMrK|*G{u1{
z$V|{;aZt`mPc4a0%*hD~1DOa;oDm=vsALEN6*S;13EoZwUhbNkT9T2U5|jjLHiFu!
z10P@D1rTYVbPSp^VpCva;^F3G0k5!Q=H%dHW@F@J<YD4u;$-Gz<q_m$;}qbO;^Adu
zWMgDwW&??GaI$i;bFy(VLpzt?MTelMjE_$%Eh#NZjgJR~24r_3^47V;q-5}%4><0?
zLF5VEatP^*g3<w!YH&9cvIQwKFCDz=1iZ!(9Bru;$*BdPUVSknw}FyiL1J=tVtQ(^
zUU6mxB4Gr95(_w=#e<?PK0XMviZDnX6lb6Xhv3jaL<*QSVACt00?#HFymihFRLB&|
mF)%O)FfubrG4e7>F)}lXF!C~ra|kdBFv>9VFmp1Cc>w^lGvxgM

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/connection.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/connection.py
new file mode 100644
index 0000000..02b3665
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/connection.py
@@ -0,0 +1,391 @@
+from __future__ import absolute_import
+import datetime
+import logging
+import os
+import socket
+from socket import error as SocketError, timeout as SocketTimeout
+import warnings
+from .packages import six
+from .packages.six.moves.http_client import HTTPConnection as _HTTPConnection
+from .packages.six.moves.http_client import HTTPException  # noqa: F401
+
+try:  # Compiled with SSL?
+    import ssl
+    BaseSSLError = ssl.SSLError
+except (ImportError, AttributeError):  # Platform-specific: No SSL.
+    ssl = None
+
+    class BaseSSLError(BaseException):
+        pass
+
+
+try:  # Python 3:
+    # Not a no-op, we're adding this to the namespace so it can be imported.
+    ConnectionError = ConnectionError
+except NameError:  # Python 2:
+    class ConnectionError(Exception):
+        pass
+
+
+from .exceptions import (
+    NewConnectionError,
+    ConnectTimeoutError,
+    SubjectAltNameWarning,
+    SystemTimeWarning,
+)
+from .packages.ssl_match_hostname import match_hostname, CertificateError
+
+from .util.ssl_ import (
+    resolve_cert_reqs,
+    resolve_ssl_version,
+    assert_fingerprint,
+    create_urllib3_context,
+    ssl_wrap_socket
+)
+
+
+from .util import connection
+
+from ._collections import HTTPHeaderDict
+
+log = logging.getLogger(__name__)
+
+port_by_scheme = {
+    'http': 80,
+    'https': 443,
+}
+
+# When updating RECENT_DATE, move it to within two years of the current date,
+# and not less than 6 months ago.
+# Example: if Today is 2018-01-01, then RECENT_DATE should be any date on or
+# after 2016-01-01 (today - 2 years) AND before 2017-07-01 (today - 6 months)
+RECENT_DATE = datetime.date(2017, 6, 30)
+
+
+class DummyConnection(object):
+    """Used to detect a failed ConnectionCls import."""
+    pass
+
+
+class HTTPConnection(_HTTPConnection, object):
+    """
+    Based on httplib.HTTPConnection but provides an extra constructor
+    backwards-compatibility layer between older and newer Pythons.
+
+    Additional keyword parameters are used to configure attributes of the connection.
+    Accepted parameters include:
+
+      - ``strict``: See the documentation on :class:`urllib3.connectionpool.HTTPConnectionPool`
+      - ``source_address``: Set the source address for the current connection.
+      - ``socket_options``: Set specific options on the underlying socket. If not specified, then
+        defaults are loaded from ``HTTPConnection.default_socket_options`` which includes disabling
+        Nagle's algorithm (sets TCP_NODELAY to 1) unless the connection is behind a proxy.
+
+        For example, if you wish to enable TCP Keep Alive in addition to the defaults,
+        you might pass::
+
+            HTTPConnection.default_socket_options + [
+                (socket.SOL_SOCKET, socket.SO_KEEPALIVE, 1),
+            ]
+
+        Or you may want to disable the defaults by passing an empty list (e.g., ``[]``).
+    """
+
+    default_port = port_by_scheme['http']
+
+    #: Disable Nagle's algorithm by default.
+    #: ``[(socket.IPPROTO_TCP, socket.TCP_NODELAY, 1)]``
+    default_socket_options = [(socket.IPPROTO_TCP, socket.TCP_NODELAY, 1)]
+
+    #: Whether this connection verifies the host's certificate.
+    is_verified = False
+
+    def __init__(self, *args, **kw):
+        if six.PY3:  # Python 3
+            kw.pop('strict', None)
+
+        # Pre-set source_address.
+        self.source_address = kw.get('source_address')
+
+        #: The socket options provided by the user. If no options are
+        #: provided, we use the default options.
+        self.socket_options = kw.pop('socket_options', self.default_socket_options)
+
+        _HTTPConnection.__init__(self, *args, **kw)
+
+    @property
+    def host(self):
+        """
+        Getter method to remove any trailing dots that indicate the hostname is an FQDN.
+
+        In general, SSL certificates don't include the trailing dot indicating a
+        fully-qualified domain name, and thus, they don't validate properly when
+        checked against a domain name that includes the dot. In addition, some
+        servers may not expect to receive the trailing dot when provided.
+
+        However, the hostname with trailing dot is critical to DNS resolution; doing a
+        lookup with the trailing dot will properly only resolve the appropriate FQDN,
+        whereas a lookup without a trailing dot will search the system's search domain
+        list. Thus, it's important to keep the original host around for use only in
+        those cases where it's appropriate (i.e., when doing DNS lookup to establish the
+        actual TCP connection across which we're going to send HTTP requests).
+        """
+        return self._dns_host.rstrip('.')
+
+    @host.setter
+    def host(self, value):
+        """
+        Setter for the `host` property.
+
+        We assume that only urllib3 uses the _dns_host attribute; httplib itself
+        only uses `host`, and it seems reasonable that other libraries follow suit.
+        """
+        self._dns_host = value
+
+    def _new_conn(self):
+        """ Establish a socket connection and set nodelay settings on it.
+
+        :return: New socket connection.
+        """
+        extra_kw = {}
+        if self.source_address:
+            extra_kw['source_address'] = self.source_address
+
+        if self.socket_options:
+            extra_kw['socket_options'] = self.socket_options
+
+        try:
+            conn = connection.create_connection(
+                (self._dns_host, self.port), self.timeout, **extra_kw)
+
+        except SocketTimeout as e:
+            raise ConnectTimeoutError(
+                self, "Connection to %s timed out. (connect timeout=%s)" %
+                (self.host, self.timeout))
+
+        except SocketError as e:
+            raise NewConnectionError(
+                self, "Failed to establish a new connection: %s" % e)
+
+        return conn
+
+    def _prepare_conn(self, conn):
+        self.sock = conn
+        if self._tunnel_host:
+            # TODO: Fix tunnel so it doesn't depend on self.sock state.
+            self._tunnel()
+            # Mark this connection as not reusable
+            self.auto_open = 0
+
+    def connect(self):
+        conn = self._new_conn()
+        self._prepare_conn(conn)
+
+    def request_chunked(self, method, url, body=None, headers=None):
+        """
+        Alternative to the common request method, which sends the
+        body with chunked encoding and not as one block
+        """
+        headers = HTTPHeaderDict(headers if headers is not None else {})
+        skip_accept_encoding = 'accept-encoding' in headers
+        skip_host = 'host' in headers
+        self.putrequest(
+            method,
+            url,
+            skip_accept_encoding=skip_accept_encoding,
+            skip_host=skip_host
+        )
+        for header, value in headers.items():
+            self.putheader(header, value)
+        if 'transfer-encoding' not in headers:
+            self.putheader('Transfer-Encoding', 'chunked')
+        self.endheaders()
+
+        if body is not None:
+            stringish_types = six.string_types + (bytes,)
+            if isinstance(body, stringish_types):
+                body = (body,)
+            for chunk in body:
+                if not chunk:
+                    continue
+                if not isinstance(chunk, bytes):
+                    chunk = chunk.encode('utf8')
+                len_str = hex(len(chunk))[2:]
+                self.send(len_str.encode('utf-8'))
+                self.send(b'\r\n')
+                self.send(chunk)
+                self.send(b'\r\n')
+
+        # After the if clause, to always have a closed body
+        self.send(b'0\r\n\r\n')
+
+
+class HTTPSConnection(HTTPConnection):
+    default_port = port_by_scheme['https']
+
+    ssl_version = None
+
+    def __init__(self, host, port=None, key_file=None, cert_file=None,
+                 strict=None, timeout=socket._GLOBAL_DEFAULT_TIMEOUT,
+                 ssl_context=None, server_hostname=None, **kw):
+
+        HTTPConnection.__init__(self, host, port, strict=strict,
+                                timeout=timeout, **kw)
+
+        self.key_file = key_file
+        self.cert_file = cert_file
+        self.ssl_context = ssl_context
+        self.server_hostname = server_hostname
+
+        # Required property for Google AppEngine 1.9.0 which otherwise causes
+        # HTTPS requests to go out as HTTP. (See Issue #356)
+        self._protocol = 'https'
+
+    def connect(self):
+        conn = self._new_conn()
+        self._prepare_conn(conn)
+
+        if self.ssl_context is None:
+            self.ssl_context = create_urllib3_context(
+                ssl_version=resolve_ssl_version(None),
+                cert_reqs=resolve_cert_reqs(None),
+            )
+
+        self.sock = ssl_wrap_socket(
+            sock=conn,
+            keyfile=self.key_file,
+            certfile=self.cert_file,
+            ssl_context=self.ssl_context,
+            server_hostname=self.server_hostname
+        )
+
+
+class VerifiedHTTPSConnection(HTTPSConnection):
+    """
+    Based on httplib.HTTPSConnection but wraps the socket with
+    SSL certification.
+    """
+    cert_reqs = None
+    ca_certs = None
+    ca_cert_dir = None
+    ssl_version = None
+    assert_fingerprint = None
+
+    def set_cert(self, key_file=None, cert_file=None,
+                 cert_reqs=None, ca_certs=None,
+                 assert_hostname=None, assert_fingerprint=None,
+                 ca_cert_dir=None):
+        """
+        This method should only be called once, before the connection is used.
+        """
+        # If cert_reqs is not provided, we can try to guess. If the user gave
+        # us a cert database, we assume they want to use it: otherwise, if
+        # they gave us an SSL Context object we should use whatever is set for
+        # it.
+        if cert_reqs is None:
+            if ca_certs or ca_cert_dir:
+                cert_reqs = 'CERT_REQUIRED'
+            elif self.ssl_context is not None:
+                cert_reqs = self.ssl_context.verify_mode
+
+        self.key_file = key_file
+        self.cert_file = cert_file
+        self.cert_reqs = cert_reqs
+        self.assert_hostname = assert_hostname
+        self.assert_fingerprint = assert_fingerprint
+        self.ca_certs = ca_certs and os.path.expanduser(ca_certs)
+        self.ca_cert_dir = ca_cert_dir and os.path.expanduser(ca_cert_dir)
+
+    def connect(self):
+        # Add certificate verification
+        conn = self._new_conn()
+        hostname = self.host
+
+        if self._tunnel_host:
+            self.sock = conn
+            # Calls self._set_hostport(), so self.host is
+            # self._tunnel_host below.
+            self._tunnel()
+            # Mark this connection as not reusable
+            self.auto_open = 0
+
+            # Override the host with the one we're requesting data from.
+            hostname = self._tunnel_host
+
+        server_hostname = hostname
+        if self.server_hostname is not None:
+            server_hostname = self.server_hostname
+
+        is_time_off = datetime.date.today() < RECENT_DATE
+        if is_time_off:
+            warnings.warn((
+                'System time is way off (before {0}). This will probably '
+                'lead to SSL verification errors').format(RECENT_DATE),
+                SystemTimeWarning
+            )
+
+        # Wrap socket using verification with the root certs in
+        # trusted_root_certs
+        if self.ssl_context is None:
+            self.ssl_context = create_urllib3_context(
+                ssl_version=resolve_ssl_version(self.ssl_version),
+                cert_reqs=resolve_cert_reqs(self.cert_reqs),
+            )
+
+        context = self.ssl_context
+        context.verify_mode = resolve_cert_reqs(self.cert_reqs)
+        self.sock = ssl_wrap_socket(
+            sock=conn,
+            keyfile=self.key_file,
+            certfile=self.cert_file,
+            ca_certs=self.ca_certs,
+            ca_cert_dir=self.ca_cert_dir,
+            server_hostname=server_hostname,
+            ssl_context=context)
+
+        if self.assert_fingerprint:
+            assert_fingerprint(self.sock.getpeercert(binary_form=True),
+                               self.assert_fingerprint)
+        elif context.verify_mode != ssl.CERT_NONE \
+                and not getattr(context, 'check_hostname', False) \
+                and self.assert_hostname is not False:
+            # While urllib3 attempts to always turn off hostname matching from
+            # the TLS library, this cannot always be done. So we check whether
+            # the TLS Library still thinks it's matching hostnames.
+            cert = self.sock.getpeercert()
+            if not cert.get('subjectAltName', ()):
+                warnings.warn((
+                    'Certificate for {0} has no `subjectAltName`, falling back to check for a '
+                    '`commonName` for now. This feature is being removed by major browsers and '
+                    'deprecated by RFC 2818. (See https://github.com/shazow/urllib3/issues/497 '
+                    'for details.)'.format(hostname)),
+                    SubjectAltNameWarning
+                )
+            _match_hostname(cert, self.assert_hostname or server_hostname)
+
+        self.is_verified = (
+            context.verify_mode == ssl.CERT_REQUIRED or
+            self.assert_fingerprint is not None
+        )
+
+
+def _match_hostname(cert, asserted_hostname):
+    try:
+        match_hostname(cert, asserted_hostname)
+    except CertificateError as e:
+        log.error(
+            'Certificate did not match expected hostname: %s. '
+            'Certificate: %s', asserted_hostname, cert
+        )
+        # Add cert to exception and reraise so client code can inspect
+        # the cert when catching the exception, if they want to
+        e._peer_cert = cert
+        raise
+
+
+if ssl:
+    # Make a copy for testing.
+    UnverifiedHTTPSConnection = HTTPSConnection
+    HTTPSConnection = VerifiedHTTPSConnection
+else:
+    HTTPSConnection = DummyConnection
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/connection.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/connection.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..13503fbb7035f54b9c1f3c2ee5be771e4137f2ff
GIT binary patch
literal 13186
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

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/connectionpool.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/connectionpool.py
new file mode 100644
index 0000000..f7a8f19
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/connectionpool.py
@@ -0,0 +1,896 @@
+from __future__ import absolute_import
+import errno
+import logging
+import sys
+import warnings
+
+from socket import error as SocketError, timeout as SocketTimeout
+import socket
+
+
+from .exceptions import (
+    ClosedPoolError,
+    ProtocolError,
+    EmptyPoolError,
+    HeaderParsingError,
+    HostChangedError,
+    LocationValueError,
+    MaxRetryError,
+    ProxyError,
+    ReadTimeoutError,
+    SSLError,
+    TimeoutError,
+    InsecureRequestWarning,
+    NewConnectionError,
+)
+from .packages.ssl_match_hostname import CertificateError
+from .packages import six
+from .packages.six.moves import queue
+from .connection import (
+    port_by_scheme,
+    DummyConnection,
+    HTTPConnection, HTTPSConnection, VerifiedHTTPSConnection,
+    HTTPException, BaseSSLError,
+)
+from .request import RequestMethods
+from .response import HTTPResponse
+
+from .util.connection import is_connection_dropped
+from .util.request import set_file_position
+from .util.response import assert_header_parsing
+from .util.retry import Retry
+from .util.timeout import Timeout
+from .util.url import get_host, Url, NORMALIZABLE_SCHEMES
+from .util.queue import LifoQueue
+
+
+xrange = six.moves.xrange
+
+log = logging.getLogger(__name__)
+
+_Default = object()
+
+
+# Pool objects
+class ConnectionPool(object):
+    """
+    Base class for all connection pools, such as
+    :class:`.HTTPConnectionPool` and :class:`.HTTPSConnectionPool`.
+    """
+
+    scheme = None
+    QueueCls = LifoQueue
+
+    def __init__(self, host, port=None):
+        if not host:
+            raise LocationValueError("No host specified.")
+
+        self.host = _ipv6_host(host, self.scheme)
+        self._proxy_host = host.lower()
+        self.port = port
+
+    def __str__(self):
+        return '%s(host=%r, port=%r)' % (type(self).__name__,
+                                         self.host, self.port)
+
+    def __enter__(self):
+        return self
+
+    def __exit__(self, exc_type, exc_val, exc_tb):
+        self.close()
+        # Return False to re-raise any potential exceptions
+        return False
+
+    def close(self):
+        """
+        Close all pooled connections and disable the pool.
+        """
+        pass
+
+
+# This is taken from http://hg.python.org/cpython/file/7aaba721ebc0/Lib/socket.py#l252
+_blocking_errnos = {errno.EAGAIN, errno.EWOULDBLOCK}
+
+
+class HTTPConnectionPool(ConnectionPool, RequestMethods):
+    """
+    Thread-safe connection pool for one host.
+
+    :param host:
+        Host used for this HTTP Connection (e.g. "localhost"), passed into
+        :class:`httplib.HTTPConnection`.
+
+    :param port:
+        Port used for this HTTP Connection (None is equivalent to 80), passed
+        into :class:`httplib.HTTPConnection`.
+
+    :param strict:
+        Causes BadStatusLine to be raised if the status line can't be parsed
+        as a valid HTTP/1.0 or 1.1 status line, passed into
+        :class:`httplib.HTTPConnection`.
+
+        .. note::
+           Only works in Python 2. This parameter is ignored in Python 3.
+
+    :param timeout:
+        Socket timeout in seconds for each individual connection. This can
+        be a float or integer, which sets the timeout for the HTTP request,
+        or an instance of :class:`urllib3.util.Timeout` which gives you more
+        fine-grained control over request timeouts. After the constructor has
+        been parsed, this is always a `urllib3.util.Timeout` object.
+
+    :param maxsize:
+        Number of connections to save that can be reused. More than 1 is useful
+        in multithreaded situations. If ``block`` is set to False, more
+        connections will be created but they will not be saved once they've
+        been used.
+
+    :param block:
+        If set to True, no more than ``maxsize`` connections will be used at
+        a time. When no free connections are available, the call will block
+        until a connection has been released. This is a useful side effect for
+        particular multithreaded situations where one does not want to use more
+        than maxsize connections per host to prevent flooding.
+
+    :param headers:
+        Headers to include with all requests, unless other headers are given
+        explicitly.
+
+    :param retries:
+        Retry configuration to use by default with requests in this pool.
+
+    :param _proxy:
+        Parsed proxy URL, should not be used directly, instead, see
+        :class:`urllib3.connectionpool.ProxyManager`"
+
+    :param _proxy_headers:
+        A dictionary with proxy headers, should not be used directly,
+        instead, see :class:`urllib3.connectionpool.ProxyManager`"
+
+    :param \\**conn_kw:
+        Additional parameters are used to create fresh :class:`urllib3.connection.HTTPConnection`,
+        :class:`urllib3.connection.HTTPSConnection` instances.
+    """
+
+    scheme = 'http'
+    ConnectionCls = HTTPConnection
+    ResponseCls = HTTPResponse
+
+    def __init__(self, host, port=None, strict=False,
+                 timeout=Timeout.DEFAULT_TIMEOUT, maxsize=1, block=False,
+                 headers=None, retries=None,
+                 _proxy=None, _proxy_headers=None,
+                 **conn_kw):
+        ConnectionPool.__init__(self, host, port)
+        RequestMethods.__init__(self, headers)
+
+        self.strict = strict
+
+        if not isinstance(timeout, Timeout):
+            timeout = Timeout.from_float(timeout)
+
+        if retries is None:
+            retries = Retry.DEFAULT
+
+        self.timeout = timeout
+        self.retries = retries
+
+        self.pool = self.QueueCls(maxsize)
+        self.block = block
+
+        self.proxy = _proxy
+        self.proxy_headers = _proxy_headers or {}
+
+        # Fill the queue up so that doing get() on it will block properly
+        for _ in xrange(maxsize):
+            self.pool.put(None)
+
+        # These are mostly for testing and debugging purposes.
+        self.num_connections = 0
+        self.num_requests = 0
+        self.conn_kw = conn_kw
+
+        if self.proxy:
+            # Enable Nagle's algorithm for proxies, to avoid packet fragmentation.
+            # We cannot know if the user has added default socket options, so we cannot replace the
+            # list.
+            self.conn_kw.setdefault('socket_options', [])
+
+    def _new_conn(self):
+        """
+        Return a fresh :class:`HTTPConnection`.
+        """
+        self.num_connections += 1
+        log.debug("Starting new HTTP connection (%d): %s:%s",
+                  self.num_connections, self.host, self.port or "80")
+
+        conn = self.ConnectionCls(host=self.host, port=self.port,
+                                  timeout=self.timeout.connect_timeout,
+                                  strict=self.strict, **self.conn_kw)
+        return conn
+
+    def _get_conn(self, timeout=None):
+        """
+        Get a connection. Will return a pooled connection if one is available.
+
+        If no connections are available and :prop:`.block` is ``False``, then a
+        fresh connection is returned.
+
+        :param timeout:
+            Seconds to wait before giving up and raising
+            :class:`urllib3.exceptions.EmptyPoolError` if the pool is empty and
+            :prop:`.block` is ``True``.
+        """
+        conn = None
+        try:
+            conn = self.pool.get(block=self.block, timeout=timeout)
+
+        except AttributeError:  # self.pool is None
+            raise ClosedPoolError(self, "Pool is closed.")
+
+        except queue.Empty:
+            if self.block:
+                raise EmptyPoolError(self,
+                                     "Pool reached maximum size and no more "
+                                     "connections are allowed.")
+            pass  # Oh well, we'll create a new connection then
+
+        # If this is a persistent connection, check if it got disconnected
+        if conn and is_connection_dropped(conn):
+            log.debug("Resetting dropped connection: %s", self.host)
+            conn.close()
+            if getattr(conn, 'auto_open', 1) == 0:
+                # This is a proxied connection that has been mutated by
+                # httplib._tunnel() and cannot be reused (since it would
+                # attempt to bypass the proxy)
+                conn = None
+
+        return conn or self._new_conn()
+
+    def _put_conn(self, conn):
+        """
+        Put a connection back into the pool.
+
+        :param conn:
+            Connection object for the current host and port as returned by
+            :meth:`._new_conn` or :meth:`._get_conn`.
+
+        If the pool is already full, the connection is closed and discarded
+        because we exceeded maxsize. If connections are discarded frequently,
+        then maxsize should be increased.
+
+        If the pool is closed, then the connection will be closed and discarded.
+        """
+        try:
+            self.pool.put(conn, block=False)
+            return  # Everything is dandy, done.
+        except AttributeError:
+            # self.pool is None.
+            pass
+        except queue.Full:
+            # This should never happen if self.block == True
+            log.warning(
+                "Connection pool is full, discarding connection: %s",
+                self.host)
+
+        # Connection never got put back into the pool, close it.
+        if conn:
+            conn.close()
+
+    def _validate_conn(self, conn):
+        """
+        Called right before a request is made, after the socket is created.
+        """
+        pass
+
+    def _prepare_proxy(self, conn):
+        # Nothing to do for HTTP connections.
+        pass
+
+    def _get_timeout(self, timeout):
+        """ Helper that always returns a :class:`urllib3.util.Timeout` """
+        if timeout is _Default:
+            return self.timeout.clone()
+
+        if isinstance(timeout, Timeout):
+            return timeout.clone()
+        else:
+            # User passed us an int/float. This is for backwards compatibility,
+            # can be removed later
+            return Timeout.from_float(timeout)
+
+    def _raise_timeout(self, err, url, timeout_value):
+        """Is the error actually a timeout? Will raise a ReadTimeout or pass"""
+
+        if isinstance(err, SocketTimeout):
+            raise ReadTimeoutError(self, url, "Read timed out. (read timeout=%s)" % timeout_value)
+
+        # See the above comment about EAGAIN in Python 3. In Python 2 we have
+        # to specifically catch it and throw the timeout error
+        if hasattr(err, 'errno') and err.errno in _blocking_errnos:
+            raise ReadTimeoutError(self, url, "Read timed out. (read timeout=%s)" % timeout_value)
+
+        # Catch possible read timeouts thrown as SSL errors. If not the
+        # case, rethrow the original. We need to do this because of:
+        # http://bugs.python.org/issue10272
+        if 'timed out' in str(err) or 'did not complete (read)' in str(err):  # Python < 2.7.4
+            raise ReadTimeoutError(self, url, "Read timed out. (read timeout=%s)" % timeout_value)
+
+    def _make_request(self, conn, method, url, timeout=_Default, chunked=False,
+                      **httplib_request_kw):
+        """
+        Perform a request on a given urllib connection object taken from our
+        pool.
+
+        :param conn:
+            a connection from one of our connection pools
+
+        :param timeout:
+            Socket timeout in seconds for the request. This can be a
+            float or integer, which will set the same timeout value for
+            the socket connect and the socket read, or an instance of
+            :class:`urllib3.util.Timeout`, which gives you more fine-grained
+            control over your timeouts.
+        """
+        self.num_requests += 1
+
+        timeout_obj = self._get_timeout(timeout)
+        timeout_obj.start_connect()
+        conn.timeout = timeout_obj.connect_timeout
+
+        # Trigger any extra validation we need to do.
+        try:
+            self._validate_conn(conn)
+        except (SocketTimeout, BaseSSLError) as e:
+            # Py2 raises this as a BaseSSLError, Py3 raises it as socket timeout.
+            self._raise_timeout(err=e, url=url, timeout_value=conn.timeout)
+            raise
+
+        # conn.request() calls httplib.*.request, not the method in
+        # urllib3.request. It also calls makefile (recv) on the socket.
+        if chunked:
+            conn.request_chunked(method, url, **httplib_request_kw)
+        else:
+            conn.request(method, url, **httplib_request_kw)
+
+        # Reset the timeout for the recv() on the socket
+        read_timeout = timeout_obj.read_timeout
+
+        # App Engine doesn't have a sock attr
+        if getattr(conn, 'sock', None):
+            # In Python 3 socket.py will catch EAGAIN and return None when you
+            # try and read into the file pointer created by http.client, which
+            # instead raises a BadStatusLine exception. Instead of catching
+            # the exception and assuming all BadStatusLine exceptions are read
+            # timeouts, check for a zero timeout before making the request.
+            if read_timeout == 0:
+                raise ReadTimeoutError(
+                    self, url, "Read timed out. (read timeout=%s)" % read_timeout)
+            if read_timeout is Timeout.DEFAULT_TIMEOUT:
+                conn.sock.settimeout(socket.getdefaulttimeout())
+            else:  # None or a value
+                conn.sock.settimeout(read_timeout)
+
+        # Receive the response from the server
+        try:
+            try:  # Python 2.7, use buffering of HTTP responses
+                httplib_response = conn.getresponse(buffering=True)
+            except TypeError:  # Python 3
+                try:
+                    httplib_response = conn.getresponse()
+                except Exception as e:
+                    # Remove the TypeError from the exception chain in Python 3;
+                    # otherwise it looks like a programming error was the cause.
+                    six.raise_from(e, None)
+        except (SocketTimeout, BaseSSLError, SocketError) as e:
+            self._raise_timeout(err=e, url=url, timeout_value=read_timeout)
+            raise
+
+        # AppEngine doesn't have a version attr.
+        http_version = getattr(conn, '_http_vsn_str', 'HTTP/?')
+        log.debug("%s://%s:%s \"%s %s %s\" %s %s", self.scheme, self.host, self.port,
+                  method, url, http_version, httplib_response.status,
+                  httplib_response.length)
+
+        try:
+            assert_header_parsing(httplib_response.msg)
+        except (HeaderParsingError, TypeError) as hpe:  # Platform-specific: Python 3
+            log.warning(
+                'Failed to parse headers (url=%s): %s',
+                self._absolute_url(url), hpe, exc_info=True)
+
+        return httplib_response
+
+    def _absolute_url(self, path):
+        return Url(scheme=self.scheme, host=self.host, port=self.port, path=path).url
+
+    def close(self):
+        """
+        Close all pooled connections and disable the pool.
+        """
+        if self.pool is None:
+            return
+        # Disable access to the pool
+        old_pool, self.pool = self.pool, None
+
+        try:
+            while True:
+                conn = old_pool.get(block=False)
+                if conn:
+                    conn.close()
+
+        except queue.Empty:
+            pass  # Done.
+
+    def is_same_host(self, url):
+        """
+        Check if the given ``url`` is a member of the same host as this
+        connection pool.
+        """
+        if url.startswith('/'):
+            return True
+
+        # TODO: Add optional support for socket.gethostbyname checking.
+        scheme, host, port = get_host(url)
+
+        host = _ipv6_host(host, self.scheme)
+
+        # Use explicit default port for comparison when none is given
+        if self.port and not port:
+            port = port_by_scheme.get(scheme)
+        elif not self.port and port == port_by_scheme.get(scheme):
+            port = None
+
+        return (scheme, host, port) == (self.scheme, self.host, self.port)
+
+    def urlopen(self, method, url, body=None, headers=None, retries=None,
+                redirect=True, assert_same_host=True, timeout=_Default,
+                pool_timeout=None, release_conn=None, chunked=False,
+                body_pos=None, **response_kw):
+        """
+        Get a connection from the pool and perform an HTTP request. This is the
+        lowest level call for making a request, so you'll need to specify all
+        the raw details.
+
+        .. note::
+
+           More commonly, it's appropriate to use a convenience method provided
+           by :class:`.RequestMethods`, such as :meth:`request`.
+
+        .. note::
+
+           `release_conn` will only behave as expected if
+           `preload_content=False` because we want to make
+           `preload_content=False` the default behaviour someday soon without
+           breaking backwards compatibility.
+
+        :param method:
+            HTTP request method (such as GET, POST, PUT, etc.)
+
+        :param body:
+            Data to send in the request body (useful for creating
+            POST requests, see HTTPConnectionPool.post_url for
+            more convenience).
+
+        :param headers:
+            Dictionary of custom headers to send, such as User-Agent,
+            If-None-Match, etc. If None, pool headers are used. If provided,
+            these headers completely replace any pool-specific headers.
+
+        :param retries:
+            Configure the number of retries to allow before raising a
+            :class:`~urllib3.exceptions.MaxRetryError` exception.
+
+            Pass ``None`` to retry until you receive a response. Pass a
+            :class:`~urllib3.util.retry.Retry` object for fine-grained control
+            over different types of retries.
+            Pass an integer number to retry connection errors that many times,
+            but no other types of errors. Pass zero to never retry.
+
+            If ``False``, then retries are disabled and any exception is raised
+            immediately. Also, instead of raising a MaxRetryError on redirects,
+            the redirect response will be returned.
+
+        :type retries: :class:`~urllib3.util.retry.Retry`, False, or an int.
+
+        :param redirect:
+            If True, automatically handle redirects (status codes 301, 302,
+            303, 307, 308). Each redirect counts as a retry. Disabling retries
+            will disable redirect, too.
+
+        :param assert_same_host:
+            If ``True``, will make sure that the host of the pool requests is
+            consistent else will raise HostChangedError. When False, you can
+            use the pool on an HTTP proxy and request foreign hosts.
+
+        :param timeout:
+            If specified, overrides the default timeout for this one
+            request. It may be a float (in seconds) or an instance of
+            :class:`urllib3.util.Timeout`.
+
+        :param pool_timeout:
+            If set and the pool is set to block=True, then this method will
+            block for ``pool_timeout`` seconds and raise EmptyPoolError if no
+            connection is available within the time period.
+
+        :param release_conn:
+            If False, then the urlopen call will not release the connection
+            back into the pool once a response is received (but will release if
+            you read the entire contents of the response such as when
+            `preload_content=True`). This is useful if you're not preloading
+            the response's content immediately. You will need to call
+            ``r.release_conn()`` on the response ``r`` to return the connection
+            back into the pool. If None, it takes the value of
+            ``response_kw.get('preload_content', True)``.
+
+        :param chunked:
+            If True, urllib3 will send the body using chunked transfer
+            encoding. Otherwise, urllib3 will send the body using the standard
+            content-length form. Defaults to False.
+
+        :param int body_pos:
+            Position to seek to in file-like body in the event of a retry or
+            redirect. Typically this won't need to be set because urllib3 will
+            auto-populate the value when needed.
+
+        :param \\**response_kw:
+            Additional parameters are passed to
+            :meth:`urllib3.response.HTTPResponse.from_httplib`
+        """
+        if headers is None:
+            headers = self.headers
+
+        if not isinstance(retries, Retry):
+            retries = Retry.from_int(retries, redirect=redirect, default=self.retries)
+
+        if release_conn is None:
+            release_conn = response_kw.get('preload_content', True)
+
+        # Check host
+        if assert_same_host and not self.is_same_host(url):
+            raise HostChangedError(self, url, retries)
+
+        conn = None
+
+        # Track whether `conn` needs to be released before
+        # returning/raising/recursing. Update this variable if necessary, and
+        # leave `release_conn` constant throughout the function. That way, if
+        # the function recurses, the original value of `release_conn` will be
+        # passed down into the recursive call, and its value will be respected.
+        #
+        # See issue #651 [1] for details.
+        #
+        # [1] <https://github.com/shazow/urllib3/issues/651>
+        release_this_conn = release_conn
+
+        # Merge the proxy headers. Only do this in HTTP. We have to copy the
+        # headers dict so we can safely change it without those changes being
+        # reflected in anyone else's copy.
+        if self.scheme == 'http':
+            headers = headers.copy()
+            headers.update(self.proxy_headers)
+
+        # Must keep the exception bound to a separate variable or else Python 3
+        # complains about UnboundLocalError.
+        err = None
+
+        # Keep track of whether we cleanly exited the except block. This
+        # ensures we do proper cleanup in finally.
+        clean_exit = False
+
+        # Rewind body position, if needed. Record current position
+        # for future rewinds in the event of a redirect/retry.
+        body_pos = set_file_position(body, body_pos)
+
+        try:
+            # Request a connection from the queue.
+            timeout_obj = self._get_timeout(timeout)
+            conn = self._get_conn(timeout=pool_timeout)
+
+            conn.timeout = timeout_obj.connect_timeout
+
+            is_new_proxy_conn = self.proxy is not None and not getattr(conn, 'sock', None)
+            if is_new_proxy_conn:
+                self._prepare_proxy(conn)
+
+            # Make the request on the httplib connection object.
+            httplib_response = self._make_request(conn, method, url,
+                                                  timeout=timeout_obj,
+                                                  body=body, headers=headers,
+                                                  chunked=chunked)
+
+            # If we're going to release the connection in ``finally:``, then
+            # the response doesn't need to know about the connection. Otherwise
+            # it will also try to release it and we'll have a double-release
+            # mess.
+            response_conn = conn if not release_conn else None
+
+            # Pass method to Response for length checking
+            response_kw['request_method'] = method
+
+            # Import httplib's response into our own wrapper object
+            response = self.ResponseCls.from_httplib(httplib_response,
+                                                     pool=self,
+                                                     connection=response_conn,
+                                                     retries=retries,
+                                                     **response_kw)
+
+            # Everything went great!
+            clean_exit = True
+
+        except queue.Empty:
+            # Timed out by queue.
+            raise EmptyPoolError(self, "No pool connections are available.")
+
+        except (TimeoutError, HTTPException, SocketError, ProtocolError,
+                BaseSSLError, SSLError, CertificateError) as e:
+            # Discard the connection for these exceptions. It will be
+            # replaced during the next _get_conn() call.
+            clean_exit = False
+            if isinstance(e, (BaseSSLError, CertificateError)):
+                e = SSLError(e)
+            elif isinstance(e, (SocketError, NewConnectionError)) and self.proxy:
+                e = ProxyError('Cannot connect to proxy.', e)
+            elif isinstance(e, (SocketError, HTTPException)):
+                e = ProtocolError('Connection aborted.', e)
+
+            retries = retries.increment(method, url, error=e, _pool=self,
+                                        _stacktrace=sys.exc_info()[2])
+            retries.sleep()
+
+            # Keep track of the error for the retry warning.
+            err = e
+
+        finally:
+            if not clean_exit:
+                # We hit some kind of exception, handled or otherwise. We need
+                # to throw the connection away unless explicitly told not to.
+                # Close the connection, set the variable to None, and make sure
+                # we put the None back in the pool to avoid leaking it.
+                conn = conn and conn.close()
+                release_this_conn = True
+
+            if release_this_conn:
+                # Put the connection back to be reused. If the connection is
+                # expired then it will be None, which will get replaced with a
+                # fresh connection during _get_conn.
+                self._put_conn(conn)
+
+        if not conn:
+            # Try again
+            log.warning("Retrying (%r) after connection "
+                        "broken by '%r': %s", retries, err, url)
+            return self.urlopen(method, url, body, headers, retries,
+                                redirect, assert_same_host,
+                                timeout=timeout, pool_timeout=pool_timeout,
+                                release_conn=release_conn, body_pos=body_pos,
+                                **response_kw)
+
+        def drain_and_release_conn(response):
+            try:
+                # discard any remaining response body, the connection will be
+                # released back to the pool once the entire response is read
+                response.read()
+            except (TimeoutError, HTTPException, SocketError, ProtocolError,
+                    BaseSSLError, SSLError) as e:
+                pass
+
+        # Handle redirect?
+        redirect_location = redirect and response.get_redirect_location()
+        if redirect_location:
+            if response.status == 303:
+                method = 'GET'
+
+            try:
+                retries = retries.increment(method, url, response=response, _pool=self)
+            except MaxRetryError:
+                if retries.raise_on_redirect:
+                    # Drain and release the connection for this response, since
+                    # we're not returning it to be released manually.
+                    drain_and_release_conn(response)
+                    raise
+                return response
+
+            # drain and return the connection to the pool before recursing
+            drain_and_release_conn(response)
+
+            retries.sleep_for_retry(response)
+            log.debug("Redirecting %s -> %s", url, redirect_location)
+            return self.urlopen(
+                method, redirect_location, body, headers,
+                retries=retries, redirect=redirect,
+                assert_same_host=assert_same_host,
+                timeout=timeout, pool_timeout=pool_timeout,
+                release_conn=release_conn, body_pos=body_pos,
+                **response_kw)
+
+        # Check if we should retry the HTTP response.
+        has_retry_after = bool(response.getheader('Retry-After'))
+        if retries.is_retry(method, response.status, has_retry_after):
+            try:
+                retries = retries.increment(method, url, response=response, _pool=self)
+            except MaxRetryError:
+                if retries.raise_on_status:
+                    # Drain and release the connection for this response, since
+                    # we're not returning it to be released manually.
+                    drain_and_release_conn(response)
+                    raise
+                return response
+
+            # drain and return the connection to the pool before recursing
+            drain_and_release_conn(response)
+
+            retries.sleep(response)
+            log.debug("Retry: %s", url)
+            return self.urlopen(
+                method, url, body, headers,
+                retries=retries, redirect=redirect,
+                assert_same_host=assert_same_host,
+                timeout=timeout, pool_timeout=pool_timeout,
+                release_conn=release_conn,
+                body_pos=body_pos, **response_kw)
+
+        return response
+
+
+class HTTPSConnectionPool(HTTPConnectionPool):
+    """
+    Same as :class:`.HTTPConnectionPool`, but HTTPS.
+
+    When Python is compiled with the :mod:`ssl` module, then
+    :class:`.VerifiedHTTPSConnection` is used, which *can* verify certificates,
+    instead of :class:`.HTTPSConnection`.
+
+    :class:`.VerifiedHTTPSConnection` uses one of ``assert_fingerprint``,
+    ``assert_hostname`` and ``host`` in this order to verify connections.
+    If ``assert_hostname`` is False, no verification is done.
+
+    The ``key_file``, ``cert_file``, ``cert_reqs``, ``ca_certs``,
+    ``ca_cert_dir``, and ``ssl_version`` are only used if :mod:`ssl` is
+    available and are fed into :meth:`urllib3.util.ssl_wrap_socket` to upgrade
+    the connection socket into an SSL socket.
+    """
+
+    scheme = 'https'
+    ConnectionCls = HTTPSConnection
+
+    def __init__(self, host, port=None,
+                 strict=False, timeout=Timeout.DEFAULT_TIMEOUT, maxsize=1,
+                 block=False, headers=None, retries=None,
+                 _proxy=None, _proxy_headers=None,
+                 key_file=None, cert_file=None, cert_reqs=None,
+                 ca_certs=None, ssl_version=None,
+                 assert_hostname=None, assert_fingerprint=None,
+                 ca_cert_dir=None, **conn_kw):
+
+        HTTPConnectionPool.__init__(self, host, port, strict, timeout, maxsize,
+                                    block, headers, retries, _proxy, _proxy_headers,
+                                    **conn_kw)
+
+        if ca_certs and cert_reqs is None:
+            cert_reqs = 'CERT_REQUIRED'
+
+        self.key_file = key_file
+        self.cert_file = cert_file
+        self.cert_reqs = cert_reqs
+        self.ca_certs = ca_certs
+        self.ca_cert_dir = ca_cert_dir
+        self.ssl_version = ssl_version
+        self.assert_hostname = assert_hostname
+        self.assert_fingerprint = assert_fingerprint
+
+    def _prepare_conn(self, conn):
+        """
+        Prepare the ``connection`` for :meth:`urllib3.util.ssl_wrap_socket`
+        and establish the tunnel if proxy is used.
+        """
+
+        if isinstance(conn, VerifiedHTTPSConnection):
+            conn.set_cert(key_file=self.key_file,
+                          cert_file=self.cert_file,
+                          cert_reqs=self.cert_reqs,
+                          ca_certs=self.ca_certs,
+                          ca_cert_dir=self.ca_cert_dir,
+                          assert_hostname=self.assert_hostname,
+                          assert_fingerprint=self.assert_fingerprint)
+            conn.ssl_version = self.ssl_version
+        return conn
+
+    def _prepare_proxy(self, conn):
+        """
+        Establish tunnel connection early, because otherwise httplib
+        would improperly set Host: header to proxy's IP:port.
+        """
+        conn.set_tunnel(self._proxy_host, self.port, self.proxy_headers)
+        conn.connect()
+
+    def _new_conn(self):
+        """
+        Return a fresh :class:`httplib.HTTPSConnection`.
+        """
+        self.num_connections += 1
+        log.debug("Starting new HTTPS connection (%d): %s:%s",
+                  self.num_connections, self.host, self.port or "443")
+
+        if not self.ConnectionCls or self.ConnectionCls is DummyConnection:
+            raise SSLError("Can't connect to HTTPS URL because the SSL "
+                           "module is not available.")
+
+        actual_host = self.host
+        actual_port = self.port
+        if self.proxy is not None:
+            actual_host = self.proxy.host
+            actual_port = self.proxy.port
+
+        conn = self.ConnectionCls(host=actual_host, port=actual_port,
+                                  timeout=self.timeout.connect_timeout,
+                                  strict=self.strict, **self.conn_kw)
+
+        return self._prepare_conn(conn)
+
+    def _validate_conn(self, conn):
+        """
+        Called right before a request is made, after the socket is created.
+        """
+        super(HTTPSConnectionPool, self)._validate_conn(conn)
+
+        # Force connect early to allow us to validate the connection.
+        if not getattr(conn, 'sock', None):  # AppEngine might not have  `.sock`
+            conn.connect()
+
+        if not conn.is_verified:
+            warnings.warn((
+                'Unverified HTTPS request is being made. '
+                'Adding certificate verification is strongly advised. See: '
+                'https://urllib3.readthedocs.io/en/latest/advanced-usage.html'
+                '#ssl-warnings'),
+                InsecureRequestWarning)
+
+
+def connection_from_url(url, **kw):
+    """
+    Given a url, return an :class:`.ConnectionPool` instance of its host.
+
+    This is a shortcut for not having to parse out the scheme, host, and port
+    of the url before creating an :class:`.ConnectionPool` instance.
+
+    :param url:
+        Absolute URL string that must include the scheme. Port is optional.
+
+    :param \\**kw:
+        Passes additional parameters to the constructor of the appropriate
+        :class:`.ConnectionPool`. Useful for specifying things like
+        timeout, maxsize, headers, etc.
+
+    Example::
+
+        >>> conn = connection_from_url('http://google.com/')
+        >>> r = conn.request('GET', '/')
+    """
+    scheme, host, port = get_host(url)
+    port = port or port_by_scheme.get(scheme, 80)
+    if scheme == 'https':
+        return HTTPSConnectionPool(host, port=port, **kw)
+    else:
+        return HTTPConnectionPool(host, port=port, **kw)
+
+
+def _ipv6_host(host, scheme):
+    """
+    Process IPv6 address literals
+    """
+
+    # httplib doesn't like it when we include brackets in IPv6 addresses
+    # Specifically, if we include brackets but also pass the port then
+    # httplib crazily doubles up the square brackets on the Host header.
+    # Instead, we need to make sure we never pass ``None`` as the port.
+    # However, for backward compatibility reasons we can't actually
+    # *assert* that.  See http://bugs.python.org/issue28539
+    #
+    # Also if an IPv6 address literal has a zone identifier, the
+    # percent sign might be URIencoded, convert it back into ASCII
+    if host.startswith('[') and host.endswith(']'):
+        host = host.replace('%25', '%').strip('[]')
+    if scheme in NORMALIZABLE_SCHEMES:
+        host = host.lower()
+    return host
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/connectionpool.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/connectionpool.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..8d6ff44b2e0996fc274c1884f86606d941af5cdd
GIT binary patch
literal 28575
zcmZSn%**AGdLky70ScHI7#JKJ7#NDZnHU&S7#LC*8FCmHav2$-7#SErd?tn*CWa^`
zupARZ4l_d(GmOo`5XAyxvob`ng4xUrIcyBM><m#H47r>PQCx6S*chVN7*bdmQdk*s
zxEXSJ7@~L>a(Nk|co}l}7^3(Xa`_pe_!)8q7@`Cias?Tp1Q~LL7@~w2a)lY9gc)*0
z7@|ZNazz=UL>Y3$7^1`&a>W^<#2IoW7@{N?7(wQ;G2}=x<VrC_NkRDR3^~#axiSn<
zG7vroLyjy%t{g*@9E8uwkR#8KtH2PYz>urR5T(eFtHcnc#E`4Z5T(qJtHKba!jP-V
z5T(kHtHuze2GPUCkfY9!tHBVZ0pW8q<Y+SFYB5A<LHIljIob@lIt)=d5I!$MjxIy4
z9z&EKgwMy2qtB3Qzz}5s;qx=(7&7D<F+>?b_yP<$#tgY83{fT!z92)6DMPLqLzEdq
zt~o=LIYX`mLzD$XPKY7Lk|EcMA<Bw@F;#{k%bFp}h9Sy^A(fdS%a$S4j-i>6A<CX1
z)q$azfg#F~Aw?L(PGe+95n*Uy00~A$IWeR%F=RP|Nf(9;CWa_ih7?hTR40a14Tdx(
zh7>WlQa6SaafVbk29N;~a8Y-L6iE;#%7Y<A3e50iNMT|K){tgkV8{d|G7Uxs28I%T
z1_p-2q~iRX(vsBp%-n+fq7pw1CXfs(0|P^9QBi(T2|I|JnVXtlT9OIUq`?ak0O@qj
z$uCY#3CPdSaRsXcNdy$-m*gkIMEDpO7+iA;N-7bGgcukYJW>-=Qi}o-i;6Sz(jj^U
zK*IUOCC(X%dFiPs5J8YypZw&+lFa<Pu*96wRERLh9^b@@pwyD0N{9#-0|P@qQGNxK
z3o<MyH8CXw;%tZ-4h9B>;9wsJhlhcI0Yz4ffq}s@uQ)Ziv?w(wwXig`xFkHWC@(WF
zy#(Y6ztnQ){Jgx>WRO$9MnD1(WRr7hQAuW6W^!T)#C;GMP!=xEtblMpp;=g(TAHc>
z4oy(7fWkUHsWQGeIU_YU6&w>TrMbD42y03}$~;0s0+572!447%MiLWeU|<MKEy_&G
zOie+T0|gaG%(WspwE*Py5|GcG5{pw|K>=|f$SSC}eN#&^@>7Z-;vm%^{Xwb41^Ic!
zsSr_7P%0{pPlks`d`eM%K|yK?L|Tx6fuT6HBt9)OCpEqxzc>?QF+>WaGqJchwWuUM
z1Dpur3m~ZgA`J>BaI`|WpumF0k_IR|OE?%97}8Tq;xqD#OG-c@p+z|*A`A=+e*Qte
zjy|4Ij!r(V@xjg>uD-6p5HmO#7#Msq)A9pB!4D2nM9_g!CA`c9C3`1Ond=2g`V63=
zHiZFP#<GD*)Kpe*Ny!E(i(42OqS!$hs)YemqNXr|vlu6+90iGRfl5;lgPS2J7#!op
zRSXOaTnY*b3ZS4@NX|(tE>=j(FH%U%$x%QAqe4M`eonEDLUCzwhC*U7Sc4T<u~mW|
zC>l_mo}iGJm!g2804ZI7JeQycHX|7nR50ue@}nCA149iXL$N4B3AlD?W@Kn$WXNM+
zC}9MN*Dx?-F)=hVG1M?H#503LvRFVx6Nt;oPy-QX1Jx|S;Nrrs7@SG+6+jWAP+X9j
z3{H)DV9y7EVy%RWfq@}Dv!Kij5_xQ(Gy+NbEDQ_`AblmE*w4u?Pc16p1}QE8WoU?M
zkP=XafusTuuQ)X)El7ibfgwnnfq?<UfDpx{3=9nV1x1-<i6yD}Wr;=lY56%RsYS*5
zNh$i}NlAIRrn$vNhDqk>Rp}O{7UelvRb~btke;U>qF<0%pqrUjT#}fRqw7}Y;b|NI
z5(4A+vedkk{389*qMV$}Bx8L<tbrm;ub>i~IOF3p^D;}~;~hZW19_Q&k&Tg`NtBVF
zF&R{Nf-uPW;7Cwl0Ec}E11OlA85yz|L5wUWFv-l2#>^lF3tmtfS1r~61(U66k&Xf=
zFl<$eG&Mkmm4J!Lf>fvz@)C1X<KvM+2V`rI&R_{AP_B-TFD@yHkM{rt6Ug-p$N>a$
zE;xWdGBpegkeuuXiDZ!E;PDG5D51uu=9Q!t#mD=Ad;=;*7#Nd5P6uI-bHRQAm9U^}
z1+L;5OBmt40%-sz{bW#e3TC+_<`k!bqZaH_aI~gYB*&M4;usWsAWm6gP6;R%f!HNU
zkiY@e>;s+yQY%0?z#kMCpb%hS<YI!SeRyzyWKuwZ0P=pZ3#@nq6_Ma(1-N7c<*d{c
zqyn-ST;io<7AGd<q$-qTq=HLKNFfK(IvCSPkP)b@0SXO}R~cCRG(eSVkUppt#RX12
zx%nxjIjQmS;HFl5d`f<Dd^|W$`{n1Q2C0JzITes<P&o>&#+-ACgLFZ{1|Y%^M3{pJ
zkWGk$0A>wbY6wzgU|;|_s~FTsVq;-rVq;`u;^E+A;bi7y1-Gg&t2B6R45|UZwec<V
z+L#g4*GXjo^=wkv!1b^ILn<djDi=c*H>gfd<zz?^Ktjw6Eu5fUO$rORmgWUZu`+<_
za6X0<Hn1Q+Lkc^XA;6Hr0cHp?q;P^6LJTQfV1_V5stCxU6mEtVCQyebg$FDy#*o4b
zW{5MS@PQc;U@O3GNR?y&ArYtu)NT9>EnJ`uQBbf3xUJ;J32hyOWE7<)rsx(YrllgK
zdT=5KHy85rQo&WM9v8S?w<<_1O3Vd|Sb+sVdB7vTxJ03}I5h>Vqa-7<SOFBy3W&CY
zf<~%dx}JhkPJVJ?4yZ~|($rBX05!`}6f*Nl^5I6onid%)B?UQ|NoY-w1XNdmsw9Lf
z0`iLpx&oBE6*7wzQVUBn%Mx=^^GXy-@)ax$;I4r?1mr4sLx(8W6qgibCYK=G<D6Jp
zoLa2ll$a7+l2}q&?30<73bHLJRiP*`6BJsRY2X5-7%Z)j1Cmcp%u_E>NJ>=zHBwVk
z;Lb@bR!CGROU%hk0SB$Vp`L+4evyKqo}mJgc1pq&6p?y*3VHb@sa6P2C@3iS=jBu?
zl;;;^7b|4uDFjrOWaQ^580jg5fZ`dP98ybCi$I~8nVy$llnRPbm@;G32rGf~ju6HN
z=O<^UmMB2QLFN~yCg<m+K$@zliOCrXnRzLhWtl0ZiO9`XsO`y#dGHWQN>xZyNXyAj
zECB^fW?o5ZdTNo5LU~4Ja)v^2YDqCTtYJ2RTEd{h9Gp&zAiXagxLKfPa-IUXS(cZa
zs*s-sPYKYrm|kf~W{w`TqmTf#Bt5e%wOFAtzf>VNzbF-MSXyRYs&0BwVrCwsVks%g
z&r!%POD$4>+6(i3v7Uls8Yn114ol9@D=sN2O)kkVQpkWd%t29<l$x3cO&mH3;H;Ke
ztdN*fo>&P=Aqm*sm!FiCnp}b!7rBWQ#hF#9h`8`8%}q)z0(lnE&@2We*y6-8P|cTE
zqL7@J2TGeosi4fRr{J4k1eVBCFa$+^X>n>=X%5`qnRyDir8y;;CEyY!HASH~v!oQ<
zu`bqA@Jv%kNJz@bPtHzA0O>6TrGk6~a5F>)HT;lWQ=XZV19CxfQEFmIYKlTqX$dG=
zD;2;JdHLY119ESQLOv+wN-|O_)yoiZ0S-N|<57w;utN|b;h6?XFd(mo6qTmxDCFgX
zU8GQwk(j5DkN^$2gao7lvl!xnq*O>bm{<Z2hD31m>M4Y0q~?K4N-Ii5E@_Ju5{pt5
z63Y@Zb3iQ&P@JYJB!fC>U@w7P1~;oTuOu@^ArZ-5P})!c`>H54CpED+H3gbAK&b-c
zmbB6wh2qSVRE5;EwAADhPzen;t{}0fBr~}*C$R`;OevISq!y(rfNFu1{M2Gl@t{zi
z2q`v8i&Mej0yhsFKG4uXa$~VVL241W$^ZpvK~ZWMsN7A<$<I&8%u7d2m5?raF(NJ?
z12^Dwn3<QHQ<{>hP@Y+m0dA~8^G~skLTO%3YH_hben|$%CU7?&60o2=i6|pdD++Ql
zlQT<lDp74MN-ZhMOhvL4JR$({LRw~eX%RTlg4_=BaZ;s1N@`kSX-)~mAuvaP3NLVe
z1T`U1jgJTSD-nJI4MU}-D1b#3LW6vC6pAzQOLJ1dp$khwDVas7$t5|JI^c3BH8Dj;
zp*R(hl3^7kEW;ym3D|z{(3EdtUSfJ`QGyamVu!c}Iv9fFXGevUOz>b+Vi71mm1IC2
z2#pf_j)bQHP@xHPEJmqGydz_@v_OjEv&#{|=9rQK9@k0C0TqCWxu9wX63d_*4T>K~
zv7nGvlv<pD$8tSTsgG!!Bp?cY+@T8AgEZEW0FIW#yyVnkNM``td<HcXz(bbFpw=X4
zC=Ar=@CJ>4@G~-iMm``t?ixnWkVZ2z17isjv=d&#4jTPntYHTA#p9V7N>~_bSQtuJ
zL88UJAVwA&NTivOp_T<SZc@Vm8V$+jU?@suDB)np;$*1h0E@GLP2ggv;Q%wZL1Y#W
zLk%lvAQ&{B!pl&@1`>?tW2oT-Gx!;5xEKnSfCg$o3IrG`R2WJGp;}yG#TaUNK<cu1
z8M1^xwl*^|FcxlS2v1=I3C9bAhNwUqMHp(p*2Rm0#IyJrintj;T~JYmEHO|^Ih_II
z9mYKH6hkn0Y{d^eI1C;pD+ad);`717hQ%77QATi+9@6uW0(D40-A_nE3p~7&Sqw^V
zpjZe34Q+tM(u(qP<G~GqAS+N8MINLN)P;3%b#n~$2?+vqiohKoXtocs2B`o=6e#O}
zyTjmO7t8`@(h^Wif?2R^1MUY`6oE#L!J~o&r6u42)x6SNq(RE!5*`Ky29Ox6lmOcc
zP1#`A7N?d#ixUlyCE(sSVjLyN9^?bKgP~<>kSoZ+ATL4lW{@*T02DTm%nc4r2ovVu
zAka`j38*t15ALObi2>}YfjX1(L0wd^Ls*3w1(-OQ_!)(mco=z@I2k#agcv!QI2rkw
zg&9SdIT=ABoGjo@Jt#Cly;x^Zt||nLDl#yzWP!)E%$efB<B3^Jpu`4Bc;JDqEO4I6
zVqqvSU`SzRXl7vmCrVb(=qX4MGidY_#9#sS&Oi({hAeha2Mxpq=b|i5hF%7iTJTV1
zum-4GTx^Lvf)JEiQd*P;YJsAZJ!l0Dq@(~f<G_VPG05-1C7@b3FI^!owH(~G2UR=J
zVSfb;)f7!D1=V6J)#4J6zby=q(gsKXoIo@{!4U)+L<XnDocwff(oIQCDosbI2Pa}g
zsR!!OgG>M?TTqHjO)iOtHjlxkf>R85tQDLn!Q~rB9mvrGKJv*48pg;=EeB_|<DhiJ
z2O5cD;b-Jzlwp!)<Y5$IOa^%mGzJYC<prmfJD}lDPKH`0hDs%H0mTR!bcPgSS<K)x
z!^qIgz*Nh`5T579z*54(kj=$V<i)_q$XLP((g8|7OyGfQeFl~ia54d@r~s(|B^G9e
zqDoL{T*ClLT+Lvmg_R6>j0_PqObkV57)m(7B|jsW4H-ZH8=S=hE*Wc>7_xXl<KB!V
zd?1A>Y@lS=%nTYN$Oapb0(O7l8E{e0#87Y><g6@yke*<0LMWce2<_X05}JEz2}*-e
zPaz!ChAx7oS5T1$>6gILTxJ@$xd&=M!dj)!<_yR@&oodY7L*PkGgFWX7~XybkCs^#
z6y+CKCFp@mQE>A<ApzX7Pe=f_Z}Suq;q3)TU5zjg)ER&{E;R+oTIjd~G<_o41Ry5`
zL%WP6`3mKUnV>E}8mMEEo>`Wem#$D+0Cp3o%bl5*4!0Mi5xurgg-ux%>!D5|CMZC=
z>Y&g9xiA$p!w51L)jTZz2K68kppzmXJHcf)xC$x;&8!9F=jVV71dqg~=oQ<6rWHYA
zMWD`aYKlT`Vnt?dX|4jOuLiOZ6#Ag<B~mE?je;D|L`I5UF{mO8N-a(;DFJyOI!%V8
z98{i^fbvgbX-R&3enDy;xG(}&!+sh9pb7_EZ-Pch!R1MMY6;lY;9AA8q@*Y_sT4Z#
z7zD~*L7<r!aESvBwIEP-3z7ku69OVaK?JDK01r!oE5P*BlEjjdqM%671OeCx&{P39
zRDvQvVxYVX(!wxsH553A;z3h?pu~9vRK$QnmVt+jk(p76iI-7`Nq~`)k&TguiG^8+
zQJ9g7QG$hs30&xa3La1>fD4^`1_p*oIdCpz0JrrRL9L|{CWdB4Mn=#Sd3c^V14{`r
zxTrA%6(o7;;G!ps6)Y4E5`q*pDUgbc16)*q%M?b2qHOSF87HU!05_~alkT9#Oz{&&
zq;epj6tx^sNJ>o329LdgI?&+pKFsU}@;Pc=L)0G%kU<4dhZ1Z;a%oW!s9y&f-2*37
z(CC~(VzB}&H!CDnqUM&|)RGLV1ig4zF`fV#xUqtX!a^Q4<_F3=o@rpKV7V|c2Q+qB
zsgPEhlLIbTkWx7!Q-K|ml3ARbSd@Y^qL!4J3>u(QC{I-Y<@?kWNM-}&Gw|>P$nVHS
z9NYv@_oA>gH4oG`gL|k1)Vqf^&tSc|q*R5>JW!Ve)GLQ{!LWD&lJmjN&jb4oVKID6
z0ip)gBYJSV!I{&q7&H`*6g{v&f&>oK^`H^~VLqrN09P47pu8UB3CgI(AR-1tfO9n{
zA-R?2<OG4TGC1#+L)Iuj+7%!>5lw_amUjzEOTf*8U!c4TT5Z9=$IK|k$ic|V#LOtb
z1j@&J%xsWm0w~9V8pq%q3-UB#rU+Di!Nb})F()TAMWHA&Jp*3RB*F*sGK&>*6H`)k
z6cXX%c#u8~I5k4XtPt@AojL+p4Q^o#p5OzurQ*S(&50$c;4qY6WMC);xs-tgUc#Y<
z7uuvLNbO+sRY6f|L1IxVq;n((_Z6bt231GkQ~>Hz)i8qk?4UljB)9+vw-=ik7=lZ{
zOB702KqYaJ5x4|q0+qnQB`geCtRQ|fBSSDE5!o;>FerGW=72`RN-`2lU_-W$!Vxrd
zi{2PP9bxv<0QK&`)3Wg{kl`nAbqTI^lXF0`cAy0S;9hW$Bd7{RL;#2du1vwi0M@9W
z&M>$}g*M}qK*0~{yD%{EF!D0-Gjg%OXR+bc=K@gI7QA$%gb^It8Vn^&pvb6U0@b56
z%nV}9%-|L|0|O*hQo!p-isC`BkOdw>$!23HipQ-jg_)s*4Wzo6ks+Inp|}~;c1IQ|
znuA9(D?>0ia*9F0?g^P@0Iy?HNK7s%P0Y!uRDg^D=a-h)LtEdV`5%Qu1*8>Ypt=t<
zAy%viDtl8CQ^3Q<DGK?eC3*@Ppn480kY8G2t6HoHj`q}|qP+ZKP)iOJo?xZLpfQt_
zOvp%La(-?>PHIUiM7yS+257_}2$W2~T|vm)3v>=6h#M5lAO#tT#o)GC21o$Z8jJ@w
z<1_Qp;~^G;+l0j>MM$d!KzSy$s0b`mT9gAe9^|I{(h^WHQkn`*d0=7ylOMQL1N8$^
zVf|b^Pyz&{N(N?rMoAVqMoCr`#$-@V;{|o@85kJALw6ZW;9&&hK?YD?j}bN;$Iej0
z4(doYGcYiMSm3fDo`s=O5R^{g#Q|e@o;A4BSi%lkQVHreHZd^PazI8SIKbUc4$uHa
z4KpYK)-W=Fmq0NyHZedtkgN<v^Fhfp3*3hUjTEvm^fECp<_UvExj-F8geb@*+zhpx
z3?)1u=@eGbWN|YyLy<0H4JT-z1Js}V!~p7NGBALwWCx7~A~I7ACup^1mH-2&_>*D;
zIY$sQ{8u8(kR<{t>%fD6x(JCHPS5}&s0~_~!cZv&vNTH+)Nw5lV`yeztmR?|&vR#B
zDG>)ZYx@})85t`DpsJb~7(nuc6Bt=aB*60BjNqUtkz~k{0u5!R@PTqaW8nnG2vExx
zDJ)B*K?|2a!Fdj%2NXG&!3k<1!^099CY+$D_GV^=T5g6C8HOxbh7|DdWfr8lE)R}A
z1z50hg9b^n6v3ntLo+7>W2GQNi87e40`@w@QK}3j;;;x#W@4=6VPFIquEvl88AMeF
zg?2L|Lk$mT9v>7q%#4g6Kh<zC1Z#kLg~g&w$W8auqO|;?Tm?isBOf%<1fJSZfQ<hm
zH+-S(@{+{t)I0^yV5mZVX%V~u18No$)6hqmWP+HI2c8MdFD*j04P;(1qH&A2pAH`0
zg%x9<`4Z&GUeKf`bd(f2g$12$M2r=HTF>BtT~J|(Hp2^^Ed$RYW~3?<C+4QY?I{B-
z;{|n7;9&qV2V@<zZ3b-+gPYe#!k{u&2V_$s%2Y6lDR?Vw*yJ-PqKe`3!V1Xq!6=3$
z=jS2jhATng3@t;UGYlYSgS+ZMxu7~C4@7`Em*9~(kYB)Ecp@thP_>a%nwFMY1X^$m
zD(>PzlNa%2#d)BGa>bxR5HxzJZ(j^r!L3?srLPYjhg48fEmi;{B?wgvS}Ej~m<ehZ
zm*j({W{Oi4paati8l^=!pb87r)d06%Kx@Y`^V0JDG(goskT=K^>7c3x<b-0-SSYx?
znVMV@6b_ODHC}>1YjlD@z6+8Bi4}m<gYpS9y~HPHl;&lprhxk=P%-exJ17caWqnW_
zNGo_`160?6TT0-uPw2Eje2Ay7tAA)n5NJplHZ%{70Ptu(D1=i>N(3Pbf}w-<Fa;nZ
z(^E@|po^BlQ34wJ0gobtR2D$iX@hz2h0#GEqrf&nDkV@Z1Fu7c)Xd;D-{5{%5U2|R
zS(OD2G|>7}h?Br8N5IUS)V%bPj37Bs(15Dr+~V{gP#gv&f<!=p8xLQ0Us{xdG}!<e
zZ~+?u>Urm<1cB2PDA>Wl2@6_KZxEC~ax#<Rp+Ov<T@H3GGz{YNld`}Q45>jCAUi>A
z2ZRpDVs3D(fCS^qQj3Z+^Yg$>hKz#2(Lex)Qf^{)D$IxWp!NZ%=gT0#4{Dw=@-Q<q
z3Nnf^$uqLEurZ1;2{Ust3$gJqg8G&GjFL>k%*<dmFC#Of03$!M45I|23?n<U5Ti6B
zKO+|tST`f6=P8Tmae%TSxW@sGSMWpzs0L#MHwYL&4GZYF53E_x%)pYx!Vs(hY9srh
zrwdT$wIH!111uY)1WNSkAOfCpz!8kpX`cY<EewJIx1cr#28Jo15C<hb2FU7VP*MhY
z6C6I}kjWm%To0&K0-kpa1_c&4)R;i?GYkyz3=EZK3>EsIHhWPNxPbv4+Xwa57#M4r
zK=pZ%4v5TR1+`-s3w0O@br{0K^F+YSvn+OS1EdHv?gpxs!M!+;L#VfC6g*@Do<@QU
zy?~3QI#4u4g9u{~0UBEY53L5pf?^2d0C0yIT#V-Dq{M@&-a#{F03O_(4vIYyP+DT)
zXJla#W@2XKWE5g#V-#f)fQ++%;u4fX!ST5g6rYR?koat7WGE5_Z3YMib?+EK?Wq`M
z&{Rz=Gibsa)U{&<x5vPJ?pg?&m7ypG)C%V*iUD=uve-ef3Y{U>0IOzY;3;YWDS?cj
z)-Zt#2DN-!K-mjAlg<Qck=3w(nvtNy!~)jI2_{)Vg4v)kRZs*JXMy?!po$oToikEF
zW2lfpNl+~hS{+nclml7Pl&FxK3R_VHZdQOAC6LikP$w}Hve^P;4zvN1nV$z8hXo0O
zFt|9?_XCg7fh!7d1z8MQ022gGE#S_g8Ys1Z^Ejvg2@(cz!N~}mszCW3QWk*6*ukYc
zSTRUq@N8w^fo$*rwcNlPFjj(+5~$K)VC83IVHRZ)VisT&Vw7j(WJ(5=)1XEPD5Zfr
zXkM%gpeRle1@~1Xz!3*qCIL!Kte}yBW+sMW4-g}Z1+=gMH0#F(N&}!62Q7_Ys$~Vw
zsd0fezJW@YOokd>hAcKvkE{f|IHQ&etbm=NXbRX04rprQDVhSF*JA+jLCY*);}I#M
z47Gfq{y{B2SOXWRUk6Hj=RnTQ;s%vIwcvFgp!FFH;Hf`G22c+Qq*DOYH>(u{^};~C
zI`9NxEe}K0d&bK9VB-Wp{UT6m7Xoty!PD5FZVn^JRv}Plt%i>wUKlJZ0`?XsL%ua*
zi6}!2cp-9%C_^(d15d3mLya&)Q3!ZeTnr=!>e}UjJH1)rAU<ThN(w7OjSy%)64YDd
z0C^#W6SUx?nVF?l1mw-)Ud9?ehCF7FRkfm^lDCEz)Wfm?g|P%fmLx-s2(*g@>I;d2
z`ad<SpkVH0WUdusC}C%)6=Vp{<78whkz&Y_2A9JhKpn*r8IUI+eL&E*q2~-NC9(`9
zattN%3?&K-C5j9sN}#@28l>#L#>7}F&H$Q21%)3ILyb6Ci882L*386EWXDvZ1QG-V
zo;X8ZIH;-ssgY+WQGuz+V*<HagrO*psYI0_g&(Y*iJ?}UAx|Aiy&O#aRHhOI(4y-a
zaZpDUq>KTS&a%|N;lRX@A_y`e1sqo?!VD$q3|ShW1dt-aAlb~sT+0eptqBrhtPy9Z
z6##eo!&5{VY6KaI|1j0?G30*$ky%<GHMM-;;Nk}-Nq&YRA!d+swL!53jlGB(K8E5<
z<`Nx-EM3qBPEbe-fRZR|0fZjZWuVjr&J&<zLG0jE!~xpm2^uDl0L5#HB&f4m!^_ai
z&JqmS-dQUFT11rJ$Xp}FkfjfHkR(HmBtua=3rNI(Aw`-2l+qV5r^qnWf;W1B=G<8s
z5aA)qP$R|w36EwbQ0@!Q(`H~PF$Bl@M`lJw#u`?JEF*@Zx6CyXAhjTWfyP1@K%C$R
zgdj+rF-Q=k0_0y4h7>uFPirJW2^^fRA)b|lmh>sSpwNbv0rH^n8&KlL<!cu9;1W}i
z`B`QRDGHz(1e9>3Kt^Plg9A~FA<KZFMhawGksB*XKE2HX^{E9z(RCJtr*QgI6XX&k
zpDKcU+ROwQMuK<~R-uvX%^ER=U=2{CvG^fB(hvmtDgwy30;pC4HA28W=K|O$MIK}o
z3$&8}?aOC^syxK%MbK1rafw1sYFTOyWVI`3L3VCpHfVwhKF*<|P@E6yH>>C5DCDK4
zrhu0CL3a98g4Tb+JI^3@6eX4`q@<Q4X66(l4R7ed7qr6_D=0wLEhp#a=H};t*H@OP
z7b_$dfF|#YG80R{i}XP&J;6gDWvO|Ysi39Aklqn!O=MXn@;st~f<jUye6gV(>Xz07
z_|8fN=)@*8SdeEmu{$yWx}X=_9ZrBu1%lkGkd&GMT9BPstdLq!keUoy2A!FP?7f77
zqST!H#1xRulGMBsTgciA1*92I*b-h)XNMTApb&=kcp>&@f`%uG^K(;E5-Syo^Yin-
zi(&Ii5$m2o;Zl?eiBZs8b9rJ>O0fcHOggb7GbuACvjnyX7u3>$jvGM&8Fk7TGztNq
zVS^}8(17k&Rd9C=(NPHS4+fE;Avy}FCCPf47{gIX`6-pChPot{B!ZJuY94sM0?32V
zs8Il^R?vW~W(SQMDS+m1L5nGnLkesu%vqofw5h4!bdQ*U4am>W(JRO=E{QKK$^n^!
zq8+w|1D3utky0%*FrZ^7XbwlL(ald&NG>fd$<Kw4wv^;66sP8aRtiJ5^D2ZErxxit
zrl;nWAlA5og4;7q7qk^d*Eg{wIRg@E3Z7{SATiKR&-@&?k)YM-pyjpTIq`y`d~o7N
zHLN5f6=}o=6vLodhnz}<qSS(%#N<?k#Joyy!&VoPc{7t?repdUx+D|T&(8UI;C0xb
z%?7Cod8M#cHB>Pu9uq;UUlfv3!7G12!zti`1SP~_V|8_qAyZ?$RK#*0l)e24-~|ET
zMW{#)1O;0FXcKip0w|ag5<u31Tu`Y1S(Xpl_)(OaoSIn%+KB=i3DQ#lYeF5w#Bd6D
zvJY&S9(d__0`lq#<N-s_&?{(=5XEQU%_J$Apus%Q3JlPm&0^3#4v>MFu=U9x_k%FR
zIiMj;@D3SRaF*nQ7HSk#f-Hco1Ov}vfeP-#5`|n)B!WhIicupUv;!kAAG-1$ZZkwD
z)bCZPMfsq>%1ec8dMPPF&iNoWfp>#IN-5Y1F{s<YyCa~xFH^wv49Feum;=qLgJK(L
zT?fd#%-r166i`u~Q>mxmm{Xh&UqlZMmPF99;dF&W1(ax4$j?(KN`)-DNAo14bbv@H
zz+x6sB!hNyf!ETZE>{DE1UNuJ+X~>d13c+r#J3J?>kDk_5p1^($UD&T0OmN<%;A})
z02*l2Q2;IH%1tcE1Z^IvRLDroOUX$^ct}A5x=$=QKP9zT!Pvl1N5R;@2sJW|4U9pe
z<{-jCQ%}Jav;hldtwM5sX<kV&Xh{#Kh6cr=f(v+GEGVx*;|nESg2&{ckq38)jzUR(
zK2pAddJeP~u&5*+-v7h!WI_VSo1hhhU}HfwmqKwVWCId-6A)yFNj{`E4sMn}3-n?I
zq`o#NJd^YDiZhErRii>`PBCahNlp%APo4s3E2A^gfgsR*JK(gb18R#XAn!Q?83t-8
zfYJxp#{4{mL}>d5yj&cdVxi6eRRO7)>3LvxA~#Z?Appu;`K3r32tlTUwj#mKHqZg@
z8Y{{K#UIE<ScMGL2r?hCBP>4;(b57L0(F3%f+r{+SAsTB!M4h2WacSAXJIrcnd`ue
zP*8Zl#@;a^6Esl+I!OZL4Uj@mJ_d=E<ST$@n{7dH4PO%lT2_+^IwAy|<xr9sST)$^
z2?-#BU^XTsz`O;C0`P=8czGhIS_TiTgVuEBA$FdE0t#s$26_1_xNVaOS)Bz6Y|wtD
z%zP}%Q<0l&7=DJPA@E8ukiScdazKkOA<bWKng;D(gBpRh5)9SP7%TT6o83UU5;DvV
z3QlNMl%k*kDx$&W!^}o)E`n1vXr=^gXKG$aW)XOU8Yq8&s}Yc6;e{To;Z>fIir7~L
z3OkHeCnyRNG!gB8XoD&<4P>EuQ7U-16SS#{zA_itN_9}HF%RS#1(b3<GQSj@9^hRA
zP{D^1Pzeb|dQd-u+QNAnnh6P@QXbiKg@lA6cwG)!!Vi)}qyrT5K+RaRC6kC&Q)Y<*
zXv!5-U8aI|>Xw3LOHs5ZB)~#3KD%5mJ+(wb9qN6M>p&h<*8!L1nxF;4aIMhd0Xh+b
zk*q+$tOK0}HiiTUs0|2?OmIuK6m;Z~0#v&~Nl{{6aat;3LKqZxsd>qey?6@#pdEDO
znZ>C@7zqlg;*!L?l*A&$MrDw3poz@Xyb@i=oD?W`=ISXxS1o~e@`1AgW|5JZR|0N)
zgHG^4^=AO|NFPu$qBu1*8$@U3DWqlQr0V8mW~YL+fo7CJZi4JD%ufSPn3oh)D&(X3
z7FMC@DTGuOK&wme&b{*dJoOTIa!N`C?*fJOnxL&la0tWW2IN~%y{lW0Ur?F@?mK3{
zVjq-4z=ol=48S|46=JlskP-u`XL0Xy11%5&cY{$J0PR^q9jFI0R}a*2f}NtI2bx?2
z&+z7CCMCeNgXa=p;Q^lSgH|fwnNhUV8Dt9@Sq4qcK;}q6<M^Ny76dwYBd7y3=LcG1
z1Fdc1Azd}_{04aJ8j-1jKuhb2L8A<Q`QVNLQlk^Pm>s_Jpjd)|fx$U34^%cnO#nqc
zxOUYm290$idRz*LN%=)3sVRCvprwi6HB#V767Vc#d~r!)a&}2kVsdIG$Pa$S;8QF>
zCwhU}FB+;vn$TsNP-{TL@kvGbpj8w}l?v*rMe5*5Y|ub8a!muC(nKz0z+nms7f>=r
z*|8K1+OY&0l&|Cijb>&+4rU3@Q)OT&VFV2+mVmeYm9T>5GSb+<<6x!?jJ2R4VMd0C
z6vPrs&_XTn95blg4g!sb2Z6#Vs0kE9pm>2yl!M#~p6LU-36?N|x<T_vpjjHw6u>|(
zu@?jF#{un(k59}?iAN5^xl9ZU#atjaGBPvsG4e8sFlOq5c2I(5VccCqf);`n^@1h<
zf}l-yP$a4rE9lxOs1}!i=AO}8l*QbjzyZa#E_j<gc;y_pw*`t<4bXNj$c901at1Av
z3j%K)1a0;L=bp^G5^%~50#B}h=U=9Pj08mncor5MBgy#%mEh_0(t?!4lGGq~kP`5O
zo-Bw3TI&!L4`LyfH-L`Df-Fx+0ZH_OauUR`km}qy2eOe6><ZBAc}`{$VrCGs-vVzM
z2m*yi5NO3j5GYK+%Midz({oevAg7uYR~84Afb0cL&=u#TrWSxF^n#K=4g$@9L)H<1
zyb5i%lz<La11-{r6(8}S!#zOft_3xNG=XNd!HXrp{j>P|ym**GaM=R3BR(y^C?3>v
zs0;!vaR7&3Qht68*n#P(C6EyiaN^A@hA0GUh8qd#(`bMugTQm6LG2)`!E;<QKrC=n
zf=Zj9sUYqW5CO{kL32T@c_0E*ZUupMB7#c^SRRSbE(cGoLVS=4-dZ0Isw6;Fbsl&D
z4x~`aNlna)Pp!x-3F-m`pCDu!3$&#HTtq>X_kg58F$6arRK|eQFgP;?EdnV3>4k+6
zJTSrj%}9j$J|4WV9Gq>z#K5hl3|h;;z_1TANe9{*!w?7Bw#m<^$i%}a$}Gkx%EZRa
z#>&sg!zj$c#=^$J&&15Y4B6hvq{PU^D8LMw73N{&WD{cMV&-RL1FwnTWaeTLU=m{D
zWfW&-V+5UGCdVkmD9R|rBn{eM!_3Fb#tPaN%Eltd#Ky$Q$jd0o$jQjV$jQjg#K{FR
zk)M&1iJ4J}k(ZH^nTwH)k(HT?iI-6rbRrrf4`{CrNG-D{qXcLV51J|gBvovTTugqD
zWCc1kDaZnpQotnyc<L0C^n=1cV&Igw0>lE9>p|drt^ndzf(XziSMVk$NR9_*Ch%G&
za6ShY1)#M|L8&0cpllxmS_1*edElZ2T*!bz8XVgQVgTbEw2~cEeiiF6Ffg!LfzMcC
z1d*Wd<yYn8<x%65<7DGx;pE{I<PYU!<`m)-1#jSGECE&5pjHXeK6+4h3=|}wqMiXX
z-wQs1sTR)>Oeq`;sq74?;2rNNOdxg&2WXWk0g{=aMG$lhE%Z<(ZqPIr=)^=G&{9|s
zgBLWj31aYp&QJsuU&Uu(%P@mMbN7kG@PQm~+X~U}0C^%o2Yea{*n7~XE%?X}=z%$z
zpk7RF0eF=hX#O7DKDWxvPq9iUF3w3%$OWIs1?lpFn`f{wLOmP@ZG!hzf<|Ux%M7)W
z6Z5nb%0S0*Rw^VTP6&mLWq~%zgO-&e9cBae1yWqVCM5`44L;cjbSOwZ=o}YlO`DdP
zm!4WwP?VWhk^ntZAt3=O2U_<4IwUXwa)M++0!RR~P6E`c&Ma2QFG@)*0yXSl?uQ@r
z30?dM9wNjvEVCFkaF&-3@p~rZ@K#V4I3+(X6&e*G8L0{h3E8QY;3Gmoqeuw}pfEz`
z7Nr&zLuC`=K?*=TaC{^rBtt~vQ!<M{N<iZm382V>tz`rG4SZHgP9^B%l@!nb15yk_
z2cb~6%7TX1)4)e2mE^;wh+qwQ@E~DvaZY@BQDQ+nWceX@)VZ`Ey(lpSGR6by@PH~4
z$W}E4h$=`YH8D>iIM@d&qzCo{xJ?XdK@@`*k|u*PB&ZPus++(oDL~a^31pihc+W)*
zY$g#jdCUfyCk34<!3mlat`TPF<z@g)_!oJCrtni3z^gAjLAx?)dBM}t+@NMI=rm6r
zFoOl840KEcD`=J)#9(8n0ndlWvoq9ymq^5OFw_Wu6?1~7y+LZYKnG4hPo)I!EO2%W
z3W*PL4Gi@Ra&^%FH<Uny66BN!P%#W{Fu>v(+?D{vBsi)OJWx!76+)x67+n8DIiNTO
z^FhH6TdD|ZKcS^S@R@Q@F{I?LAp$DU!Ru{6Wj1(~4P;L}xbfi!k_DaN0O>h_+b01a
zu|N>9A4D7g5eGrUArNr{L>vVX$3Vnk5CJ;S0c83>@5Kj)`&UqVT?$l)b4oDsGqN**
z>S;)+4<q6G#z5f+UjLO1YW0AV8FXt;I%qB(ba(?JC<#D!<THS_K|ohP!jEiV0~Oz(
z1rO|?;v2-^02SXL2512cJ9x^U3uIh8WYG@j;73qPz8KWr1Lp-$-#q}b8w^|+CnO;9
zQ9^<OXhIsTXN@&O!p#De2dTv+iAgz`#Tj4|OG@+dQgcAX0Jtp(Dw042HY6*8tPjE#
z*Wk#7$2BB<gL@;Oy*=O*3p(i-l%k2y9t27`;4UDfeGFRcI~WoTI3vfyHsgT;o{yP<
zp%|2J7})q3g+K>>Krt8SpjJ@60bx+z7Mymp;A;m#aSll@Owd#VI#&m@T?KrAFe7;R
zCP;5Fs2L8AE>}cUL81xd2xuvqnpgx{7yujk0Us*`8Wd9i6`eVmNpM5T!N)db=7QD^
zq!#5=f=7%%a|l+@DNY5@ig?he!s^8eo&i>%J<*8h_XDrX1NS39Q3^>eK_H(&N(@lf
z5j-dZb=n||#~@HkRvr{}pqOD`m4PhV1#!4Q12>=%j~k$<BKwRMo?>5cw1NjkK+E!C
zK<l1TSU{_AKr6u@tJIi5Ym7iCfd#Z=6vW^F9jBSi$xt){tet})3$BI(RHD=}fvYG6
z&~{DG+8;)6LBa$pMIc9WaDeslfJt8P2{6oHHXmpi5om`ecxh&_6Y{E197n-GlMa?P
z7pNovVQ`gPtO+_a9<&bvG@t=H6DAmGgbd|S7|?KtiHUJBs19)kpB)KJE1-l2Zi|8r
z7=thU0JRoCZ30MZ6I399#?|0W5<SSSZtyZvP>uoDS$^OxN#NsUkai=03K2*u1^0tQ
zKs6F*xG4xcm;tJV!TVDon>fIy7=h}mpc9~>Cs67D7f0YK7P3ncyyz2|56UXwE;z`h
z0k7jC85kJULCG9+t_1`1m>Ee%e(=#mpnfjs#BCl%A;hYFkSD<<RVbvE108b?KK%-G
z+BSH3Gb3nCGx#tF(5W)a48^9P`U<)x9klwA5w!ZWI1rTHv%ve=N;pAF3&HC{nHhq?
z8!(GO#>2}aXDV(_2M_WVuV!Fi2+aex$}>|ThmQusmc4+|Pf{u<oq~3~>nVT+uJh87
z`yLog^5T-B{JeC~me`cCOwhRq3c;zVR^W0Kw8IG2^aTxTmSm)+<R=&FW#;Rr=IMh5
z*NaQ^6I04Sr+ua9mKG<br|M;t<mM<B7w70gPbDaZu9XIlVwD!876t7AB}`BU6EeUC
zPMD`aF~SWQse$<nT(QDT0S`ohI6<HR?ZH^=f_!8TN{=81GO&m-3o-ICfleb~X7PjM
zS8U@Jpz&77xCJ;Iu#HxLGAOuE4~m3^93lgPSpzus0E)~9pq3_Rn-iM=Xw-p?i5WZs
z#0EZ#g^iI%h*OZ0gHr-L@D54_APnx>fPxHu@ICU@f*KZv0xi(a15nNcZz^wQ0&O_}
zZ7^p7FJkopEgJ_ddS(VKdahw)=w)OC?es?%N`dXlDQ<v`9JpterGj>AmKNpcfEI*+
zrWh0R5CaKlg9z|b1wji{GE0iViv{3)*i6t;28Be>0V72v$)(`aJi*hb8HwPtjzEo#
z#G>L<(5`WC3lwtIhYr{j9q>#zs8|IT7tn<gptWhxWmB+aZlEO$@F4(P?t{7sIyqTd
zl!KVVa)e&*0<L*LhxO&9gN{xuQOGSVE&&~h0zSnPR24y-r>6iux*0SI0A6&Jn1gC~
zjFuMiF_54IOsT~RiC9mAEXfD^I~nQpT&PDA5eq!Q{s+~#xO}MxS~v$fITh3ifGk?8
z1Ql~78JT(M#R{MqN4OcF1p)b`B|4y!nm~ug=s;V3#gJunkhO@e6^Wp|_*PaBF34^>
zJ3DZtu3!tMAT7^$@DM*}f1Wz1y<nxUpPrweo|CGVoS&<&t_imkq`3&HQx7`frlIcc
z8ltYFpbk@*3GP$w1!ZGUjSgvT27$MX2!jN{(-@#E6$I)&gWICuy<y;!=CaGdQyPc{
z0XXl2iGeEszypZT22N&v9z3)_$526Li$p+UyF84-h<X^*LIT&rAn$@2hTyGYpxs6`
z;HDgSn;nA71lsNaYF#pc8jLBRjUf!R4B)0BBj`*{&`}cMV2$9tV^As3%p7R9Wie=Y
z7#vFhMfu5~BWXPY%FIA%wFtz?$t+1NO3Z=m`~h$7i3XFg#UNLz8kvH5s^EiGqGQ3Q
zN(4;?RaT&$YieE!c;^qeM*v+~2_DY@WwC-FWl)rY8jq0b3KUb|7z8l}y!iy$qLc@!
zu0Wjv20l4PIYu5vent)OnS~&+`1rKalG38o`1l~uAVLuM^a;>xQ%-(*dS+gF5U3pz
zbOGeYY7haM;DyX~g4?N}y}{sq6ntf1F(^$i1c6#%kO?wS^aO!S1YZsl#0fG5WHb2W
ziy&~*6*LM4uJOTBWhJ1o{er~g?8NlcVm;76P%db-EV!Wx8p;Gus)3sgFh!6Jy`VvC
zn226+W`$mEepzZUWWH_|$X0OX12>q#^9bNd8PvCjOyPoeID>XN27!iCAag_@mw+dN
zz#|Zd3;;f54Lku2mVg!nL7<67a0eSI3YkTO><tEa87f>-R0)~k1bH4T1})1Vd!s>V
z4lG()lmjU>Kr{B>bOsJ;uv{VNj-wzIP#OhQv=Fa??pOg2w56w(_~fUjrxt<lo&fhA
zz*D1;BMKnX9-uoLz=E!h?v9>*;4Xk`xPPdRi<6JPvv&|^kO*8rL7H-xK_LiAPKb03
zW({DW1PUk{NRP@6lrF)C_z5ubKp>MCBM)-~zW^f$ny?8l3NV3K5G=zez|6zM&&0_h
SrYgiN`JdrGL$g>Brwjmd=3g`b

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/contrib/__init__.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/contrib/__init__.py
new file mode 100644
index 0000000..e69de29
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/contrib/__init__.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/contrib/__init__.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..f6cf36c0a8d8b1eab79a3146f70b9beb699a9297
GIT binary patch
literal 206
zcmZSn%**AGdLky70SXuy7#JKF7#NCK7#J8*7#M;zKq7t`AZawBxSWB3LBF6Vvn;VB
zRlh8;NIxw<CndG0SU)L6zdR`^FV{4;*vK%+JiRL2!qlQXC#%ZL00h$W^h5LuG7EGw
z^NLFnb8>Xu$~-)c13*Gx9AB22my%zkUs{xtlbK|!pPZjpQk0pbA0MBYmst`YuUAl6
W!ok46V3V7lQks)$2XbLC$bkTPOEm@n

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/contrib/_appengine_environ.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/contrib/_appengine_environ.py
new file mode 100644
index 0000000..f3e0094
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/contrib/_appengine_environ.py
@@ -0,0 +1,30 @@
+"""
+This module provides means to detect the App Engine environment.
+"""
+
+import os
+
+
+def is_appengine():
+    return (is_local_appengine() or
+            is_prod_appengine() or
+            is_prod_appengine_mvms())
+
+
+def is_appengine_sandbox():
+    return is_appengine() and not is_prod_appengine_mvms()
+
+
+def is_local_appengine():
+    return ('APPENGINE_RUNTIME' in os.environ and
+            'Development/' in os.environ['SERVER_SOFTWARE'])
+
+
+def is_prod_appengine():
+    return ('APPENGINE_RUNTIME' in os.environ and
+            'Google App Engine/' in os.environ['SERVER_SOFTWARE'] and
+            not is_prod_appengine_mvms())
+
+
+def is_prod_appengine_mvms():
+    return os.environ.get('GAE_VM', False) == 'true'
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/contrib/_appengine_environ.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/contrib/_appengine_environ.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..cdec88e97fe508061bfc5159e089e7ba74b5cfd4
GIT binary patch
literal 1838
zcmZSn%**AGdLky70ScHH7#JKF7#ND385kH+7#N}$7*ZG+QkWQW7#X4%8B&-TS{N9j
zm>5!6zzk-F6jm^Ug&~Cv%wT0mVFxqVK)Ql8I6#IuF)%Q2g=AzFE9B;<l;)%=6cpu`
zWu~MSE99mo<`pZH<SV44mZT<^D3oNRDmWGtD7faOXXd3Uq~?`n7Uk#VrskFCab^Dh
z|Np-q+^LKV3=AMw7E3ZPFqAMbG&3+1NHCNz!Wc{-Mz97*nV$wTNR1E!14CwUd`^CH
zVorQwK|w0mk`h6Pa6wUi3X-T8HqrRpvfN?~P*@>|;zkAr2K|Df%(BFiRQ<BVBK@@d
zoRrj}V*R8P{qm%wyj;`VVk5&O^Yp583sZ~ooUAG{0}x2h(+|-v$Sly!%quQQ%*oMp
zEA#L)4gd*(aeP^7UP^wEerZuoPG*v^esX?ZNl|8!KEjdl(D2bKs4U@uxEJm%aKN*H
zoXW__$jOKqY#?t#f-PSF8f-kU-~uIsAW)bEfmj+KQxL=;@vsP*hvSPA^HP%XEBHVu
z4&-bGgr`AX0jCuOP_kwOC6_ElhHN&5e0fkZEn#5D0w-?CY&M2q4HgCl20w7Ja101=
z^>g?1bBzxQ^$YRzbu9)3vrB4OYEFIuC{^m0@G~$l1iJ=>xdz1t`@4mNI|jLGfNU=T
z5&6X>><kPH&}c#gA(%Bd!Z8RGxuBd;4DvPuBR`f<(?Sn5O^i^>*JLOG=Qti{_yw_o
z;sIo^dwza;4sy2E4+5o2aGneT1y2wttq$Il76d9n#6i9RIU5v0!dSuxS_)+`GGsA<
z%FGgGhGr&EFl93_1cUwRR|3-S?&umH=34>^?2@9=RB&QLghB}@rKYErlz>9dEitD!
z6`WKM#2`sDpu{Z;3K9^5fl&h#jo_pnAD@z+93Kzy5y&$^AfJL088{pVZ#0*HQlU*Q
YxPr0+xg4C=*_e2kIoUW_I9WN_0Py(7Q2+n{

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/contrib/_securetransport/__init__.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/contrib/_securetransport/__init__.py
new file mode 100644
index 0000000..e69de29
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/contrib/_securetransport/__init__.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/contrib/_securetransport/__init__.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..b8b94a1bcd31cbf05472e074ceb9992aff79f29c
GIT binary patch
literal 223
zcmZSn%**AGdLky70SXuy7#JKF7#NCK7#J8*7#M;zKq7t`AZawBxPyU#LBF6Vvn;VB
zRlh8;NIxw<CndG0SU)L6zdR`^FV{4;*vK%+JiRL2!qlQXC#%ZL00h$W^h5LuG7EGw
z^NLFnb8>Xu$~-)c13*Gx9AB22my%zkUs{xtlbK|!pPZjpQk0pbA77lBTw0V`Qk0li
nT##Q>q8}fhnU`4-AFo$XS;E1<z+jV`pHiBWY6o(1G04RLrCmH3

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/contrib/_securetransport/bindings.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/contrib/_securetransport/bindings.py
new file mode 100644
index 0000000..bcf41c0
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/contrib/_securetransport/bindings.py
@@ -0,0 +1,593 @@
+"""
+This module uses ctypes to bind a whole bunch of functions and constants from
+SecureTransport. The goal here is to provide the low-level API to
+SecureTransport. These are essentially the C-level functions and constants, and
+they're pretty gross to work with.
+
+This code is a bastardised version of the code found in Will Bond's oscrypto
+library. An enormous debt is owed to him for blazing this trail for us. For
+that reason, this code should be considered to be covered both by urllib3's
+license and by oscrypto's:
+
+    Copyright (c) 2015-2016 Will Bond <will@wbond.net>
+
+    Permission is hereby granted, free of charge, to any person obtaining a
+    copy of this software and associated documentation files (the "Software"),
+    to deal in the Software without restriction, including without limitation
+    the rights to use, copy, modify, merge, publish, distribute, sublicense,
+    and/or sell copies of the Software, and to permit persons to whom the
+    Software is furnished to do so, subject to the following conditions:
+
+    The above copyright notice and this permission notice shall be included in
+    all copies or substantial portions of the Software.
+
+    THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
+    IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
+    FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
+    AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
+    LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
+    FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
+    DEALINGS IN THE SOFTWARE.
+"""
+from __future__ import absolute_import
+
+import platform
+from ctypes.util import find_library
+from ctypes import (
+    c_void_p, c_int32, c_char_p, c_size_t, c_byte, c_uint32, c_ulong, c_long,
+    c_bool
+)
+from ctypes import CDLL, POINTER, CFUNCTYPE
+
+
+security_path = find_library('Security')
+if not security_path:
+    raise ImportError('The library Security could not be found')
+
+
+core_foundation_path = find_library('CoreFoundation')
+if not core_foundation_path:
+    raise ImportError('The library CoreFoundation could not be found')
+
+
+version = platform.mac_ver()[0]
+version_info = tuple(map(int, version.split('.')))
+if version_info < (10, 8):
+    raise OSError(
+        'Only OS X 10.8 and newer are supported, not %s.%s' % (
+            version_info[0], version_info[1]
+        )
+    )
+
+Security = CDLL(security_path, use_errno=True)
+CoreFoundation = CDLL(core_foundation_path, use_errno=True)
+
+Boolean = c_bool
+CFIndex = c_long
+CFStringEncoding = c_uint32
+CFData = c_void_p
+CFString = c_void_p
+CFArray = c_void_p
+CFMutableArray = c_void_p
+CFDictionary = c_void_p
+CFError = c_void_p
+CFType = c_void_p
+CFTypeID = c_ulong
+
+CFTypeRef = POINTER(CFType)
+CFAllocatorRef = c_void_p
+
+OSStatus = c_int32
+
+CFDataRef = POINTER(CFData)
+CFStringRef = POINTER(CFString)
+CFArrayRef = POINTER(CFArray)
+CFMutableArrayRef = POINTER(CFMutableArray)
+CFDictionaryRef = POINTER(CFDictionary)
+CFArrayCallBacks = c_void_p
+CFDictionaryKeyCallBacks = c_void_p
+CFDictionaryValueCallBacks = c_void_p
+
+SecCertificateRef = POINTER(c_void_p)
+SecExternalFormat = c_uint32
+SecExternalItemType = c_uint32
+SecIdentityRef = POINTER(c_void_p)
+SecItemImportExportFlags = c_uint32
+SecItemImportExportKeyParameters = c_void_p
+SecKeychainRef = POINTER(c_void_p)
+SSLProtocol = c_uint32
+SSLCipherSuite = c_uint32
+SSLContextRef = POINTER(c_void_p)
+SecTrustRef = POINTER(c_void_p)
+SSLConnectionRef = c_uint32
+SecTrustResultType = c_uint32
+SecTrustOptionFlags = c_uint32
+SSLProtocolSide = c_uint32
+SSLConnectionType = c_uint32
+SSLSessionOption = c_uint32
+
+
+try:
+    Security.SecItemImport.argtypes = [
+        CFDataRef,
+        CFStringRef,
+        POINTER(SecExternalFormat),
+        POINTER(SecExternalItemType),
+        SecItemImportExportFlags,
+        POINTER(SecItemImportExportKeyParameters),
+        SecKeychainRef,
+        POINTER(CFArrayRef),
+    ]
+    Security.SecItemImport.restype = OSStatus
+
+    Security.SecCertificateGetTypeID.argtypes = []
+    Security.SecCertificateGetTypeID.restype = CFTypeID
+
+    Security.SecIdentityGetTypeID.argtypes = []
+    Security.SecIdentityGetTypeID.restype = CFTypeID
+
+    Security.SecKeyGetTypeID.argtypes = []
+    Security.SecKeyGetTypeID.restype = CFTypeID
+
+    Security.SecCertificateCreateWithData.argtypes = [
+        CFAllocatorRef,
+        CFDataRef
+    ]
+    Security.SecCertificateCreateWithData.restype = SecCertificateRef
+
+    Security.SecCertificateCopyData.argtypes = [
+        SecCertificateRef
+    ]
+    Security.SecCertificateCopyData.restype = CFDataRef
+
+    Security.SecCopyErrorMessageString.argtypes = [
+        OSStatus,
+        c_void_p
+    ]
+    Security.SecCopyErrorMessageString.restype = CFStringRef
+
+    Security.SecIdentityCreateWithCertificate.argtypes = [
+        CFTypeRef,
+        SecCertificateRef,
+        POINTER(SecIdentityRef)
+    ]
+    Security.SecIdentityCreateWithCertificate.restype = OSStatus
+
+    Security.SecKeychainCreate.argtypes = [
+        c_char_p,
+        c_uint32,
+        c_void_p,
+        Boolean,
+        c_void_p,
+        POINTER(SecKeychainRef)
+    ]
+    Security.SecKeychainCreate.restype = OSStatus
+
+    Security.SecKeychainDelete.argtypes = [
+        SecKeychainRef
+    ]
+    Security.SecKeychainDelete.restype = OSStatus
+
+    Security.SecPKCS12Import.argtypes = [
+        CFDataRef,
+        CFDictionaryRef,
+        POINTER(CFArrayRef)
+    ]
+    Security.SecPKCS12Import.restype = OSStatus
+
+    SSLReadFunc = CFUNCTYPE(OSStatus, SSLConnectionRef, c_void_p, POINTER(c_size_t))
+    SSLWriteFunc = CFUNCTYPE(OSStatus, SSLConnectionRef, POINTER(c_byte), POINTER(c_size_t))
+
+    Security.SSLSetIOFuncs.argtypes = [
+        SSLContextRef,
+        SSLReadFunc,
+        SSLWriteFunc
+    ]
+    Security.SSLSetIOFuncs.restype = OSStatus
+
+    Security.SSLSetPeerID.argtypes = [
+        SSLContextRef,
+        c_char_p,
+        c_size_t
+    ]
+    Security.SSLSetPeerID.restype = OSStatus
+
+    Security.SSLSetCertificate.argtypes = [
+        SSLContextRef,
+        CFArrayRef
+    ]
+    Security.SSLSetCertificate.restype = OSStatus
+
+    Security.SSLSetCertificateAuthorities.argtypes = [
+        SSLContextRef,
+        CFTypeRef,
+        Boolean
+    ]
+    Security.SSLSetCertificateAuthorities.restype = OSStatus
+
+    Security.SSLSetConnection.argtypes = [
+        SSLContextRef,
+        SSLConnectionRef
+    ]
+    Security.SSLSetConnection.restype = OSStatus
+
+    Security.SSLSetPeerDomainName.argtypes = [
+        SSLContextRef,
+        c_char_p,
+        c_size_t
+    ]
+    Security.SSLSetPeerDomainName.restype = OSStatus
+
+    Security.SSLHandshake.argtypes = [
+        SSLContextRef
+    ]
+    Security.SSLHandshake.restype = OSStatus
+
+    Security.SSLRead.argtypes = [
+        SSLContextRef,
+        c_char_p,
+        c_size_t,
+        POINTER(c_size_t)
+    ]
+    Security.SSLRead.restype = OSStatus
+
+    Security.SSLWrite.argtypes = [
+        SSLContextRef,
+        c_char_p,
+        c_size_t,
+        POINTER(c_size_t)
+    ]
+    Security.SSLWrite.restype = OSStatus
+
+    Security.SSLClose.argtypes = [
+        SSLContextRef
+    ]
+    Security.SSLClose.restype = OSStatus
+
+    Security.SSLGetNumberSupportedCiphers.argtypes = [
+        SSLContextRef,
+        POINTER(c_size_t)
+    ]
+    Security.SSLGetNumberSupportedCiphers.restype = OSStatus
+
+    Security.SSLGetSupportedCiphers.argtypes = [
+        SSLContextRef,
+        POINTER(SSLCipherSuite),
+        POINTER(c_size_t)
+    ]
+    Security.SSLGetSupportedCiphers.restype = OSStatus
+
+    Security.SSLSetEnabledCiphers.argtypes = [
+        SSLContextRef,
+        POINTER(SSLCipherSuite),
+        c_size_t
+    ]
+    Security.SSLSetEnabledCiphers.restype = OSStatus
+
+    Security.SSLGetNumberEnabledCiphers.argtype = [
+        SSLContextRef,
+        POINTER(c_size_t)
+    ]
+    Security.SSLGetNumberEnabledCiphers.restype = OSStatus
+
+    Security.SSLGetEnabledCiphers.argtypes = [
+        SSLContextRef,
+        POINTER(SSLCipherSuite),
+        POINTER(c_size_t)
+    ]
+    Security.SSLGetEnabledCiphers.restype = OSStatus
+
+    Security.SSLGetNegotiatedCipher.argtypes = [
+        SSLContextRef,
+        POINTER(SSLCipherSuite)
+    ]
+    Security.SSLGetNegotiatedCipher.restype = OSStatus
+
+    Security.SSLGetNegotiatedProtocolVersion.argtypes = [
+        SSLContextRef,
+        POINTER(SSLProtocol)
+    ]
+    Security.SSLGetNegotiatedProtocolVersion.restype = OSStatus
+
+    Security.SSLCopyPeerTrust.argtypes = [
+        SSLContextRef,
+        POINTER(SecTrustRef)
+    ]
+    Security.SSLCopyPeerTrust.restype = OSStatus
+
+    Security.SecTrustSetAnchorCertificates.argtypes = [
+        SecTrustRef,
+        CFArrayRef
+    ]
+    Security.SecTrustSetAnchorCertificates.restype = OSStatus
+
+    Security.SecTrustSetAnchorCertificatesOnly.argstypes = [
+        SecTrustRef,
+        Boolean
+    ]
+    Security.SecTrustSetAnchorCertificatesOnly.restype = OSStatus
+
+    Security.SecTrustEvaluate.argtypes = [
+        SecTrustRef,
+        POINTER(SecTrustResultType)
+    ]
+    Security.SecTrustEvaluate.restype = OSStatus
+
+    Security.SecTrustGetCertificateCount.argtypes = [
+        SecTrustRef
+    ]
+    Security.SecTrustGetCertificateCount.restype = CFIndex
+
+    Security.SecTrustGetCertificateAtIndex.argtypes = [
+        SecTrustRef,
+        CFIndex
+    ]
+    Security.SecTrustGetCertificateAtIndex.restype = SecCertificateRef
+
+    Security.SSLCreateContext.argtypes = [
+        CFAllocatorRef,
+        SSLProtocolSide,
+        SSLConnectionType
+    ]
+    Security.SSLCreateContext.restype = SSLContextRef
+
+    Security.SSLSetSessionOption.argtypes = [
+        SSLContextRef,
+        SSLSessionOption,
+        Boolean
+    ]
+    Security.SSLSetSessionOption.restype = OSStatus
+
+    Security.SSLSetProtocolVersionMin.argtypes = [
+        SSLContextRef,
+        SSLProtocol
+    ]
+    Security.SSLSetProtocolVersionMin.restype = OSStatus
+
+    Security.SSLSetProtocolVersionMax.argtypes = [
+        SSLContextRef,
+        SSLProtocol
+    ]
+    Security.SSLSetProtocolVersionMax.restype = OSStatus
+
+    Security.SecCopyErrorMessageString.argtypes = [
+        OSStatus,
+        c_void_p
+    ]
+    Security.SecCopyErrorMessageString.restype = CFStringRef
+
+    Security.SSLReadFunc = SSLReadFunc
+    Security.SSLWriteFunc = SSLWriteFunc
+    Security.SSLContextRef = SSLContextRef
+    Security.SSLProtocol = SSLProtocol
+    Security.SSLCipherSuite = SSLCipherSuite
+    Security.SecIdentityRef = SecIdentityRef
+    Security.SecKeychainRef = SecKeychainRef
+    Security.SecTrustRef = SecTrustRef
+    Security.SecTrustResultType = SecTrustResultType
+    Security.SecExternalFormat = SecExternalFormat
+    Security.OSStatus = OSStatus
+
+    Security.kSecImportExportPassphrase = CFStringRef.in_dll(
+        Security, 'kSecImportExportPassphrase'
+    )
+    Security.kSecImportItemIdentity = CFStringRef.in_dll(
+        Security, 'kSecImportItemIdentity'
+    )
+
+    # CoreFoundation time!
+    CoreFoundation.CFRetain.argtypes = [
+        CFTypeRef
+    ]
+    CoreFoundation.CFRetain.restype = CFTypeRef
+
+    CoreFoundation.CFRelease.argtypes = [
+        CFTypeRef
+    ]
+    CoreFoundation.CFRelease.restype = None
+
+    CoreFoundation.CFGetTypeID.argtypes = [
+        CFTypeRef
+    ]
+    CoreFoundation.CFGetTypeID.restype = CFTypeID
+
+    CoreFoundation.CFStringCreateWithCString.argtypes = [
+        CFAllocatorRef,
+        c_char_p,
+        CFStringEncoding
+    ]
+    CoreFoundation.CFStringCreateWithCString.restype = CFStringRef
+
+    CoreFoundation.CFStringGetCStringPtr.argtypes = [
+        CFStringRef,
+        CFStringEncoding
+    ]
+    CoreFoundation.CFStringGetCStringPtr.restype = c_char_p
+
+    CoreFoundation.CFStringGetCString.argtypes = [
+        CFStringRef,
+        c_char_p,
+        CFIndex,
+        CFStringEncoding
+    ]
+    CoreFoundation.CFStringGetCString.restype = c_bool
+
+    CoreFoundation.CFDataCreate.argtypes = [
+        CFAllocatorRef,
+        c_char_p,
+        CFIndex
+    ]
+    CoreFoundation.CFDataCreate.restype = CFDataRef
+
+    CoreFoundation.CFDataGetLength.argtypes = [
+        CFDataRef
+    ]
+    CoreFoundation.CFDataGetLength.restype = CFIndex
+
+    CoreFoundation.CFDataGetBytePtr.argtypes = [
+        CFDataRef
+    ]
+    CoreFoundation.CFDataGetBytePtr.restype = c_void_p
+
+    CoreFoundation.CFDictionaryCreate.argtypes = [
+        CFAllocatorRef,
+        POINTER(CFTypeRef),
+        POINTER(CFTypeRef),
+        CFIndex,
+        CFDictionaryKeyCallBacks,
+        CFDictionaryValueCallBacks
+    ]
+    CoreFoundation.CFDictionaryCreate.restype = CFDictionaryRef
+
+    CoreFoundation.CFDictionaryGetValue.argtypes = [
+        CFDictionaryRef,
+        CFTypeRef
+    ]
+    CoreFoundation.CFDictionaryGetValue.restype = CFTypeRef
+
+    CoreFoundation.CFArrayCreate.argtypes = [
+        CFAllocatorRef,
+        POINTER(CFTypeRef),
+        CFIndex,
+        CFArrayCallBacks,
+    ]
+    CoreFoundation.CFArrayCreate.restype = CFArrayRef
+
+    CoreFoundation.CFArrayCreateMutable.argtypes = [
+        CFAllocatorRef,
+        CFIndex,
+        CFArrayCallBacks
+    ]
+    CoreFoundation.CFArrayCreateMutable.restype = CFMutableArrayRef
+
+    CoreFoundation.CFArrayAppendValue.argtypes = [
+        CFMutableArrayRef,
+        c_void_p
+    ]
+    CoreFoundation.CFArrayAppendValue.restype = None
+
+    CoreFoundation.CFArrayGetCount.argtypes = [
+        CFArrayRef
+    ]
+    CoreFoundation.CFArrayGetCount.restype = CFIndex
+
+    CoreFoundation.CFArrayGetValueAtIndex.argtypes = [
+        CFArrayRef,
+        CFIndex
+    ]
+    CoreFoundation.CFArrayGetValueAtIndex.restype = c_void_p
+
+    CoreFoundation.kCFAllocatorDefault = CFAllocatorRef.in_dll(
+        CoreFoundation, 'kCFAllocatorDefault'
+    )
+    CoreFoundation.kCFTypeArrayCallBacks = c_void_p.in_dll(CoreFoundation, 'kCFTypeArrayCallBacks')
+    CoreFoundation.kCFTypeDictionaryKeyCallBacks = c_void_p.in_dll(
+        CoreFoundation, 'kCFTypeDictionaryKeyCallBacks'
+    )
+    CoreFoundation.kCFTypeDictionaryValueCallBacks = c_void_p.in_dll(
+        CoreFoundation, 'kCFTypeDictionaryValueCallBacks'
+    )
+
+    CoreFoundation.CFTypeRef = CFTypeRef
+    CoreFoundation.CFArrayRef = CFArrayRef
+    CoreFoundation.CFStringRef = CFStringRef
+    CoreFoundation.CFDictionaryRef = CFDictionaryRef
+
+except (AttributeError):
+    raise ImportError('Error initializing ctypes')
+
+
+class CFConst(object):
+    """
+    A class object that acts as essentially a namespace for CoreFoundation
+    constants.
+    """
+    kCFStringEncodingUTF8 = CFStringEncoding(0x08000100)
+
+
+class SecurityConst(object):
+    """
+    A class object that acts as essentially a namespace for Security constants.
+    """
+    kSSLSessionOptionBreakOnServerAuth = 0
+
+    kSSLProtocol2 = 1
+    kSSLProtocol3 = 2
+    kTLSProtocol1 = 4
+    kTLSProtocol11 = 7
+    kTLSProtocol12 = 8
+
+    kSSLClientSide = 1
+    kSSLStreamType = 0
+
+    kSecFormatPEMSequence = 10
+
+    kSecTrustResultInvalid = 0
+    kSecTrustResultProceed = 1
+    # This gap is present on purpose: this was kSecTrustResultConfirm, which
+    # is deprecated.
+    kSecTrustResultDeny = 3
+    kSecTrustResultUnspecified = 4
+    kSecTrustResultRecoverableTrustFailure = 5
+    kSecTrustResultFatalTrustFailure = 6
+    kSecTrustResultOtherError = 7
+
+    errSSLProtocol = -9800
+    errSSLWouldBlock = -9803
+    errSSLClosedGraceful = -9805
+    errSSLClosedNoNotify = -9816
+    errSSLClosedAbort = -9806
+
+    errSSLXCertChainInvalid = -9807
+    errSSLCrypto = -9809
+    errSSLInternal = -9810
+    errSSLCertExpired = -9814
+    errSSLCertNotYetValid = -9815
+    errSSLUnknownRootCert = -9812
+    errSSLNoRootCert = -9813
+    errSSLHostNameMismatch = -9843
+    errSSLPeerHandshakeFail = -9824
+    errSSLPeerUserCancelled = -9839
+    errSSLWeakPeerEphemeralDHKey = -9850
+    errSSLServerAuthCompleted = -9841
+    errSSLRecordOverflow = -9847
+
+    errSecVerifyFailed = -67808
+    errSecNoTrustSettings = -25263
+    errSecItemNotFound = -25300
+    errSecInvalidTrustSettings = -25262
+
+    # Cipher suites. We only pick the ones our default cipher string allows.
+    TLS_ECDHE_ECDSA_WITH_AES_256_GCM_SHA384 = 0xC02C
+    TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384 = 0xC030
+    TLS_ECDHE_ECDSA_WITH_AES_128_GCM_SHA256 = 0xC02B
+    TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256 = 0xC02F
+    TLS_DHE_DSS_WITH_AES_256_GCM_SHA384 = 0x00A3
+    TLS_DHE_RSA_WITH_AES_256_GCM_SHA384 = 0x009F
+    TLS_DHE_DSS_WITH_AES_128_GCM_SHA256 = 0x00A2
+    TLS_DHE_RSA_WITH_AES_128_GCM_SHA256 = 0x009E
+    TLS_ECDHE_ECDSA_WITH_AES_256_CBC_SHA384 = 0xC024
+    TLS_ECDHE_RSA_WITH_AES_256_CBC_SHA384 = 0xC028
+    TLS_ECDHE_ECDSA_WITH_AES_256_CBC_SHA = 0xC00A
+    TLS_ECDHE_RSA_WITH_AES_256_CBC_SHA = 0xC014
+    TLS_DHE_RSA_WITH_AES_256_CBC_SHA256 = 0x006B
+    TLS_DHE_DSS_WITH_AES_256_CBC_SHA256 = 0x006A
+    TLS_DHE_RSA_WITH_AES_256_CBC_SHA = 0x0039
+    TLS_DHE_DSS_WITH_AES_256_CBC_SHA = 0x0038
+    TLS_ECDHE_ECDSA_WITH_AES_128_CBC_SHA256 = 0xC023
+    TLS_ECDHE_RSA_WITH_AES_128_CBC_SHA256 = 0xC027
+    TLS_ECDHE_ECDSA_WITH_AES_128_CBC_SHA = 0xC009
+    TLS_ECDHE_RSA_WITH_AES_128_CBC_SHA = 0xC013
+    TLS_DHE_RSA_WITH_AES_128_CBC_SHA256 = 0x0067
+    TLS_DHE_DSS_WITH_AES_128_CBC_SHA256 = 0x0040
+    TLS_DHE_RSA_WITH_AES_128_CBC_SHA = 0x0033
+    TLS_DHE_DSS_WITH_AES_128_CBC_SHA = 0x0032
+    TLS_RSA_WITH_AES_256_GCM_SHA384 = 0x009D
+    TLS_RSA_WITH_AES_128_GCM_SHA256 = 0x009C
+    TLS_RSA_WITH_AES_256_CBC_SHA256 = 0x003D
+    TLS_RSA_WITH_AES_128_CBC_SHA256 = 0x003C
+    TLS_RSA_WITH_AES_256_CBC_SHA = 0x0035
+    TLS_RSA_WITH_AES_128_CBC_SHA = 0x002F
+    TLS_AES_128_GCM_SHA256 = 0x1301
+    TLS_AES_256_GCM_SHA384 = 0x1302
+    TLS_CHACHA20_POLY1305_SHA256 = 0x1303
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/contrib/_securetransport/bindings.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/contrib/_securetransport/bindings.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..48f5ba97f35ec52758665790d3244dbcfb00bb31
GIT binary patch
literal 12359
zcmZSn%**AGdLky70SY)77#JKJ7#NCOxfvKz7#N}$7*ZG+QkWQW7#VVz7^0XM7(sky
zh8$*wC}yx63quYILoO>r6e~oIl_7_XA(x#Yik%^sgCUB8A(xXOijyIiiy?}OA(xvW
zikl&qharlGA(xjSikBgmk0FYWA(x*aiXWn%4Xj^)AxeNDSCAn}kRexyAxemWF_o1e
zg`J_9ks(T$Ayt^6cs)a^2tx`7NTi98A&-Fpq<|B|jS^)@6=f*C09L>S5`ijUX2=p_
zXa;*pGD@5wRe~W^k|9-!Ayu3qOPV2t8>F<E2}DN8Fr>;bq{uL2GcXisGp5Qir0{`7
z7#So%68sF3X-o`a&5R6CqXj^2N)cd4m1AgTWQ>w$NEHA%0wJQnkjl>xrO1%V#}K8&
zkjldlrOc4Z&Jd*nCRM?t8kkfElNw-B6HIC`r1COEX)~k>GNfvOou>m9*JViMV2IKK
zi>rXe^}%daFxvpkRs*vQ!EALf+X&3o0JDw3=9qv<Q!r@;mW2egIoO>RVA2vv+zKpW
z4OVZ1ByI~9w*!;*Na7AiY)7!H6PR=clP+M=6->H;Nq2_IDvnfrhE#|bEI>{L`P~xC
zum+oE17_QT*@hr?ItN3lJVTZTL%b(LsveB(#gNVbW_yFhwP9?yxDS%J4?{d$+!smQ
z7bKpl%aE$ikj?})!4E8J4r6;Uq?$9NGlIGPU@3hV+Y9U%c9_Nhu&e=CHUMm_4oEM^
zcUE9uFoUH6!O9@M2m~wR1cgj0J431>DA+;jZNci<!0LmL)CYmp+rr!vj3gBdmeOZP
zHAV_Ih>amg%0j@(gupI$f>{U7NX;w^QK1Z}a4A8CRB)~Vxd*Nwj3L#5AvKgCHH;x0
zVt6=`;o)Gz9T-wM8B)1m3L=mcM8Fgn!U8Q4Nj4HDs{;xOsQFPy3Zh^NoM76ckz}J`
zvdFf_ASsA}DuBjjERs|#R0`s9xR=vez)=u~q%sb#%6KG|@lcge>k^Qp5};BDiy&z)
z5lKxVk{WwZdO#?KgnSZ`;v@{k@bFJYQkIOQ3>>G>G@rr{p9)SA@(fuiNNTX!n}%dy
z8oFYrf$2zU(vj5Ifjk0LlYyir14)e|lA25;HJM;Fjtr^r#FK?2n+20qgr$vahWH$q
zr?O$Pf()t7Nap7vnUD)r1C6gdu#^%w0pvlYQk7ta=YwS-r9?hhR+k~wl_Av)mh20_
z3LL=N3&08-7*gGl5_Tb20i+x#gekCtnO}q?TZAE7j3iqOmem90WoW=+7DS;SXT*cE
zZK^y&JR}#(GsHVEq}qX{>=;t*!3=wbR4XvUiXqh&%&=uhbp$gUK|u%7?#z&C0T!`<
z25-C`s65Xq0STrEGBkq|b9^b1pb$*3j3HGATzn}oWR-(`p~H|0VS6D-Re+>Yn88vN
zU=PA|Re_{ZwZT$VU@2X2fujr#c?E{7YOn$Wu!3r^0t1FrWpKbMFl5z$WjVpJH85FD
zhEyf68Wym4Em#ddjP1n$svy8>K!uV5LslJFfj(G49oP_kn5XK&Qc7T{dQ_<fuoOF3
zssSve3ofg5KnW6*yCDoEhE!9AR5ONjHn7S@ur6a5+Y4O6>%hFz1eS$_VH1X#N(`wc
z44^_xfg!6ItkMu{PBTm;L;)n6Tfhp8zzSNx3XEWhN`WD(6(kFdkyfy*A<WBdASqA)
zDllZVL8YKMMS&r!9V`p+bvsyAmjRSi6c|#3!Kp%lA-)4-5mZnFCfJE2C<+toLJ|~%
z33h{0PO1V!ybh>v05J?fX%ECO00)->L%cCVc%Cc+OKJ~8HWx#Y2sa}mBdC!n4hnlv
zLywUmB1M8BwU;4{ks(Erp@jj|nv9I<V@Q#LiAuvo`x#Q08G<!r85kIfE7=$rxI!{A
zixqP7Q%ZAE6-tX!ixrYfDhpDJ6-x3Ik}~sB6cQE6GxBp%6_QHxk~0+Y(-hK5^O8$4
z^Ye-o67y0NlJoP5OA_-+iWSm|@^iU@Q<F=JQbURo^NI`di%RqqLNZbn((@B@6f#na
zQWY}6<`xv?mu04;DwJfTD&*vs>*l1ErRFF&26!rz<YP6VI8`CBC{-b~xHvVhBr`E5
zrxL8!8LAV9i*!H^<SNNXtyC{cRVXM*Eh(u~NH5AS20NlWzbIRwJhLQ2j|&n8$@wW@
z2PP^cB^H+?7Nuksr=}>Br4|)u=I4Pt4stG7QCfa!UW!6yo<ewLPL6_8eqM@tu|j@v
za#3YLNj_IjW>QgNQKg=OW1d24UVc$-erd5nN@`LG$oKi>sVShK&B)AENXsu$NXkj9
z%FIhwC;`PnNl{{E4p_LfSWm$%zlf_OBe6uGC^fM-KTiju2JC?1jQrA^6osTzaPViQ
zq!vL;1q+mcc}e*t845|23Z+FkIhjeu>cw0+naQbnppeW<0ZG8zt6pry#igL2px~Te
zP+63jo>8Kpk*uj;WMF8jYh++(hVZ0<O?hTcjzf7;eqM@RUTTRQL|;H^QEp~2IFK@n
z!O@%q3g*PTlGGF(g|wp7R8Zh0XCxM-r|N+Go|spuP>@<w3<}kxlElnBPyi%?-H@DL
zPzh2E4vymdw32dAyo1tNVsUYPa%N&lYKlTiesXDUYF<eqC>1KCW#*(7D`<csM=2Pp
zLrGHyY+OmcLP~044k)TX@-S&|wC9(CLbkZ1C=;BTbrdr5l5<K^KyCr03XpV8W^N|L
z7KmvXsS4l#0;iwS;#3_4kb8ANxhFHNQb!>-73{@=(xjZs;tU;yluVHENu?#JIts-g
zL2v{>oR*lEqMu)+P@I~R12QEuwHV^>R0WtT!O0gCUIm~4E`bIa*zWR-{9I5D06Pn&
z9+bS&N{jL`i!&gpAthg-I3H|tR%&ty$Rto8q~+)2<d=iInVg@Ok_ie!SPB5;)x@Oy
zGElODrG>owlFZ~(P)>rRKd@sUu?>|f&PdG30i{Jq0H&rWWafb#1`<xrF93V32owO|
zf+909M*&ncfJ>14G>|voUe<%8s1OfVg<yZTkZ{K!R|U^tg@7RcFi#g(7X>B9U<J=$
zB^`xu&kzs)&=7@i$DklbzmP};e>Vk3zeojdPd^tO1=omxAlKkv1^*zhJ3M^@d^}xU
zbQC=OoP9!FJpJ4ioI*ns{QN@{d^~+ULtI@HLi`m#mO_p5bPWa>=<6Ef?BVDa;^^e*
z;~5eOi8nXT5I>OFZvH_EjtT*eK_Q;bp+1g53IU-(0sg_R3XXm*3V!~6o_=mYo__AG
zzOH^DdJ3L?3V!|yu3@fzAqv4Bjy^sh>%fk43=Q${4+6PW!P!3`GRV{2BSgW&-^ax@
zC|JSCRl&#8(aFbE0c@RLq=K`Lqo=Qqf{UZCqdUlzK??pM9<C67f|NpBsu1qs3K9m{
z>*%N8=p5qd?+5adv%g<RkfU>mjzWlkP>6y*RC~B*u&a)OV~}UCr=L66S#Cl8zB&q^
zAoh0yDf9GGaQ64}bA^}$3Vx6e5V7PR1m=eZyMk0B+~nfw=;P_<9t?5`D1>3rs>hWH
z8r;!fWME(@;b&lANK7iu&nYcQjnB*lr4B!c3=abXLt18DN<6es)c_3zm2faHFeJy9
z<!7eE7nHDrIhlDS#zs&HP*D?K0Ob^CR;9+5l(2zSB~_NBLd8oVIv~1BbMo`jp=ywr
zN%{FX8q6RUvM?|(IJ@}xfNcx#_w);K4JrY-#n~;?&p9MAz!hvPxc18|sVr7!U|;~{
zCaAL&U=j++;DS3ZzXX(F!1YK8AIR+dqEt6ftpYC7ignSnJEKTrGXxZldYN1d3=El|
z&?z=#U|{gi%c)fG4_1g!Ff`D!0B7O6)bi9Ka9vtlS^x@XP!SDsjcT!;YH=pW6tK5S
zi&NuMi;D8{OQaYW7_x&?lRd%F;#vXH6p&b4T#!+eSe#lSh9d1*lA7z80;;1+Docbx
zQqFFUIXU^si6!|(E~#mWr8y-fq7d<r%7RqKqN2n~=fs>Gr^Mv!;u27!B-_~yB;x`p
zl@p69y;G4?$RqS3RD>nwl%~Q>DVAhlU~nxe$}dvL%*zC|7Bay#ETmZjjzDKOXHcsJ
zKEBArz`)=H8ear?HkE-PiV-}@$i$Ee9!vy{?y)cg1#5uR6~{9$Fo3g&qe5~{VsWuT
zeiEd31y$9F$tA@KiNz=_l|+TS#N5>4g2d!haNUj?nP8*fjVL`ZH<N*pfkT58l<+{2
z86OWaAU?hX6ut5Bx!|^1d_34I@$o77$?@?e0-!|X7F<%4nV0UGmz)o($6z6iDjFK%
zW}yMjdvKz-gMooTzo00yEU_e2zbvsxKP^8eCAFwnKPg4OJSizJ*EF}-$S}z~y(-<p
z)S^5mtIEs(1k&^LL-Y$W3v@F<jli57UAHn1PvZcP5E#dorRJsN7wJPAA^OSrc_l@e
zN&4}{;AUb8teL0}YH4QXr5EcJR0c^fFfe>!WMC);WjZz%HpUWO1_lOL4nmDNP=W==
z+zv(t2IQDaVFZr^GciQ5fEv6}tPCkE3{h+hDXgF&;1o8{5O4|;Xb2djk_$A58^sM8
zIga814J=3Tf(CJ;_`tgO8B#bw1HUO;pn+eI2|}P@*(hO#6dr~s5r!0AhA2_cP;8VK
zLkd4blsH3*07H}nLy90nlq5rn5JQv{sKXE?&5$C(5GBKqBFYdY%a9_*5GBWuBF+#c
z&yXU)5TyWWyGJR48tqX^3@Or}q1Y4|&`@lOEJKtkLy8<jlo~^dJVTT^Ly7`Jlm<hJ
zB14oWLy8hZlomsZGH56^MTH?shap9kAxf7aMGZ6vo1)GTrO%L}!4PG@kfO;DWyp}C
z#Smr0kfO~HWz3MG!w_Y{kfO^FWy+AE#}H-4kfP5JWzLXdzz}7@kYdOXWyz3Y#1Li0
zkYdabWzCRc!VqP{kYdUZWy_Fa#t>!4kYdgdWzUde!4T!ZkYdRY<;aj?#SrDhkYddc
z<;;*`!w}`dkYdXa<;sv^#}MVlkYdje<<5}ez!2rZkmAS?<q67HPN2?6D5d!dmO{X7
zVsMuPmYYDOA}FO~f--O>C|PBK%6)K22`Mu{g?uI`!)1ahip(81|Nqb23L-Xxh!r4W
z6NuOdBG!Y5bs%CDh*$|C)_{oBAfgvUEC3M`K|~vf=m!y<AVT5$zyFzmbN~O()BzDe
zAVTK=14E_(h|mTR`XFL4$j$RX#3B$e4@9VdBs4$-7l;r65!oP#ED&J{A}m0JGDt!l
zL~w!#VGxlHl5hYK#vsB7M9c*db3lYGh_C?>rXWHeL@)|7Fk~`;2xegh1`RI;28JL|
z(HaCQB!i?ug_9DfG!72-2~I5rHUIq!K#fVKqSVA}|GePTqO#N?$I_AvaQ4j(4)zHs
z$}h=J&d)Kz5HW^`g!lx*)EI)R#cX5|EJ8*QRl&hN&N-Q>c_qP_DXDOw;F6-$#9UBi
z0x1ZCQ<L5Di*gf70$hEAQwvK|^O6zuS4dH5aY;~WacNG8XI@!iPG$<cYD1C=D9TSx
zO-+GRZNaI@NK!7Td6n?W5=lHXuecyJIWsLYHKjxi99}5ef>M+7%TkLHlX6nQn%ojI
zb4rU+OB67bx+Rt*=AbA7MF*&E1`9$Q?_ZLUS_H2Bz~PWuRD=}p;93GA6b@>KIOXIg
zXP1aDFfc#_opbVwQ&ZfF5|dNYN^>wI{PO+sOES|cO9at$I40#6m6V9XMI)S3i%Og`
z5;OB)VF_x-LG1u{l93$enOBlpl$V%;Y-(yziEBkcW>IPiIO?D}Q;SOc@=GF9OTxhM
z18PS=WJ2?@^YY8{g7WiAKsF<J(=Q(`2x_T7lzZeCm-r>-rut?U=O&gUXCS#eAT_nf
zBQY<fI3qDT6%-d}a-qekMb3$N$*DOxsVOBga36=KCT4^5x)x-l=B5@U=D2uxr&gAL
zA_!t9B0D(e=N9ComZYX2g)b--6s7o=r52^-<d>HSLCsA~4ofY{OsfPr1Su#|ll}6+
zQ68LHQj(dMUW}vx)B^L%F9EkD!O0P1eQGi^9#D0G8>v3Q@vhD;9<CrV*fAc|vX6Ik
z4URW5HH&w5_Kgqra5T0sDNzNrNa1RO@TkOVs-cku%v2*&Gkm6^sZ@sA4|1tXa4=4H
zBCEsaN@R5?=Hamy#XK~1czq2DOJ^r%BEu3%r3%#7IAaK^wgglXhv1GLm@;Hvqxc5N
zg`jvrR)-QgXzD<v6v$dotl%;aT$I5S;WDfQZ}@@28tMg*>+qySG?jS64@oV)@IzLH
z94;vSMN$NEA+kCYFQci$8GcCWaEBkVB2dQ&6v!y90>u_m9>%H$WC&CZ$mLkofXqP(
zf2?Xi<{+s76^&Tk162bqJ24a>83L|;K?*>H5l9@#k)Wa+CIxaER0>p1!R&SRaCG)?
zG%|<}@b`%{G&V2=Wj-TQvq9bSkz-(B_yg+sOkiMOU}I)uWMg7ughCLD3CstHLqtJh
z=qv~yLBiA^bRpzOVu5?Vkk&G&Q>p=SBcvG!>6WIImXsEy#>WSNx|QJ3kb<1VlC=Dy
z+!Aik;0t(GL9etVGbaet7Ke<sfCYm<&GH~n6FdmiHV*=|!-GKW@E}ktJqTo55NNC=
z2xL(Z$gm(#dm;$bEd)0l!M(}MlFImk#F7lKZP3vQ&?o@7noZ6xN{t5(w}1y&APPaI
z=O!k{m!%eg`_j;%{t}S=C8eNB8sw(j#DWqKotakxmMJdC$t)=WIRL6YJ~J;ZA8des
zFr?)L@<m8dX=)H?XeS6Xx&@YY%FoY9P0Rzco!vb1Qc^2|K<O166wYogi6x2PaC3(C
z<Dm+{gCyVvle3#|X$h#Q2oVCg!PyNl4gysVaRVs)AVVooGeHeuPZ#j$4n#aCH4SPi
ze24}l1PX5d;NX(PlG0+RYLLr7QlOxRIS#}J#fP&S*fAh3s9A{WM35-R`^c^Yi9tpy
zz#8G>HYK2bKe9rUfgez(16dMv%m>_d3{Fi3wf-{GGLsWaQbE>$92A_I>{<b7VM1E}
z;Kn<WD5%8*3L9`(fCjpt<5wU9Ku!V)frhn^#=qQh64Q&p<uVpY@6^hG#G=I9)RNSq
zVwj=csg=o~_Atm$P$(id%0Y=FIM~NIvmhh2D7ZAUBo&;fK|=X?C8-r9a82-@LmIe=
z3sI4m3ZB0JDFU?{QF|p|kAVi_V8W0-8pH#jm_c#~xbp-KvS1(Q{5+_+U=u*`h2GDD
zI5IUE6n>EG22N;+Md{#74Ni<jsl^};xDkySJ?^O`Ad@{^z}XWNjL=|5NPwM}n(Uog
zi4X&27gU3si&7IyQo}P#GC-*mTx*~y$S<e_OMx2WAgTO<N^lnOO)V}?OizW3j=^IS
z>I{UjNNEa|%wVwzQG_n)k_u|xg9o*PQ<DR{or4XHpaBGp`k>Ur6gSW;DkujB2m6E<
zWtOCZ1wcg_IG{^B{Xqi7;DQDs0_tCQx<G6L^|`@)9cXF?SEmqVNbUvozVnMROEOc7
zVF@NUwFD8jkgx}v1v1<vKQ}Qm57aY)*$VFpfnzf`*azfta5TeQ4dZ~jjxblar<VAY
z<|ctsGjxy{lDLZ@(G%?Bo>~$N8-IpLfx4j(AGqd$%D5Dm1SsnVgY`fRMUw`V;?P6~
z^N)LK37R5MivemzYI=SNcpedAehH{GgDwRdg$RR8{=xzeG(!psC~!9lJX#IQR>7$y
zj(N!$`9(;fUtFRH8Mg#0$Ew0VFQ*b*#wHe}gL4Wro}d}swJb5GG_fSL1T@+Lv&uac
zIpUr3OY=%loPsLvSOTtR;64E77H3Gg0x1c>(T_5M11^anQGpf^zL|M=BoiyZHCbj}
zd`eDE5U4N;0u?>rB;xEAlnR>a1^X7n$w>uGAAo8~zx=#ZaHZ|+hREok%nGY&AlVF*
z#hsy<71Z^I$%6a~5e_IR0{4V5Wx(kfQo}+FD*+WQ5CQkp5}(w(^pXs47{SGyDoauk
z1|lk1sD4mtMXrzB!J`tTkfIw}C!#2YRCeIthgRZHw}K@c3kp*6QoxlO)M;R0kl(-&
z3`)OHQ(-niV>Srnk|0ok1c4L<fkt7#wT@#6XsErkBo$oPfnx?TQvn`e4+6C{2XkW>
zoN8=x!E+sUpgdZv!^FVA#wftV!zjS$z#_xU!^p<S4<!W{<rsMwnHiZGrCEd+g<y?d
z)CMjS52!)S#KQ=K;HEW5l#z`QWEz5m@WAqnY|P9|Ad@*6IT@M3Sd@teWC{#3Gc)ot
z@i2ohgauM9%EZGAq9GW>gUB;8f^<tWDuQKUVh|ca!puPC!PsEkV4V;aL>y!~$Yn4Z
zn<zvMnS`i<kRWjg3qr!&0HYzIaFPiW78sa`jgcROSwZSx803Et8)g!M4-o;$fiTGZ
opzwu=!bp$^L>49j;(;)j53-F(6qF7?EM|y{c$s(^1(?M+0Oen7_W%F@

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/contrib/_securetransport/low_level.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/contrib/_securetransport/low_level.py
new file mode 100644
index 0000000..b13cd9e
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/contrib/_securetransport/low_level.py
@@ -0,0 +1,346 @@
+"""
+Low-level helpers for the SecureTransport bindings.
+
+These are Python functions that are not directly related to the high-level APIs
+but are necessary to get them to work. They include a whole bunch of low-level
+CoreFoundation messing about and memory management. The concerns in this module
+are almost entirely about trying to avoid memory leaks and providing
+appropriate and useful assistance to the higher-level code.
+"""
+import base64
+import ctypes
+import itertools
+import re
+import os
+import ssl
+import tempfile
+
+from .bindings import Security, CoreFoundation, CFConst
+
+
+# This regular expression is used to grab PEM data out of a PEM bundle.
+_PEM_CERTS_RE = re.compile(
+    b"-----BEGIN CERTIFICATE-----\n(.*?)\n-----END CERTIFICATE-----", re.DOTALL
+)
+
+
+def _cf_data_from_bytes(bytestring):
+    """
+    Given a bytestring, create a CFData object from it. This CFData object must
+    be CFReleased by the caller.
+    """
+    return CoreFoundation.CFDataCreate(
+        CoreFoundation.kCFAllocatorDefault, bytestring, len(bytestring)
+    )
+
+
+def _cf_dictionary_from_tuples(tuples):
+    """
+    Given a list of Python tuples, create an associated CFDictionary.
+    """
+    dictionary_size = len(tuples)
+
+    # We need to get the dictionary keys and values out in the same order.
+    keys = (t[0] for t in tuples)
+    values = (t[1] for t in tuples)
+    cf_keys = (CoreFoundation.CFTypeRef * dictionary_size)(*keys)
+    cf_values = (CoreFoundation.CFTypeRef * dictionary_size)(*values)
+
+    return CoreFoundation.CFDictionaryCreate(
+        CoreFoundation.kCFAllocatorDefault,
+        cf_keys,
+        cf_values,
+        dictionary_size,
+        CoreFoundation.kCFTypeDictionaryKeyCallBacks,
+        CoreFoundation.kCFTypeDictionaryValueCallBacks,
+    )
+
+
+def _cf_string_to_unicode(value):
+    """
+    Creates a Unicode string from a CFString object. Used entirely for error
+    reporting.
+
+    Yes, it annoys me quite a lot that this function is this complex.
+    """
+    value_as_void_p = ctypes.cast(value, ctypes.POINTER(ctypes.c_void_p))
+
+    string = CoreFoundation.CFStringGetCStringPtr(
+        value_as_void_p,
+        CFConst.kCFStringEncodingUTF8
+    )
+    if string is None:
+        buffer = ctypes.create_string_buffer(1024)
+        result = CoreFoundation.CFStringGetCString(
+            value_as_void_p,
+            buffer,
+            1024,
+            CFConst.kCFStringEncodingUTF8
+        )
+        if not result:
+            raise OSError('Error copying C string from CFStringRef')
+        string = buffer.value
+    if string is not None:
+        string = string.decode('utf-8')
+    return string
+
+
+def _assert_no_error(error, exception_class=None):
+    """
+    Checks the return code and throws an exception if there is an error to
+    report
+    """
+    if error == 0:
+        return
+
+    cf_error_string = Security.SecCopyErrorMessageString(error, None)
+    output = _cf_string_to_unicode(cf_error_string)
+    CoreFoundation.CFRelease(cf_error_string)
+
+    if output is None or output == u'':
+        output = u'OSStatus %s' % error
+
+    if exception_class is None:
+        exception_class = ssl.SSLError
+
+    raise exception_class(output)
+
+
+def _cert_array_from_pem(pem_bundle):
+    """
+    Given a bundle of certs in PEM format, turns them into a CFArray of certs
+    that can be used to validate a cert chain.
+    """
+    # Normalize the PEM bundle's line endings.
+    pem_bundle = pem_bundle.replace(b"\r\n", b"\n")
+
+    der_certs = [
+        base64.b64decode(match.group(1))
+        for match in _PEM_CERTS_RE.finditer(pem_bundle)
+    ]
+    if not der_certs:
+        raise ssl.SSLError("No root certificates specified")
+
+    cert_array = CoreFoundation.CFArrayCreateMutable(
+        CoreFoundation.kCFAllocatorDefault,
+        0,
+        ctypes.byref(CoreFoundation.kCFTypeArrayCallBacks)
+    )
+    if not cert_array:
+        raise ssl.SSLError("Unable to allocate memory!")
+
+    try:
+        for der_bytes in der_certs:
+            certdata = _cf_data_from_bytes(der_bytes)
+            if not certdata:
+                raise ssl.SSLError("Unable to allocate memory!")
+            cert = Security.SecCertificateCreateWithData(
+                CoreFoundation.kCFAllocatorDefault, certdata
+            )
+            CoreFoundation.CFRelease(certdata)
+            if not cert:
+                raise ssl.SSLError("Unable to build cert object!")
+
+            CoreFoundation.CFArrayAppendValue(cert_array, cert)
+            CoreFoundation.CFRelease(cert)
+    except Exception:
+        # We need to free the array before the exception bubbles further.
+        # We only want to do that if an error occurs: otherwise, the caller
+        # should free.
+        CoreFoundation.CFRelease(cert_array)
+
+    return cert_array
+
+
+def _is_cert(item):
+    """
+    Returns True if a given CFTypeRef is a certificate.
+    """
+    expected = Security.SecCertificateGetTypeID()
+    return CoreFoundation.CFGetTypeID(item) == expected
+
+
+def _is_identity(item):
+    """
+    Returns True if a given CFTypeRef is an identity.
+    """
+    expected = Security.SecIdentityGetTypeID()
+    return CoreFoundation.CFGetTypeID(item) == expected
+
+
+def _temporary_keychain():
+    """
+    This function creates a temporary Mac keychain that we can use to work with
+    credentials. This keychain uses a one-time password and a temporary file to
+    store the data. We expect to have one keychain per socket. The returned
+    SecKeychainRef must be freed by the caller, including calling
+    SecKeychainDelete.
+
+    Returns a tuple of the SecKeychainRef and the path to the temporary
+    directory that contains it.
+    """
+    # Unfortunately, SecKeychainCreate requires a path to a keychain. This
+    # means we cannot use mkstemp to use a generic temporary file. Instead,
+    # we're going to create a temporary directory and a filename to use there.
+    # This filename will be 8 random bytes expanded into base64. We also need
+    # some random bytes to password-protect the keychain we're creating, so we
+    # ask for 40 random bytes.
+    random_bytes = os.urandom(40)
+    filename = base64.b16encode(random_bytes[:8]).decode('utf-8')
+    password = base64.b16encode(random_bytes[8:])  # Must be valid UTF-8
+    tempdirectory = tempfile.mkdtemp()
+
+    keychain_path = os.path.join(tempdirectory, filename).encode('utf-8')
+
+    # We now want to create the keychain itself.
+    keychain = Security.SecKeychainRef()
+    status = Security.SecKeychainCreate(
+        keychain_path,
+        len(password),
+        password,
+        False,
+        None,
+        ctypes.byref(keychain)
+    )
+    _assert_no_error(status)
+
+    # Having created the keychain, we want to pass it off to the caller.
+    return keychain, tempdirectory
+
+
+def _load_items_from_file(keychain, path):
+    """
+    Given a single file, loads all the trust objects from it into arrays and
+    the keychain.
+    Returns a tuple of lists: the first list is a list of identities, the
+    second a list of certs.
+    """
+    certificates = []
+    identities = []
+    result_array = None
+
+    with open(path, 'rb') as f:
+        raw_filedata = f.read()
+
+    try:
+        filedata = CoreFoundation.CFDataCreate(
+            CoreFoundation.kCFAllocatorDefault,
+            raw_filedata,
+            len(raw_filedata)
+        )
+        result_array = CoreFoundation.CFArrayRef()
+        result = Security.SecItemImport(
+            filedata,  # cert data
+            None,  # Filename, leaving it out for now
+            None,  # What the type of the file is, we don't care
+            None,  # what's in the file, we don't care
+            0,  # import flags
+            None,  # key params, can include passphrase in the future
+            keychain,  # The keychain to insert into
+            ctypes.byref(result_array)  # Results
+        )
+        _assert_no_error(result)
+
+        # A CFArray is not very useful to us as an intermediary
+        # representation, so we are going to extract the objects we want
+        # and then free the array. We don't need to keep hold of keys: the
+        # keychain already has them!
+        result_count = CoreFoundation.CFArrayGetCount(result_array)
+        for index in range(result_count):
+            item = CoreFoundation.CFArrayGetValueAtIndex(
+                result_array, index
+            )
+            item = ctypes.cast(item, CoreFoundation.CFTypeRef)
+
+            if _is_cert(item):
+                CoreFoundation.CFRetain(item)
+                certificates.append(item)
+            elif _is_identity(item):
+                CoreFoundation.CFRetain(item)
+                identities.append(item)
+    finally:
+        if result_array:
+            CoreFoundation.CFRelease(result_array)
+
+        CoreFoundation.CFRelease(filedata)
+
+    return (identities, certificates)
+
+
+def _load_client_cert_chain(keychain, *paths):
+    """
+    Load certificates and maybe keys from a number of files. Has the end goal
+    of returning a CFArray containing one SecIdentityRef, and then zero or more
+    SecCertificateRef objects, suitable for use as a client certificate trust
+    chain.
+    """
+    # Ok, the strategy.
+    #
+    # This relies on knowing that macOS will not give you a SecIdentityRef
+    # unless you have imported a key into a keychain. This is a somewhat
+    # artificial limitation of macOS (for example, it doesn't necessarily
+    # affect iOS), but there is nothing inside Security.framework that lets you
+    # get a SecIdentityRef without having a key in a keychain.
+    #
+    # So the policy here is we take all the files and iterate them in order.
+    # Each one will use SecItemImport to have one or more objects loaded from
+    # it. We will also point at a keychain that macOS can use to work with the
+    # private key.
+    #
+    # Once we have all the objects, we'll check what we actually have. If we
+    # already have a SecIdentityRef in hand, fab: we'll use that. Otherwise,
+    # we'll take the first certificate (which we assume to be our leaf) and
+    # ask the keychain to give us a SecIdentityRef with that cert's associated
+    # key.
+    #
+    # We'll then return a CFArray containing the trust chain: one
+    # SecIdentityRef and then zero-or-more SecCertificateRef objects. The
+    # responsibility for freeing this CFArray will be with the caller. This
+    # CFArray must remain alive for the entire connection, so in practice it
+    # will be stored with a single SSLSocket, along with the reference to the
+    # keychain.
+    certificates = []
+    identities = []
+
+    # Filter out bad paths.
+    paths = (path for path in paths if path)
+
+    try:
+        for file_path in paths:
+            new_identities, new_certs = _load_items_from_file(
+                keychain, file_path
+            )
+            identities.extend(new_identities)
+            certificates.extend(new_certs)
+
+        # Ok, we have everything. The question is: do we have an identity? If
+        # not, we want to grab one from the first cert we have.
+        if not identities:
+            new_identity = Security.SecIdentityRef()
+            status = Security.SecIdentityCreateWithCertificate(
+                keychain,
+                certificates[0],
+                ctypes.byref(new_identity)
+            )
+            _assert_no_error(status)
+            identities.append(new_identity)
+
+            # We now want to release the original certificate, as we no longer
+            # need it.
+            CoreFoundation.CFRelease(certificates.pop(0))
+
+        # We now need to build a new CFArray that holds the trust chain.
+        trust_chain = CoreFoundation.CFArrayCreateMutable(
+            CoreFoundation.kCFAllocatorDefault,
+            0,
+            ctypes.byref(CoreFoundation.kCFTypeArrayCallBacks),
+        )
+        for item in itertools.chain(identities, certificates):
+            # ArrayAppendValue does a CFRetain on the item. That's fine,
+            # because the finally block will release our other refs to them.
+            CoreFoundation.CFArrayAppendValue(trust_chain, item)
+
+        return trust_chain
+    finally:
+        for obj in itertools.chain(identities, certificates):
+            CoreFoundation.CFRelease(obj)
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/contrib/_securetransport/low_level.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/contrib/_securetransport/low_level.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..d1079dbd1756979c617ea12e1a93c62468a18533
GIT binary patch
literal 10132
zcmZSn%**AGdLky70ScHI7#JKF7#ND*FfcHrFfc?hFr+Xtq%bk$Ffv3j!q`j<QA{v4
zGeZ<JjLpIj#R6lqGDNY$*lY|@Y%n%ELliqh3Nu3r3quYELoO#n6emM27ef>mLoPQ%
z6gLB7Dhopv4?_wo1Bk)P(9FaT#mA7s#?ZpR5XH}s!VYE#Fr;vR8G<0krEoH|Ffv35
zGo)~V1w|NAxWNojh7=w!LyRGX7t9c6NZ|uBBp6co!3;@|3BeiyAYU(IWMJU($uHN<
zNi9pwQOHQmDM&3UR!GY)QYgttRR~T^E-gw8DN4*MF32w`QAo<nOUcYjFV^GY3du+<
zPE|-ON>vD`EXl~vQ%Eb#OD@UG&ns3a$w({#%jD&kD5PW-r6!l;R4Npu<|LM+rYMx;
zgN@F}OwWMY>KNcz%#~CM)svc>T3no1R0&d;o>~G@oC{)?=NDz`DTHLCRw`uXCFhi;
zq$(sTlxO7Uq$(tp<|St+<fkd*z<k2xoL`jcmS38ek_d8>LT+ktab{k+LSj-r$ez3u
zh1}HK{Gv*Q+{C=Z^wiwcyb`e43d#9-$*Dzo#R{2u3MCnt#R|FkDWy57Tp*7o=H%uV
zmnfv>m1GvB=2SurD=Df3nOu^ukXV+V2{$+=H8HzbAu%sSp`a+gEE5!LT!{q*Mfn9q
znTaK-V42e5)U?tZg~a0G%;J*7yyR4nKSALR3Y^p;Xz(QGr=;p}W&Z#F|G!@*BLf42
z1}M>%a4;}1fa52#q_TvMfq?<l%O&g}AvfpzyyB8#YX$}eT@Y|`b@%jBaCQv}@pSWa
zb_{U^3F>lb=xNz&a)H^del8gD$sk)nm=$CuDBZ{~Fff!bFk~@;NhXFG28I%55ZTPg
z(9FybtN~J8T*kn_z@?y|px~ZamYS!KsE|}yl3H9+l$n>VqmW#b3JwPaXE&F`l0=34
zq^#8B5{0y){9J`haBO52qsir#7MFm{OG;I6b_+_)Nlh$HO;Jdy1SJxM<iwnu)FM5w
z0u2@h28JMzBT9HcZU$T747RaEn1O*I+u6-ACnrBSu_V99B{eOvG^eBl6skF?d0?lP
za4|42AY7{fDlNc7aVG-<gML9#W?5oMs(x8wk$zf!PD*M~v3^pDetA+-Uao0wv5{et
zd3sg4g{eh(PF9tf0SKh$>4)eSWESXV<`tJD=H%$Qm3ep?2Y`gYIKC`3FD1W7zqBYP
zCo{=dKRG|Iq$o2<KfV~82TNdiP(LTXJRY1|^$IG%eu+;`i%&@`NsI>tT|C&)(x5m3
z1pxyq8zVUO*cccXz$pSGQx1u}8U}`DMuu8&Dc8aPiai$)p9xexAn}<QN*Eckm>6mp
z8ANKB7<w2OYFUtln88A<U?GTF7KR!Yh8k9o4v<!e6dOY`8$&QS?G}5ZCyboT;u25>
zhL$BIr3E>u#fUVL2g)P)$)Jpr0!kB^;F2b>s1g#}U>`CuFff3kuo&b+Nd~ZgV);Sd
zt6>C{?2=)Oh2VlaSOcUq6BMO>;5Y^IOF)8p1|{G$0}%$P7+mpP%*nvOV3VGjms(L!
zWTyl2DahGu3}l4>$g4;p5Ckewf<QJ54e#qBysrUD+CiYw36keQo^W;xsVqnhN=+*f
zf|LO8L<1=Yf<XDBL>5vQfRwtx6?mssIw$7jI3*@$7njImQxTS!Q<@4_qXEiYC13)a
za7*|>jS0AM@x_@{sU;xmvQsOI!RpFD`isG3baGleSQzBy<g|E*%wUay5-A1-25^Cc
z@Ey3=f#g_KP?Si3@(l|QvjC$2qcEc|6B{ENBQqF6%OX%bfv_`3^%_W7l*I@te?V0V
z6SzuY1{F=sOrY#r!orXRDNEQGve-fGqgp108YWPKDw~6$s0*x~6V%)Sm0rvYAoX0J
zvZn@|-Af?4SU{y#4GTkY9YYB>sDx`~WN2b!$YWrrVFtCoYMH=nh_RduMJqs7WbuMp
zZXjb}vcVc4mlv;q6=0CGRIHGw5So_>s;Lzq^&6xfOH^=n3kKJB(CST3Arw?&!J81E
zhE{4(QGOA))+$N`wX!nv()GB&{76t4m|3Ebn3tDdS*(zos!&*(32Hki<m7`IMu{LI
zvl!m=Qpf}~zA}pylJj#5a#AZGrDG-o3j;&3Is*fPE665=<op6~i^UnmsW68IrKS~w
zyjWV2rfcD+0cu!)Q*3fcWkG5&I29)+7MFmNZh*h1Ux;fExG9nx4{H6y7eF$gC^*YO
zyzZV_;tXL0loSPl%BvEPbT-UJ*SzF>Q1d7>#LWV1zF&S`YKaH~0|TUq5Dy8__@vUb
zwA3PKZiX0$FdFP0|6s5WOF-@i=OeJoQ&K_k0*<#JP-X__POx-*VlmX!V1*ESz)YxJ
zpe$XKT3nh_GH5d-C@4W065{yylKl8mNJ0d)`HGc5d68X?36ukQn0OfZ;dzmViH(t;
zk%y6oQHU`a6e*zc2~>ZAb7cpl{!C$H$Yx?F5&-3wU{K}+=h74=XeI<T`ItZ%wHA`=
zSV4KFnUR4Jl=GMvvN;%vgF)FVg&Ay20w~MYFffSKGK2FPxSs{e!W9gVOj--ckBlHa
zknEYl!~o54(eNCXk(!(hO6RExMX4pFMR^LK=moc@OEQY`%R!B9h181V)B<qJKQj%~
zI4nv9<&DHV1#o6lD9H!sFGzj^Ga=1^Qc!S}ax*Y6_y-4<B$kvGE2tK0fa^t&ObMu2
z5uBRroL^80PHDcNu1b0;BryhoT3tb)A`p@XIKg=U+DZktE{ltEz<DJ&*axf~+)4$f
zR<N_c2@~$}_~e|#;$pB^a#}oC0W>FoQ)qr^NkQr0O_reEWqe|BacWUXd|p1p`4OP<
z9+a;cSa}#(n1mR47<ri_7<rj^7<rh$Ef`QW4$8dXH0aL=Zo_54dgP$mfPo>M0o>4J
z0#z5yj0`TZa^O0GnIVe>ROV-~LQCvsMus>hhC(F<NM%tR2TfxsET9AnDfvq{7_vAS
zKqMEa|6Rfjst7<_UXYq*W`<g3P*N<O1=Gt05{KxmoWM}g2}<uSv5larrGyXE=mk|3
zte~cE@i{DdO86PF1fcfSu!1uY8<;By(gMynYz)O5jF8-r!j7;F<R~GKTWZ)q+89B6
zK?V?qk%6&r2}5{zo*V;9i7-Pp7ekR3BO@bB1-Kq%%wuGTr~!4$KuNi{36_=M-LlfW
zl$=yh`#U+cs07^i4RG}ZjRNE*mgp#eG8s6-<tk+6f%>@$&TfuHMTwPg9pEek?)E1q
z<|!nlDwKk1xsrT^vc#Os6i7D@WVAwZMq*|jq*^Kl6*|0J#h_Lw7r0+rEXTmW;FqsZ
zl%HRs08*ZrmYJMbl3J`#T#%ZanU<NF0?wwzphie&USd)XxWk+X>Byx*yY!01G7Jn1
z2<fEK%$yXkanL$gQ3I3)!4*bPYC%q7a%u@Ls8ti->KhO083)G)xq`E48fdhmB((^f
z-;xrGQ_W0DK$$wp%mh-WfU|CTQGRJb5U73#(u8+9K{h}G3DQFFEiD1L7u@I!0+rcd
zy-AftscEp<5Yz?*2P?c?83f7?LEw@H<R?(clUh^)4HbyF;h7~Fpzd=JsD6jmjbK9@
z3kp*6Qo!w0u%lgJB_g=34DR0+q~^vafukPmnB2sY<P5Odl+>blQ1};vm4R6CiJ<s~
zOM*L@;4lJ7f;ykziW|fM1q1__7+hT^aDxKuD~Mkpz2$<`++0wpWC99gHX&waMnfhx
zMj>dMRTRu-X5?k$VPs<zVq|0FXW|91m;@L_8F^U*A*B{5A%ifu)B?9Kz#}8g4B(Q9
zi6M&_T3FS9t5fLUh%GD^27zm_Vug^R(o}`aG=)TkbntKqyaNNSy1*$I8ugG21g<?G
zsY4tx7UYab9qy?mp!DSF0;!9*!F3T_5YpoX)%ckuskz{YOsyzLO)g1I0Y@E}7-aDW
zD!Sq`i@{Mi8x&_C=QFVIK*l#f;Sa*3#Q~^|1TMRXi-SCc%oI@5y#zY$fD{9u3?H1D
z><N{Jhcr0&gIqwPb|B{kxq^xaHxL(;;s#?lgT~81;SBTYVwA83xf)a|fnoz3)?4BI
zw-iQDeO1fAPy$QxDNGCs&5WR$IR#t~)iR>U$%AT3CWaDLhAcJ)P;Oxccjed_vN*t1
z9V4i!%i@Gq=%7I-E`}^_uu4{j5-w0>UBkjq!V9W}n;Ai52_LA5St7uY1*=h;*%)fs
z7)pd-btPz2ikTq|-mKgV8UP0kQHFp9dtqbP(7{Pix2_~Lw;;a=G#>4nn5>YUS_!Vg
zAY<I+sS2R_uCy3j4}k`#70NS9GQcS+xhNH!77}xcK_knV#R$En#i<~Z^Yc=5OEPm)
z6$%oIi_7ziQowE4L<NM6X_?>}4s2d=Nq$i(s41%eDsJ@@!c!F>Sr#;AoRL_Ts*s<T
zim;;~wMd~jKRG)UJd&CUZ7QdxfXxa{P4<R*Bq%ja0W_=%s<hLJQqf0Kb)aMIpb>7+
z_-bZeI=TrisX3`7sn8xPEFUE*fCmIX4Fu45HkyT?QE`xPL1IY;$oU{P+}B|9A+rXc
z0eVQQB0sMrF%vW@UjixnGC?^f6O;&%JFB3PUGO+wK4fU6v?wtzB|kUF2$V*_HMgNz
zDyX-a8l(Uc0_g|Y3kqj&dmuME1;hteW+2Cb8Cm(6dEh1hR4XV8fCt=BeN`d|DTHAm
z3#p&MgHqt?)h#inI2F=I0M-9NW}uQl4^$F>@)LNN8sc2Y5H7e-201J*F*g;=fh7}g
zYX#&?cp!mAU`aC`>~N6RU?O107lXSqpkN!6wKFK{;z6DQ=QYrX7&xD;1{FS_W+8(h
zKcftzFe49>95bjgW@h9B4=FJ-3NdjpgFCRGf(u;Ff%IfEg1ZW}OrQ=!Ei<SC3o1Yu
zL45>JLB+(-FU(L2ZmMT7fr}J2hVT?7hQNp_7RC~AZvsTJg365&HV_G!*{Ed)O>}^U
zp&-NH;2uN`JIMSL@W44}rVrdX0Toc(&^|#k2SY6fLkSN<4F{-<1Y5uhm8<1ssOV(?
zbssoEaxSs;47FTfOZY)5YPdk9U@bSez!PAo;RZ_y!UTmtBF&5pMLb|bg`r%=8YYG;
z5g4a%8$*dGlvA_~Yyd(bGpfSEZ4BX{fT&?%C<+FfDF$)|sB@ABp5)0AW2gc5Oc+63
ziW(+JVG62@i%-FtG_Z~ZXwEGsRRNTYbrf>)6H|&65_59ErC3Q(DQL(aJn2&m87<2!
zf%Y#zZB0-&9#UF?N(Wd{hU9)Mr3`2Sq1Xy+a$06laft#*0Mc**v+~nmb$2FcP^}~*
z6<p2~rzYp;r6?pql;@{`TUo^rTfikrQIa3H&!GWoVu5onxJ<||NX-K?ic%9(Aay)w
z>;%%h2lZgVEoW#CASg8r(o6$&GeC`mlGI#JP_0q|?g=1D0&r&^stGi-m0y}y0xmm>
z67$kiOT@s9IB@IUJ+%bfw0A7=%u7kF2m(n3ae+z{cUZv&njixen&8}@2<{C8d4g1c
zdI}n#%n}p@;`)O$fViO6JG6lbY4}510GX-9kkSb}5C&;IgQrQ-Ai{~|@t_C>RZHM<
z3dRXiftd^$LW@s^`zI6ZXi!^d&=yFbGCCfVWaB|i<YGv70pzvIpyI^?R0*(yMz-0Q
zgcyaGm>EHAW=4J{NZ|w-?}m^<Ok8aIjKYj;j66)DOgxOdi~^vM4@L<lHbwy^K1d$|
z6ak>oMo{z>d!rX#jG&488b${2{2U`g)nA4RTTn^n5^D+`djJoV)UbdGg%~DKu~y3l
zYC(Yp)mcG>3b;66gqC8Ag=!4pHOvgfhoP-8P}7SY%w_>~R6s-PObn8cW*H=_gN8yl
z7)sb-<riqkoC8)2lyEX+ae-Q2S+H?+SYg2lYNCOpc|qkP#6S?259B70nVbw2S`3g;
zks4-@5zR~tF0o?Z0+18jh~s2{6o8C{zZk-6I2nS&Q<xbl)G;*)Gl0rSh*P*h<}()R
zGloZ`fJQyQh0`Bc;pCH_2pJE6C3bMTD>tz+3EX~y7DkB*d8N5YsYReB3@F-*^%Oi3
z!J{Awsd*_1>G_E{;1VQ14cfK>HIYE${owowT1NoNd>}zky9|`;!Og*v%AnLV9k7ih
z8L4>+RjEb!3i(9}x%owq5(%}F4{Dx4CdP|(6pBkT!Gj2(ff>*Ui$Wr(8JV1unVN?(
zUZMalTfwdaSE7*O3_QRF>VtqVc#;$}URlGy5Gx4kr`9ks6fuL+6l9u|0Xm0|F+T_@
zE(U9+MV%fsVq{<d4>GYafQxWH4bVhjP(G+s0%f(-ijvg46iCSon&v=_qY_XH5lINr
zoC6KFAoa4*%I}~wP=N{>(1HxdfU1Oo{DL4;kT56_2AP8_2em{qLE}pK`8mbl@*Nya
zL6)G#AP-0_s9*+5fZB4!LFpi|4476>YJ@cMK(5Y9EssYks6l3fgg}Kkq}T@Wpb9F3
zK%?j-phglniNr(f1(n0#@#*}etic+!C7}8jQXWGRJa`-c;sHKTM1z{s3<_+FY|H{o
zpb;BT!;qIzkcACAcEilb4r(Ye^0G)WLrQ8<CP`)yCJrV^Mh(z#BDnb<AD@z+93Kzv
zFF>NU1Qh6?3{#XE<OPZaQ1}G-f<!?rY}k4za3X><13-$whJohbGILVF)vt?xh@+2B
zkO9a9P-{O3G+Y3gDgb4|AW%0T$O$A1D*qwXbPR|KN~}S(pmYJMa6pz1%GNt5ENmbv
srR+c{uo&c0P{@Pkm!OzQhJ}rhpM{f)Q;buVN0d{KlY^6kQ-jkQ00yiCRR910

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/contrib/appengine.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/contrib/appengine.py
new file mode 100644
index 0000000..9b42952
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/contrib/appengine.py
@@ -0,0 +1,289 @@
+"""
+This module provides a pool manager that uses Google App Engine's
+`URLFetch Service <https://cloud.google.com/appengine/docs/python/urlfetch>`_.
+
+Example usage::
+
+    from pip._vendor.urllib3 import PoolManager
+    from pip._vendor.urllib3.contrib.appengine import AppEngineManager, is_appengine_sandbox
+
+    if is_appengine_sandbox():
+        # AppEngineManager uses AppEngine's URLFetch API behind the scenes
+        http = AppEngineManager()
+    else:
+        # PoolManager uses a socket-level API behind the scenes
+        http = PoolManager()
+
+    r = http.request('GET', 'https://google.com/')
+
+There are `limitations <https://cloud.google.com/appengine/docs/python/\
+urlfetch/#Python_Quotas_and_limits>`_ to the URLFetch service and it may not be
+the best choice for your application. There are three options for using
+urllib3 on Google App Engine:
+
+1. You can use :class:`AppEngineManager` with URLFetch. URLFetch is
+   cost-effective in many circumstances as long as your usage is within the
+   limitations.
+2. You can use a normal :class:`~urllib3.PoolManager` by enabling sockets.
+   Sockets also have `limitations and restrictions
+   <https://cloud.google.com/appengine/docs/python/sockets/\
+   #limitations-and-restrictions>`_ and have a lower free quota than URLFetch.
+   To use sockets, be sure to specify the following in your ``app.yaml``::
+
+        env_variables:
+            GAE_USE_SOCKETS_HTTPLIB : 'true'
+
+3. If you are using `App Engine Flexible
+<https://cloud.google.com/appengine/docs/flexible/>`_, you can use the standard
+:class:`PoolManager` without any configuration or special environment variables.
+"""
+
+from __future__ import absolute_import
+import io
+import logging
+import warnings
+from ..packages.six.moves.urllib.parse import urljoin
+
+from ..exceptions import (
+    HTTPError,
+    HTTPWarning,
+    MaxRetryError,
+    ProtocolError,
+    TimeoutError,
+    SSLError
+)
+
+from ..request import RequestMethods
+from ..response import HTTPResponse
+from ..util.timeout import Timeout
+from ..util.retry import Retry
+from . import _appengine_environ
+
+try:
+    from google.appengine.api import urlfetch
+except ImportError:
+    urlfetch = None
+
+
+log = logging.getLogger(__name__)
+
+
+class AppEnginePlatformWarning(HTTPWarning):
+    pass
+
+
+class AppEnginePlatformError(HTTPError):
+    pass
+
+
+class AppEngineManager(RequestMethods):
+    """
+    Connection manager for Google App Engine sandbox applications.
+
+    This manager uses the URLFetch service directly instead of using the
+    emulated httplib, and is subject to URLFetch limitations as described in
+    the App Engine documentation `here
+    <https://cloud.google.com/appengine/docs/python/urlfetch>`_.
+
+    Notably it will raise an :class:`AppEnginePlatformError` if:
+        * URLFetch is not available.
+        * If you attempt to use this on App Engine Flexible, as full socket
+          support is available.
+        * If a request size is more than 10 megabytes.
+        * If a response size is more than 32 megabtyes.
+        * If you use an unsupported request method such as OPTIONS.
+
+    Beyond those cases, it will raise normal urllib3 errors.
+    """
+
+    def __init__(self, headers=None, retries=None, validate_certificate=True,
+                 urlfetch_retries=True):
+        if not urlfetch:
+            raise AppEnginePlatformError(
+                "URLFetch is not available in this environment.")
+
+        if is_prod_appengine_mvms():
+            raise AppEnginePlatformError(
+                "Use normal urllib3.PoolManager instead of AppEngineManager"
+                "on Managed VMs, as using URLFetch is not necessary in "
+                "this environment.")
+
+        warnings.warn(
+            "urllib3 is using URLFetch on Google App Engine sandbox instead "
+            "of sockets. To use sockets directly instead of URLFetch see "
+            "https://urllib3.readthedocs.io/en/latest/reference/urllib3.contrib.html.",
+            AppEnginePlatformWarning)
+
+        RequestMethods.__init__(self, headers)
+        self.validate_certificate = validate_certificate
+        self.urlfetch_retries = urlfetch_retries
+
+        self.retries = retries or Retry.DEFAULT
+
+    def __enter__(self):
+        return self
+
+    def __exit__(self, exc_type, exc_val, exc_tb):
+        # Return False to re-raise any potential exceptions
+        return False
+
+    def urlopen(self, method, url, body=None, headers=None,
+                retries=None, redirect=True, timeout=Timeout.DEFAULT_TIMEOUT,
+                **response_kw):
+
+        retries = self._get_retries(retries, redirect)
+
+        try:
+            follow_redirects = (
+                    redirect and
+                    retries.redirect != 0 and
+                    retries.total)
+            response = urlfetch.fetch(
+                url,
+                payload=body,
+                method=method,
+                headers=headers or {},
+                allow_truncated=False,
+                follow_redirects=self.urlfetch_retries and follow_redirects,
+                deadline=self._get_absolute_timeout(timeout),
+                validate_certificate=self.validate_certificate,
+            )
+        except urlfetch.DeadlineExceededError as e:
+            raise TimeoutError(self, e)
+
+        except urlfetch.InvalidURLError as e:
+            if 'too large' in str(e):
+                raise AppEnginePlatformError(
+                    "URLFetch request too large, URLFetch only "
+                    "supports requests up to 10mb in size.", e)
+            raise ProtocolError(e)
+
+        except urlfetch.DownloadError as e:
+            if 'Too many redirects' in str(e):
+                raise MaxRetryError(self, url, reason=e)
+            raise ProtocolError(e)
+
+        except urlfetch.ResponseTooLargeError as e:
+            raise AppEnginePlatformError(
+                "URLFetch response too large, URLFetch only supports"
+                "responses up to 32mb in size.", e)
+
+        except urlfetch.SSLCertificateError as e:
+            raise SSLError(e)
+
+        except urlfetch.InvalidMethodError as e:
+            raise AppEnginePlatformError(
+                "URLFetch does not support method: %s" % method, e)
+
+        http_response = self._urlfetch_response_to_http_response(
+            response, retries=retries, **response_kw)
+
+        # Handle redirect?
+        redirect_location = redirect and http_response.get_redirect_location()
+        if redirect_location:
+            # Check for redirect response
+            if (self.urlfetch_retries and retries.raise_on_redirect):
+                raise MaxRetryError(self, url, "too many redirects")
+            else:
+                if http_response.status == 303:
+                    method = 'GET'
+
+                try:
+                    retries = retries.increment(method, url, response=http_response, _pool=self)
+                except MaxRetryError:
+                    if retries.raise_on_redirect:
+                        raise MaxRetryError(self, url, "too many redirects")
+                    return http_response
+
+                retries.sleep_for_retry(http_response)
+                log.debug("Redirecting %s -> %s", url, redirect_location)
+                redirect_url = urljoin(url, redirect_location)
+                return self.urlopen(
+                    method, redirect_url, body, headers,
+                    retries=retries, redirect=redirect,
+                    timeout=timeout, **response_kw)
+
+        # Check if we should retry the HTTP response.
+        has_retry_after = bool(http_response.getheader('Retry-After'))
+        if retries.is_retry(method, http_response.status, has_retry_after):
+            retries = retries.increment(
+                method, url, response=http_response, _pool=self)
+            log.debug("Retry: %s", url)
+            retries.sleep(http_response)
+            return self.urlopen(
+                method, url,
+                body=body, headers=headers,
+                retries=retries, redirect=redirect,
+                timeout=timeout, **response_kw)
+
+        return http_response
+
+    def _urlfetch_response_to_http_response(self, urlfetch_resp, **response_kw):
+
+        if is_prod_appengine():
+            # Production GAE handles deflate encoding automatically, but does
+            # not remove the encoding header.
+            content_encoding = urlfetch_resp.headers.get('content-encoding')
+
+            if content_encoding == 'deflate':
+                del urlfetch_resp.headers['content-encoding']
+
+        transfer_encoding = urlfetch_resp.headers.get('transfer-encoding')
+        # We have a full response's content,
+        # so let's make sure we don't report ourselves as chunked data.
+        if transfer_encoding == 'chunked':
+            encodings = transfer_encoding.split(",")
+            encodings.remove('chunked')
+            urlfetch_resp.headers['transfer-encoding'] = ','.join(encodings)
+
+        original_response = HTTPResponse(
+            # In order for decoding to work, we must present the content as
+            # a file-like object.
+            body=io.BytesIO(urlfetch_resp.content),
+            msg=urlfetch_resp.header_msg,
+            headers=urlfetch_resp.headers,
+            status=urlfetch_resp.status_code,
+            **response_kw
+        )
+
+        return HTTPResponse(
+            body=io.BytesIO(urlfetch_resp.content),
+            headers=urlfetch_resp.headers,
+            status=urlfetch_resp.status_code,
+            original_response=original_response,
+            **response_kw
+        )
+
+    def _get_absolute_timeout(self, timeout):
+        if timeout is Timeout.DEFAULT_TIMEOUT:
+            return None  # Defer to URLFetch's default.
+        if isinstance(timeout, Timeout):
+            if timeout._read is not None or timeout._connect is not None:
+                warnings.warn(
+                    "URLFetch does not support granular timeout settings, "
+                    "reverting to total or default URLFetch timeout.",
+                    AppEnginePlatformWarning)
+            return timeout.total
+        return timeout
+
+    def _get_retries(self, retries, redirect):
+        if not isinstance(retries, Retry):
+            retries = Retry.from_int(
+                retries, redirect=redirect, default=self.retries)
+
+        if retries.connect or retries.read or retries.redirect:
+            warnings.warn(
+                "URLFetch only supports total retries and does not "
+                "recognize connect, read, or redirect retry parameters.",
+                AppEnginePlatformWarning)
+
+        return retries
+
+
+# Alias methods from _appengine_environ to maintain public API interface.
+
+is_appengine = _appengine_environ.is_appengine
+is_appengine_sandbox = _appengine_environ.is_appengine_sandbox
+is_local_appengine = _appengine_environ.is_local_appengine
+is_prod_appengine = _appengine_environ.is_prod_appengine
+is_prod_appengine_mvms = _appengine_environ.is_prod_appengine_mvms
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/contrib/appengine.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/contrib/appengine.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..4b91fc1a53ebe3b532d35b386fa059682c03ecf8
GIT binary patch
literal 10129
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

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/contrib/ntlmpool.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/contrib/ntlmpool.py
new file mode 100644
index 0000000..8ea127c
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/contrib/ntlmpool.py
@@ -0,0 +1,111 @@
+"""
+NTLM authenticating pool, contributed by erikcederstran
+
+Issue #10, see: http://code.google.com/p/urllib3/issues/detail?id=10
+"""
+from __future__ import absolute_import
+
+from logging import getLogger
+from ntlm import ntlm
+
+from .. import HTTPSConnectionPool
+from ..packages.six.moves.http_client import HTTPSConnection
+
+
+log = getLogger(__name__)
+
+
+class NTLMConnectionPool(HTTPSConnectionPool):
+    """
+    Implements an NTLM authentication version of an urllib3 connection pool
+    """
+
+    scheme = 'https'
+
+    def __init__(self, user, pw, authurl, *args, **kwargs):
+        """
+        authurl is a random URL on the server that is protected by NTLM.
+        user is the Windows user, probably in the DOMAIN\\username format.
+        pw is the password for the user.
+        """
+        super(NTLMConnectionPool, self).__init__(*args, **kwargs)
+        self.authurl = authurl
+        self.rawuser = user
+        user_parts = user.split('\\', 1)
+        self.domain = user_parts[0].upper()
+        self.user = user_parts[1]
+        self.pw = pw
+
+    def _new_conn(self):
+        # Performs the NTLM handshake that secures the connection. The socket
+        # must be kept open while requests are performed.
+        self.num_connections += 1
+        log.debug('Starting NTLM HTTPS connection no. %d: https://%s%s',
+                  self.num_connections, self.host, self.authurl)
+
+        headers = {'Connection': 'Keep-Alive'}
+        req_header = 'Authorization'
+        resp_header = 'www-authenticate'
+
+        conn = HTTPSConnection(host=self.host, port=self.port)
+
+        # Send negotiation message
+        headers[req_header] = (
+            'NTLM %s' % ntlm.create_NTLM_NEGOTIATE_MESSAGE(self.rawuser))
+        log.debug('Request headers: %s', headers)
+        conn.request('GET', self.authurl, None, headers)
+        res = conn.getresponse()
+        reshdr = dict(res.getheaders())
+        log.debug('Response status: %s %s', res.status, res.reason)
+        log.debug('Response headers: %s', reshdr)
+        log.debug('Response data: %s [...]', res.read(100))
+
+        # Remove the reference to the socket, so that it can not be closed by
+        # the response object (we want to keep the socket open)
+        res.fp = None
+
+        # Server should respond with a challenge message
+        auth_header_values = reshdr[resp_header].split(', ')
+        auth_header_value = None
+        for s in auth_header_values:
+            if s[:5] == 'NTLM ':
+                auth_header_value = s[5:]
+        if auth_header_value is None:
+            raise Exception('Unexpected %s response header: %s' %
+                            (resp_header, reshdr[resp_header]))
+
+        # Send authentication message
+        ServerChallenge, NegotiateFlags = \
+            ntlm.parse_NTLM_CHALLENGE_MESSAGE(auth_header_value)
+        auth_msg = ntlm.create_NTLM_AUTHENTICATE_MESSAGE(ServerChallenge,
+                                                         self.user,
+                                                         self.domain,
+                                                         self.pw,
+                                                         NegotiateFlags)
+        headers[req_header] = 'NTLM %s' % auth_msg
+        log.debug('Request headers: %s', headers)
+        conn.request('GET', self.authurl, None, headers)
+        res = conn.getresponse()
+        log.debug('Response status: %s %s', res.status, res.reason)
+        log.debug('Response headers: %s', dict(res.getheaders()))
+        log.debug('Response data: %s [...]', res.read()[:100])
+        if res.status != 200:
+            if res.status == 401:
+                raise Exception('Server rejected request: wrong '
+                                'username or password')
+            raise Exception('Wrong server response: %s %s' %
+                            (res.status, res.reason))
+
+        res.fp = None
+        log.debug('Connection established')
+        return conn
+
+    def urlopen(self, method, url, body=None, headers=None, retries=3,
+                redirect=True, assert_same_host=True):
+        if headers is None:
+            headers = {}
+        headers['Connection'] = 'Keep-Alive'
+        return super(NTLMConnectionPool, self).urlopen(method, url, body,
+                                                       headers, retries,
+                                                       redirect,
+                                                       assert_same_host)
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/contrib/ntlmpool.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/contrib/ntlmpool.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..69b2494d808fb3c8c2ebb7f50337dc967e63d1aa
GIT binary patch
literal 4173
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
b1{~`)ka)HO1yeC7eXubKFbO~~GY>NW>om+*

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/contrib/pyopenssl.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/contrib/pyopenssl.py
new file mode 100644
index 0000000..363667c
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/contrib/pyopenssl.py
@@ -0,0 +1,466 @@
+"""
+SSL with SNI_-support for Python 2. Follow these instructions if you would
+like to verify SSL certificates in Python 2. Note, the default libraries do
+*not* do certificate checking; you need to do additional work to validate
+certificates yourself.
+
+This needs the following packages installed:
+
+* pyOpenSSL (tested with 16.0.0)
+* cryptography (minimum 1.3.4, from pyopenssl)
+* idna (minimum 2.0, from cryptography)
+
+However, pyopenssl depends on cryptography, which depends on idna, so while we
+use all three directly here we end up having relatively few packages required.
+
+You can install them with the following command:
+
+    pip install pyopenssl cryptography idna
+
+To activate certificate checking, call
+:func:`~urllib3.contrib.pyopenssl.inject_into_urllib3` from your Python code
+before you begin making HTTP requests. This can be done in a ``sitecustomize``
+module, or at any other time before your application begins using ``urllib3``,
+like this::
+
+    try:
+        import urllib3.contrib.pyopenssl
+        urllib3.contrib.pyopenssl.inject_into_urllib3()
+    except ImportError:
+        pass
+
+Now you can use :mod:`urllib3` as you normally would, and it will support SNI
+when the required modules are installed.
+
+Activating this module also has the positive side effect of disabling SSL/TLS
+compression in Python 2 (see `CRIME attack`_).
+
+If you want to configure the default list of supported cipher suites, you can
+set the ``urllib3.contrib.pyopenssl.DEFAULT_SSL_CIPHER_LIST`` variable.
+
+.. _sni: https://en.wikipedia.org/wiki/Server_Name_Indication
+.. _crime attack: https://en.wikipedia.org/wiki/CRIME_(security_exploit)
+"""
+from __future__ import absolute_import
+
+import OpenSSL.SSL
+from cryptography import x509
+from cryptography.hazmat.backends.openssl import backend as openssl_backend
+from cryptography.hazmat.backends.openssl.x509 import _Certificate
+try:
+    from cryptography.x509 import UnsupportedExtension
+except ImportError:
+    # UnsupportedExtension is gone in cryptography >= 2.1.0
+    class UnsupportedExtension(Exception):
+        pass
+
+from socket import timeout, error as SocketError
+from io import BytesIO
+
+try:  # Platform-specific: Python 2
+    from socket import _fileobject
+except ImportError:  # Platform-specific: Python 3
+    _fileobject = None
+    from ..packages.backports.makefile import backport_makefile
+
+import logging
+import ssl
+from ..packages import six
+import sys
+
+from .. import util
+
+__all__ = ['inject_into_urllib3', 'extract_from_urllib3']
+
+# SNI always works.
+HAS_SNI = True
+
+# Map from urllib3 to PyOpenSSL compatible parameter-values.
+_openssl_versions = {
+    ssl.PROTOCOL_SSLv23: OpenSSL.SSL.SSLv23_METHOD,
+    ssl.PROTOCOL_TLSv1: OpenSSL.SSL.TLSv1_METHOD,
+}
+
+if hasattr(ssl, 'PROTOCOL_TLSv1_1') and hasattr(OpenSSL.SSL, 'TLSv1_1_METHOD'):
+    _openssl_versions[ssl.PROTOCOL_TLSv1_1] = OpenSSL.SSL.TLSv1_1_METHOD
+
+if hasattr(ssl, 'PROTOCOL_TLSv1_2') and hasattr(OpenSSL.SSL, 'TLSv1_2_METHOD'):
+    _openssl_versions[ssl.PROTOCOL_TLSv1_2] = OpenSSL.SSL.TLSv1_2_METHOD
+
+try:
+    _openssl_versions.update({ssl.PROTOCOL_SSLv3: OpenSSL.SSL.SSLv3_METHOD})
+except AttributeError:
+    pass
+
+_stdlib_to_openssl_verify = {
+    ssl.CERT_NONE: OpenSSL.SSL.VERIFY_NONE,
+    ssl.CERT_OPTIONAL: OpenSSL.SSL.VERIFY_PEER,
+    ssl.CERT_REQUIRED:
+        OpenSSL.SSL.VERIFY_PEER + OpenSSL.SSL.VERIFY_FAIL_IF_NO_PEER_CERT,
+}
+_openssl_to_stdlib_verify = dict(
+    (v, k) for k, v in _stdlib_to_openssl_verify.items()
+)
+
+# OpenSSL will only write 16K at a time
+SSL_WRITE_BLOCKSIZE = 16384
+
+orig_util_HAS_SNI = util.HAS_SNI
+orig_util_SSLContext = util.ssl_.SSLContext
+
+
+log = logging.getLogger(__name__)
+
+
+def inject_into_urllib3():
+    'Monkey-patch urllib3 with PyOpenSSL-backed SSL-support.'
+
+    _validate_dependencies_met()
+
+    util.ssl_.SSLContext = PyOpenSSLContext
+    util.HAS_SNI = HAS_SNI
+    util.ssl_.HAS_SNI = HAS_SNI
+    util.IS_PYOPENSSL = True
+    util.ssl_.IS_PYOPENSSL = True
+
+
+def extract_from_urllib3():
+    'Undo monkey-patching by :func:`inject_into_urllib3`.'
+
+    util.ssl_.SSLContext = orig_util_SSLContext
+    util.HAS_SNI = orig_util_HAS_SNI
+    util.ssl_.HAS_SNI = orig_util_HAS_SNI
+    util.IS_PYOPENSSL = False
+    util.ssl_.IS_PYOPENSSL = False
+
+
+def _validate_dependencies_met():
+    """
+    Verifies that PyOpenSSL's package-level dependencies have been met.
+    Throws `ImportError` if they are not met.
+    """
+    # Method added in `cryptography==1.1`; not available in older versions
+    from cryptography.x509.extensions import Extensions
+    if getattr(Extensions, "get_extension_for_class", None) is None:
+        raise ImportError("'cryptography' module missing required functionality.  "
+                          "Try upgrading to v1.3.4 or newer.")
+
+    # pyOpenSSL 0.14 and above use cryptography for OpenSSL bindings. The _x509
+    # attribute is only present on those versions.
+    from OpenSSL.crypto import X509
+    x509 = X509()
+    if getattr(x509, "_x509", None) is None:
+        raise ImportError("'pyOpenSSL' module missing required functionality. "
+                          "Try upgrading to v0.14 or newer.")
+
+
+def _dnsname_to_stdlib(name):
+    """
+    Converts a dNSName SubjectAlternativeName field to the form used by the
+    standard library on the given Python version.
+
+    Cryptography produces a dNSName as a unicode string that was idna-decoded
+    from ASCII bytes. We need to idna-encode that string to get it back, and
+    then on Python 3 we also need to convert to unicode via UTF-8 (the stdlib
+    uses PyUnicode_FromStringAndSize on it, which decodes via UTF-8).
+
+    If the name cannot be idna-encoded then we return None signalling that
+    the name given should be skipped.
+    """
+    def idna_encode(name):
+        """
+        Borrowed wholesale from the Python Cryptography Project. It turns out
+        that we can't just safely call `idna.encode`: it can explode for
+        wildcard names. This avoids that problem.
+        """
+        from pip._vendor import idna
+
+        try:
+            for prefix in [u'*.', u'.']:
+                if name.startswith(prefix):
+                    name = name[len(prefix):]
+                    return prefix.encode('ascii') + idna.encode(name)
+            return idna.encode(name)
+        except idna.core.IDNAError:
+            return None
+
+    name = idna_encode(name)
+    if name is None:
+        return None
+    elif sys.version_info >= (3, 0):
+        name = name.decode('utf-8')
+    return name
+
+
+def get_subj_alt_name(peer_cert):
+    """
+    Given an PyOpenSSL certificate, provides all the subject alternative names.
+    """
+    # Pass the cert to cryptography, which has much better APIs for this.
+    if hasattr(peer_cert, "to_cryptography"):
+        cert = peer_cert.to_cryptography()
+    else:
+        # This is technically using private APIs, but should work across all
+        # relevant versions before PyOpenSSL got a proper API for this.
+        cert = _Certificate(openssl_backend, peer_cert._x509)
+
+    # We want to find the SAN extension. Ask Cryptography to locate it (it's
+    # faster than looping in Python)
+    try:
+        ext = cert.extensions.get_extension_for_class(
+            x509.SubjectAlternativeName
+        ).value
+    except x509.ExtensionNotFound:
+        # No such extension, return the empty list.
+        return []
+    except (x509.DuplicateExtension, UnsupportedExtension,
+            x509.UnsupportedGeneralNameType, UnicodeError) as e:
+        # A problem has been found with the quality of the certificate. Assume
+        # no SAN field is present.
+        log.warning(
+            "A problem was encountered with the certificate that prevented "
+            "urllib3 from finding the SubjectAlternativeName field. This can "
+            "affect certificate validation. The error was %s",
+            e,
+        )
+        return []
+
+    # We want to return dNSName and iPAddress fields. We need to cast the IPs
+    # back to strings because the match_hostname function wants them as
+    # strings.
+    # Sadly the DNS names need to be idna encoded and then, on Python 3, UTF-8
+    # decoded. This is pretty frustrating, but that's what the standard library
+    # does with certificates, and so we need to attempt to do the same.
+    # We also want to skip over names which cannot be idna encoded.
+    names = [
+        ('DNS', name) for name in map(_dnsname_to_stdlib, ext.get_values_for_type(x509.DNSName))
+        if name is not None
+    ]
+    names.extend(
+        ('IP Address', str(name))
+        for name in ext.get_values_for_type(x509.IPAddress)
+    )
+
+    return names
+
+
+class WrappedSocket(object):
+    '''API-compatibility wrapper for Python OpenSSL's Connection-class.
+
+    Note: _makefile_refs, _drop() and _reuse() are needed for the garbage
+    collector of pypy.
+    '''
+
+    def __init__(self, connection, socket, suppress_ragged_eofs=True):
+        self.connection = connection
+        self.socket = socket
+        self.suppress_ragged_eofs = suppress_ragged_eofs
+        self._makefile_refs = 0
+        self._closed = False
+
+    def fileno(self):
+        return self.socket.fileno()
+
+    # Copy-pasted from Python 3.5 source code
+    def _decref_socketios(self):
+        if self._makefile_refs > 0:
+            self._makefile_refs -= 1
+        if self._closed:
+            self.close()
+
+    def recv(self, *args, **kwargs):
+        try:
+            data = self.connection.recv(*args, **kwargs)
+        except OpenSSL.SSL.SysCallError as e:
+            if self.suppress_ragged_eofs and e.args == (-1, 'Unexpected EOF'):
+                return b''
+            else:
+                raise SocketError(str(e))
+        except OpenSSL.SSL.ZeroReturnError as e:
+            if self.connection.get_shutdown() == OpenSSL.SSL.RECEIVED_SHUTDOWN:
+                return b''
+            else:
+                raise
+        except OpenSSL.SSL.WantReadError:
+            if not util.wait_for_read(self.socket, self.socket.gettimeout()):
+                raise timeout('The read operation timed out')
+            else:
+                return self.recv(*args, **kwargs)
+        else:
+            return data
+
+    def recv_into(self, *args, **kwargs):
+        try:
+            return self.connection.recv_into(*args, **kwargs)
+        except OpenSSL.SSL.SysCallError as e:
+            if self.suppress_ragged_eofs and e.args == (-1, 'Unexpected EOF'):
+                return 0
+            else:
+                raise SocketError(str(e))
+        except OpenSSL.SSL.ZeroReturnError as e:
+            if self.connection.get_shutdown() == OpenSSL.SSL.RECEIVED_SHUTDOWN:
+                return 0
+            else:
+                raise
+        except OpenSSL.SSL.WantReadError:
+            if not util.wait_for_read(self.socket, self.socket.gettimeout()):
+                raise timeout('The read operation timed out')
+            else:
+                return self.recv_into(*args, **kwargs)
+
+    def settimeout(self, timeout):
+        return self.socket.settimeout(timeout)
+
+    def _send_until_done(self, data):
+        while True:
+            try:
+                return self.connection.send(data)
+            except OpenSSL.SSL.WantWriteError:
+                if not util.wait_for_write(self.socket, self.socket.gettimeout()):
+                    raise timeout()
+                continue
+            except OpenSSL.SSL.SysCallError as e:
+                raise SocketError(str(e))
+
+    def sendall(self, data):
+        total_sent = 0
+        while total_sent < len(data):
+            sent = self._send_until_done(data[total_sent:total_sent + SSL_WRITE_BLOCKSIZE])
+            total_sent += sent
+
+    def shutdown(self):
+        # FIXME rethrow compatible exceptions should we ever use this
+        self.connection.shutdown()
+
+    def close(self):
+        if self._makefile_refs < 1:
+            try:
+                self._closed = True
+                return self.connection.close()
+            except OpenSSL.SSL.Error:
+                return
+        else:
+            self._makefile_refs -= 1
+
+    def getpeercert(self, binary_form=False):
+        x509 = self.connection.get_peer_certificate()
+
+        if not x509:
+            return x509
+
+        if binary_form:
+            return OpenSSL.crypto.dump_certificate(
+                OpenSSL.crypto.FILETYPE_ASN1,
+                x509)
+
+        return {
+            'subject': (
+                (('commonName', x509.get_subject().CN),),
+            ),
+            'subjectAltName': get_subj_alt_name(x509)
+        }
+
+    def _reuse(self):
+        self._makefile_refs += 1
+
+    def _drop(self):
+        if self._makefile_refs < 1:
+            self.close()
+        else:
+            self._makefile_refs -= 1
+
+
+if _fileobject:  # Platform-specific: Python 2
+    def makefile(self, mode, bufsize=-1):
+        self._makefile_refs += 1
+        return _fileobject(self, mode, bufsize, close=True)
+else:  # Platform-specific: Python 3
+    makefile = backport_makefile
+
+WrappedSocket.makefile = makefile
+
+
+class PyOpenSSLContext(object):
+    """
+    I am a wrapper class for the PyOpenSSL ``Context`` object. I am responsible
+    for translating the interface of the standard library ``SSLContext`` object
+    to calls into PyOpenSSL.
+    """
+    def __init__(self, protocol):
+        self.protocol = _openssl_versions[protocol]
+        self._ctx = OpenSSL.SSL.Context(self.protocol)
+        self._options = 0
+        self.check_hostname = False
+
+    @property
+    def options(self):
+        return self._options
+
+    @options.setter
+    def options(self, value):
+        self._options = value
+        self._ctx.set_options(value)
+
+    @property
+    def verify_mode(self):
+        return _openssl_to_stdlib_verify[self._ctx.get_verify_mode()]
+
+    @verify_mode.setter
+    def verify_mode(self, value):
+        self._ctx.set_verify(
+            _stdlib_to_openssl_verify[value],
+            _verify_callback
+        )
+
+    def set_default_verify_paths(self):
+        self._ctx.set_default_verify_paths()
+
+    def set_ciphers(self, ciphers):
+        if isinstance(ciphers, six.text_type):
+            ciphers = ciphers.encode('utf-8')
+        self._ctx.set_cipher_list(ciphers)
+
+    def load_verify_locations(self, cafile=None, capath=None, cadata=None):
+        if cafile is not None:
+            cafile = cafile.encode('utf-8')
+        if capath is not None:
+            capath = capath.encode('utf-8')
+        self._ctx.load_verify_locations(cafile, capath)
+        if cadata is not None:
+            self._ctx.load_verify_locations(BytesIO(cadata))
+
+    def load_cert_chain(self, certfile, keyfile=None, password=None):
+        self._ctx.use_certificate_chain_file(certfile)
+        if password is not None:
+            self._ctx.set_passwd_cb(lambda max_length, prompt_twice, userdata: password)
+        self._ctx.use_privatekey_file(keyfile or certfile)
+
+    def wrap_socket(self, sock, server_side=False,
+                    do_handshake_on_connect=True, suppress_ragged_eofs=True,
+                    server_hostname=None):
+        cnx = OpenSSL.SSL.Connection(self._ctx, sock)
+
+        if isinstance(server_hostname, six.text_type):  # Platform-specific: Python 3
+            server_hostname = server_hostname.encode('utf-8')
+
+        if server_hostname is not None:
+            cnx.set_tlsext_host_name(server_hostname)
+
+        cnx.set_connect_state()
+
+        while True:
+            try:
+                cnx.do_handshake()
+            except OpenSSL.SSL.WantReadError:
+                if not util.wait_for_read(sock, sock.gettimeout()):
+                    raise timeout('select timed out')
+                continue
+            except OpenSSL.SSL.Error as e:
+                raise ssl.SSLError('bad handshake: %r' % e)
+            break
+
+        return WrappedSocket(cnx, sock)
+
+
+def _verify_callback(cnx, x509, err_no, err_depth, return_code):
+    return err_no == 0
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/contrib/pyopenssl.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/contrib/pyopenssl.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..ff01ef2c8918edebb1664c1f30a9908b1a927766
GIT binary patch
literal 19914
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

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/contrib/securetransport.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/contrib/securetransport.py
new file mode 100644
index 0000000..77cb59e
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/contrib/securetransport.py
@@ -0,0 +1,804 @@
+"""
+SecureTranport support for urllib3 via ctypes.
+
+This makes platform-native TLS available to urllib3 users on macOS without the
+use of a compiler. This is an important feature because the Python Package
+Index is moving to become a TLSv1.2-or-higher server, and the default OpenSSL
+that ships with macOS is not capable of doing TLSv1.2. The only way to resolve
+this is to give macOS users an alternative solution to the problem, and that
+solution is to use SecureTransport.
+
+We use ctypes here because this solution must not require a compiler. That's
+because pip is not allowed to require a compiler either.
+
+This is not intended to be a seriously long-term solution to this problem.
+The hope is that PEP 543 will eventually solve this issue for us, at which
+point we can retire this contrib module. But in the short term, we need to
+solve the impending tire fire that is Python on Mac without this kind of
+contrib module. So...here we are.
+
+To use this module, simply import and inject it::
+
+    import urllib3.contrib.securetransport
+    urllib3.contrib.securetransport.inject_into_urllib3()
+
+Happy TLSing!
+"""
+from __future__ import absolute_import
+
+import contextlib
+import ctypes
+import errno
+import os.path
+import shutil
+import socket
+import ssl
+import threading
+import weakref
+
+from .. import util
+from ._securetransport.bindings import (
+    Security, SecurityConst, CoreFoundation
+)
+from ._securetransport.low_level import (
+    _assert_no_error, _cert_array_from_pem, _temporary_keychain,
+    _load_client_cert_chain
+)
+
+try:  # Platform-specific: Python 2
+    from socket import _fileobject
+except ImportError:  # Platform-specific: Python 3
+    _fileobject = None
+    from ..packages.backports.makefile import backport_makefile
+
+__all__ = ['inject_into_urllib3', 'extract_from_urllib3']
+
+# SNI always works
+HAS_SNI = True
+
+orig_util_HAS_SNI = util.HAS_SNI
+orig_util_SSLContext = util.ssl_.SSLContext
+
+# This dictionary is used by the read callback to obtain a handle to the
+# calling wrapped socket. This is a pretty silly approach, but for now it'll
+# do. I feel like I should be able to smuggle a handle to the wrapped socket
+# directly in the SSLConnectionRef, but for now this approach will work I
+# guess.
+#
+# We need to lock around this structure for inserts, but we don't do it for
+# reads/writes in the callbacks. The reasoning here goes as follows:
+#
+#    1. It is not possible to call into the callbacks before the dictionary is
+#       populated, so once in the callback the id must be in the dictionary.
+#    2. The callbacks don't mutate the dictionary, they only read from it, and
+#       so cannot conflict with any of the insertions.
+#
+# This is good: if we had to lock in the callbacks we'd drastically slow down
+# the performance of this code.
+_connection_refs = weakref.WeakValueDictionary()
+_connection_ref_lock = threading.Lock()
+
+# Limit writes to 16kB. This is OpenSSL's limit, but we'll cargo-cult it over
+# for no better reason than we need *a* limit, and this one is right there.
+SSL_WRITE_BLOCKSIZE = 16384
+
+# This is our equivalent of util.ssl_.DEFAULT_CIPHERS, but expanded out to
+# individual cipher suites. We need to do this because this is how
+# SecureTransport wants them.
+CIPHER_SUITES = [
+    SecurityConst.TLS_AES_256_GCM_SHA384,
+    SecurityConst.TLS_CHACHA20_POLY1305_SHA256,
+    SecurityConst.TLS_AES_128_GCM_SHA256,
+    SecurityConst.TLS_ECDHE_ECDSA_WITH_AES_256_GCM_SHA384,
+    SecurityConst.TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384,
+    SecurityConst.TLS_ECDHE_ECDSA_WITH_AES_128_GCM_SHA256,
+    SecurityConst.TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256,
+    SecurityConst.TLS_DHE_DSS_WITH_AES_256_GCM_SHA384,
+    SecurityConst.TLS_DHE_RSA_WITH_AES_256_GCM_SHA384,
+    SecurityConst.TLS_DHE_DSS_WITH_AES_128_GCM_SHA256,
+    SecurityConst.TLS_DHE_RSA_WITH_AES_128_GCM_SHA256,
+    SecurityConst.TLS_ECDHE_ECDSA_WITH_AES_256_CBC_SHA384,
+    SecurityConst.TLS_ECDHE_RSA_WITH_AES_256_CBC_SHA384,
+    SecurityConst.TLS_ECDHE_ECDSA_WITH_AES_256_CBC_SHA,
+    SecurityConst.TLS_ECDHE_RSA_WITH_AES_256_CBC_SHA,
+    SecurityConst.TLS_DHE_RSA_WITH_AES_256_CBC_SHA256,
+    SecurityConst.TLS_DHE_DSS_WITH_AES_256_CBC_SHA256,
+    SecurityConst.TLS_DHE_RSA_WITH_AES_256_CBC_SHA,
+    SecurityConst.TLS_DHE_DSS_WITH_AES_256_CBC_SHA,
+    SecurityConst.TLS_ECDHE_ECDSA_WITH_AES_128_CBC_SHA256,
+    SecurityConst.TLS_ECDHE_RSA_WITH_AES_128_CBC_SHA256,
+    SecurityConst.TLS_ECDHE_ECDSA_WITH_AES_128_CBC_SHA,
+    SecurityConst.TLS_ECDHE_RSA_WITH_AES_128_CBC_SHA,
+    SecurityConst.TLS_DHE_RSA_WITH_AES_128_CBC_SHA256,
+    SecurityConst.TLS_DHE_DSS_WITH_AES_128_CBC_SHA256,
+    SecurityConst.TLS_DHE_RSA_WITH_AES_128_CBC_SHA,
+    SecurityConst.TLS_DHE_DSS_WITH_AES_128_CBC_SHA,
+    SecurityConst.TLS_RSA_WITH_AES_256_GCM_SHA384,
+    SecurityConst.TLS_RSA_WITH_AES_128_GCM_SHA256,
+    SecurityConst.TLS_RSA_WITH_AES_256_CBC_SHA256,
+    SecurityConst.TLS_RSA_WITH_AES_128_CBC_SHA256,
+    SecurityConst.TLS_RSA_WITH_AES_256_CBC_SHA,
+    SecurityConst.TLS_RSA_WITH_AES_128_CBC_SHA,
+]
+
+# Basically this is simple: for PROTOCOL_SSLv23 we turn it into a low of
+# TLSv1 and a high of TLSv1.2. For everything else, we pin to that version.
+_protocol_to_min_max = {
+    ssl.PROTOCOL_SSLv23: (SecurityConst.kTLSProtocol1, SecurityConst.kTLSProtocol12),
+}
+
+if hasattr(ssl, "PROTOCOL_SSLv2"):
+    _protocol_to_min_max[ssl.PROTOCOL_SSLv2] = (
+        SecurityConst.kSSLProtocol2, SecurityConst.kSSLProtocol2
+    )
+if hasattr(ssl, "PROTOCOL_SSLv3"):
+    _protocol_to_min_max[ssl.PROTOCOL_SSLv3] = (
+        SecurityConst.kSSLProtocol3, SecurityConst.kSSLProtocol3
+    )
+if hasattr(ssl, "PROTOCOL_TLSv1"):
+    _protocol_to_min_max[ssl.PROTOCOL_TLSv1] = (
+        SecurityConst.kTLSProtocol1, SecurityConst.kTLSProtocol1
+    )
+if hasattr(ssl, "PROTOCOL_TLSv1_1"):
+    _protocol_to_min_max[ssl.PROTOCOL_TLSv1_1] = (
+        SecurityConst.kTLSProtocol11, SecurityConst.kTLSProtocol11
+    )
+if hasattr(ssl, "PROTOCOL_TLSv1_2"):
+    _protocol_to_min_max[ssl.PROTOCOL_TLSv1_2] = (
+        SecurityConst.kTLSProtocol12, SecurityConst.kTLSProtocol12
+    )
+if hasattr(ssl, "PROTOCOL_TLS"):
+    _protocol_to_min_max[ssl.PROTOCOL_TLS] = _protocol_to_min_max[ssl.PROTOCOL_SSLv23]
+
+
+def inject_into_urllib3():
+    """
+    Monkey-patch urllib3 with SecureTransport-backed SSL-support.
+    """
+    util.ssl_.SSLContext = SecureTransportContext
+    util.HAS_SNI = HAS_SNI
+    util.ssl_.HAS_SNI = HAS_SNI
+    util.IS_SECURETRANSPORT = True
+    util.ssl_.IS_SECURETRANSPORT = True
+
+
+def extract_from_urllib3():
+    """
+    Undo monkey-patching by :func:`inject_into_urllib3`.
+    """
+    util.ssl_.SSLContext = orig_util_SSLContext
+    util.HAS_SNI = orig_util_HAS_SNI
+    util.ssl_.HAS_SNI = orig_util_HAS_SNI
+    util.IS_SECURETRANSPORT = False
+    util.ssl_.IS_SECURETRANSPORT = False
+
+
+def _read_callback(connection_id, data_buffer, data_length_pointer):
+    """
+    SecureTransport read callback. This is called by ST to request that data
+    be returned from the socket.
+    """
+    wrapped_socket = None
+    try:
+        wrapped_socket = _connection_refs.get(connection_id)
+        if wrapped_socket is None:
+            return SecurityConst.errSSLInternal
+        base_socket = wrapped_socket.socket
+
+        requested_length = data_length_pointer[0]
+
+        timeout = wrapped_socket.gettimeout()
+        error = None
+        read_count = 0
+
+        try:
+            while read_count < requested_length:
+                if timeout is None or timeout >= 0:
+                    if not util.wait_for_read(base_socket, timeout):
+                        raise socket.error(errno.EAGAIN, 'timed out')
+
+                remaining = requested_length - read_count
+                buffer = (ctypes.c_char * remaining).from_address(
+                    data_buffer + read_count
+                )
+                chunk_size = base_socket.recv_into(buffer, remaining)
+                read_count += chunk_size
+                if not chunk_size:
+                    if not read_count:
+                        return SecurityConst.errSSLClosedGraceful
+                    break
+        except (socket.error) as e:
+            error = e.errno
+
+            if error is not None and error != errno.EAGAIN:
+                data_length_pointer[0] = read_count
+                if error == errno.ECONNRESET or error == errno.EPIPE:
+                    return SecurityConst.errSSLClosedAbort
+                raise
+
+        data_length_pointer[0] = read_count
+
+        if read_count != requested_length:
+            return SecurityConst.errSSLWouldBlock
+
+        return 0
+    except Exception as e:
+        if wrapped_socket is not None:
+            wrapped_socket._exception = e
+        return SecurityConst.errSSLInternal
+
+
+def _write_callback(connection_id, data_buffer, data_length_pointer):
+    """
+    SecureTransport write callback. This is called by ST to request that data
+    actually be sent on the network.
+    """
+    wrapped_socket = None
+    try:
+        wrapped_socket = _connection_refs.get(connection_id)
+        if wrapped_socket is None:
+            return SecurityConst.errSSLInternal
+        base_socket = wrapped_socket.socket
+
+        bytes_to_write = data_length_pointer[0]
+        data = ctypes.string_at(data_buffer, bytes_to_write)
+
+        timeout = wrapped_socket.gettimeout()
+        error = None
+        sent = 0
+
+        try:
+            while sent < bytes_to_write:
+                if timeout is None or timeout >= 0:
+                    if not util.wait_for_write(base_socket, timeout):
+                        raise socket.error(errno.EAGAIN, 'timed out')
+                chunk_sent = base_socket.send(data)
+                sent += chunk_sent
+
+                # This has some needless copying here, but I'm not sure there's
+                # much value in optimising this data path.
+                data = data[chunk_sent:]
+        except (socket.error) as e:
+            error = e.errno
+
+            if error is not None and error != errno.EAGAIN:
+                data_length_pointer[0] = sent
+                if error == errno.ECONNRESET or error == errno.EPIPE:
+                    return SecurityConst.errSSLClosedAbort
+                raise
+
+        data_length_pointer[0] = sent
+
+        if sent != bytes_to_write:
+            return SecurityConst.errSSLWouldBlock
+
+        return 0
+    except Exception as e:
+        if wrapped_socket is not None:
+            wrapped_socket._exception = e
+        return SecurityConst.errSSLInternal
+
+
+# We need to keep these two objects references alive: if they get GC'd while
+# in use then SecureTransport could attempt to call a function that is in freed
+# memory. That would be...uh...bad. Yeah, that's the word. Bad.
+_read_callback_pointer = Security.SSLReadFunc(_read_callback)
+_write_callback_pointer = Security.SSLWriteFunc(_write_callback)
+
+
+class WrappedSocket(object):
+    """
+    API-compatibility wrapper for Python's OpenSSL wrapped socket object.
+
+    Note: _makefile_refs, _drop(), and _reuse() are needed for the garbage
+    collector of PyPy.
+    """
+    def __init__(self, socket):
+        self.socket = socket
+        self.context = None
+        self._makefile_refs = 0
+        self._closed = False
+        self._exception = None
+        self._keychain = None
+        self._keychain_dir = None
+        self._client_cert_chain = None
+
+        # We save off the previously-configured timeout and then set it to
+        # zero. This is done because we use select and friends to handle the
+        # timeouts, but if we leave the timeout set on the lower socket then
+        # Python will "kindly" call select on that socket again for us. Avoid
+        # that by forcing the timeout to zero.
+        self._timeout = self.socket.gettimeout()
+        self.socket.settimeout(0)
+
+    @contextlib.contextmanager
+    def _raise_on_error(self):
+        """
+        A context manager that can be used to wrap calls that do I/O from
+        SecureTransport. If any of the I/O callbacks hit an exception, this
+        context manager will correctly propagate the exception after the fact.
+        This avoids silently swallowing those exceptions.
+
+        It also correctly forces the socket closed.
+        """
+        self._exception = None
+
+        # We explicitly don't catch around this yield because in the unlikely
+        # event that an exception was hit in the block we don't want to swallow
+        # it.
+        yield
+        if self._exception is not None:
+            exception, self._exception = self._exception, None
+            self.close()
+            raise exception
+
+    def _set_ciphers(self):
+        """
+        Sets up the allowed ciphers. By default this matches the set in
+        util.ssl_.DEFAULT_CIPHERS, at least as supported by macOS. This is done
+        custom and doesn't allow changing at this time, mostly because parsing
+        OpenSSL cipher strings is going to be a freaking nightmare.
+        """
+        ciphers = (Security.SSLCipherSuite * len(CIPHER_SUITES))(*CIPHER_SUITES)
+        result = Security.SSLSetEnabledCiphers(
+            self.context, ciphers, len(CIPHER_SUITES)
+        )
+        _assert_no_error(result)
+
+    def _custom_validate(self, verify, trust_bundle):
+        """
+        Called when we have set custom validation. We do this in two cases:
+        first, when cert validation is entirely disabled; and second, when
+        using a custom trust DB.
+        """
+        # If we disabled cert validation, just say: cool.
+        if not verify:
+            return
+
+        # We want data in memory, so load it up.
+        if os.path.isfile(trust_bundle):
+            with open(trust_bundle, 'rb') as f:
+                trust_bundle = f.read()
+
+        cert_array = None
+        trust = Security.SecTrustRef()
+
+        try:
+            # Get a CFArray that contains the certs we want.
+            cert_array = _cert_array_from_pem(trust_bundle)
+
+            # Ok, now the hard part. We want to get the SecTrustRef that ST has
+            # created for this connection, shove our CAs into it, tell ST to
+            # ignore everything else it knows, and then ask if it can build a
+            # chain. This is a buuuunch of code.
+            result = Security.SSLCopyPeerTrust(
+                self.context, ctypes.byref(trust)
+            )
+            _assert_no_error(result)
+            if not trust:
+                raise ssl.SSLError("Failed to copy trust reference")
+
+            result = Security.SecTrustSetAnchorCertificates(trust, cert_array)
+            _assert_no_error(result)
+
+            result = Security.SecTrustSetAnchorCertificatesOnly(trust, True)
+            _assert_no_error(result)
+
+            trust_result = Security.SecTrustResultType()
+            result = Security.SecTrustEvaluate(
+                trust, ctypes.byref(trust_result)
+            )
+            _assert_no_error(result)
+        finally:
+            if trust:
+                CoreFoundation.CFRelease(trust)
+
+            if cert_array is not None:
+                CoreFoundation.CFRelease(cert_array)
+
+        # Ok, now we can look at what the result was.
+        successes = (
+            SecurityConst.kSecTrustResultUnspecified,
+            SecurityConst.kSecTrustResultProceed
+        )
+        if trust_result.value not in successes:
+            raise ssl.SSLError(
+                "certificate verify failed, error code: %d" %
+                trust_result.value
+            )
+
+    def handshake(self,
+                  server_hostname,
+                  verify,
+                  trust_bundle,
+                  min_version,
+                  max_version,
+                  client_cert,
+                  client_key,
+                  client_key_passphrase):
+        """
+        Actually performs the TLS handshake. This is run automatically by
+        wrapped socket, and shouldn't be needed in user code.
+        """
+        # First, we do the initial bits of connection setup. We need to create
+        # a context, set its I/O funcs, and set the connection reference.
+        self.context = Security.SSLCreateContext(
+            None, SecurityConst.kSSLClientSide, SecurityConst.kSSLStreamType
+        )
+        result = Security.SSLSetIOFuncs(
+            self.context, _read_callback_pointer, _write_callback_pointer
+        )
+        _assert_no_error(result)
+
+        # Here we need to compute the handle to use. We do this by taking the
+        # id of self modulo 2**31 - 1. If this is already in the dictionary, we
+        # just keep incrementing by one until we find a free space.
+        with _connection_ref_lock:
+            handle = id(self) % 2147483647
+            while handle in _connection_refs:
+                handle = (handle + 1) % 2147483647
+            _connection_refs[handle] = self
+
+        result = Security.SSLSetConnection(self.context, handle)
+        _assert_no_error(result)
+
+        # If we have a server hostname, we should set that too.
+        if server_hostname:
+            if not isinstance(server_hostname, bytes):
+                server_hostname = server_hostname.encode('utf-8')
+
+            result = Security.SSLSetPeerDomainName(
+                self.context, server_hostname, len(server_hostname)
+            )
+            _assert_no_error(result)
+
+        # Setup the ciphers.
+        self._set_ciphers()
+
+        # Set the minimum and maximum TLS versions.
+        result = Security.SSLSetProtocolVersionMin(self.context, min_version)
+        _assert_no_error(result)
+        result = Security.SSLSetProtocolVersionMax(self.context, max_version)
+        _assert_no_error(result)
+
+        # If there's a trust DB, we need to use it. We do that by telling
+        # SecureTransport to break on server auth. We also do that if we don't
+        # want to validate the certs at all: we just won't actually do any
+        # authing in that case.
+        if not verify or trust_bundle is not None:
+            result = Security.SSLSetSessionOption(
+                self.context,
+                SecurityConst.kSSLSessionOptionBreakOnServerAuth,
+                True
+            )
+            _assert_no_error(result)
+
+        # If there's a client cert, we need to use it.
+        if client_cert:
+            self._keychain, self._keychain_dir = _temporary_keychain()
+            self._client_cert_chain = _load_client_cert_chain(
+                self._keychain, client_cert, client_key
+            )
+            result = Security.SSLSetCertificate(
+                self.context, self._client_cert_chain
+            )
+            _assert_no_error(result)
+
+        while True:
+            with self._raise_on_error():
+                result = Security.SSLHandshake(self.context)
+
+                if result == SecurityConst.errSSLWouldBlock:
+                    raise socket.timeout("handshake timed out")
+                elif result == SecurityConst.errSSLServerAuthCompleted:
+                    self._custom_validate(verify, trust_bundle)
+                    continue
+                else:
+                    _assert_no_error(result)
+                    break
+
+    def fileno(self):
+        return self.socket.fileno()
+
+    # Copy-pasted from Python 3.5 source code
+    def _decref_socketios(self):
+        if self._makefile_refs > 0:
+            self._makefile_refs -= 1
+        if self._closed:
+            self.close()
+
+    def recv(self, bufsiz):
+        buffer = ctypes.create_string_buffer(bufsiz)
+        bytes_read = self.recv_into(buffer, bufsiz)
+        data = buffer[:bytes_read]
+        return data
+
+    def recv_into(self, buffer, nbytes=None):
+        # Read short on EOF.
+        if self._closed:
+            return 0
+
+        if nbytes is None:
+            nbytes = len(buffer)
+
+        buffer = (ctypes.c_char * nbytes).from_buffer(buffer)
+        processed_bytes = ctypes.c_size_t(0)
+
+        with self._raise_on_error():
+            result = Security.SSLRead(
+                self.context, buffer, nbytes, ctypes.byref(processed_bytes)
+            )
+
+        # There are some result codes that we want to treat as "not always
+        # errors". Specifically, those are errSSLWouldBlock,
+        # errSSLClosedGraceful, and errSSLClosedNoNotify.
+        if (result == SecurityConst.errSSLWouldBlock):
+            # If we didn't process any bytes, then this was just a time out.
+            # However, we can get errSSLWouldBlock in situations when we *did*
+            # read some data, and in those cases we should just read "short"
+            # and return.
+            if processed_bytes.value == 0:
+                # Timed out, no data read.
+                raise socket.timeout("recv timed out")
+        elif result in (SecurityConst.errSSLClosedGraceful, SecurityConst.errSSLClosedNoNotify):
+            # The remote peer has closed this connection. We should do so as
+            # well. Note that we don't actually return here because in
+            # principle this could actually be fired along with return data.
+            # It's unlikely though.
+            self.close()
+        else:
+            _assert_no_error(result)
+
+        # Ok, we read and probably succeeded. We should return whatever data
+        # was actually read.
+        return processed_bytes.value
+
+    def settimeout(self, timeout):
+        self._timeout = timeout
+
+    def gettimeout(self):
+        return self._timeout
+
+    def send(self, data):
+        processed_bytes = ctypes.c_size_t(0)
+
+        with self._raise_on_error():
+            result = Security.SSLWrite(
+                self.context, data, len(data), ctypes.byref(processed_bytes)
+            )
+
+        if result == SecurityConst.errSSLWouldBlock and processed_bytes.value == 0:
+            # Timed out
+            raise socket.timeout("send timed out")
+        else:
+            _assert_no_error(result)
+
+        # We sent, and probably succeeded. Tell them how much we sent.
+        return processed_bytes.value
+
+    def sendall(self, data):
+        total_sent = 0
+        while total_sent < len(data):
+            sent = self.send(data[total_sent:total_sent + SSL_WRITE_BLOCKSIZE])
+            total_sent += sent
+
+    def shutdown(self):
+        with self._raise_on_error():
+            Security.SSLClose(self.context)
+
+    def close(self):
+        # TODO: should I do clean shutdown here? Do I have to?
+        if self._makefile_refs < 1:
+            self._closed = True
+            if self.context:
+                CoreFoundation.CFRelease(self.context)
+                self.context = None
+            if self._client_cert_chain:
+                CoreFoundation.CFRelease(self._client_cert_chain)
+                self._client_cert_chain = None
+            if self._keychain:
+                Security.SecKeychainDelete(self._keychain)
+                CoreFoundation.CFRelease(self._keychain)
+                shutil.rmtree(self._keychain_dir)
+                self._keychain = self._keychain_dir = None
+            return self.socket.close()
+        else:
+            self._makefile_refs -= 1
+
+    def getpeercert(self, binary_form=False):
+        # Urgh, annoying.
+        #
+        # Here's how we do this:
+        #
+        # 1. Call SSLCopyPeerTrust to get hold of the trust object for this
+        #    connection.
+        # 2. Call SecTrustGetCertificateAtIndex for index 0 to get the leaf.
+        # 3. To get the CN, call SecCertificateCopyCommonName and process that
+        #    string so that it's of the appropriate type.
+        # 4. To get the SAN, we need to do something a bit more complex:
+        #    a. Call SecCertificateCopyValues to get the data, requesting
+        #       kSecOIDSubjectAltName.
+        #    b. Mess about with this dictionary to try to get the SANs out.
+        #
+        # This is gross. Really gross. It's going to be a few hundred LoC extra
+        # just to repeat something that SecureTransport can *already do*. So my
+        # operating assumption at this time is that what we want to do is
+        # instead to just flag to urllib3 that it shouldn't do its own hostname
+        # validation when using SecureTransport.
+        if not binary_form:
+            raise ValueError(
+                "SecureTransport only supports dumping binary certs"
+            )
+        trust = Security.SecTrustRef()
+        certdata = None
+        der_bytes = None
+
+        try:
+            # Grab the trust store.
+            result = Security.SSLCopyPeerTrust(
+                self.context, ctypes.byref(trust)
+            )
+            _assert_no_error(result)
+            if not trust:
+                # Probably we haven't done the handshake yet. No biggie.
+                return None
+
+            cert_count = Security.SecTrustGetCertificateCount(trust)
+            if not cert_count:
+                # Also a case that might happen if we haven't handshaked.
+                # Handshook? Handshaken?
+                return None
+
+            leaf = Security.SecTrustGetCertificateAtIndex(trust, 0)
+            assert leaf
+
+            # Ok, now we want the DER bytes.
+            certdata = Security.SecCertificateCopyData(leaf)
+            assert certdata
+
+            data_length = CoreFoundation.CFDataGetLength(certdata)
+            data_buffer = CoreFoundation.CFDataGetBytePtr(certdata)
+            der_bytes = ctypes.string_at(data_buffer, data_length)
+        finally:
+            if certdata:
+                CoreFoundation.CFRelease(certdata)
+            if trust:
+                CoreFoundation.CFRelease(trust)
+
+        return der_bytes
+
+    def _reuse(self):
+        self._makefile_refs += 1
+
+    def _drop(self):
+        if self._makefile_refs < 1:
+            self.close()
+        else:
+            self._makefile_refs -= 1
+
+
+if _fileobject:  # Platform-specific: Python 2
+    def makefile(self, mode, bufsize=-1):
+        self._makefile_refs += 1
+        return _fileobject(self, mode, bufsize, close=True)
+else:  # Platform-specific: Python 3
+    def makefile(self, mode="r", buffering=None, *args, **kwargs):
+        # We disable buffering with SecureTransport because it conflicts with
+        # the buffering that ST does internally (see issue #1153 for more).
+        buffering = 0
+        return backport_makefile(self, mode, buffering, *args, **kwargs)
+
+WrappedSocket.makefile = makefile
+
+
+class SecureTransportContext(object):
+    """
+    I am a wrapper class for the SecureTransport library, to translate the
+    interface of the standard library ``SSLContext`` object to calls into
+    SecureTransport.
+    """
+    def __init__(self, protocol):
+        self._min_version, self._max_version = _protocol_to_min_max[protocol]
+        self._options = 0
+        self._verify = False
+        self._trust_bundle = None
+        self._client_cert = None
+        self._client_key = None
+        self._client_key_passphrase = None
+
+    @property
+    def check_hostname(self):
+        """
+        SecureTransport cannot have its hostname checking disabled. For more,
+        see the comment on getpeercert() in this file.
+        """
+        return True
+
+    @check_hostname.setter
+    def check_hostname(self, value):
+        """
+        SecureTransport cannot have its hostname checking disabled. For more,
+        see the comment on getpeercert() in this file.
+        """
+        pass
+
+    @property
+    def options(self):
+        # TODO: Well, crap.
+        #
+        # So this is the bit of the code that is the most likely to cause us
+        # trouble. Essentially we need to enumerate all of the SSL options that
+        # users might want to use and try to see if we can sensibly translate
+        # them, or whether we should just ignore them.
+        return self._options
+
+    @options.setter
+    def options(self, value):
+        # TODO: Update in line with above.
+        self._options = value
+
+    @property
+    def verify_mode(self):
+        return ssl.CERT_REQUIRED if self._verify else ssl.CERT_NONE
+
+    @verify_mode.setter
+    def verify_mode(self, value):
+        self._verify = True if value == ssl.CERT_REQUIRED else False
+
+    def set_default_verify_paths(self):
+        # So, this has to do something a bit weird. Specifically, what it does
+        # is nothing.
+        #
+        # This means that, if we had previously had load_verify_locations
+        # called, this does not undo that. We need to do that because it turns
+        # out that the rest of the urllib3 code will attempt to load the
+        # default verify paths if it hasn't been told about any paths, even if
+        # the context itself was sometime earlier. We resolve that by just
+        # ignoring it.
+        pass
+
+    def load_default_certs(self):
+        return self.set_default_verify_paths()
+
+    def set_ciphers(self, ciphers):
+        # For now, we just require the default cipher string.
+        if ciphers != util.ssl_.DEFAULT_CIPHERS:
+            raise ValueError(
+                "SecureTransport doesn't support custom cipher strings"
+            )
+
+    def load_verify_locations(self, cafile=None, capath=None, cadata=None):
+        # OK, we only really support cadata and cafile.
+        if capath is not None:
+            raise ValueError(
+                "SecureTransport does not support cert directories"
+            )
+
+        self._trust_bundle = cafile or cadata
+
+    def load_cert_chain(self, certfile, keyfile=None, password=None):
+        self._client_cert = certfile
+        self._client_key = keyfile
+        self._client_cert_passphrase = password
+
+    def wrap_socket(self, sock, server_side=False,
+                    do_handshake_on_connect=True, suppress_ragged_eofs=True,
+                    server_hostname=None):
+        # So, what do we do here? Firstly, we assert some properties. This is a
+        # stripped down shim, so there is some functionality we don't support.
+        # See PEP 543 for the real deal.
+        assert not server_side
+        assert do_handshake_on_connect
+        assert suppress_ragged_eofs
+
+        # Ok, we're good to go. Now we want to create the wrapped socket object
+        # and store it in the appropriate place.
+        wrapped_socket = WrappedSocket(sock)
+
+        # Now we can handshake
+        wrapped_socket.handshake(
+            server_hostname, self._verify, self._trust_bundle,
+            self._min_version, self._max_version, self._client_cert,
+            self._client_key, self._client_key_passphrase
+        )
+        return wrapped_socket
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/contrib/securetransport.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/contrib/securetransport.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..fe9a3e6126c9ffa44cf9078cdcfa74d603f8a908
GIT binary patch
literal 24494
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%0A6Tg%sI3f2gP;*nCWayr#u8qJ
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
Wrx`yZKeO0>h7LAHeinW<PG$gae`$sQ

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/contrib/socks.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/contrib/socks.py
new file mode 100644
index 0000000..811e312
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/contrib/socks.py
@@ -0,0 +1,192 @@
+# -*- coding: utf-8 -*-
+"""
+This module contains provisional support for SOCKS proxies from within
+urllib3. This module supports SOCKS4 (specifically the SOCKS4A variant) and
+SOCKS5. To enable its functionality, either install PySocks or install this
+module with the ``socks`` extra.
+
+The SOCKS implementation supports the full range of urllib3 features. It also
+supports the following SOCKS features:
+
+- SOCKS4
+- SOCKS4a
+- SOCKS5
+- Usernames and passwords for the SOCKS proxy
+
+Known Limitations:
+
+- Currently PySocks does not support contacting remote websites via literal
+  IPv6 addresses. Any such connection attempt will fail. You must use a domain
+  name.
+- Currently PySocks does not support IPv6 connections to the SOCKS proxy. Any
+  such connection attempt will fail.
+"""
+from __future__ import absolute_import
+
+try:
+    import socks
+except ImportError:
+    import warnings
+    from ..exceptions import DependencyWarning
+
+    warnings.warn((
+        'SOCKS support in urllib3 requires the installation of optional '
+        'dependencies: specifically, PySocks.  For more information, see '
+        'https://urllib3.readthedocs.io/en/latest/contrib.html#socks-proxies'
+        ),
+        DependencyWarning
+    )
+    raise
+
+from socket import error as SocketError, timeout as SocketTimeout
+
+from ..connection import (
+    HTTPConnection, HTTPSConnection
+)
+from ..connectionpool import (
+    HTTPConnectionPool, HTTPSConnectionPool
+)
+from ..exceptions import ConnectTimeoutError, NewConnectionError
+from ..poolmanager import PoolManager
+from ..util.url import parse_url
+
+try:
+    import ssl
+except ImportError:
+    ssl = None
+
+
+class SOCKSConnection(HTTPConnection):
+    """
+    A plain-text HTTP connection that connects via a SOCKS proxy.
+    """
+    def __init__(self, *args, **kwargs):
+        self._socks_options = kwargs.pop('_socks_options')
+        super(SOCKSConnection, self).__init__(*args, **kwargs)
+
+    def _new_conn(self):
+        """
+        Establish a new connection via the SOCKS proxy.
+        """
+        extra_kw = {}
+        if self.source_address:
+            extra_kw['source_address'] = self.source_address
+
+        if self.socket_options:
+            extra_kw['socket_options'] = self.socket_options
+
+        try:
+            conn = socks.create_connection(
+                (self.host, self.port),
+                proxy_type=self._socks_options['socks_version'],
+                proxy_addr=self._socks_options['proxy_host'],
+                proxy_port=self._socks_options['proxy_port'],
+                proxy_username=self._socks_options['username'],
+                proxy_password=self._socks_options['password'],
+                proxy_rdns=self._socks_options['rdns'],
+                timeout=self.timeout,
+                **extra_kw
+            )
+
+        except SocketTimeout as e:
+            raise ConnectTimeoutError(
+                self, "Connection to %s timed out. (connect timeout=%s)" %
+                (self.host, self.timeout))
+
+        except socks.ProxyError as e:
+            # This is fragile as hell, but it seems to be the only way to raise
+            # useful errors here.
+            if e.socket_err:
+                error = e.socket_err
+                if isinstance(error, SocketTimeout):
+                    raise ConnectTimeoutError(
+                        self,
+                        "Connection to %s timed out. (connect timeout=%s)" %
+                        (self.host, self.timeout)
+                    )
+                else:
+                    raise NewConnectionError(
+                        self,
+                        "Failed to establish a new connection: %s" % error
+                    )
+            else:
+                raise NewConnectionError(
+                    self,
+                    "Failed to establish a new connection: %s" % e
+                )
+
+        except SocketError as e:  # Defensive: PySocks should catch all these.
+            raise NewConnectionError(
+                self, "Failed to establish a new connection: %s" % e)
+
+        return conn
+
+
+# We don't need to duplicate the Verified/Unverified distinction from
+# urllib3/connection.py here because the HTTPSConnection will already have been
+# correctly set to either the Verified or Unverified form by that module. This
+# means the SOCKSHTTPSConnection will automatically be the correct type.
+class SOCKSHTTPSConnection(SOCKSConnection, HTTPSConnection):
+    pass
+
+
+class SOCKSHTTPConnectionPool(HTTPConnectionPool):
+    ConnectionCls = SOCKSConnection
+
+
+class SOCKSHTTPSConnectionPool(HTTPSConnectionPool):
+    ConnectionCls = SOCKSHTTPSConnection
+
+
+class SOCKSProxyManager(PoolManager):
+    """
+    A version of the urllib3 ProxyManager that routes connections via the
+    defined SOCKS proxy.
+    """
+    pool_classes_by_scheme = {
+        'http': SOCKSHTTPConnectionPool,
+        'https': SOCKSHTTPSConnectionPool,
+    }
+
+    def __init__(self, proxy_url, username=None, password=None,
+                 num_pools=10, headers=None, **connection_pool_kw):
+        parsed = parse_url(proxy_url)
+
+        if username is None and password is None and parsed.auth is not None:
+            split = parsed.auth.split(':')
+            if len(split) == 2:
+                username, password = split
+        if parsed.scheme == 'socks5':
+            socks_version = socks.PROXY_TYPE_SOCKS5
+            rdns = False
+        elif parsed.scheme == 'socks5h':
+            socks_version = socks.PROXY_TYPE_SOCKS5
+            rdns = True
+        elif parsed.scheme == 'socks4':
+            socks_version = socks.PROXY_TYPE_SOCKS4
+            rdns = False
+        elif parsed.scheme == 'socks4a':
+            socks_version = socks.PROXY_TYPE_SOCKS4
+            rdns = True
+        else:
+            raise ValueError(
+                "Unable to determine SOCKS version from %s" % proxy_url
+            )
+
+        self.proxy_url = proxy_url
+
+        socks_options = {
+            'socks_version': socks_version,
+            'proxy_host': parsed.host,
+            'proxy_port': parsed.port,
+            'username': username,
+            'password': password,
+            'rdns': rdns
+        }
+        connection_pool_kw['_socks_options'] = socks_options
+
+        super(SOCKSProxyManager, self).__init__(
+            num_pools, headers, **connection_pool_kw
+        )
+
+        self.pool_classes_by_scheme = SOCKSProxyManager.pool_classes_by_scheme
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/contrib/socks.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/contrib/socks.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..2125f84900662706e8287c7b47c5a75c94c33c14
GIT binary patch
literal 6298
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
OT+Cu_k}P5@Vk`hvF$6&X

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/exceptions.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/exceptions.py
new file mode 100644
index 0000000..7bbaa98
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/exceptions.py
@@ -0,0 +1,246 @@
+from __future__ import absolute_import
+from .packages.six.moves.http_client import (
+    IncompleteRead as httplib_IncompleteRead
+)
+# Base Exceptions
+
+
+class HTTPError(Exception):
+    "Base exception used by this module."
+    pass
+
+
+class HTTPWarning(Warning):
+    "Base warning used by this module."
+    pass
+
+
+class PoolError(HTTPError):
+    "Base exception for errors caused within a pool."
+    def __init__(self, pool, message):
+        self.pool = pool
+        HTTPError.__init__(self, "%s: %s" % (pool, message))
+
+    def __reduce__(self):
+        # For pickling purposes.
+        return self.__class__, (None, None)
+
+
+class RequestError(PoolError):
+    "Base exception for PoolErrors that have associated URLs."
+    def __init__(self, pool, url, message):
+        self.url = url
+        PoolError.__init__(self, pool, message)
+
+    def __reduce__(self):
+        # For pickling purposes.
+        return self.__class__, (None, self.url, None)
+
+
+class SSLError(HTTPError):
+    "Raised when SSL certificate fails in an HTTPS connection."
+    pass
+
+
+class ProxyError(HTTPError):
+    "Raised when the connection to a proxy fails."
+    pass
+
+
+class DecodeError(HTTPError):
+    "Raised when automatic decoding based on Content-Type fails."
+    pass
+
+
+class ProtocolError(HTTPError):
+    "Raised when something unexpected happens mid-request/response."
+    pass
+
+
+#: Renamed to ProtocolError but aliased for backwards compatibility.
+ConnectionError = ProtocolError
+
+
+# Leaf Exceptions
+
+class MaxRetryError(RequestError):
+    """Raised when the maximum number of retries is exceeded.
+
+    :param pool: The connection pool
+    :type pool: :class:`~urllib3.connectionpool.HTTPConnectionPool`
+    :param string url: The requested Url
+    :param exceptions.Exception reason: The underlying error
+
+    """
+
+    def __init__(self, pool, url, reason=None):
+        self.reason = reason
+
+        message = "Max retries exceeded with url: %s (Caused by %r)" % (
+            url, reason)
+
+        RequestError.__init__(self, pool, url, message)
+
+
+class HostChangedError(RequestError):
+    "Raised when an existing pool gets a request for a foreign host."
+
+    def __init__(self, pool, url, retries=3):
+        message = "Tried to open a foreign host with url: %s" % url
+        RequestError.__init__(self, pool, url, message)
+        self.retries = retries
+
+
+class TimeoutStateError(HTTPError):
+    """ Raised when passing an invalid state to a timeout """
+    pass
+
+
+class TimeoutError(HTTPError):
+    """ Raised when a socket timeout error occurs.
+
+    Catching this error will catch both :exc:`ReadTimeoutErrors
+    <ReadTimeoutError>` and :exc:`ConnectTimeoutErrors <ConnectTimeoutError>`.
+    """
+    pass
+
+
+class ReadTimeoutError(TimeoutError, RequestError):
+    "Raised when a socket timeout occurs while receiving data from a server"
+    pass
+
+
+# This timeout error does not have a URL attached and needs to inherit from the
+# base HTTPError
+class ConnectTimeoutError(TimeoutError):
+    "Raised when a socket timeout occurs while connecting to a server"
+    pass
+
+
+class NewConnectionError(ConnectTimeoutError, PoolError):
+    "Raised when we fail to establish a new connection. Usually ECONNREFUSED."
+    pass
+
+
+class EmptyPoolError(PoolError):
+    "Raised when a pool runs out of connections and no more are allowed."
+    pass
+
+
+class ClosedPoolError(PoolError):
+    "Raised when a request enters a pool after the pool has been closed."
+    pass
+
+
+class LocationValueError(ValueError, HTTPError):
+    "Raised when there is something wrong with a given URL input."
+    pass
+
+
+class LocationParseError(LocationValueError):
+    "Raised when get_host or similar fails to parse the URL input."
+
+    def __init__(self, location):
+        message = "Failed to parse: %s" % location
+        HTTPError.__init__(self, message)
+
+        self.location = location
+
+
+class ResponseError(HTTPError):
+    "Used as a container for an error reason supplied in a MaxRetryError."
+    GENERIC_ERROR = 'too many error responses'
+    SPECIFIC_ERROR = 'too many {status_code} error responses'
+
+
+class SecurityWarning(HTTPWarning):
+    "Warned when performing security reducing actions"
+    pass
+
+
+class SubjectAltNameWarning(SecurityWarning):
+    "Warned when connecting to a host with a certificate missing a SAN."
+    pass
+
+
+class InsecureRequestWarning(SecurityWarning):
+    "Warned when making an unverified HTTPS request."
+    pass
+
+
+class SystemTimeWarning(SecurityWarning):
+    "Warned when system time is suspected to be wrong"
+    pass
+
+
+class InsecurePlatformWarning(SecurityWarning):
+    "Warned when certain SSL configuration is not available on a platform."
+    pass
+
+
+class SNIMissingWarning(HTTPWarning):
+    "Warned when making a HTTPS request without SNI available."
+    pass
+
+
+class DependencyWarning(HTTPWarning):
+    """
+    Warned when an attempt is made to import a module with missing optional
+    dependencies.
+    """
+    pass
+
+
+class ResponseNotChunked(ProtocolError, ValueError):
+    "Response needs to be chunked in order to read it as chunks."
+    pass
+
+
+class BodyNotHttplibCompatible(HTTPError):
+    """
+    Body should be httplib.HTTPResponse like (have an fp attribute which
+    returns raw chunks) for read_chunked().
+    """
+    pass
+
+
+class IncompleteRead(HTTPError, httplib_IncompleteRead):
+    """
+    Response length doesn't match expected Content-Length
+
+    Subclass of http_client.IncompleteRead to allow int value
+    for `partial` to avoid creating large objects on streamed
+    reads.
+    """
+    def __init__(self, partial, expected):
+        super(IncompleteRead, self).__init__(partial, expected)
+
+    def __repr__(self):
+        return ('IncompleteRead(%i bytes read, '
+                '%i more expected)' % (self.partial, self.expected))
+
+
+class InvalidHeader(HTTPError):
+    "The header provided was somehow invalid."
+    pass
+
+
+class ProxySchemeUnknown(AssertionError, ValueError):
+    "ProxyManager does not support the supplied scheme"
+    # TODO(t-8ch): Stop inheriting from AssertionError in v2.0.
+
+    def __init__(self, scheme):
+        message = "Not supported proxy scheme %s" % scheme
+        super(ProxySchemeUnknown, self).__init__(message)
+
+
+class HeaderParsingError(HTTPError):
+    "Raised by assert_header_parsing, but we convert it to a log.warning statement."
+    def __init__(self, defects, unparsed_data):
+        message = '%s, unparsed data: %r' % (defects or 'Unknown', unparsed_data)
+        super(HeaderParsingError, self).__init__(message)
+
+
+class UnrewindableBodyError(HTTPError):
+    "urllib3 encountered an error when trying to rewind a body"
+    pass
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/exceptions.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/exceptions.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..4cf321f73f48c646e07f9aaa46d027f84e62ae4e
GIT binary patch
literal 15502
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
As{jB1

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/fields.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/fields.py
new file mode 100644
index 0000000..37fe64a
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/fields.py
@@ -0,0 +1,178 @@
+from __future__ import absolute_import
+import email.utils
+import mimetypes
+
+from .packages import six
+
+
+def guess_content_type(filename, default='application/octet-stream'):
+    """
+    Guess the "Content-Type" of a file.
+
+    :param filename:
+        The filename to guess the "Content-Type" of using :mod:`mimetypes`.
+    :param default:
+        If no "Content-Type" can be guessed, default to `default`.
+    """
+    if filename:
+        return mimetypes.guess_type(filename)[0] or default
+    return default
+
+
+def format_header_param(name, value):
+    """
+    Helper function to format and quote a single header parameter.
+
+    Particularly useful for header parameters which might contain
+    non-ASCII values, like file names. This follows RFC 2231, as
+    suggested by RFC 2388 Section 4.4.
+
+    :param name:
+        The name of the parameter, a string expected to be ASCII only.
+    :param value:
+        The value of the parameter, provided as a unicode string.
+    """
+    if not any(ch in value for ch in '"\\\r\n'):
+        result = '%s="%s"' % (name, value)
+        try:
+            result.encode('ascii')
+        except (UnicodeEncodeError, UnicodeDecodeError):
+            pass
+        else:
+            return result
+    if not six.PY3 and isinstance(value, six.text_type):  # Python 2:
+        value = value.encode('utf-8')
+    value = email.utils.encode_rfc2231(value, 'utf-8')
+    value = '%s*=%s' % (name, value)
+    return value
+
+
+class RequestField(object):
+    """
+    A data container for request body parameters.
+
+    :param name:
+        The name of this request field.
+    :param data:
+        The data/value body.
+    :param filename:
+        An optional filename of the request field.
+    :param headers:
+        An optional dict-like object of headers to initially use for the field.
+    """
+    def __init__(self, name, data, filename=None, headers=None):
+        self._name = name
+        self._filename = filename
+        self.data = data
+        self.headers = {}
+        if headers:
+            self.headers = dict(headers)
+
+    @classmethod
+    def from_tuples(cls, fieldname, value):
+        """
+        A :class:`~urllib3.fields.RequestField` factory from old-style tuple parameters.
+
+        Supports constructing :class:`~urllib3.fields.RequestField` from
+        parameter of key/value strings AND key/filetuple. A filetuple is a
+        (filename, data, MIME type) tuple where the MIME type is optional.
+        For example::
+
+            'foo': 'bar',
+            'fakefile': ('foofile.txt', 'contents of foofile'),
+            'realfile': ('barfile.txt', open('realfile').read()),
+            'typedfile': ('bazfile.bin', open('bazfile').read(), 'image/jpeg'),
+            'nonamefile': 'contents of nonamefile field',
+
+        Field names and filenames must be unicode.
+        """
+        if isinstance(value, tuple):
+            if len(value) == 3:
+                filename, data, content_type = value
+            else:
+                filename, data = value
+                content_type = guess_content_type(filename)
+        else:
+            filename = None
+            content_type = None
+            data = value
+
+        request_param = cls(fieldname, data, filename=filename)
+        request_param.make_multipart(content_type=content_type)
+
+        return request_param
+
+    def _render_part(self, name, value):
+        """
+        Overridable helper function to format a single header parameter.
+
+        :param name:
+            The name of the parameter, a string expected to be ASCII only.
+        :param value:
+            The value of the parameter, provided as a unicode string.
+        """
+        return format_header_param(name, value)
+
+    def _render_parts(self, header_parts):
+        """
+        Helper function to format and quote a single header.
+
+        Useful for single headers that are composed of multiple items. E.g.,
+        'Content-Disposition' fields.
+
+        :param header_parts:
+            A sequence of (k, v) tuples or a :class:`dict` of (k, v) to format
+            as `k1="v1"; k2="v2"; ...`.
+        """
+        parts = []
+        iterable = header_parts
+        if isinstance(header_parts, dict):
+            iterable = header_parts.items()
+
+        for name, value in iterable:
+            if value is not None:
+                parts.append(self._render_part(name, value))
+
+        return '; '.join(parts)
+
+    def render_headers(self):
+        """
+        Renders the headers for this request field.
+        """
+        lines = []
+
+        sort_keys = ['Content-Disposition', 'Content-Type', 'Content-Location']
+        for sort_key in sort_keys:
+            if self.headers.get(sort_key, False):
+                lines.append('%s: %s' % (sort_key, self.headers[sort_key]))
+
+        for header_name, header_value in self.headers.items():
+            if header_name not in sort_keys:
+                if header_value:
+                    lines.append('%s: %s' % (header_name, header_value))
+
+        lines.append('\r\n')
+        return '\r\n'.join(lines)
+
+    def make_multipart(self, content_disposition=None, content_type=None,
+                       content_location=None):
+        """
+        Makes this request field into a multipart request field.
+
+        This method overrides "Content-Disposition", "Content-Type" and
+        "Content-Location" headers to the request parameter.
+
+        :param content_type:
+            The 'Content-Type' of the request body.
+        :param content_location:
+            The 'Content-Location' of the request body.
+
+        """
+        self.headers['Content-Disposition'] = content_disposition or 'form-data'
+        self.headers['Content-Disposition'] += '; '.join([
+            '', self._render_parts(
+                (('name', self._name), ('filename', self._filename))
+            )
+        ])
+        self.headers['Content-Type'] = content_type
+        self.headers['Content-Location'] = content_location
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/fields.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/fields.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..9fdacb64e6bda43aa688ba5cbc7e53bc82746033
GIT binary patch
literal 7346
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

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/filepost.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/filepost.py
new file mode 100644
index 0000000..78f1e19
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/filepost.py
@@ -0,0 +1,98 @@
+from __future__ import absolute_import
+import binascii
+import codecs
+import os
+
+from io import BytesIO
+
+from .packages import six
+from .packages.six import b
+from .fields import RequestField
+
+writer = codecs.lookup('utf-8')[3]
+
+
+def choose_boundary():
+    """
+    Our embarrassingly-simple replacement for mimetools.choose_boundary.
+    """
+    boundary = binascii.hexlify(os.urandom(16))
+    if six.PY3:
+        boundary = boundary.decode('ascii')
+    return boundary
+
+
+def iter_field_objects(fields):
+    """
+    Iterate over fields.
+
+    Supports list of (k, v) tuples and dicts, and lists of
+    :class:`~urllib3.fields.RequestField`.
+
+    """
+    if isinstance(fields, dict):
+        i = six.iteritems(fields)
+    else:
+        i = iter(fields)
+
+    for field in i:
+        if isinstance(field, RequestField):
+            yield field
+        else:
+            yield RequestField.from_tuples(*field)
+
+
+def iter_fields(fields):
+    """
+    .. deprecated:: 1.6
+
+    Iterate over fields.
+
+    The addition of :class:`~urllib3.fields.RequestField` makes this function
+    obsolete. Instead, use :func:`iter_field_objects`, which returns
+    :class:`~urllib3.fields.RequestField` objects.
+
+    Supports list of (k, v) tuples and dicts.
+    """
+    if isinstance(fields, dict):
+        return ((k, v) for k, v in six.iteritems(fields))
+
+    return ((k, v) for k, v in fields)
+
+
+def encode_multipart_formdata(fields, boundary=None):
+    """
+    Encode a dictionary of ``fields`` using the multipart/form-data MIME format.
+
+    :param fields:
+        Dictionary of fields or list of (key, :class:`~urllib3.fields.RequestField`).
+
+    :param boundary:
+        If not specified, then a random boundary will be generated using
+        :func:`urllib3.filepost.choose_boundary`.
+    """
+    body = BytesIO()
+    if boundary is None:
+        boundary = choose_boundary()
+
+    for field in iter_field_objects(fields):
+        body.write(b('--%s\r\n' % (boundary)))
+
+        writer(body).write(field.render_headers())
+        data = field.data
+
+        if isinstance(data, int):
+            data = str(data)  # Backwards compatibility
+
+        if isinstance(data, six.text_type):
+            writer(body).write(data)
+        else:
+            body.write(data)
+
+        body.write(b'\r\n')
+
+    body.write(b('--%s--\r\n' % (boundary)))
+
+    content_type = str('multipart/form-data; boundary=%s' % boundary)
+
+    return body.getvalue(), content_type
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/filepost.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/filepost.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..e63b6ca464aad06be4a21bc3862365079765a4ff
GIT binary patch
literal 3780
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

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/packages/__init__.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/packages/__init__.py
new file mode 100644
index 0000000..170e974
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/packages/__init__.py
@@ -0,0 +1,5 @@
+from __future__ import absolute_import
+
+from . import ssl_match_hostname
+
+__all__ = ('ssl_match_hostname', )
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/packages/__init__.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/packages/__init__.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..135036ab7b160eb9efb1f2d45a77d7308f718add
GIT binary patch
literal 387
zcmZSn%**AGdLky70ScHH7#JKJ7#NDR7#J8*7#LC*8FCmHav2$-7#SE-m>5!+8FH8y
za+w*Tm>C#T*chT%7*bdnf;HF~7#K1^W@s=nFff$xGcYhDCKc!Bl$NB%XXX~<7nNj!
zBp|Xv3=9m##X0f0i6zMy@frEWC3%UtsX-tGeqa^F*i~q-g3RV(U|@)kPb)1cElQ1#
z4+2?Q0wTcrOF#~Zk5A0WiI3L+i6V&N3I+xS{eq&*vc!^9{j$U&{j~g?l+>bP{iGEA
z@}#7^T+`fQBf})~^s00VQ;YJPtSU1D5J=C{5795kEYQu&D=taQ$<cKy^YAnd011I{
zd|7H<N`8@kX;Ds2W|FafL1J=tVtQ(^etdjpUS>&ryk0?N2?qlMgH3LJN@-529mu1_
MEDQ_`0!#u-0Pn_JA^-pY

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/packages/backports/__init__.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/packages/backports/__init__.py
new file mode 100644
index 0000000..e69de29
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/packages/backports/__init__.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/packages/backports/__init__.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..6cf9f73f9b420fa84ce97b0a1e4462b71f31d62e
GIT binary patch
literal 217
zcmZSn%**AGdLky70SXuy7#JKF7#NCK7#J8*7#M;zKq7t`AZawBxQT&*LBF6Vvn;VB
zRlh8;NIxw<CndG0SU)L6zdR`^FV{4;*vK%+JiRL2!qlQXC#%ZL00h$W^h5LuG7EGw
z^NLFnb8>Xu$~-)c13*Gx9AB22my%zkUs{xtlbK|!UyzubotU0lte=#aoL!J#R8p)T
hAD@|*SrQ+wS5R5P!N9;^lbfGXnv-e=a%?fktpF2FIadGx

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/packages/backports/makefile.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/packages/backports/makefile.py
new file mode 100644
index 0000000..740db37
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/packages/backports/makefile.py
@@ -0,0 +1,53 @@
+# -*- coding: utf-8 -*-
+"""
+backports.makefile
+~~~~~~~~~~~~~~~~~~
+
+Backports the Python 3 ``socket.makefile`` method for use with anything that
+wants to create a "fake" socket object.
+"""
+import io
+
+from socket import SocketIO
+
+
+def backport_makefile(self, mode="r", buffering=None, encoding=None,
+                      errors=None, newline=None):
+    """
+    Backport of ``socket.makefile`` from Python 3.5.
+    """
+    if not set(mode) <= {"r", "w", "b"}:
+        raise ValueError(
+            "invalid mode %r (only r, w, b allowed)" % (mode,)
+        )
+    writing = "w" in mode
+    reading = "r" in mode or not writing
+    assert reading or writing
+    binary = "b" in mode
+    rawmode = ""
+    if reading:
+        rawmode += "r"
+    if writing:
+        rawmode += "w"
+    raw = SocketIO(self, rawmode)
+    self._makefile_refs += 1
+    if buffering is None:
+        buffering = -1
+    if buffering < 0:
+        buffering = io.DEFAULT_BUFFER_SIZE
+    if buffering == 0:
+        if not binary:
+            raise ValueError("unbuffered streams must be binary")
+        return raw
+    if reading and writing:
+        buffer = io.BufferedRWPair(raw, raw, buffering)
+    elif reading:
+        buffer = io.BufferedReader(raw, buffering)
+    else:
+        assert writing
+        buffer = io.BufferedWriter(raw, buffering)
+    if binary:
+        return buffer
+    text = io.TextIOWrapper(buffer, encoding, errors, newline)
+    text.mode = mode
+    return text
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/packages/backports/makefile.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/packages/backports/makefile.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..6cd8606f35e1aa025c7f9c006dd63c19edabb541
GIT binary patch
literal 1713
zcmZSn%**AGdLky70Sed{7#JKF7#ND}7#J8*7#N}$7*ZG+QkWQW7#X4%!E9!R943Zb
zW`-zc2F4T?kX#BAjAUhKVP%M71#yElKxP%sWnf_7N=i)5F32w`Db~wP%uY?q%t_^{
z!vI`dPB3K(B^jv-0hJ{g`FRS)3JD3t`N`R-C2-9N2@1KXB^miC3TgR83Z=!V3gww4
z848Jcl_eROdFcuz8Hpua<%xME#R?_)3du#Oi6yBDi3&<-iP@=23J}8-@{_VslS}lt
zGXMYo|KCr8k%57sgoA;BAsB3zr+*1Zq$nBW30?*U237_J24_&fOk-qVC}CizVPt5A
zga;Et3Nu3nGeb5bL$M)42_r)a3rIGNkwL7Pk)er^A&&tR9yN>%*=!88Y@jfNunT+{
zYS<WfYS|fT*cpnGK%C+vh7u-_o)l(~86XWD3@NM(wVWU|MePhVoFM(?wVWVRYuFfy
zW`Tv67@$HW%nUUQAfaX^hFUHVn<a~dA%%^>oGG4#p@xYeg^MAZgQ4gwLkc@XEfd%j
zCWaIahHM6gqNfZcYz$dw;!F%hT#Pjw48?4WAir^fybbYG4HrXj4Ld`T9wW#hdW;~=
z91JyFV8q1G%*;^B&5&macDW~5mJ=q$1eTHmdpVR5;$@I_xL&Y=8V-h{LdF_yhG38!
zH$x3KLk%-S4GTjJD?>92LoE*|jB0oo;&~Wqco>2;xIyt_1xj!V3JMCa)TEG~hBXPL
z73Jr`6Pcc=9v4Vc5GdBcQC|)wlZw?C7#K41$`W%jQxtOZQ&JUFixf2S^KvQ`igXmp
zbrg~m5_59$%TrS{OF(%j6J!85O=W_(#fl6J45fKVrD<uYMX4zY#U(|liMhoJxuwM=
z3Q4I7Ntt<xMU{RUpd?np403;JNeLGN14CG1PHC!ZQBi(T2_FLkgJW@VYEemMejZpT
z2xK%^JRX*z;)_z#ic44+7#RHW^HNKgK(5X&5oTauaB+2W4D|_#cM5fLa}A0Q_Kb1`
zYjuLUDJVQ3F%x17Tqrd$B^6aDyeP9IwWtK-&XClK5>Nl|qQruN)FQBzpm2eB0px(<
z)SR>+0Z@M8WME)`cs(;O9h|#T^OEyZKparMN(FhZxP+a7fgvxoJSQ_R70fO#$}9mX
z0f`r-Cc>3N!V0XUD6t%5Cpg5463a_Kra>$MyQd_zqC^7}Mqr}2iGhJZzo00yEU_e2
zzbvsxKP^8eCAFwnKPg4OJSizJ*EF}-$S}z~y(-<p)S^5mtIEs(1k&^LL-Y$W3v@H{
zic1o6a&+CwJUop9Ktf;~UzVDel3%1>T9lKMnPjYAkeHmEn4Vg!4=?ZZVbP;kP+1}f
z3Jqux2ah*U<Q6-D+{!A=$jm6r#KS1eD8$Ia$i~RV$P32&jQor|jGT--V93VE&&a~a
z!zjVX#wg0f!zjea#>m1b!N|!7E^xuY6Ca<FpBx__1WHKYuz{3$;A9g7ij*K(1_lOj
h;2?;>5=@{%*d{kWr8Fni4#X}75p0Y+OajcDi~#FKpyL1l

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/packages/six.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/packages/six.py
new file mode 100644
index 0000000..190c023
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/packages/six.py
@@ -0,0 +1,868 @@
+"""Utilities for writing code that runs on Python 2 and 3"""
+
+# Copyright (c) 2010-2015 Benjamin Peterson
+#
+# Permission is hereby granted, free of charge, to any person obtaining a copy
+# of this software and associated documentation files (the "Software"), to deal
+# in the Software without restriction, including without limitation the rights
+# to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
+# copies of the Software, and to permit persons to whom the Software is
+# furnished to do so, subject to the following conditions:
+#
+# The above copyright notice and this permission notice shall be included in all
+# copies or substantial portions of the Software.
+#
+# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
+# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
+# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
+# AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
+# LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
+# OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
+# SOFTWARE.
+
+from __future__ import absolute_import
+
+import functools
+import itertools
+import operator
+import sys
+import types
+
+__author__ = "Benjamin Peterson <benjamin@python.org>"
+__version__ = "1.10.0"
+
+
+# Useful for very coarse version differentiation.
+PY2 = sys.version_info[0] == 2
+PY3 = sys.version_info[0] == 3
+PY34 = sys.version_info[0:2] >= (3, 4)
+
+if PY3:
+    string_types = str,
+    integer_types = int,
+    class_types = type,
+    text_type = str
+    binary_type = bytes
+
+    MAXSIZE = sys.maxsize
+else:
+    string_types = basestring,
+    integer_types = (int, long)
+    class_types = (type, types.ClassType)
+    text_type = unicode
+    binary_type = str
+
+    if sys.platform.startswith("java"):
+        # Jython always uses 32 bits.
+        MAXSIZE = int((1 << 31) - 1)
+    else:
+        # It's possible to have sizeof(long) != sizeof(Py_ssize_t).
+        class X(object):
+
+            def __len__(self):
+                return 1 << 31
+        try:
+            len(X())
+        except OverflowError:
+            # 32-bit
+            MAXSIZE = int((1 << 31) - 1)
+        else:
+            # 64-bit
+            MAXSIZE = int((1 << 63) - 1)
+        del X
+
+
+def _add_doc(func, doc):
+    """Add documentation to a function."""
+    func.__doc__ = doc
+
+
+def _import_module(name):
+    """Import module, returning the module after the last dot."""
+    __import__(name)
+    return sys.modules[name]
+
+
+class _LazyDescr(object):
+
+    def __init__(self, name):
+        self.name = name
+
+    def __get__(self, obj, tp):
+        result = self._resolve()
+        setattr(obj, self.name, result)  # Invokes __set__.
+        try:
+            # This is a bit ugly, but it avoids running this again by
+            # removing this descriptor.
+            delattr(obj.__class__, self.name)
+        except AttributeError:
+            pass
+        return result
+
+
+class MovedModule(_LazyDescr):
+
+    def __init__(self, name, old, new=None):
+        super(MovedModule, self).__init__(name)
+        if PY3:
+            if new is None:
+                new = name
+            self.mod = new
+        else:
+            self.mod = old
+
+    def _resolve(self):
+        return _import_module(self.mod)
+
+    def __getattr__(self, attr):
+        _module = self._resolve()
+        value = getattr(_module, attr)
+        setattr(self, attr, value)
+        return value
+
+
+class _LazyModule(types.ModuleType):
+
+    def __init__(self, name):
+        super(_LazyModule, self).__init__(name)
+        self.__doc__ = self.__class__.__doc__
+
+    def __dir__(self):
+        attrs = ["__doc__", "__name__"]
+        attrs += [attr.name for attr in self._moved_attributes]
+        return attrs
+
+    # Subclasses should override this
+    _moved_attributes = []
+
+
+class MovedAttribute(_LazyDescr):
+
+    def __init__(self, name, old_mod, new_mod, old_attr=None, new_attr=None):
+        super(MovedAttribute, self).__init__(name)
+        if PY3:
+            if new_mod is None:
+                new_mod = name
+            self.mod = new_mod
+            if new_attr is None:
+                if old_attr is None:
+                    new_attr = name
+                else:
+                    new_attr = old_attr
+            self.attr = new_attr
+        else:
+            self.mod = old_mod
+            if old_attr is None:
+                old_attr = name
+            self.attr = old_attr
+
+    def _resolve(self):
+        module = _import_module(self.mod)
+        return getattr(module, self.attr)
+
+
+class _SixMetaPathImporter(object):
+
+    """
+    A meta path importer to import six.moves and its submodules.
+
+    This class implements a PEP302 finder and loader. It should be compatible
+    with Python 2.5 and all existing versions of Python3
+    """
+
+    def __init__(self, six_module_name):
+        self.name = six_module_name
+        self.known_modules = {}
+
+    def _add_module(self, mod, *fullnames):
+        for fullname in fullnames:
+            self.known_modules[self.name + "." + fullname] = mod
+
+    def _get_module(self, fullname):
+        return self.known_modules[self.name + "." + fullname]
+
+    def find_module(self, fullname, path=None):
+        if fullname in self.known_modules:
+            return self
+        return None
+
+    def __get_module(self, fullname):
+        try:
+            return self.known_modules[fullname]
+        except KeyError:
+            raise ImportError("This loader does not know module " + fullname)
+
+    def load_module(self, fullname):
+        try:
+            # in case of a reload
+            return sys.modules[fullname]
+        except KeyError:
+            pass
+        mod = self.__get_module(fullname)
+        if isinstance(mod, MovedModule):
+            mod = mod._resolve()
+        else:
+            mod.__loader__ = self
+        sys.modules[fullname] = mod
+        return mod
+
+    def is_package(self, fullname):
+        """
+        Return true, if the named module is a package.
+
+        We need this method to get correct spec objects with
+        Python 3.4 (see PEP451)
+        """
+        return hasattr(self.__get_module(fullname), "__path__")
+
+    def get_code(self, fullname):
+        """Return None
+
+        Required, if is_package is implemented"""
+        self.__get_module(fullname)  # eventually raises ImportError
+        return None
+    get_source = get_code  # same as get_code
+
+_importer = _SixMetaPathImporter(__name__)
+
+
+class _MovedItems(_LazyModule):
+
+    """Lazy loading of moved objects"""
+    __path__ = []  # mark as package
+
+
+_moved_attributes = [
+    MovedAttribute("cStringIO", "cStringIO", "io", "StringIO"),
+    MovedAttribute("filter", "itertools", "builtins", "ifilter", "filter"),
+    MovedAttribute("filterfalse", "itertools", "itertools", "ifilterfalse", "filterfalse"),
+    MovedAttribute("input", "__builtin__", "builtins", "raw_input", "input"),
+    MovedAttribute("intern", "__builtin__", "sys"),
+    MovedAttribute("map", "itertools", "builtins", "imap", "map"),
+    MovedAttribute("getcwd", "os", "os", "getcwdu", "getcwd"),
+    MovedAttribute("getcwdb", "os", "os", "getcwd", "getcwdb"),
+    MovedAttribute("range", "__builtin__", "builtins", "xrange", "range"),
+    MovedAttribute("reload_module", "__builtin__", "importlib" if PY34 else "imp", "reload"),
+    MovedAttribute("reduce", "__builtin__", "functools"),
+    MovedAttribute("shlex_quote", "pipes", "shlex", "quote"),
+    MovedAttribute("StringIO", "StringIO", "io"),
+    MovedAttribute("UserDict", "UserDict", "collections"),
+    MovedAttribute("UserList", "UserList", "collections"),
+    MovedAttribute("UserString", "UserString", "collections"),
+    MovedAttribute("xrange", "__builtin__", "builtins", "xrange", "range"),
+    MovedAttribute("zip", "itertools", "builtins", "izip", "zip"),
+    MovedAttribute("zip_longest", "itertools", "itertools", "izip_longest", "zip_longest"),
+    MovedModule("builtins", "__builtin__"),
+    MovedModule("configparser", "ConfigParser"),
+    MovedModule("copyreg", "copy_reg"),
+    MovedModule("dbm_gnu", "gdbm", "dbm.gnu"),
+    MovedModule("_dummy_thread", "dummy_thread", "_dummy_thread"),
+    MovedModule("http_cookiejar", "cookielib", "http.cookiejar"),
+    MovedModule("http_cookies", "Cookie", "http.cookies"),
+    MovedModule("html_entities", "htmlentitydefs", "html.entities"),
+    MovedModule("html_parser", "HTMLParser", "html.parser"),
+    MovedModule("http_client", "httplib", "http.client"),
+    MovedModule("email_mime_multipart", "email.MIMEMultipart", "email.mime.multipart"),
+    MovedModule("email_mime_nonmultipart", "email.MIMENonMultipart", "email.mime.nonmultipart"),
+    MovedModule("email_mime_text", "email.MIMEText", "email.mime.text"),
+    MovedModule("email_mime_base", "email.MIMEBase", "email.mime.base"),
+    MovedModule("BaseHTTPServer", "BaseHTTPServer", "http.server"),
+    MovedModule("CGIHTTPServer", "CGIHTTPServer", "http.server"),
+    MovedModule("SimpleHTTPServer", "SimpleHTTPServer", "http.server"),
+    MovedModule("cPickle", "cPickle", "pickle"),
+    MovedModule("queue", "Queue"),
+    MovedModule("reprlib", "repr"),
+    MovedModule("socketserver", "SocketServer"),
+    MovedModule("_thread", "thread", "_thread"),
+    MovedModule("tkinter", "Tkinter"),
+    MovedModule("tkinter_dialog", "Dialog", "tkinter.dialog"),
+    MovedModule("tkinter_filedialog", "FileDialog", "tkinter.filedialog"),
+    MovedModule("tkinter_scrolledtext", "ScrolledText", "tkinter.scrolledtext"),
+    MovedModule("tkinter_simpledialog", "SimpleDialog", "tkinter.simpledialog"),
+    MovedModule("tkinter_tix", "Tix", "tkinter.tix"),
+    MovedModule("tkinter_ttk", "ttk", "tkinter.ttk"),
+    MovedModule("tkinter_constants", "Tkconstants", "tkinter.constants"),
+    MovedModule("tkinter_dnd", "Tkdnd", "tkinter.dnd"),
+    MovedModule("tkinter_colorchooser", "tkColorChooser",
+                "tkinter.colorchooser"),
+    MovedModule("tkinter_commondialog", "tkCommonDialog",
+                "tkinter.commondialog"),
+    MovedModule("tkinter_tkfiledialog", "tkFileDialog", "tkinter.filedialog"),
+    MovedModule("tkinter_font", "tkFont", "tkinter.font"),
+    MovedModule("tkinter_messagebox", "tkMessageBox", "tkinter.messagebox"),
+    MovedModule("tkinter_tksimpledialog", "tkSimpleDialog",
+                "tkinter.simpledialog"),
+    MovedModule("urllib_parse", __name__ + ".moves.urllib_parse", "urllib.parse"),
+    MovedModule("urllib_error", __name__ + ".moves.urllib_error", "urllib.error"),
+    MovedModule("urllib", __name__ + ".moves.urllib", __name__ + ".moves.urllib"),
+    MovedModule("urllib_robotparser", "robotparser", "urllib.robotparser"),
+    MovedModule("xmlrpc_client", "xmlrpclib", "xmlrpc.client"),
+    MovedModule("xmlrpc_server", "SimpleXMLRPCServer", "xmlrpc.server"),
+]
+# Add windows specific modules.
+if sys.platform == "win32":
+    _moved_attributes += [
+        MovedModule("winreg", "_winreg"),
+    ]
+
+for attr in _moved_attributes:
+    setattr(_MovedItems, attr.name, attr)
+    if isinstance(attr, MovedModule):
+        _importer._add_module(attr, "moves." + attr.name)
+del attr
+
+_MovedItems._moved_attributes = _moved_attributes
+
+moves = _MovedItems(__name__ + ".moves")
+_importer._add_module(moves, "moves")
+
+
+class Module_six_moves_urllib_parse(_LazyModule):
+
+    """Lazy loading of moved objects in six.moves.urllib_parse"""
+
+
+_urllib_parse_moved_attributes = [
+    MovedAttribute("ParseResult", "urlparse", "urllib.parse"),
+    MovedAttribute("SplitResult", "urlparse", "urllib.parse"),
+    MovedAttribute("parse_qs", "urlparse", "urllib.parse"),
+    MovedAttribute("parse_qsl", "urlparse", "urllib.parse"),
+    MovedAttribute("urldefrag", "urlparse", "urllib.parse"),
+    MovedAttribute("urljoin", "urlparse", "urllib.parse"),
+    MovedAttribute("urlparse", "urlparse", "urllib.parse"),
+    MovedAttribute("urlsplit", "urlparse", "urllib.parse"),
+    MovedAttribute("urlunparse", "urlparse", "urllib.parse"),
+    MovedAttribute("urlunsplit", "urlparse", "urllib.parse"),
+    MovedAttribute("quote", "urllib", "urllib.parse"),
+    MovedAttribute("quote_plus", "urllib", "urllib.parse"),
+    MovedAttribute("unquote", "urllib", "urllib.parse"),
+    MovedAttribute("unquote_plus", "urllib", "urllib.parse"),
+    MovedAttribute("urlencode", "urllib", "urllib.parse"),
+    MovedAttribute("splitquery", "urllib", "urllib.parse"),
+    MovedAttribute("splittag", "urllib", "urllib.parse"),
+    MovedAttribute("splituser", "urllib", "urllib.parse"),
+    MovedAttribute("uses_fragment", "urlparse", "urllib.parse"),
+    MovedAttribute("uses_netloc", "urlparse", "urllib.parse"),
+    MovedAttribute("uses_params", "urlparse", "urllib.parse"),
+    MovedAttribute("uses_query", "urlparse", "urllib.parse"),
+    MovedAttribute("uses_relative", "urlparse", "urllib.parse"),
+]
+for attr in _urllib_parse_moved_attributes:
+    setattr(Module_six_moves_urllib_parse, attr.name, attr)
+del attr
+
+Module_six_moves_urllib_parse._moved_attributes = _urllib_parse_moved_attributes
+
+_importer._add_module(Module_six_moves_urllib_parse(__name__ + ".moves.urllib_parse"),
+                      "moves.urllib_parse", "moves.urllib.parse")
+
+
+class Module_six_moves_urllib_error(_LazyModule):
+
+    """Lazy loading of moved objects in six.moves.urllib_error"""
+
+
+_urllib_error_moved_attributes = [
+    MovedAttribute("URLError", "urllib2", "urllib.error"),
+    MovedAttribute("HTTPError", "urllib2", "urllib.error"),
+    MovedAttribute("ContentTooShortError", "urllib", "urllib.error"),
+]
+for attr in _urllib_error_moved_attributes:
+    setattr(Module_six_moves_urllib_error, attr.name, attr)
+del attr
+
+Module_six_moves_urllib_error._moved_attributes = _urllib_error_moved_attributes
+
+_importer._add_module(Module_six_moves_urllib_error(__name__ + ".moves.urllib.error"),
+                      "moves.urllib_error", "moves.urllib.error")
+
+
+class Module_six_moves_urllib_request(_LazyModule):
+
+    """Lazy loading of moved objects in six.moves.urllib_request"""
+
+
+_urllib_request_moved_attributes = [
+    MovedAttribute("urlopen", "urllib2", "urllib.request"),
+    MovedAttribute("install_opener", "urllib2", "urllib.request"),
+    MovedAttribute("build_opener", "urllib2", "urllib.request"),
+    MovedAttribute("pathname2url", "urllib", "urllib.request"),
+    MovedAttribute("url2pathname", "urllib", "urllib.request"),
+    MovedAttribute("getproxies", "urllib", "urllib.request"),
+    MovedAttribute("Request", "urllib2", "urllib.request"),
+    MovedAttribute("OpenerDirector", "urllib2", "urllib.request"),
+    MovedAttribute("HTTPDefaultErrorHandler", "urllib2", "urllib.request"),
+    MovedAttribute("HTTPRedirectHandler", "urllib2", "urllib.request"),
+    MovedAttribute("HTTPCookieProcessor", "urllib2", "urllib.request"),
+    MovedAttribute("ProxyHandler", "urllib2", "urllib.request"),
+    MovedAttribute("BaseHandler", "urllib2", "urllib.request"),
+    MovedAttribute("HTTPPasswordMgr", "urllib2", "urllib.request"),
+    MovedAttribute("HTTPPasswordMgrWithDefaultRealm", "urllib2", "urllib.request"),
+    MovedAttribute("AbstractBasicAuthHandler", "urllib2", "urllib.request"),
+    MovedAttribute("HTTPBasicAuthHandler", "urllib2", "urllib.request"),
+    MovedAttribute("ProxyBasicAuthHandler", "urllib2", "urllib.request"),
+    MovedAttribute("AbstractDigestAuthHandler", "urllib2", "urllib.request"),
+    MovedAttribute("HTTPDigestAuthHandler", "urllib2", "urllib.request"),
+    MovedAttribute("ProxyDigestAuthHandler", "urllib2", "urllib.request"),
+    MovedAttribute("HTTPHandler", "urllib2", "urllib.request"),
+    MovedAttribute("HTTPSHandler", "urllib2", "urllib.request"),
+    MovedAttribute("FileHandler", "urllib2", "urllib.request"),
+    MovedAttribute("FTPHandler", "urllib2", "urllib.request"),
+    MovedAttribute("CacheFTPHandler", "urllib2", "urllib.request"),
+    MovedAttribute("UnknownHandler", "urllib2", "urllib.request"),
+    MovedAttribute("HTTPErrorProcessor", "urllib2", "urllib.request"),
+    MovedAttribute("urlretrieve", "urllib", "urllib.request"),
+    MovedAttribute("urlcleanup", "urllib", "urllib.request"),
+    MovedAttribute("URLopener", "urllib", "urllib.request"),
+    MovedAttribute("FancyURLopener", "urllib", "urllib.request"),
+    MovedAttribute("proxy_bypass", "urllib", "urllib.request"),
+]
+for attr in _urllib_request_moved_attributes:
+    setattr(Module_six_moves_urllib_request, attr.name, attr)
+del attr
+
+Module_six_moves_urllib_request._moved_attributes = _urllib_request_moved_attributes
+
+_importer._add_module(Module_six_moves_urllib_request(__name__ + ".moves.urllib.request"),
+                      "moves.urllib_request", "moves.urllib.request")
+
+
+class Module_six_moves_urllib_response(_LazyModule):
+
+    """Lazy loading of moved objects in six.moves.urllib_response"""
+
+
+_urllib_response_moved_attributes = [
+    MovedAttribute("addbase", "urllib", "urllib.response"),
+    MovedAttribute("addclosehook", "urllib", "urllib.response"),
+    MovedAttribute("addinfo", "urllib", "urllib.response"),
+    MovedAttribute("addinfourl", "urllib", "urllib.response"),
+]
+for attr in _urllib_response_moved_attributes:
+    setattr(Module_six_moves_urllib_response, attr.name, attr)
+del attr
+
+Module_six_moves_urllib_response._moved_attributes = _urllib_response_moved_attributes
+
+_importer._add_module(Module_six_moves_urllib_response(__name__ + ".moves.urllib.response"),
+                      "moves.urllib_response", "moves.urllib.response")
+
+
+class Module_six_moves_urllib_robotparser(_LazyModule):
+
+    """Lazy loading of moved objects in six.moves.urllib_robotparser"""
+
+
+_urllib_robotparser_moved_attributes = [
+    MovedAttribute("RobotFileParser", "robotparser", "urllib.robotparser"),
+]
+for attr in _urllib_robotparser_moved_attributes:
+    setattr(Module_six_moves_urllib_robotparser, attr.name, attr)
+del attr
+
+Module_six_moves_urllib_robotparser._moved_attributes = _urllib_robotparser_moved_attributes
+
+_importer._add_module(Module_six_moves_urllib_robotparser(__name__ + ".moves.urllib.robotparser"),
+                      "moves.urllib_robotparser", "moves.urllib.robotparser")
+
+
+class Module_six_moves_urllib(types.ModuleType):
+
+    """Create a six.moves.urllib namespace that resembles the Python 3 namespace"""
+    __path__ = []  # mark as package
+    parse = _importer._get_module("moves.urllib_parse")
+    error = _importer._get_module("moves.urllib_error")
+    request = _importer._get_module("moves.urllib_request")
+    response = _importer._get_module("moves.urllib_response")
+    robotparser = _importer._get_module("moves.urllib_robotparser")
+
+    def __dir__(self):
+        return ['parse', 'error', 'request', 'response', 'robotparser']
+
+_importer._add_module(Module_six_moves_urllib(__name__ + ".moves.urllib"),
+                      "moves.urllib")
+
+
+def add_move(move):
+    """Add an item to six.moves."""
+    setattr(_MovedItems, move.name, move)
+
+
+def remove_move(name):
+    """Remove item from six.moves."""
+    try:
+        delattr(_MovedItems, name)
+    except AttributeError:
+        try:
+            del moves.__dict__[name]
+        except KeyError:
+            raise AttributeError("no such move, %r" % (name,))
+
+
+if PY3:
+    _meth_func = "__func__"
+    _meth_self = "__self__"
+
+    _func_closure = "__closure__"
+    _func_code = "__code__"
+    _func_defaults = "__defaults__"
+    _func_globals = "__globals__"
+else:
+    _meth_func = "im_func"
+    _meth_self = "im_self"
+
+    _func_closure = "func_closure"
+    _func_code = "func_code"
+    _func_defaults = "func_defaults"
+    _func_globals = "func_globals"
+
+
+try:
+    advance_iterator = next
+except NameError:
+    def advance_iterator(it):
+        return it.next()
+next = advance_iterator
+
+
+try:
+    callable = callable
+except NameError:
+    def callable(obj):
+        return any("__call__" in klass.__dict__ for klass in type(obj).__mro__)
+
+
+if PY3:
+    def get_unbound_function(unbound):
+        return unbound
+
+    create_bound_method = types.MethodType
+
+    def create_unbound_method(func, cls):
+        return func
+
+    Iterator = object
+else:
+    def get_unbound_function(unbound):
+        return unbound.im_func
+
+    def create_bound_method(func, obj):
+        return types.MethodType(func, obj, obj.__class__)
+
+    def create_unbound_method(func, cls):
+        return types.MethodType(func, None, cls)
+
+    class Iterator(object):
+
+        def next(self):
+            return type(self).__next__(self)
+
+    callable = callable
+_add_doc(get_unbound_function,
+         """Get the function out of a possibly unbound function""")
+
+
+get_method_function = operator.attrgetter(_meth_func)
+get_method_self = operator.attrgetter(_meth_self)
+get_function_closure = operator.attrgetter(_func_closure)
+get_function_code = operator.attrgetter(_func_code)
+get_function_defaults = operator.attrgetter(_func_defaults)
+get_function_globals = operator.attrgetter(_func_globals)
+
+
+if PY3:
+    def iterkeys(d, **kw):
+        return iter(d.keys(**kw))
+
+    def itervalues(d, **kw):
+        return iter(d.values(**kw))
+
+    def iteritems(d, **kw):
+        return iter(d.items(**kw))
+
+    def iterlists(d, **kw):
+        return iter(d.lists(**kw))
+
+    viewkeys = operator.methodcaller("keys")
+
+    viewvalues = operator.methodcaller("values")
+
+    viewitems = operator.methodcaller("items")
+else:
+    def iterkeys(d, **kw):
+        return d.iterkeys(**kw)
+
+    def itervalues(d, **kw):
+        return d.itervalues(**kw)
+
+    def iteritems(d, **kw):
+        return d.iteritems(**kw)
+
+    def iterlists(d, **kw):
+        return d.iterlists(**kw)
+
+    viewkeys = operator.methodcaller("viewkeys")
+
+    viewvalues = operator.methodcaller("viewvalues")
+
+    viewitems = operator.methodcaller("viewitems")
+
+_add_doc(iterkeys, "Return an iterator over the keys of a dictionary.")
+_add_doc(itervalues, "Return an iterator over the values of a dictionary.")
+_add_doc(iteritems,
+         "Return an iterator over the (key, value) pairs of a dictionary.")
+_add_doc(iterlists,
+         "Return an iterator over the (key, [values]) pairs of a dictionary.")
+
+
+if PY3:
+    def b(s):
+        return s.encode("latin-1")
+
+    def u(s):
+        return s
+    unichr = chr
+    import struct
+    int2byte = struct.Struct(">B").pack
+    del struct
+    byte2int = operator.itemgetter(0)
+    indexbytes = operator.getitem
+    iterbytes = iter
+    import io
+    StringIO = io.StringIO
+    BytesIO = io.BytesIO
+    _assertCountEqual = "assertCountEqual"
+    if sys.version_info[1] <= 1:
+        _assertRaisesRegex = "assertRaisesRegexp"
+        _assertRegex = "assertRegexpMatches"
+    else:
+        _assertRaisesRegex = "assertRaisesRegex"
+        _assertRegex = "assertRegex"
+else:
+    def b(s):
+        return s
+    # Workaround for standalone backslash
+
+    def u(s):
+        return unicode(s.replace(r'\\', r'\\\\'), "unicode_escape")
+    unichr = unichr
+    int2byte = chr
+
+    def byte2int(bs):
+        return ord(bs[0])
+
+    def indexbytes(buf, i):
+        return ord(buf[i])
+    iterbytes = functools.partial(itertools.imap, ord)
+    import StringIO
+    StringIO = BytesIO = StringIO.StringIO
+    _assertCountEqual = "assertItemsEqual"
+    _assertRaisesRegex = "assertRaisesRegexp"
+    _assertRegex = "assertRegexpMatches"
+_add_doc(b, """Byte literal""")
+_add_doc(u, """Text literal""")
+
+
+def assertCountEqual(self, *args, **kwargs):
+    return getattr(self, _assertCountEqual)(*args, **kwargs)
+
+
+def assertRaisesRegex(self, *args, **kwargs):
+    return getattr(self, _assertRaisesRegex)(*args, **kwargs)
+
+
+def assertRegex(self, *args, **kwargs):
+    return getattr(self, _assertRegex)(*args, **kwargs)
+
+
+if PY3:
+    exec_ = getattr(moves.builtins, "exec")
+
+    def reraise(tp, value, tb=None):
+        if value is None:
+            value = tp()
+        if value.__traceback__ is not tb:
+            raise value.with_traceback(tb)
+        raise value
+
+else:
+    def exec_(_code_, _globs_=None, _locs_=None):
+        """Execute code in a namespace."""
+        if _globs_ is None:
+            frame = sys._getframe(1)
+            _globs_ = frame.f_globals
+            if _locs_ is None:
+                _locs_ = frame.f_locals
+            del frame
+        elif _locs_ is None:
+            _locs_ = _globs_
+        exec("""exec _code_ in _globs_, _locs_""")
+
+    exec_("""def reraise(tp, value, tb=None):
+    raise tp, value, tb
+""")
+
+
+if sys.version_info[:2] == (3, 2):
+    exec_("""def raise_from(value, from_value):
+    if from_value is None:
+        raise value
+    raise value from from_value
+""")
+elif sys.version_info[:2] > (3, 2):
+    exec_("""def raise_from(value, from_value):
+    raise value from from_value
+""")
+else:
+    def raise_from(value, from_value):
+        raise value
+
+
+print_ = getattr(moves.builtins, "print", None)
+if print_ is None:
+    def print_(*args, **kwargs):
+        """The new-style print function for Python 2.4 and 2.5."""
+        fp = kwargs.pop("file", sys.stdout)
+        if fp is None:
+            return
+
+        def write(data):
+            if not isinstance(data, basestring):
+                data = str(data)
+            # If the file has an encoding, encode unicode with it.
+            if (isinstance(fp, file) and
+                    isinstance(data, unicode) and
+                    fp.encoding is not None):
+                errors = getattr(fp, "errors", None)
+                if errors is None:
+                    errors = "strict"
+                data = data.encode(fp.encoding, errors)
+            fp.write(data)
+        want_unicode = False
+        sep = kwargs.pop("sep", None)
+        if sep is not None:
+            if isinstance(sep, unicode):
+                want_unicode = True
+            elif not isinstance(sep, str):
+                raise TypeError("sep must be None or a string")
+        end = kwargs.pop("end", None)
+        if end is not None:
+            if isinstance(end, unicode):
+                want_unicode = True
+            elif not isinstance(end, str):
+                raise TypeError("end must be None or a string")
+        if kwargs:
+            raise TypeError("invalid keyword arguments to print()")
+        if not want_unicode:
+            for arg in args:
+                if isinstance(arg, unicode):
+                    want_unicode = True
+                    break
+        if want_unicode:
+            newline = unicode("\n")
+            space = unicode(" ")
+        else:
+            newline = "\n"
+            space = " "
+        if sep is None:
+            sep = space
+        if end is None:
+            end = newline
+        for i, arg in enumerate(args):
+            if i:
+                write(sep)
+            write(arg)
+        write(end)
+if sys.version_info[:2] < (3, 3):
+    _print = print_
+
+    def print_(*args, **kwargs):
+        fp = kwargs.get("file", sys.stdout)
+        flush = kwargs.pop("flush", False)
+        _print(*args, **kwargs)
+        if flush and fp is not None:
+            fp.flush()
+
+_add_doc(reraise, """Reraise an exception.""")
+
+if sys.version_info[0:2] < (3, 4):
+    def wraps(wrapped, assigned=functools.WRAPPER_ASSIGNMENTS,
+              updated=functools.WRAPPER_UPDATES):
+        def wrapper(f):
+            f = functools.wraps(wrapped, assigned, updated)(f)
+            f.__wrapped__ = wrapped
+            return f
+        return wrapper
+else:
+    wraps = functools.wraps
+
+
+def with_metaclass(meta, *bases):
+    """Create a base class with a metaclass."""
+    # This requires a bit of explanation: the basic idea is to make a dummy
+    # metaclass for one level of class instantiation that replaces itself with
+    # the actual metaclass.
+    class metaclass(meta):
+
+        def __new__(cls, name, this_bases, d):
+            return meta(name, bases, d)
+    return type.__new__(metaclass, 'temporary_class', (), {})
+
+
+def add_metaclass(metaclass):
+    """Class decorator for creating a class with a metaclass."""
+    def wrapper(cls):
+        orig_vars = cls.__dict__.copy()
+        slots = orig_vars.get('__slots__')
+        if slots is not None:
+            if isinstance(slots, str):
+                slots = [slots]
+            for slots_var in slots:
+                orig_vars.pop(slots_var)
+        orig_vars.pop('__dict__', None)
+        orig_vars.pop('__weakref__', None)
+        return metaclass(cls.__name__, cls.__bases__, orig_vars)
+    return wrapper
+
+
+def python_2_unicode_compatible(klass):
+    """
+    A decorator that defines __unicode__ and __str__ methods under Python 2.
+    Under Python 3 it does nothing.
+
+    To support Python 2 and 3 with a single code base, define a __str__ method
+    returning text and apply this decorator to the class.
+    """
+    if PY2:
+        if '__str__' not in klass.__dict__:
+            raise ValueError("@python_2_unicode_compatible cannot be applied "
+                             "to %s because it doesn't define __str__()." %
+                             klass.__name__)
+        klass.__unicode__ = klass.__str__
+        klass.__str__ = lambda self: self.__unicode__().encode('utf-8')
+    return klass
+
+
+# Complete the moves implementation.
+# This code is at the end of this module to speed up module loading.
+# Turn this module into a package.
+__path__ = []  # required for PEP 302 and PEP 451
+__package__ = __name__  # see PEP 366 @ReservedAssignment
+if globals().get("__spec__") is not None:
+    __spec__.submodule_search_locations = []  # PEP 451 @UndefinedVariable
+# Remove other six meta path importers, since they cause problems. This can
+# happen if six is removed from sys.modules and then reloaded. (Setuptools does
+# this for some reason.)
+if sys.meta_path:
+    for i, importer in enumerate(sys.meta_path):
+        # Here's some real nastiness: Another "instance" of the six module might
+        # be floating around. Therefore, we can't use isinstance() to check for
+        # the six meta path importer, since the other six instance will have
+        # inserted an importer with different class.
+        if (type(importer).__name__ == "_SixMetaPathImporter" and
+                importer.name == __name__):
+            del sys.meta_path[i]
+            break
+    del i, importer
+# Finally, add the importer to the meta path import hook.
+sys.meta_path.append(_importer)
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/packages/six.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/packages/six.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..821f44ce9fa7df1dea1a5612fdc7ca0204efa823
GIT binary patch
literal 36102
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

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/packages/ssl_match_hostname/__init__.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/packages/ssl_match_hostname/__init__.py
new file mode 100644
index 0000000..d6594eb
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/packages/ssl_match_hostname/__init__.py
@@ -0,0 +1,19 @@
+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 CertificateError, match_hostname
+    except ImportError:
+        # Our vendored copy
+        from ._implementation import CertificateError, match_hostname
+
+# Not needed, but documenting what we provide.
+__all__ = ('CertificateError', 'match_hostname')
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/packages/ssl_match_hostname/__init__.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/packages/ssl_match_hostname/__init__.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..5082e7d5af5e1c979edfa6f1d1246cfcc3b8799c
GIT binary patch
literal 697
zcmZSn%**AGdLky70SZ_d7#JKF7#NC|F)%QsFfgPrGUPBYL@_W_S}>$CFk~?@q;N81
zGcXkCGNdvwq_8kFGcq(WGUP!Nvoho`Gvu-`M6odBvNA-mGBAecg)*?DGBIRxF%->a
zU}R*hlmZ*e%8<i`rm}DjT;+6-$`m$+6jp{Dc2s4Ba~LA>7#Si`xEP{1K+X%+;AUW8
z$o&8R|9`(sW)KtPhhj+v1_rmpoSdY@<ZOkKe1)>qyp;T+)D(r}{FGD;CI$wE5&;GV
z2IthGlFYQs<iwIx*P^2Qq7ps^28P_klH`o|jQrw~yu{qpOhyI<h9FS*1c6v!y$FlI
z++u7-6=NEu!3nY#<jCU6;u0PP28OcKqT<Z_y!gz#wEPl~M?7;2@{39!ZUHMS&Oz8+
zBE!JI0P+z?O|f2aaZWs{TTA#E7#QL+a|?1(b5rw55=%1k^Geu3V)2PNIq~rtAa5Xu
z;%){82K|Df%(BFiRQ<BVBK@@doRrj}V*R8P{qm%wyj;`VVk5&O^Yp583sZ~ooUAG{
z0}x2h(+|-v$Sly!%quQQ%*oMpEA#L)4gd*(aXcir^-GI#ax#;Q^$QY{vlG)(i}f*`
ztREkrnU`4-AFo$XS;E1<z+jV`pHiBWY6lAJVi5)g1|BA6W`0I~CMiZ<MrIJnB*zQ@
DSjecX

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/packages/ssl_match_hostname/_implementation.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/packages/ssl_match_hostname/_implementation.py
new file mode 100644
index 0000000..970cf65
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/packages/ssl_match_hostname/_implementation.py
@@ -0,0 +1,156 @@
+"""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:
+    from pip._vendor 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/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/packages/ssl_match_hostname/_implementation.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/packages/ssl_match_hostname/_implementation.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..a182da92e67dde1f5d0df72dfdedb3d9f979a5d2
GIT binary patch
literal 4598
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

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/poolmanager.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/poolmanager.py
new file mode 100644
index 0000000..fe5491c
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/poolmanager.py
@@ -0,0 +1,450 @@
+from __future__ import absolute_import
+import collections
+import functools
+import logging
+
+from ._collections import RecentlyUsedContainer
+from .connectionpool import HTTPConnectionPool, HTTPSConnectionPool
+from .connectionpool import port_by_scheme
+from .exceptions import LocationValueError, MaxRetryError, ProxySchemeUnknown
+from .packages.six.moves.urllib.parse import urljoin
+from .request import RequestMethods
+from .util.url import parse_url
+from .util.retry import Retry
+
+
+__all__ = ['PoolManager', 'ProxyManager', 'proxy_from_url']
+
+
+log = logging.getLogger(__name__)
+
+SSL_KEYWORDS = ('key_file', 'cert_file', 'cert_reqs', 'ca_certs',
+                'ssl_version', 'ca_cert_dir', 'ssl_context')
+
+# All known keyword arguments that could be provided to the pool manager, its
+# pools, or the underlying connections. This is used to construct a pool key.
+_key_fields = (
+    'key_scheme',  # str
+    'key_host',  # str
+    'key_port',  # int
+    'key_timeout',  # int or float or Timeout
+    'key_retries',  # int or Retry
+    'key_strict',  # bool
+    'key_block',  # bool
+    'key_source_address',  # str
+    'key_key_file',  # str
+    'key_cert_file',  # str
+    'key_cert_reqs',  # str
+    'key_ca_certs',  # str
+    'key_ssl_version',  # str
+    'key_ca_cert_dir',  # str
+    'key_ssl_context',  # instance of ssl.SSLContext or urllib3.util.ssl_.SSLContext
+    'key_maxsize',  # int
+    'key_headers',  # dict
+    'key__proxy',  # parsed proxy url
+    'key__proxy_headers',  # dict
+    'key_socket_options',  # list of (level (int), optname (int), value (int or str)) tuples
+    'key__socks_options',  # dict
+    'key_assert_hostname',  # bool or string
+    'key_assert_fingerprint',  # str
+    'key_server_hostname', #str
+)
+
+#: The namedtuple class used to construct keys for the connection pool.
+#: All custom key schemes should include the fields in this key at a minimum.
+PoolKey = collections.namedtuple('PoolKey', _key_fields)
+
+
+def _default_key_normalizer(key_class, request_context):
+    """
+    Create a pool key out of a request context dictionary.
+
+    According to RFC 3986, both the scheme and host are case-insensitive.
+    Therefore, this function normalizes both before constructing the pool
+    key for an HTTPS request. If you wish to change this behaviour, provide
+    alternate callables to ``key_fn_by_scheme``.
+
+    :param key_class:
+        The class to use when constructing the key. This should be a namedtuple
+        with the ``scheme`` and ``host`` keys at a minimum.
+    :type  key_class: namedtuple
+    :param request_context:
+        A dictionary-like object that contain the context for a request.
+    :type  request_context: dict
+
+    :return: A namedtuple that can be used as a connection pool key.
+    :rtype:  PoolKey
+    """
+    # Since we mutate the dictionary, make a copy first
+    context = request_context.copy()
+    context['scheme'] = context['scheme'].lower()
+    context['host'] = context['host'].lower()
+
+    # These are both dictionaries and need to be transformed into frozensets
+    for key in ('headers', '_proxy_headers', '_socks_options'):
+        if key in context and context[key] is not None:
+            context[key] = frozenset(context[key].items())
+
+    # The socket_options key may be a list and needs to be transformed into a
+    # tuple.
+    socket_opts = context.get('socket_options')
+    if socket_opts is not None:
+        context['socket_options'] = tuple(socket_opts)
+
+    # Map the kwargs to the names in the namedtuple - this is necessary since
+    # namedtuples can't have fields starting with '_'.
+    for key in list(context.keys()):
+        context['key_' + key] = context.pop(key)
+
+    # Default to ``None`` for keys missing from the context
+    for field in key_class._fields:
+        if field not in context:
+            context[field] = None
+
+    return key_class(**context)
+
+
+#: A dictionary that maps a scheme to a callable that creates a pool key.
+#: This can be used to alter the way pool keys are constructed, if desired.
+#: Each PoolManager makes a copy of this dictionary so they can be configured
+#: globally here, or individually on the instance.
+key_fn_by_scheme = {
+    'http': functools.partial(_default_key_normalizer, PoolKey),
+    'https': functools.partial(_default_key_normalizer, PoolKey),
+}
+
+pool_classes_by_scheme = {
+    'http': HTTPConnectionPool,
+    'https': HTTPSConnectionPool,
+}
+
+
+class PoolManager(RequestMethods):
+    """
+    Allows for arbitrary requests while transparently keeping track of
+    necessary connection pools for you.
+
+    :param num_pools:
+        Number of connection pools to cache before discarding the least
+        recently used pool.
+
+    :param headers:
+        Headers to include with all requests, unless other headers are given
+        explicitly.
+
+    :param \\**connection_pool_kw:
+        Additional parameters are used to create fresh
+        :class:`urllib3.connectionpool.ConnectionPool` instances.
+
+    Example::
+
+        >>> manager = PoolManager(num_pools=2)
+        >>> r = manager.request('GET', 'http://google.com/')
+        >>> r = manager.request('GET', 'http://google.com/mail')
+        >>> r = manager.request('GET', 'http://yahoo.com/')
+        >>> len(manager.pools)
+        2
+
+    """
+
+    proxy = None
+
+    def __init__(self, num_pools=10, headers=None, **connection_pool_kw):
+        RequestMethods.__init__(self, headers)
+        self.connection_pool_kw = connection_pool_kw
+        self.pools = RecentlyUsedContainer(num_pools,
+                                           dispose_func=lambda p: p.close())
+
+        # Locally set the pool classes and keys so other PoolManagers can
+        # override them.
+        self.pool_classes_by_scheme = pool_classes_by_scheme
+        self.key_fn_by_scheme = key_fn_by_scheme.copy()
+
+    def __enter__(self):
+        return self
+
+    def __exit__(self, exc_type, exc_val, exc_tb):
+        self.clear()
+        # Return False to re-raise any potential exceptions
+        return False
+
+    def _new_pool(self, scheme, host, port, request_context=None):
+        """
+        Create a new :class:`ConnectionPool` based on host, port, scheme, and
+        any additional pool keyword arguments.
+
+        If ``request_context`` is provided, it is provided as keyword arguments
+        to the pool class used. This method is used to actually create the
+        connection pools handed out by :meth:`connection_from_url` and
+        companion methods. It is intended to be overridden for customization.
+        """
+        pool_cls = self.pool_classes_by_scheme[scheme]
+        if request_context is None:
+            request_context = self.connection_pool_kw.copy()
+
+        # Although the context has everything necessary to create the pool,
+        # this function has historically only used the scheme, host, and port
+        # in the positional args. When an API change is acceptable these can
+        # be removed.
+        for key in ('scheme', 'host', 'port'):
+            request_context.pop(key, None)
+
+        if scheme == 'http':
+            for kw in SSL_KEYWORDS:
+                request_context.pop(kw, None)
+
+        return pool_cls(host, port, **request_context)
+
+    def clear(self):
+        """
+        Empty our store of pools and direct them all to close.
+
+        This will not affect in-flight connections, but they will not be
+        re-used after completion.
+        """
+        self.pools.clear()
+
+    def connection_from_host(self, host, port=None, scheme='http', pool_kwargs=None):
+        """
+        Get a :class:`ConnectionPool` based on the host, port, and scheme.
+
+        If ``port`` isn't given, it will be derived from the ``scheme`` using
+        ``urllib3.connectionpool.port_by_scheme``. If ``pool_kwargs`` is
+        provided, it is merged with the instance's ``connection_pool_kw``
+        variable and used to create the new connection pool, if one is
+        needed.
+        """
+
+        if not host:
+            raise LocationValueError("No host specified.")
+
+        request_context = self._merge_pool_kwargs(pool_kwargs)
+        request_context['scheme'] = scheme or 'http'
+        if not port:
+            port = port_by_scheme.get(request_context['scheme'].lower(), 80)
+        request_context['port'] = port
+        request_context['host'] = host
+
+        return self.connection_from_context(request_context)
+
+    def connection_from_context(self, request_context):
+        """
+        Get a :class:`ConnectionPool` based on the request context.
+
+        ``request_context`` must at least contain the ``scheme`` key and its
+        value must be a key in ``key_fn_by_scheme`` instance variable.
+        """
+        scheme = request_context['scheme'].lower()
+        pool_key_constructor = self.key_fn_by_scheme[scheme]
+        pool_key = pool_key_constructor(request_context)
+
+        return self.connection_from_pool_key(pool_key, request_context=request_context)
+
+    def connection_from_pool_key(self, pool_key, request_context=None):
+        """
+        Get a :class:`ConnectionPool` based on the provided pool key.
+
+        ``pool_key`` should be a namedtuple that only contains immutable
+        objects. At a minimum it must have the ``scheme``, ``host``, and
+        ``port`` fields.
+        """
+        with self.pools.lock:
+            # If the scheme, host, or port doesn't match existing open
+            # connections, open a new ConnectionPool.
+            pool = self.pools.get(pool_key)
+            if pool:
+                return pool
+
+            # Make a fresh ConnectionPool of the desired type
+            scheme = request_context['scheme']
+            host = request_context['host']
+            port = request_context['port']
+            pool = self._new_pool(scheme, host, port, request_context=request_context)
+            self.pools[pool_key] = pool
+
+        return pool
+
+    def connection_from_url(self, url, pool_kwargs=None):
+        """
+        Similar to :func:`urllib3.connectionpool.connection_from_url`.
+
+        If ``pool_kwargs`` is not provided and a new pool needs to be
+        constructed, ``self.connection_pool_kw`` is used to initialize
+        the :class:`urllib3.connectionpool.ConnectionPool`. If ``pool_kwargs``
+        is provided, it is used instead. Note that if a new pool does not
+        need to be created for the request, the provided ``pool_kwargs`` are
+        not used.
+        """
+        u = parse_url(url)
+        return self.connection_from_host(u.host, port=u.port, scheme=u.scheme,
+                                         pool_kwargs=pool_kwargs)
+
+    def _merge_pool_kwargs(self, override):
+        """
+        Merge a dictionary of override values for self.connection_pool_kw.
+
+        This does not modify self.connection_pool_kw and returns a new dict.
+        Any keys in the override dictionary with a value of ``None`` are
+        removed from the merged dictionary.
+        """
+        base_pool_kwargs = self.connection_pool_kw.copy()
+        if override:
+            for key, value in override.items():
+                if value is None:
+                    try:
+                        del base_pool_kwargs[key]
+                    except KeyError:
+                        pass
+                else:
+                    base_pool_kwargs[key] = value
+        return base_pool_kwargs
+
+    def urlopen(self, method, url, redirect=True, **kw):
+        """
+        Same as :meth:`urllib3.connectionpool.HTTPConnectionPool.urlopen`
+        with custom cross-host redirect logic and only sends the request-uri
+        portion of the ``url``.
+
+        The given ``url`` parameter must be absolute, such that an appropriate
+        :class:`urllib3.connectionpool.ConnectionPool` can be chosen for it.
+        """
+        u = parse_url(url)
+        conn = self.connection_from_host(u.host, port=u.port, scheme=u.scheme)
+
+        kw['assert_same_host'] = False
+        kw['redirect'] = False
+
+        if 'headers' not in kw:
+            kw['headers'] = self.headers.copy()
+
+        if self.proxy is not None and u.scheme == "http":
+            response = conn.urlopen(method, url, **kw)
+        else:
+            response = conn.urlopen(method, u.request_uri, **kw)
+
+        redirect_location = redirect and response.get_redirect_location()
+        if not redirect_location:
+            return response
+
+        # Support relative URLs for redirecting.
+        redirect_location = urljoin(url, redirect_location)
+
+        # RFC 7231, Section 6.4.4
+        if response.status == 303:
+            method = 'GET'
+
+        retries = kw.get('retries')
+        if not isinstance(retries, Retry):
+            retries = Retry.from_int(retries, redirect=redirect)
+
+        # Strip headers marked as unsafe to forward to the redirected location.
+        # Check remove_headers_on_redirect to avoid a potential network call within
+        # conn.is_same_host() which may use socket.gethostbyname() in the future.
+        if (retries.remove_headers_on_redirect
+                and not conn.is_same_host(redirect_location)):
+            for header in retries.remove_headers_on_redirect:
+                kw['headers'].pop(header, None)
+
+        try:
+            retries = retries.increment(method, url, response=response, _pool=conn)
+        except MaxRetryError:
+            if retries.raise_on_redirect:
+                raise
+            return response
+
+        kw['retries'] = retries
+        kw['redirect'] = redirect
+
+        log.info("Redirecting %s -> %s", url, redirect_location)
+        return self.urlopen(method, redirect_location, **kw)
+
+
+class ProxyManager(PoolManager):
+    """
+    Behaves just like :class:`PoolManager`, but sends all requests through
+    the defined proxy, using the CONNECT method for HTTPS URLs.
+
+    :param proxy_url:
+        The URL of the proxy to be used.
+
+    :param proxy_headers:
+        A dictionary containing headers that will be sent to the proxy. In case
+        of HTTP they are being sent with each request, while in the
+        HTTPS/CONNECT case they are sent only once. Could be used for proxy
+        authentication.
+
+    Example:
+        >>> proxy = urllib3.ProxyManager('http://localhost:3128/')
+        >>> r1 = proxy.request('GET', 'http://google.com/')
+        >>> r2 = proxy.request('GET', 'http://httpbin.org/')
+        >>> len(proxy.pools)
+        1
+        >>> r3 = proxy.request('GET', 'https://httpbin.org/')
+        >>> r4 = proxy.request('GET', 'https://twitter.com/')
+        >>> len(proxy.pools)
+        3
+
+    """
+
+    def __init__(self, proxy_url, num_pools=10, headers=None,
+                 proxy_headers=None, **connection_pool_kw):
+
+        if isinstance(proxy_url, HTTPConnectionPool):
+            proxy_url = '%s://%s:%i' % (proxy_url.scheme, proxy_url.host,
+                                        proxy_url.port)
+        proxy = parse_url(proxy_url)
+        if not proxy.port:
+            port = port_by_scheme.get(proxy.scheme, 80)
+            proxy = proxy._replace(port=port)
+
+        if proxy.scheme not in ("http", "https"):
+            raise ProxySchemeUnknown(proxy.scheme)
+
+        self.proxy = proxy
+        self.proxy_headers = proxy_headers or {}
+
+        connection_pool_kw['_proxy'] = self.proxy
+        connection_pool_kw['_proxy_headers'] = self.proxy_headers
+
+        super(ProxyManager, self).__init__(
+            num_pools, headers, **connection_pool_kw)
+
+    def connection_from_host(self, host, port=None, scheme='http', pool_kwargs=None):
+        if scheme == "https":
+            return super(ProxyManager, self).connection_from_host(
+                host, port, scheme, pool_kwargs=pool_kwargs)
+
+        return super(ProxyManager, self).connection_from_host(
+            self.proxy.host, self.proxy.port, self.proxy.scheme, pool_kwargs=pool_kwargs)
+
+    def _set_proxy_headers(self, url, headers=None):
+        """
+        Sets headers needed by proxies: specifically, the Accept and Host
+        headers. Only sets headers not provided by the user.
+        """
+        headers_ = {'Accept': '*/*'}
+
+        netloc = parse_url(url).netloc
+        if netloc:
+            headers_['Host'] = netloc
+
+        if headers:
+            headers_.update(headers)
+        return headers_
+
+    def urlopen(self, method, url, redirect=True, **kw):
+        "Same as HTTP(S)ConnectionPool.urlopen, ``url`` must be absolute."
+        u = parse_url(url)
+
+        if u.scheme == "http":
+            # For proxied HTTPS requests, httplib sets the necessary headers
+            # on the CONNECT to the proxy. For HTTP, we'll definitely
+            # need to set 'Host' at the very least.
+            headers = kw.get('headers', self.headers)
+            kw['headers'] = self._set_proxy_headers(url, headers)
+
+        return super(ProxyManager, self).urlopen(method, url, redirect=redirect, **kw)
+
+
+def proxy_from_url(url, **kw):
+    return ProxyManager(proxy_url=url, **kw)
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/poolmanager.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/poolmanager.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..382ed2b16db47cceaa791e1cd37d415b98100beb
GIT binary patch
literal 16523
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
aV-;fNG-YNKW)x#)W@KmNViEfw77hSeldr-6

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/request.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/request.py
new file mode 100644
index 0000000..8f2f44b
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/request.py
@@ -0,0 +1,150 @@
+from __future__ import absolute_import
+
+from .filepost import encode_multipart_formdata
+from .packages.six.moves.urllib.parse import urlencode
+
+
+__all__ = ['RequestMethods']
+
+
+class RequestMethods(object):
+    """
+    Convenience mixin for classes who implement a :meth:`urlopen` method, such
+    as :class:`~urllib3.connectionpool.HTTPConnectionPool` and
+    :class:`~urllib3.poolmanager.PoolManager`.
+
+    Provides behavior for making common types of HTTP request methods and
+    decides which type of request field encoding to use.
+
+    Specifically,
+
+    :meth:`.request_encode_url` is for sending requests whose fields are
+    encoded in the URL (such as GET, HEAD, DELETE).
+
+    :meth:`.request_encode_body` is for sending requests whose fields are
+    encoded in the *body* of the request using multipart or www-form-urlencoded
+    (such as for POST, PUT, PATCH).
+
+    :meth:`.request` is for making any kind of request, it will look up the
+    appropriate encoding format and use one of the above two methods to make
+    the request.
+
+    Initializer parameters:
+
+    :param headers:
+        Headers to include with all requests, unless other headers are given
+        explicitly.
+    """
+
+    _encode_url_methods = {'DELETE', 'GET', 'HEAD', 'OPTIONS'}
+
+    def __init__(self, headers=None):
+        self.headers = headers or {}
+
+    def urlopen(self, method, url, body=None, headers=None,
+                encode_multipart=True, multipart_boundary=None,
+                **kw):  # Abstract
+        raise NotImplementedError("Classes extending RequestMethods must implement "
+                                  "their own ``urlopen`` method.")
+
+    def request(self, method, url, fields=None, headers=None, **urlopen_kw):
+        """
+        Make a request using :meth:`urlopen` with the appropriate encoding of
+        ``fields`` based on the ``method`` used.
+
+        This is a convenience method that requires the least amount of manual
+        effort. It can be used in most situations, while still having the
+        option to drop down to more specific methods when necessary, such as
+        :meth:`request_encode_url`, :meth:`request_encode_body`,
+        or even the lowest level :meth:`urlopen`.
+        """
+        method = method.upper()
+
+        urlopen_kw['request_url'] = url
+
+        if method in self._encode_url_methods:
+            return self.request_encode_url(method, url, fields=fields,
+                                           headers=headers,
+                                           **urlopen_kw)
+        else:
+            return self.request_encode_body(method, url, fields=fields,
+                                            headers=headers,
+                                            **urlopen_kw)
+
+    def request_encode_url(self, method, url, fields=None, headers=None,
+                           **urlopen_kw):
+        """
+        Make a request using :meth:`urlopen` with the ``fields`` encoded in
+        the url. This is useful for request methods like GET, HEAD, DELETE, etc.
+        """
+        if headers is None:
+            headers = self.headers
+
+        extra_kw = {'headers': headers}
+        extra_kw.update(urlopen_kw)
+
+        if fields:
+            url += '?' + urlencode(fields)
+
+        return self.urlopen(method, url, **extra_kw)
+
+    def request_encode_body(self, method, url, fields=None, headers=None,
+                            encode_multipart=True, multipart_boundary=None,
+                            **urlopen_kw):
+        """
+        Make a request using :meth:`urlopen` with the ``fields`` encoded in
+        the body. This is useful for request methods like POST, PUT, PATCH, etc.
+
+        When ``encode_multipart=True`` (default), then
+        :meth:`urllib3.filepost.encode_multipart_formdata` is used to encode
+        the payload with the appropriate content type. Otherwise
+        :meth:`urllib.urlencode` is used with the
+        'application/x-www-form-urlencoded' content type.
+
+        Multipart encoding must be used when posting files, and it's reasonably
+        safe to use it in other times too. However, it may break request
+        signing, such as with OAuth.
+
+        Supports an optional ``fields`` parameter of key/value strings AND
+        key/filetuple. A filetuple is a (filename, data, MIME type) tuple where
+        the MIME type is optional. For example::
+
+            fields = {
+                'foo': 'bar',
+                'fakefile': ('foofile.txt', 'contents of foofile'),
+                'realfile': ('barfile.txt', open('realfile').read()),
+                'typedfile': ('bazfile.bin', open('bazfile').read(),
+                              'image/jpeg'),
+                'nonamefile': 'contents of nonamefile field',
+            }
+
+        When uploading a file, providing a filename (the first parameter of the
+        tuple) is optional but recommended to best mimic behavior of browsers.
+
+        Note that if ``headers`` are supplied, the 'Content-Type' header will
+        be overwritten because it depends on the dynamic random boundary string
+        which is used to compose the body of the request. The random boundary
+        string can be explicitly set with the ``multipart_boundary`` parameter.
+        """
+        if headers is None:
+            headers = self.headers
+
+        extra_kw = {'headers': {}}
+
+        if fields:
+            if 'body' in urlopen_kw:
+                raise TypeError(
+                    "request got values for both 'fields' and 'body', can only specify one.")
+
+            if encode_multipart:
+                body, content_type = encode_multipart_formdata(fields, boundary=multipart_boundary)
+            else:
+                body, content_type = urlencode(fields), 'application/x-www-form-urlencoded'
+
+            extra_kw['body'] = body
+            extra_kw['headers'] = {'Content-Type': content_type}
+
+        extra_kw['headers'].update(headers)
+        extra_kw.update(urlopen_kw)
+
+        return self.urlopen(method, url, **extra_kw)
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/request.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/request.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..3675f2badeb35b1912eccace7c9088a52112e0e0
GIT binary patch
literal 6445
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

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/response.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/response.py
new file mode 100644
index 0000000..c112690
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/response.py
@@ -0,0 +1,705 @@
+from __future__ import absolute_import
+from contextlib import contextmanager
+import zlib
+import io
+import logging
+from socket import timeout as SocketTimeout
+from socket import error as SocketError
+
+from ._collections import HTTPHeaderDict
+from .exceptions import (
+    BodyNotHttplibCompatible, ProtocolError, DecodeError, ReadTimeoutError,
+    ResponseNotChunked, IncompleteRead, InvalidHeader
+)
+from .packages.six import string_types as basestring, PY3
+from .packages.six.moves import http_client as httplib
+from .connection import HTTPException, BaseSSLError
+from .util.response import is_fp_closed, is_response_to_head
+
+log = logging.getLogger(__name__)
+
+
+class DeflateDecoder(object):
+
+    def __init__(self):
+        self._first_try = True
+        self._data = b''
+        self._obj = zlib.decompressobj()
+
+    def __getattr__(self, name):
+        return getattr(self._obj, name)
+
+    def decompress(self, data):
+        if not data:
+            return data
+
+        if not self._first_try:
+            return self._obj.decompress(data)
+
+        self._data += data
+        try:
+            decompressed = self._obj.decompress(data)
+            if decompressed:
+                self._first_try = False
+                self._data = None
+            return decompressed
+        except zlib.error:
+            self._first_try = False
+            self._obj = zlib.decompressobj(-zlib.MAX_WBITS)
+            try:
+                return self.decompress(self._data)
+            finally:
+                self._data = None
+
+
+class GzipDecoderState(object):
+
+    FIRST_MEMBER = 0
+    OTHER_MEMBERS = 1
+    SWALLOW_DATA = 2
+
+
+class GzipDecoder(object):
+
+    def __init__(self):
+        self._obj = zlib.decompressobj(16 + zlib.MAX_WBITS)
+        self._state = GzipDecoderState.FIRST_MEMBER
+
+    def __getattr__(self, name):
+        return getattr(self._obj, name)
+
+    def decompress(self, data):
+        ret = bytearray()
+        if self._state == GzipDecoderState.SWALLOW_DATA or not data:
+            return bytes(ret)
+        while True:
+            try:
+                ret += self._obj.decompress(data)
+            except zlib.error:
+                previous_state = self._state
+                # Ignore data after the first error
+                self._state = GzipDecoderState.SWALLOW_DATA
+                if previous_state == GzipDecoderState.OTHER_MEMBERS:
+                    # Allow trailing garbage acceptable in other gzip clients
+                    return bytes(ret)
+                raise
+            data = self._obj.unused_data
+            if not data:
+                return bytes(ret)
+            self._state = GzipDecoderState.OTHER_MEMBERS
+            self._obj = zlib.decompressobj(16 + zlib.MAX_WBITS)
+
+
+class MultiDecoder(object):
+    """
+    From RFC7231:
+        If one or more encodings have been applied to a representation, the
+        sender that applied the encodings MUST generate a Content-Encoding
+        header field that lists the content codings in the order in which
+        they were applied.
+    """
+
+    def __init__(self, modes):
+        self._decoders = [_get_decoder(m.strip()) for m in modes.split(',')]
+
+    def flush(self):
+        return self._decoders[0].flush()
+
+    def decompress(self, data):
+        for d in reversed(self._decoders):
+            data = d.decompress(data)
+        return data
+
+
+def _get_decoder(mode):
+    if ',' in mode:
+        return MultiDecoder(mode)
+
+    if mode == 'gzip':
+        return GzipDecoder()
+
+    return DeflateDecoder()
+
+
+class HTTPResponse(io.IOBase):
+    """
+    HTTP Response container.
+
+    Backwards-compatible to httplib's HTTPResponse but the response ``body`` is
+    loaded and decoded on-demand when the ``data`` property is accessed.  This
+    class is also compatible with the Python standard library's :mod:`io`
+    module, and can hence be treated as a readable object in the context of that
+    framework.
+
+    Extra parameters for behaviour not present in httplib.HTTPResponse:
+
+    :param preload_content:
+        If True, the response's body will be preloaded during construction.
+
+    :param decode_content:
+        If True, will attempt to decode the body based on the
+        'content-encoding' header.
+
+    :param original_response:
+        When this HTTPResponse wrapper is generated from an httplib.HTTPResponse
+        object, it's convenient to include the original for debug purposes. It's
+        otherwise unused.
+
+    :param retries:
+        The retries contains the last :class:`~urllib3.util.retry.Retry` that
+        was used during the request.
+
+    :param enforce_content_length:
+        Enforce content length checking. Body returned by server must match
+        value of Content-Length header, if present. Otherwise, raise error.
+    """
+
+    CONTENT_DECODERS = ['gzip', 'deflate']
+    REDIRECT_STATUSES = [301, 302, 303, 307, 308]
+
+    def __init__(self, body='', headers=None, status=0, version=0, reason=None,
+                 strict=0, preload_content=True, decode_content=True,
+                 original_response=None, pool=None, connection=None, msg=None,
+                 retries=None, enforce_content_length=False,
+                 request_method=None, request_url=None):
+
+        if isinstance(headers, HTTPHeaderDict):
+            self.headers = headers
+        else:
+            self.headers = HTTPHeaderDict(headers)
+        self.status = status
+        self.version = version
+        self.reason = reason
+        self.strict = strict
+        self.decode_content = decode_content
+        self.retries = retries
+        self.enforce_content_length = enforce_content_length
+
+        self._decoder = None
+        self._body = None
+        self._fp = None
+        self._original_response = original_response
+        self._fp_bytes_read = 0
+        self.msg = msg
+        self._request_url = request_url
+
+        if body and isinstance(body, (basestring, bytes)):
+            self._body = body
+
+        self._pool = pool
+        self._connection = connection
+
+        if hasattr(body, 'read'):
+            self._fp = body
+
+        # Are we using the chunked-style of transfer encoding?
+        self.chunked = False
+        self.chunk_left = None
+        tr_enc = self.headers.get('transfer-encoding', '').lower()
+        # Don't incur the penalty of creating a list and then discarding it
+        encodings = (enc.strip() for enc in tr_enc.split(","))
+        if "chunked" in encodings:
+            self.chunked = True
+
+        # Determine length of response
+        self.length_remaining = self._init_length(request_method)
+
+        # If requested, preload the body.
+        if preload_content and not self._body:
+            self._body = self.read(decode_content=decode_content)
+
+    def get_redirect_location(self):
+        """
+        Should we redirect and where to?
+
+        :returns: Truthy redirect location string if we got a redirect status
+            code and valid location. ``None`` if redirect status and no
+            location. ``False`` if not a redirect status code.
+        """
+        if self.status in self.REDIRECT_STATUSES:
+            return self.headers.get('location')
+
+        return False
+
+    def release_conn(self):
+        if not self._pool or not self._connection:
+            return
+
+        self._pool._put_conn(self._connection)
+        self._connection = None
+
+    @property
+    def data(self):
+        # For backwords-compat with earlier urllib3 0.4 and earlier.
+        if self._body:
+            return self._body
+
+        if self._fp:
+            return self.read(cache_content=True)
+
+    @property
+    def connection(self):
+        return self._connection
+
+    def isclosed(self):
+        return is_fp_closed(self._fp)
+
+    def tell(self):
+        """
+        Obtain the number of bytes pulled over the wire so far. May differ from
+        the amount of content returned by :meth:``HTTPResponse.read`` if bytes
+        are encoded on the wire (e.g, compressed).
+        """
+        return self._fp_bytes_read
+
+    def _init_length(self, request_method):
+        """
+        Set initial length value for Response content if available.
+        """
+        length = self.headers.get('content-length')
+
+        if length is not None:
+            if self.chunked:
+                # This Response will fail with an IncompleteRead if it can't be
+                # received as chunked. This method falls back to attempt reading
+                # the response before raising an exception.
+                log.warning("Received response with both Content-Length and "
+                            "Transfer-Encoding set. This is expressly forbidden "
+                            "by RFC 7230 sec 3.3.2. Ignoring Content-Length and "
+                            "attempting to process response as Transfer-Encoding: "
+                            "chunked.")
+                return None
+
+            try:
+                # RFC 7230 section 3.3.2 specifies multiple content lengths can
+                # be sent in a single Content-Length header
+                # (e.g. Content-Length: 42, 42). This line ensures the values
+                # are all valid ints and that as long as the `set` length is 1,
+                # all values are the same. Otherwise, the header is invalid.
+                lengths = set([int(val) for val in length.split(',')])
+                if len(lengths) > 1:
+                    raise InvalidHeader("Content-Length contained multiple "
+                                        "unmatching values (%s)" % length)
+                length = lengths.pop()
+            except ValueError:
+                length = None
+            else:
+                if length < 0:
+                    length = None
+
+        # Convert status to int for comparison
+        # In some cases, httplib returns a status of "_UNKNOWN"
+        try:
+            status = int(self.status)
+        except ValueError:
+            status = 0
+
+        # Check for responses that shouldn't include a body
+        if status in (204, 304) or 100 <= status < 200 or request_method == 'HEAD':
+            length = 0
+
+        return length
+
+    def _init_decoder(self):
+        """
+        Set-up the _decoder attribute if necessary.
+        """
+        # Note: content-encoding value should be case-insensitive, per RFC 7230
+        # Section 3.2
+        content_encoding = self.headers.get('content-encoding', '').lower()
+        if self._decoder is None:
+            if content_encoding in self.CONTENT_DECODERS:
+                self._decoder = _get_decoder(content_encoding)
+            elif ',' in content_encoding:
+                encodings = [e.strip() for e in content_encoding.split(',') if e.strip() in self.CONTENT_DECODERS]
+                if len(encodings):
+                    self._decoder = _get_decoder(content_encoding)
+
+    def _decode(self, data, decode_content, flush_decoder):
+        """
+        Decode the data passed in and potentially flush the decoder.
+        """
+        try:
+            if decode_content and self._decoder:
+                data = self._decoder.decompress(data)
+        except (IOError, zlib.error) as e:
+            content_encoding = self.headers.get('content-encoding', '').lower()
+            raise DecodeError(
+                "Received response with content-encoding: %s, but "
+                "failed to decode it." % content_encoding, e)
+
+        if flush_decoder and decode_content:
+            data += self._flush_decoder()
+
+        return data
+
+    def _flush_decoder(self):
+        """
+        Flushes the decoder. Should only be called if the decoder is actually
+        being used.
+        """
+        if self._decoder:
+            buf = self._decoder.decompress(b'')
+            return buf + self._decoder.flush()
+
+        return b''
+
+    @contextmanager
+    def _error_catcher(self):
+        """
+        Catch low-level python exceptions, instead re-raising urllib3
+        variants, so that low-level exceptions are not leaked in the
+        high-level api.
+
+        On exit, release the connection back to the pool.
+        """
+        clean_exit = False
+
+        try:
+            try:
+                yield
+
+            except SocketTimeout:
+                # FIXME: Ideally we'd like to include the url in the ReadTimeoutError but
+                # there is yet no clean way to get at it from this context.
+                raise ReadTimeoutError(self._pool, None, 'Read timed out.')
+
+            except BaseSSLError as e:
+                # FIXME: Is there a better way to differentiate between SSLErrors?
+                if 'read operation timed out' not in str(e):  # Defensive:
+                    # This shouldn't happen but just in case we're missing an edge
+                    # case, let's avoid swallowing SSL errors.
+                    raise
+
+                raise ReadTimeoutError(self._pool, None, 'Read timed out.')
+
+            except (HTTPException, SocketError) as e:
+                # This includes IncompleteRead.
+                raise ProtocolError('Connection broken: %r' % e, e)
+
+            # If no exception is thrown, we should avoid cleaning up
+            # unnecessarily.
+            clean_exit = True
+        finally:
+            # If we didn't terminate cleanly, we need to throw away our
+            # connection.
+            if not clean_exit:
+                # The response may not be closed but we're not going to use it
+                # anymore so close it now to ensure that the connection is
+                # released back to the pool.
+                if self._original_response:
+                    self._original_response.close()
+
+                # Closing the response may not actually be sufficient to close
+                # everything, so if we have a hold of the connection close that
+                # too.
+                if self._connection:
+                    self._connection.close()
+
+            # If we hold the original response but it's closed now, we should
+            # return the connection back to the pool.
+            if self._original_response and self._original_response.isclosed():
+                self.release_conn()
+
+    def read(self, amt=None, decode_content=None, cache_content=False):
+        """
+        Similar to :meth:`httplib.HTTPResponse.read`, but with two additional
+        parameters: ``decode_content`` and ``cache_content``.
+
+        :param amt:
+            How much of the content to read. If specified, caching is skipped
+            because it doesn't make sense to cache partial content as the full
+            response.
+
+        :param decode_content:
+            If True, will attempt to decode the body based on the
+            'content-encoding' header.
+
+        :param cache_content:
+            If True, will save the returned data such that the same result is
+            returned despite of the state of the underlying file object. This
+            is useful if you want the ``.data`` property to continue working
+            after having ``.read()`` the file object. (Overridden if ``amt`` is
+            set.)
+        """
+        self._init_decoder()
+        if decode_content is None:
+            decode_content = self.decode_content
+
+        if self._fp is None:
+            return
+
+        flush_decoder = False
+        data = None
+
+        with self._error_catcher():
+            if amt is None:
+                # cStringIO doesn't like amt=None
+                data = self._fp.read()
+                flush_decoder = True
+            else:
+                cache_content = False
+                data = self._fp.read(amt)
+                if amt != 0 and not data:  # Platform-specific: Buggy versions of Python.
+                    # Close the connection when no data is returned
+                    #
+                    # This is redundant to what httplib/http.client _should_
+                    # already do.  However, versions of python released before
+                    # December 15, 2012 (http://bugs.python.org/issue16298) do
+                    # not properly close the connection in all cases. There is
+                    # no harm in redundantly calling close.
+                    self._fp.close()
+                    flush_decoder = True
+                    if self.enforce_content_length and self.length_remaining not in (0, None):
+                        # This is an edge case that httplib failed to cover due
+                        # to concerns of backward compatibility. We're
+                        # addressing it here to make sure IncompleteRead is
+                        # raised during streaming, so all calls with incorrect
+                        # Content-Length are caught.
+                        raise IncompleteRead(self._fp_bytes_read, self.length_remaining)
+
+        if data:
+            self._fp_bytes_read += len(data)
+            if self.length_remaining is not None:
+                self.length_remaining -= len(data)
+
+            data = self._decode(data, decode_content, flush_decoder)
+
+            if cache_content:
+                self._body = data
+
+        return data
+
+    def stream(self, amt=2**16, decode_content=None):
+        """
+        A generator wrapper for the read() method. A call will block until
+        ``amt`` bytes have been read from the connection or until the
+        connection is closed.
+
+        :param amt:
+            How much of the content to read. The generator will return up to
+            much data per iteration, but may return less. This is particularly
+            likely when using compressed data. However, the empty string will
+            never be returned.
+
+        :param decode_content:
+            If True, will attempt to decode the body based on the
+            'content-encoding' header.
+        """
+        if self.chunked and self.supports_chunked_reads():
+            for line in self.read_chunked(amt, decode_content=decode_content):
+                yield line
+        else:
+            while not is_fp_closed(self._fp):
+                data = self.read(amt=amt, decode_content=decode_content)
+
+                if data:
+                    yield data
+
+    @classmethod
+    def from_httplib(ResponseCls, r, **response_kw):
+        """
+        Given an :class:`httplib.HTTPResponse` instance ``r``, return a
+        corresponding :class:`urllib3.response.HTTPResponse` object.
+
+        Remaining parameters are passed to the HTTPResponse constructor, along
+        with ``original_response=r``.
+        """
+        headers = r.msg
+
+        if not isinstance(headers, HTTPHeaderDict):
+            if PY3:  # Python 3
+                headers = HTTPHeaderDict(headers.items())
+            else:  # Python 2
+                headers = HTTPHeaderDict.from_httplib(headers)
+
+        # HTTPResponse objects in Python 3 don't have a .strict attribute
+        strict = getattr(r, 'strict', 0)
+        resp = ResponseCls(body=r,
+                           headers=headers,
+                           status=r.status,
+                           version=r.version,
+                           reason=r.reason,
+                           strict=strict,
+                           original_response=r,
+                           **response_kw)
+        return resp
+
+    # Backwards-compatibility methods for httplib.HTTPResponse
+    def getheaders(self):
+        return self.headers
+
+    def getheader(self, name, default=None):
+        return self.headers.get(name, default)
+
+    # Backwards compatibility for http.cookiejar
+    def info(self):
+        return self.headers
+
+    # Overrides from io.IOBase
+    def close(self):
+        if not self.closed:
+            self._fp.close()
+
+        if self._connection:
+            self._connection.close()
+
+    @property
+    def closed(self):
+        if self._fp is None:
+            return True
+        elif hasattr(self._fp, 'isclosed'):
+            return self._fp.isclosed()
+        elif hasattr(self._fp, 'closed'):
+            return self._fp.closed
+        else:
+            return True
+
+    def fileno(self):
+        if self._fp is None:
+            raise IOError("HTTPResponse has no file to get a fileno from")
+        elif hasattr(self._fp, "fileno"):
+            return self._fp.fileno()
+        else:
+            raise IOError("The file-like object this HTTPResponse is wrapped "
+                          "around has no file descriptor")
+
+    def flush(self):
+        if self._fp is not None and hasattr(self._fp, 'flush'):
+            return self._fp.flush()
+
+    def readable(self):
+        # This method is required for `io` module compatibility.
+        return True
+
+    def readinto(self, b):
+        # This method is required for `io` module compatibility.
+        temp = self.read(len(b))
+        if len(temp) == 0:
+            return 0
+        else:
+            b[:len(temp)] = temp
+            return len(temp)
+
+    def supports_chunked_reads(self):
+        """
+        Checks if the underlying file-like object looks like a
+        httplib.HTTPResponse object. We do this by testing for the fp
+        attribute. If it is present we assume it returns raw chunks as
+        processed by read_chunked().
+        """
+        return hasattr(self._fp, 'fp')
+
+    def _update_chunk_length(self):
+        # First, we'll figure out length of a chunk and then
+        # we'll try to read it from socket.
+        if self.chunk_left is not None:
+            return
+        line = self._fp.fp.readline()
+        line = line.split(b';', 1)[0]
+        try:
+            self.chunk_left = int(line, 16)
+        except ValueError:
+            # Invalid chunked protocol response, abort.
+            self.close()
+            raise httplib.IncompleteRead(line)
+
+    def _handle_chunk(self, amt):
+        returned_chunk = None
+        if amt is None:
+            chunk = self._fp._safe_read(self.chunk_left)
+            returned_chunk = chunk
+            self._fp._safe_read(2)  # Toss the CRLF at the end of the chunk.
+            self.chunk_left = None
+        elif amt < self.chunk_left:
+            value = self._fp._safe_read(amt)
+            self.chunk_left = self.chunk_left - amt
+            returned_chunk = value
+        elif amt == self.chunk_left:
+            value = self._fp._safe_read(amt)
+            self._fp._safe_read(2)  # Toss the CRLF at the end of the chunk.
+            self.chunk_left = None
+            returned_chunk = value
+        else:  # amt > self.chunk_left
+            returned_chunk = self._fp._safe_read(self.chunk_left)
+            self._fp._safe_read(2)  # Toss the CRLF at the end of the chunk.
+            self.chunk_left = None
+        return returned_chunk
+
+    def read_chunked(self, amt=None, decode_content=None):
+        """
+        Similar to :meth:`HTTPResponse.read`, but with an additional
+        parameter: ``decode_content``.
+
+        :param amt:
+            How much of the content to read. If specified, caching is skipped
+            because it doesn't make sense to cache partial content as the full
+            response.
+
+        :param decode_content:
+            If True, will attempt to decode the body based on the
+            'content-encoding' header.
+        """
+        self._init_decoder()
+        # FIXME: Rewrite this method and make it a class with a better structured logic.
+        if not self.chunked:
+            raise ResponseNotChunked(
+                "Response is not chunked. "
+                "Header 'transfer-encoding: chunked' is missing.")
+        if not self.supports_chunked_reads():
+            raise BodyNotHttplibCompatible(
+                "Body should be httplib.HTTPResponse like. "
+                "It should have have an fp attribute which returns raw chunks.")
+
+        with self._error_catcher():
+            # Don't bother reading the body of a HEAD request.
+            if self._original_response and is_response_to_head(self._original_response):
+                self._original_response.close()
+                return
+
+            # If a response is already read and closed
+            # then return immediately.
+            if self._fp.fp is None:
+                return
+
+            while True:
+                self._update_chunk_length()
+                if self.chunk_left == 0:
+                    break
+                chunk = self._handle_chunk(amt)
+                decoded = self._decode(chunk, decode_content=decode_content,
+                                       flush_decoder=False)
+                if decoded:
+                    yield decoded
+
+            if decode_content:
+                # On CPython and PyPy, we should never need to flush the
+                # decoder. However, on Jython we *might* need to, so
+                # lets defensively do it anyway.
+                decoded = self._flush_decoder()
+                if decoded:  # Platform-specific: Jython.
+                    yield decoded
+
+            # Chunk content ends with \r\n: discard it.
+            while True:
+                line = self._fp.fp.readline()
+                if not line:
+                    # Some sites may not end with '\r\n'.
+                    break
+                if line == b'\r\n':
+                    break
+
+            # We read everything; close the "file".
+            if self._original_response:
+                self._original_response.close()
+
+    def geturl(self):
+        """
+        Returns the URL that was the source of this response.
+        If the request that generated this response redirected, this method
+        will return the final redirect location.
+        """
+        if self.retries is not None and len(self.retries.history):
+            return self.retries.history[-1].redirect_location
+        else:
+            return self._request_url
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/response.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/response.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..824840aabeed37e4906fed762c30dfffd1a25ace
GIT binary patch
literal 24614
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

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/util/__init__.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/util/__init__.py
new file mode 100644
index 0000000..2f2770b
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/util/__init__.py
@@ -0,0 +1,54 @@
+from __future__ import absolute_import
+# For backwards compatibility, provide imports that used to be here.
+from .connection import is_connection_dropped
+from .request import make_headers
+from .response import is_fp_closed
+from .ssl_ import (
+    SSLContext,
+    HAS_SNI,
+    IS_PYOPENSSL,
+    IS_SECURETRANSPORT,
+    assert_fingerprint,
+    resolve_cert_reqs,
+    resolve_ssl_version,
+    ssl_wrap_socket,
+)
+from .timeout import (
+    current_time,
+    Timeout,
+)
+
+from .retry import Retry
+from .url import (
+    get_host,
+    parse_url,
+    split_first,
+    Url,
+)
+from .wait import (
+    wait_for_read,
+    wait_for_write
+)
+
+__all__ = (
+    'HAS_SNI',
+    'IS_PYOPENSSL',
+    'IS_SECURETRANSPORT',
+    'SSLContext',
+    'Retry',
+    'Timeout',
+    'Url',
+    'assert_fingerprint',
+    'current_time',
+    'is_connection_dropped',
+    'is_fp_closed',
+    'get_host',
+    'parse_url',
+    'make_headers',
+    'resolve_cert_reqs',
+    'resolve_ssl_version',
+    'split_first',
+    'ssl_wrap_socket',
+    'wait_for_read',
+    'wait_for_write'
+)
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/util/__init__.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/util/__init__.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..9b9f968bb3dbf2e63c121b7aa34c45f57b4eace9
GIT binary patch
literal 1567
zcmZSn%**AGdLky70SZJI7#JKJ7#NBlF)%QsFfgPrGUPBY<T5fuF)}cwFfpVsGvqKa
z<T5ivF+=z)3^^<exvUIPtPnmcLk=55E;~aMJA}{1ki)@{%gGSM$&ky%5XHri%gqqQ
z&5+B(5XHlg%gYeO%aF^*5XHxk%g+$S&yXv?5G4T7$<B}?$dD_<5GBNrE6flj3=!pE
z$Pr=46=jGLh448Ua>N*N#TlZ+8FD2Uq9hn{B^jb58FHl<qNE@yxEOMz8FFP9qGT9y
zWf`Jm85mO(7^37DQsfzeH53^b7&1YA*I;B|U?|~dU|>j0D$dU-ElG{f%q_?-D#-*%
zKx9Qhii_iu^YijjlS?x5^WsyA@(T)5Qy|hj3=9mpiP@>~8L5dWsYS&I(ahrbw1W8L
zoc!X{6b%lLMO+LF48g%Z&iQ#IsTCz9><kPH9*)8B!G4}4AY(j(;{zi716=)rgMCVb
z7#J8lgX4o;okN3MLxLRrf&=`6Lcqd_#l@*bCGlyQdFiP|1x1;8B_)Ck3=Bo7#rZj9
zsqx7m$)eQ4;u2vb(c<Eq__EZZ;>`R!u!lkX@}k6o_~QKJ?9>tsCXfR`u1GE|DoV{O
zi7&~_O$9qKBr`WPzqAD6F;)f!hM?4vqDl=GkOq*q(o;*~GxCc|N;nx97zz@Lic{lD
zi*ic185kIf3vx0+4lOD!DPd+{U<fVBfmp=Lz`#(R2$IV$iZ4n{Oex_*7AY^vEJ+Ol
z+r<X5kR3#TEDQoE3j*m50tHYI$o?RZtAjuh76h^*2o#+`0w5hAKLvqY6$A?TAW$F$
zft(ct3YZ{Js`t|Xk;NeMp)pYmG7UK<ia{1(#zZm5NJL~7gB=SB7_ec`Fe?T*D6}XC
zYzAhuf$c&L?_!*Z4XhM7MHPd*4h#BXkSF0m4_1quCW}En$4DN<piqE`f|3I?c@%?!
z2r1@@K>-SqM@lZmpeR6zz+zC$z(v3js38wZBA{@Jk54NtDJ@Ekj}HQ6yAqHXB13`W
z4xH4AQVUB{i%Wt)5my58U{PvuL4ICwDmZ3KKq&y^kRT8PJ$ZnXBSkjI6JRqz={Uc%
z1d>WX&MpB(RS_tvz^MtGFiVSakkSn(xWMTPY$M21h!g`hGd?~sCnr8$1LPS5QCz~n
zz@T4Hlv$QolB!>pSfrnpp93lr^pjHb%afAwa!qrKjSQ2_)2q@gOfAZDvZ~AsKp;I&
zKSaMEvp_d9uec;JCr8(<%)`?-03-y)@nxxbDfvbErA0Y8nMua_r6rj;`tk9Zd6^~g
u@p=W7;GnX}%}*)KNwouIgklQ@1_l8p0Y(tC;u2#OU{qogV`E?>1_A)a@?{bL

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/util/connection.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/util/connection.py
new file mode 100644
index 0000000..5ad70b2
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/util/connection.py
@@ -0,0 +1,134 @@
+from __future__ import absolute_import
+import socket
+from .wait import NoWayToWaitForSocketError, wait_for_read
+from ..contrib import _appengine_environ
+
+
+def is_connection_dropped(conn):  # Platform-specific
+    """
+    Returns True if the connection is dropped and should be closed.
+
+    :param conn:
+        :class:`httplib.HTTPConnection` object.
+
+    Note: For platforms like AppEngine, this will always return ``False`` to
+    let the platform handle connection recycling transparently for us.
+    """
+    sock = getattr(conn, 'sock', False)
+    if sock is False:  # Platform-specific: AppEngine
+        return False
+    if sock is None:  # Connection already closed (such as by httplib).
+        return True
+    try:
+        # Returns True if readable, which here means it's been dropped
+        return wait_for_read(sock, timeout=0.0)
+    except NoWayToWaitForSocketError:  # Platform-specific: AppEngine
+        return False
+
+
+# This function is copied from socket.py in the Python 2.7 standard
+# library test suite. Added to its signature is only `socket_options`.
+# One additional modification is that we avoid binding to IPv6 servers
+# discovered in DNS if the system doesn't have IPv6 functionality.
+def create_connection(address, timeout=socket._GLOBAL_DEFAULT_TIMEOUT,
+                      source_address=None, socket_options=None):
+    """Connect to *address* and return the socket object.
+
+    Convenience function.  Connect to *address* (a 2-tuple ``(host,
+    port)``) and return the socket object.  Passing the optional
+    *timeout* parameter will set the timeout on the socket instance
+    before attempting to connect.  If no *timeout* is supplied, the
+    global default timeout setting returned by :func:`getdefaulttimeout`
+    is used.  If *source_address* is set it must be a tuple of (host, port)
+    for the socket to bind as a source address before making the connection.
+    An host of '' or port 0 tells the OS to use the default.
+    """
+
+    host, port = address
+    if host.startswith('['):
+        host = host.strip('[]')
+    err = None
+
+    # Using the value from allowed_gai_family() in the context of getaddrinfo lets
+    # us select whether to work with IPv4 DNS records, IPv6 records, or both.
+    # The original create_connection function always returns all records.
+    family = allowed_gai_family()
+
+    for res in socket.getaddrinfo(host, port, family, socket.SOCK_STREAM):
+        af, socktype, proto, canonname, sa = res
+        sock = None
+        try:
+            sock = socket.socket(af, socktype, proto)
+
+            # If provided, set socket level options before connecting.
+            _set_socket_options(sock, socket_options)
+
+            if timeout is not socket._GLOBAL_DEFAULT_TIMEOUT:
+                sock.settimeout(timeout)
+            if source_address:
+                sock.bind(source_address)
+            sock.connect(sa)
+            return sock
+
+        except socket.error as e:
+            err = e
+            if sock is not None:
+                sock.close()
+                sock = None
+
+    if err is not None:
+        raise err
+
+    raise socket.error("getaddrinfo returns an empty list")
+
+
+def _set_socket_options(sock, options):
+    if options is None:
+        return
+
+    for opt in options:
+        sock.setsockopt(*opt)
+
+
+def allowed_gai_family():
+    """This function is designed to work in the context of
+    getaddrinfo, where family=socket.AF_UNSPEC is the default and
+    will perform a DNS search for both IPv6 and IPv4 records."""
+
+    family = socket.AF_INET
+    if HAS_IPV6:
+        family = socket.AF_UNSPEC
+    return family
+
+
+def _has_ipv6(host):
+    """ Returns True if the system can bind an IPv6 address. """
+    sock = None
+    has_ipv6 = False
+
+    # App Engine doesn't support IPV6 sockets and actually has a quota on the
+    # number of sockets that can be used, so just early out here instead of
+    # creating a socket needlessly.
+    # See https://github.com/urllib3/urllib3/issues/1446
+    if _appengine_environ.is_appengine_sandbox():
+        return False
+
+    if socket.has_ipv6:
+        # has_ipv6 returns true if cPython was compiled with IPv6 support.
+        # It does not tell us if the system has IPv6 support enabled. To
+        # determine that we must bind to an IPv6 address.
+        # https://github.com/shazow/urllib3/pull/611
+        # https://bugs.python.org/issue658327
+        try:
+            sock = socket.socket(socket.AF_INET6)
+            sock.bind((host, 0))
+            has_ipv6 = True
+        except Exception:
+            pass
+
+    if sock:
+        sock.close()
+    return has_ipv6
+
+
+HAS_IPV6 = _has_ipv6('::1')
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/util/connection.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/util/connection.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..fd37a491e5c9bd8a16fdbd5104795dfd4eba5076
GIT binary patch
literal 4192
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
A(*OVf

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/util/queue.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/util/queue.py
new file mode 100644
index 0000000..d3d379a
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/util/queue.py
@@ -0,0 +1,21 @@
+import collections
+from ..packages import six
+from ..packages.six.moves import queue
+
+if six.PY2:
+    # Queue is imported for side effects on MS Windows. See issue #229.
+    import Queue as _unused_module_Queue  # noqa: F401
+
+
+class LifoQueue(queue.Queue):
+    def _init(self, _):
+        self.queue = collections.deque()
+
+    def _qsize(self, len=len):
+        return len(self.queue)
+
+    def _put(self, item):
+        self.queue.append(item)
+
+    def _get(self):
+        return self.queue.pop()
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/util/queue.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/util/queue.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..0d14a8e626f0b96e7fd7948076ba9487ab88f7f9
GIT binary patch
literal 1665
zcmZSn%**AGdLky70ScHI7#JKF7#NBZ85kH+7#LC*8FCmHq8J!bm>5!+8FCmIa+w&S
zm>3vAd=`crW`<lAhA0*W##APTELMgh7nmkChA4K1JO+joR)$m-hAcLQG)9ILHii}k
zhGqta$S4kw$-x@z3=9mJ|NsC0@0ZEMz`&rv$iTo*0&+ufW(9=9%D})-SejazTEfY|
zz~GaamLCY>!5s|J<^*!EJ_7?oDg#3lBgh3U3?N6QGJ|YsVFWoag$ZPL6f4LVAXzqs
zpkNIa1_p*?kO?sC3^GX=<Ol|aEJl!1YZw^fnLtJcgWcn&0didlH%McCPEKlaNoIat
zaS6zkDXE2}sX-tgXn>3>0U2JLnv+%n5{lOV1u&Q>E@WU}&@U*;EK4j&)h|md(of6J
zNl7g#)=x^&FHcI!%Qej{HZn{yPp?Y1FtsSp$*M9l0D<&8{Sf_v%mUrayyB9?oE%-Z
zG7nGV0FV$E$Cst%rQ{dsmloyZWF{HwmzHGa=!3&fub>j_#Q4m-Ot9OFK`vxq#PmBa
z0|P@1BSQ@XLly%=Gb01c*C0P2{1ycAFF2lZQuDx`0uuw|Gd2bWhWNtb%&JsAQ1s#Q
znh3~iV1H#Xg8bOb$iSGw0QVtC8`y^>AoCIn3R3e@z!3@YEGRZJOHy;e9t9Hv<XezK
z;tNVk1d;p-iX9jRCt+|j!u;Bd&6A*HT##P?PSju@g8c+02GV2csU@Izf~HS!`B1_E
zir@IW#N5>Q_!2HKCpSN(G$%DaJ_uBR1c4L;aWXJ41o40fP$~d>1VIdpmx4fP3gqBo
zkPF!uIhlEwIhi%UE(L`@*k=Wa$=QkNsl`E{0-{8Sfq?-gqF0<*p_iLqmRbx+mmn<x
zkw)O03@!x0K^0$`S6ZB!5)Ta$umsp*gzv$ufe8Yz7i}PJvjZj3Vo-SSFbXgVFmW>R
GGXnr9AAOks

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/util/request.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/util/request.py
new file mode 100644
index 0000000..3ddfcd5
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/util/request.py
@@ -0,0 +1,118 @@
+from __future__ import absolute_import
+from base64 import b64encode
+
+from ..packages.six import b, integer_types
+from ..exceptions import UnrewindableBodyError
+
+ACCEPT_ENCODING = 'gzip,deflate'
+_FAILEDTELL = object()
+
+
+def make_headers(keep_alive=None, accept_encoding=None, user_agent=None,
+                 basic_auth=None, proxy_basic_auth=None, disable_cache=None):
+    """
+    Shortcuts for generating request headers.
+
+    :param keep_alive:
+        If ``True``, adds 'connection: keep-alive' header.
+
+    :param accept_encoding:
+        Can be a boolean, list, or string.
+        ``True`` translates to 'gzip,deflate'.
+        List will get joined by comma.
+        String will be used as provided.
+
+    :param user_agent:
+        String representing the user-agent you want, such as
+        "python-urllib3/0.6"
+
+    :param basic_auth:
+        Colon-separated username:password string for 'authorization: basic ...'
+        auth header.
+
+    :param proxy_basic_auth:
+        Colon-separated username:password string for 'proxy-authorization: basic ...'
+        auth header.
+
+    :param disable_cache:
+        If ``True``, adds 'cache-control: no-cache' header.
+
+    Example::
+
+        >>> make_headers(keep_alive=True, user_agent="Batman/1.0")
+        {'connection': 'keep-alive', 'user-agent': 'Batman/1.0'}
+        >>> make_headers(accept_encoding=True)
+        {'accept-encoding': 'gzip,deflate'}
+    """
+    headers = {}
+    if accept_encoding:
+        if isinstance(accept_encoding, str):
+            pass
+        elif isinstance(accept_encoding, list):
+            accept_encoding = ','.join(accept_encoding)
+        else:
+            accept_encoding = ACCEPT_ENCODING
+        headers['accept-encoding'] = accept_encoding
+
+    if user_agent:
+        headers['user-agent'] = user_agent
+
+    if keep_alive:
+        headers['connection'] = 'keep-alive'
+
+    if basic_auth:
+        headers['authorization'] = 'Basic ' + \
+            b64encode(b(basic_auth)).decode('utf-8')
+
+    if proxy_basic_auth:
+        headers['proxy-authorization'] = 'Basic ' + \
+            b64encode(b(proxy_basic_auth)).decode('utf-8')
+
+    if disable_cache:
+        headers['cache-control'] = 'no-cache'
+
+    return headers
+
+
+def set_file_position(body, pos):
+    """
+    If a position is provided, move file to that point.
+    Otherwise, we'll attempt to record a position for future use.
+    """
+    if pos is not None:
+        rewind_body(body, pos)
+    elif getattr(body, 'tell', None) is not None:
+        try:
+            pos = body.tell()
+        except (IOError, OSError):
+            # This differentiates from None, allowing us to catch
+            # a failed `tell()` later when trying to rewind the body.
+            pos = _FAILEDTELL
+
+    return pos
+
+
+def rewind_body(body, body_pos):
+    """
+    Attempt to rewind body to a certain position.
+    Primarily used for request redirects and retries.
+
+    :param body:
+        File-like object that supports seek.
+
+    :param int pos:
+        Position to seek to in file.
+    """
+    body_seek = getattr(body, 'seek', None)
+    if body_seek is not None and isinstance(body_pos, integer_types):
+        try:
+            body_seek(body_pos)
+        except (IOError, OSError):
+            raise UnrewindableBodyError("An error occurred when rewinding request "
+                                        "body for redirect/retry.")
+    elif body_pos is _FAILEDTELL:
+        raise UnrewindableBodyError("Unable to record file position for rewinding "
+                                    "request body during a redirect/retry.")
+    else:
+        raise ValueError("body_pos must be of type integer, "
+                         "instead it was %s." % type(body_pos))
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/util/request.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/util/request.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..5ea7a4f88931732a2a3564e51fc35aabe0109508
GIT binary patch
literal 3945
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
NMowl<Mj=N|Apmgj4gCNB

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/util/response.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/util/response.py
new file mode 100644
index 0000000..3d54864
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/util/response.py
@@ -0,0 +1,87 @@
+from __future__ import absolute_import
+from ..packages.six.moves import http_client as httplib
+
+from ..exceptions import HeaderParsingError
+
+
+def is_fp_closed(obj):
+    """
+    Checks whether a given file-like object is closed.
+
+    :param obj:
+        The file-like object to check.
+    """
+
+    try:
+        # Check `isclosed()` first, in case Python3 doesn't set `closed`.
+        # GH Issue #928
+        return obj.isclosed()
+    except AttributeError:
+        pass
+
+    try:
+        # Check via the official file-like-object way.
+        return obj.closed
+    except AttributeError:
+        pass
+
+    try:
+        # Check if the object is a container for another file-like object that
+        # gets released on exhaustion (e.g. HTTPResponse).
+        return obj.fp is None
+    except AttributeError:
+        pass
+
+    raise ValueError("Unable to determine whether fp is closed.")
+
+
+def assert_header_parsing(headers):
+    """
+    Asserts whether all headers have been successfully parsed.
+    Extracts encountered errors from the result of parsing headers.
+
+    Only works on Python 3.
+
+    :param headers: Headers to verify.
+    :type headers: `httplib.HTTPMessage`.
+
+    :raises urllib3.exceptions.HeaderParsingError:
+        If parsing errors are found.
+    """
+
+    # This will fail silently if we pass in the wrong kind of parameter.
+    # To make debugging easier add an explicit check.
+    if not isinstance(headers, httplib.HTTPMessage):
+        raise TypeError('expected httplib.Message, got {0}.'.format(
+            type(headers)))
+
+    defects = getattr(headers, 'defects', None)
+    get_payload = getattr(headers, 'get_payload', None)
+
+    unparsed_data = None
+    if get_payload:
+        # get_payload is actually email.message.Message.get_payload;
+        # we're only interested in the result if it's not a multipart message
+        if not headers.is_multipart():
+            payload = get_payload()
+
+            if isinstance(payload, (bytes, str)):
+                unparsed_data = payload
+
+    if defects or unparsed_data:
+        raise HeaderParsingError(defects=defects, unparsed_data=unparsed_data)
+
+
+def is_response_to_head(response):
+    """
+    Checks whether the request of a response has been a HEAD-request.
+    Handles the quirks of AppEngine.
+
+    :param conn:
+    :type conn: :class:`httplib.HTTPResponse`
+    """
+    # FIXME: Can we do this somehow without accessing private httplib _method?
+    method = response._method
+    if isinstance(method, int):  # Platform-specific: Appengine
+        return method == 3
+    return method.upper() == 'HEAD'
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/util/response.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/util/response.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..0693d7270bdb58a646b3cebdcbdeaa2651eeef22
GIT binary patch
literal 2583
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

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/util/retry.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/util/retry.py
new file mode 100644
index 0000000..e7d0abd
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/util/retry.py
@@ -0,0 +1,411 @@
+from __future__ import absolute_import
+import time
+import logging
+from collections import namedtuple
+from itertools import takewhile
+import email
+import re
+
+from ..exceptions import (
+    ConnectTimeoutError,
+    MaxRetryError,
+    ProtocolError,
+    ReadTimeoutError,
+    ResponseError,
+    InvalidHeader,
+)
+from ..packages import six
+
+
+log = logging.getLogger(__name__)
+
+
+# Data structure for representing the metadata of requests that result in a retry.
+RequestHistory = namedtuple('RequestHistory', ["method", "url", "error",
+                                               "status", "redirect_location"])
+
+
+class Retry(object):
+    """ Retry configuration.
+
+    Each retry attempt will create a new Retry object with updated values, so
+    they can be safely reused.
+
+    Retries can be defined as a default for a pool::
+
+        retries = Retry(connect=5, read=2, redirect=5)
+        http = PoolManager(retries=retries)
+        response = http.request('GET', 'http://example.com/')
+
+    Or per-request (which overrides the default for the pool)::
+
+        response = http.request('GET', 'http://example.com/', retries=Retry(10))
+
+    Retries can be disabled by passing ``False``::
+
+        response = http.request('GET', 'http://example.com/', retries=False)
+
+    Errors will be wrapped in :class:`~urllib3.exceptions.MaxRetryError` unless
+    retries are disabled, in which case the causing exception will be raised.
+
+    :param int total:
+        Total number of retries to allow. Takes precedence over other counts.
+
+        Set to ``None`` to remove this constraint and fall back on other
+        counts. It's a good idea to set this to some sensibly-high value to
+        account for unexpected edge cases and avoid infinite retry loops.
+
+        Set to ``0`` to fail on the first retry.
+
+        Set to ``False`` to disable and imply ``raise_on_redirect=False``.
+
+    :param int connect:
+        How many connection-related errors to retry on.
+
+        These are errors raised before the request is sent to the remote server,
+        which we assume has not triggered the server to process the request.
+
+        Set to ``0`` to fail on the first retry of this type.
+
+    :param int read:
+        How many times to retry on read errors.
+
+        These errors are raised after the request was sent to the server, so the
+        request may have side-effects.
+
+        Set to ``0`` to fail on the first retry of this type.
+
+    :param int redirect:
+        How many redirects to perform. Limit this to avoid infinite redirect
+        loops.
+
+        A redirect is a HTTP response with a status code 301, 302, 303, 307 or
+        308.
+
+        Set to ``0`` to fail on the first retry of this type.
+
+        Set to ``False`` to disable and imply ``raise_on_redirect=False``.
+
+    :param int status:
+        How many times to retry on bad status codes.
+
+        These are retries made on responses, where status code matches
+        ``status_forcelist``.
+
+        Set to ``0`` to fail on the first retry of this type.
+
+    :param iterable method_whitelist:
+        Set of uppercased HTTP method verbs that we should retry on.
+
+        By default, we only retry on methods which are considered to be
+        idempotent (multiple requests with the same parameters end with the
+        same state). See :attr:`Retry.DEFAULT_METHOD_WHITELIST`.
+
+        Set to a ``False`` value to retry on any verb.
+
+    :param iterable status_forcelist:
+        A set of integer HTTP status codes that we should force a retry on.
+        A retry is initiated if the request method is in ``method_whitelist``
+        and the response status code is in ``status_forcelist``.
+
+        By default, this is disabled with ``None``.
+
+    :param float backoff_factor:
+        A backoff factor to apply between attempts after the second try
+        (most errors are resolved immediately by a second try without a
+        delay). urllib3 will sleep for::
+
+            {backoff factor} * (2 ** ({number of total retries} - 1))
+
+        seconds. If the backoff_factor is 0.1, then :func:`.sleep` will sleep
+        for [0.0s, 0.2s, 0.4s, ...] between retries. It will never be longer
+        than :attr:`Retry.BACKOFF_MAX`.
+
+        By default, backoff is disabled (set to 0).
+
+    :param bool raise_on_redirect: Whether, if the number of redirects is
+        exhausted, to raise a MaxRetryError, or to return a response with a
+        response code in the 3xx range.
+
+    :param bool raise_on_status: Similar meaning to ``raise_on_redirect``:
+        whether we should raise an exception, or return a response,
+        if status falls in ``status_forcelist`` range and retries have
+        been exhausted.
+
+    :param tuple history: The history of the request encountered during
+        each call to :meth:`~Retry.increment`. The list is in the order
+        the requests occurred. Each list item is of class :class:`RequestHistory`.
+
+    :param bool respect_retry_after_header:
+        Whether to respect Retry-After header on status codes defined as
+        :attr:`Retry.RETRY_AFTER_STATUS_CODES` or not.
+
+    :param iterable remove_headers_on_redirect:
+        Sequence of headers to remove from the request when a response
+        indicating a redirect is returned before firing off the redirected
+        request.
+    """
+
+    DEFAULT_METHOD_WHITELIST = frozenset([
+        'HEAD', 'GET', 'PUT', 'DELETE', 'OPTIONS', 'TRACE'])
+
+    RETRY_AFTER_STATUS_CODES = frozenset([413, 429, 503])
+
+    DEFAULT_REDIRECT_HEADERS_BLACKLIST = frozenset(['Authorization'])
+
+    #: Maximum backoff time.
+    BACKOFF_MAX = 120
+
+    def __init__(self, total=10, connect=None, read=None, redirect=None, status=None,
+                 method_whitelist=DEFAULT_METHOD_WHITELIST, status_forcelist=None,
+                 backoff_factor=0, raise_on_redirect=True, raise_on_status=True,
+                 history=None, respect_retry_after_header=True,
+                 remove_headers_on_redirect=DEFAULT_REDIRECT_HEADERS_BLACKLIST):
+
+        self.total = total
+        self.connect = connect
+        self.read = read
+        self.status = status
+
+        if redirect is False or total is False:
+            redirect = 0
+            raise_on_redirect = False
+
+        self.redirect = redirect
+        self.status_forcelist = status_forcelist or set()
+        self.method_whitelist = method_whitelist
+        self.backoff_factor = backoff_factor
+        self.raise_on_redirect = raise_on_redirect
+        self.raise_on_status = raise_on_status
+        self.history = history or tuple()
+        self.respect_retry_after_header = respect_retry_after_header
+        self.remove_headers_on_redirect = remove_headers_on_redirect
+
+    def new(self, **kw):
+        params = dict(
+            total=self.total,
+            connect=self.connect, read=self.read, redirect=self.redirect, status=self.status,
+            method_whitelist=self.method_whitelist,
+            status_forcelist=self.status_forcelist,
+            backoff_factor=self.backoff_factor,
+            raise_on_redirect=self.raise_on_redirect,
+            raise_on_status=self.raise_on_status,
+            history=self.history,
+            remove_headers_on_redirect=self.remove_headers_on_redirect
+        )
+        params.update(kw)
+        return type(self)(**params)
+
+    @classmethod
+    def from_int(cls, retries, redirect=True, default=None):
+        """ Backwards-compatibility for the old retries format."""
+        if retries is None:
+            retries = default if default is not None else cls.DEFAULT
+
+        if isinstance(retries, Retry):
+            return retries
+
+        redirect = bool(redirect) and None
+        new_retries = cls(retries, redirect=redirect)
+        log.debug("Converted retries value: %r -> %r", retries, new_retries)
+        return new_retries
+
+    def get_backoff_time(self):
+        """ Formula for computing the current backoff
+
+        :rtype: float
+        """
+        # We want to consider only the last consecutive errors sequence (Ignore redirects).
+        consecutive_errors_len = len(list(takewhile(lambda x: x.redirect_location is None,
+                                                    reversed(self.history))))
+        if consecutive_errors_len <= 1:
+            return 0
+
+        backoff_value = self.backoff_factor * (2 ** (consecutive_errors_len - 1))
+        return min(self.BACKOFF_MAX, backoff_value)
+
+    def parse_retry_after(self, retry_after):
+        # Whitespace: https://tools.ietf.org/html/rfc7230#section-3.2.4
+        if re.match(r"^\s*[0-9]+\s*$", retry_after):
+            seconds = int(retry_after)
+        else:
+            retry_date_tuple = email.utils.parsedate(retry_after)
+            if retry_date_tuple is None:
+                raise InvalidHeader("Invalid Retry-After header: %s" % retry_after)
+            retry_date = time.mktime(retry_date_tuple)
+            seconds = retry_date - time.time()
+
+        if seconds < 0:
+            seconds = 0
+
+        return seconds
+
+    def get_retry_after(self, response):
+        """ Get the value of Retry-After in seconds. """
+
+        retry_after = response.getheader("Retry-After")
+
+        if retry_after is None:
+            return None
+
+        return self.parse_retry_after(retry_after)
+
+    def sleep_for_retry(self, response=None):
+        retry_after = self.get_retry_after(response)
+        if retry_after:
+            time.sleep(retry_after)
+            return True
+
+        return False
+
+    def _sleep_backoff(self):
+        backoff = self.get_backoff_time()
+        if backoff <= 0:
+            return
+        time.sleep(backoff)
+
+    def sleep(self, response=None):
+        """ Sleep between retry attempts.
+
+        This method will respect a server's ``Retry-After`` response header
+        and sleep the duration of the time requested. If that is not present, it
+        will use an exponential backoff. By default, the backoff factor is 0 and
+        this method will return immediately.
+        """
+
+        if response:
+            slept = self.sleep_for_retry(response)
+            if slept:
+                return
+
+        self._sleep_backoff()
+
+    def _is_connection_error(self, err):
+        """ Errors when we're fairly sure that the server did not receive the
+        request, so it should be safe to retry.
+        """
+        return isinstance(err, ConnectTimeoutError)
+
+    def _is_read_error(self, err):
+        """ Errors that occur after the request has been started, so we should
+        assume that the server began processing it.
+        """
+        return isinstance(err, (ReadTimeoutError, ProtocolError))
+
+    def _is_method_retryable(self, method):
+        """ Checks if a given HTTP method should be retried upon, depending if
+        it is included on the method whitelist.
+        """
+        if self.method_whitelist and method.upper() not in self.method_whitelist:
+            return False
+
+        return True
+
+    def is_retry(self, method, status_code, has_retry_after=False):
+        """ Is this method/status code retryable? (Based on whitelists and control
+        variables such as the number of total retries to allow, whether to
+        respect the Retry-After header, whether this header is present, and
+        whether the returned status code is on the list of status codes to
+        be retried upon on the presence of the aforementioned header)
+        """
+        if not self._is_method_retryable(method):
+            return False
+
+        if self.status_forcelist and status_code in self.status_forcelist:
+            return True
+
+        return (self.total and self.respect_retry_after_header and
+                has_retry_after and (status_code in self.RETRY_AFTER_STATUS_CODES))
+
+    def is_exhausted(self):
+        """ Are we out of retries? """
+        retry_counts = (self.total, self.connect, self.read, self.redirect, self.status)
+        retry_counts = list(filter(None, retry_counts))
+        if not retry_counts:
+            return False
+
+        return min(retry_counts) < 0
+
+    def increment(self, method=None, url=None, response=None, error=None,
+                  _pool=None, _stacktrace=None):
+        """ Return a new Retry object with incremented retry counters.
+
+        :param response: A response object, or None, if the server did not
+            return a response.
+        :type response: :class:`~urllib3.response.HTTPResponse`
+        :param Exception error: An error encountered during the request, or
+            None if the response was received successfully.
+
+        :return: A new ``Retry`` object.
+        """
+        if self.total is False and error:
+            # Disabled, indicate to re-raise the error.
+            raise six.reraise(type(error), error, _stacktrace)
+
+        total = self.total
+        if total is not None:
+            total -= 1
+
+        connect = self.connect
+        read = self.read
+        redirect = self.redirect
+        status_count = self.status
+        cause = 'unknown'
+        status = None
+        redirect_location = None
+
+        if error and self._is_connection_error(error):
+            # Connect retry?
+            if connect is False:
+                raise six.reraise(type(error), error, _stacktrace)
+            elif connect is not None:
+                connect -= 1
+
+        elif error and self._is_read_error(error):
+            # Read retry?
+            if read is False or not self._is_method_retryable(method):
+                raise six.reraise(type(error), error, _stacktrace)
+            elif read is not None:
+                read -= 1
+
+        elif response and response.get_redirect_location():
+            # Redirect retry?
+            if redirect is not None:
+                redirect -= 1
+            cause = 'too many redirects'
+            redirect_location = response.get_redirect_location()
+            status = response.status
+
+        else:
+            # Incrementing because of a server error like a 500 in
+            # status_forcelist and a the given method is in the whitelist
+            cause = ResponseError.GENERIC_ERROR
+            if response and response.status:
+                if status_count is not None:
+                    status_count -= 1
+                cause = ResponseError.SPECIFIC_ERROR.format(
+                    status_code=response.status)
+                status = response.status
+
+        history = self.history + (RequestHistory(method, url, error, status, redirect_location),)
+
+        new_retry = self.new(
+            total=total,
+            connect=connect, read=read, redirect=redirect, status=status_count,
+            history=history)
+
+        if new_retry.is_exhausted():
+            raise MaxRetryError(_pool, url, error or ResponseError(cause))
+
+        log.debug("Incremented Retry for (url='%s'): %r", url, new_retry)
+
+        return new_retry
+
+    def __repr__(self):
+        return ('{cls.__name__}(total={self.total}, connect={self.connect}, '
+                'read={self.read}, redirect={self.redirect}, status={self.status})').format(
+                    cls=type(self), self=self)
+
+
+# For backwards compatibility (equivalent to pre-v1.9):
+Retry.DEFAULT = Retry(3)
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/util/retry.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/util/retry.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..c9a9523dd69e7fce109e44aeb6e0b778c4cad41f
GIT binary patch
literal 15622
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

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/util/ssl_.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/util/ssl_.py
new file mode 100644
index 0000000..dfc553f
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/util/ssl_.py
@@ -0,0 +1,381 @@
+from __future__ import absolute_import
+import errno
+import warnings
+import hmac
+import socket
+
+from binascii import hexlify, unhexlify
+from hashlib import md5, sha1, sha256
+
+from ..exceptions import SSLError, InsecurePlatformWarning, SNIMissingWarning
+from ..packages import six
+
+
+SSLContext = None
+HAS_SNI = False
+IS_PYOPENSSL = False
+IS_SECURETRANSPORT = False
+
+# Maps the length of a digest to a possible hash function producing this digest
+HASHFUNC_MAP = {
+    32: md5,
+    40: sha1,
+    64: sha256,
+}
+
+
+def _const_compare_digest_backport(a, b):
+    """
+    Compare two digests of equal length in constant time.
+
+    The digests must be of type str/bytes.
+    Returns True if the digests match, and False otherwise.
+    """
+    result = abs(len(a) - len(b))
+    for l, r in zip(bytearray(a), bytearray(b)):
+        result |= l ^ r
+    return result == 0
+
+
+_const_compare_digest = getattr(hmac, 'compare_digest',
+                                _const_compare_digest_backport)
+
+
+try:  # Test for SSL features
+    import ssl
+    from ssl import wrap_socket, CERT_NONE, PROTOCOL_SSLv23
+    from ssl import HAS_SNI  # Has SNI?
+except ImportError:
+    pass
+
+
+try:
+    from ssl import OP_NO_SSLv2, OP_NO_SSLv3, OP_NO_COMPRESSION
+except ImportError:
+    OP_NO_SSLv2, OP_NO_SSLv3 = 0x1000000, 0x2000000
+    OP_NO_COMPRESSION = 0x20000
+
+
+# Python 2.7 doesn't have inet_pton on non-Linux so we fallback on inet_aton in
+# those cases. This means that we can only detect IPv4 addresses in this case.
+if hasattr(socket, 'inet_pton'):
+    inet_pton = socket.inet_pton
+else:
+    # Maybe we can use ipaddress if the user has urllib3[secure]?
+    try:
+        from pip._vendor import ipaddress
+
+        def inet_pton(_, host):
+            if isinstance(host, bytes):
+                host = host.decode('ascii')
+            return ipaddress.ip_address(host)
+
+    except ImportError:  # Platform-specific: Non-Linux
+        def inet_pton(_, host):
+            return socket.inet_aton(host)
+
+
+# A secure default.
+# Sources for more information on TLS ciphers:
+#
+# - https://wiki.mozilla.org/Security/Server_Side_TLS
+# - https://www.ssllabs.com/projects/best-practices/index.html
+# - https://hynek.me/articles/hardening-your-web-servers-ssl-ciphers/
+#
+# The general intent is:
+# - Prefer TLS 1.3 cipher suites
+# - prefer cipher suites that offer perfect forward secrecy (DHE/ECDHE),
+# - prefer ECDHE over DHE for better performance,
+# - prefer any AES-GCM and ChaCha20 over any AES-CBC for better performance and
+#   security,
+# - prefer AES-GCM over ChaCha20 because hardware-accelerated AES is common,
+# - disable NULL authentication, MD5 MACs and DSS for security reasons.
+DEFAULT_CIPHERS = ':'.join([
+    'TLS13-AES-256-GCM-SHA384',
+    'TLS13-CHACHA20-POLY1305-SHA256',
+    'TLS13-AES-128-GCM-SHA256',
+    'ECDH+AESGCM',
+    'ECDH+CHACHA20',
+    'DH+AESGCM',
+    'DH+CHACHA20',
+    'ECDH+AES256',
+    'DH+AES256',
+    'ECDH+AES128',
+    'DH+AES',
+    'RSA+AESGCM',
+    'RSA+AES',
+    '!aNULL',
+    '!eNULL',
+    '!MD5',
+])
+
+try:
+    from ssl import SSLContext  # Modern SSL?
+except ImportError:
+    import sys
+
+    class SSLContext(object):  # Platform-specific: Python 2
+        def __init__(self, protocol_version):
+            self.protocol = protocol_version
+            # Use default values from a real SSLContext
+            self.check_hostname = False
+            self.verify_mode = ssl.CERT_NONE
+            self.ca_certs = None
+            self.options = 0
+            self.certfile = None
+            self.keyfile = None
+            self.ciphers = None
+
+        def load_cert_chain(self, certfile, keyfile):
+            self.certfile = certfile
+            self.keyfile = keyfile
+
+        def load_verify_locations(self, cafile=None, capath=None):
+            self.ca_certs = cafile
+
+            if capath is not None:
+                raise SSLError("CA directories not supported in older Pythons")
+
+        def set_ciphers(self, cipher_suite):
+            self.ciphers = cipher_suite
+
+        def wrap_socket(self, socket, server_hostname=None, server_side=False):
+            warnings.warn(
+                'A true SSLContext object is not available. This prevents '
+                'urllib3 from configuring SSL appropriately and may cause '
+                'certain SSL connections to fail. You can upgrade to a newer '
+                'version of Python to solve this. For more information, see '
+                'https://urllib3.readthedocs.io/en/latest/advanced-usage.html'
+                '#ssl-warnings',
+                InsecurePlatformWarning
+            )
+            kwargs = {
+                'keyfile': self.keyfile,
+                'certfile': self.certfile,
+                'ca_certs': self.ca_certs,
+                'cert_reqs': self.verify_mode,
+                'ssl_version': self.protocol,
+                'server_side': server_side,
+            }
+            return wrap_socket(socket, ciphers=self.ciphers, **kwargs)
+
+
+def assert_fingerprint(cert, fingerprint):
+    """
+    Checks if given fingerprint matches the supplied certificate.
+
+    :param cert:
+        Certificate as bytes object.
+    :param fingerprint:
+        Fingerprint as string of hexdigits, can be interspersed by colons.
+    """
+
+    fingerprint = fingerprint.replace(':', '').lower()
+    digest_length = len(fingerprint)
+    hashfunc = HASHFUNC_MAP.get(digest_length)
+    if not hashfunc:
+        raise SSLError(
+            'Fingerprint of invalid length: {0}'.format(fingerprint))
+
+    # We need encode() here for py32; works on py2 and p33.
+    fingerprint_bytes = unhexlify(fingerprint.encode())
+
+    cert_digest = hashfunc(cert).digest()
+
+    if not _const_compare_digest(cert_digest, fingerprint_bytes):
+        raise SSLError('Fingerprints did not match. Expected "{0}", got "{1}".'
+                       .format(fingerprint, hexlify(cert_digest)))
+
+
+def resolve_cert_reqs(candidate):
+    """
+    Resolves the argument to a numeric constant, which can be passed to
+    the wrap_socket function/method from the ssl module.
+    Defaults to :data:`ssl.CERT_NONE`.
+    If given a string it is assumed to be the name of the constant in the
+    :mod:`ssl` module or its abbreviation.
+    (So you can specify `REQUIRED` instead of `CERT_REQUIRED`.
+    If it's neither `None` nor a string we assume it is already the numeric
+    constant which can directly be passed to wrap_socket.
+    """
+    if candidate is None:
+        return CERT_NONE
+
+    if isinstance(candidate, str):
+        res = getattr(ssl, candidate, None)
+        if res is None:
+            res = getattr(ssl, 'CERT_' + candidate)
+        return res
+
+    return candidate
+
+
+def resolve_ssl_version(candidate):
+    """
+    like resolve_cert_reqs
+    """
+    if candidate is None:
+        return PROTOCOL_SSLv23
+
+    if isinstance(candidate, str):
+        res = getattr(ssl, candidate, None)
+        if res is None:
+            res = getattr(ssl, 'PROTOCOL_' + candidate)
+        return res
+
+    return candidate
+
+
+def create_urllib3_context(ssl_version=None, cert_reqs=None,
+                           options=None, ciphers=None):
+    """All arguments have the same meaning as ``ssl_wrap_socket``.
+
+    By default, this function does a lot of the same work that
+    ``ssl.create_default_context`` does on Python 3.4+. It:
+
+    - Disables SSLv2, SSLv3, and compression
+    - Sets a restricted set of server ciphers
+
+    If you wish to enable SSLv3, you can do::
+
+        from pip._vendor.urllib3.util import ssl_
+        context = ssl_.create_urllib3_context()
+        context.options &= ~ssl_.OP_NO_SSLv3
+
+    You can do the same to enable compression (substituting ``COMPRESSION``
+    for ``SSLv3`` in the last line above).
+
+    :param ssl_version:
+        The desired protocol version to use. This will default to
+        PROTOCOL_SSLv23 which will negotiate the highest protocol that both
+        the server and your installation of OpenSSL support.
+    :param cert_reqs:
+        Whether to require the certificate verification. This defaults to
+        ``ssl.CERT_REQUIRED``.
+    :param options:
+        Specific OpenSSL options. These default to ``ssl.OP_NO_SSLv2``,
+        ``ssl.OP_NO_SSLv3``, ``ssl.OP_NO_COMPRESSION``.
+    :param ciphers:
+        Which cipher suites to allow the server to select.
+    :returns:
+        Constructed SSLContext object with specified options
+    :rtype: SSLContext
+    """
+    context = SSLContext(ssl_version or ssl.PROTOCOL_SSLv23)
+
+    context.set_ciphers(ciphers or DEFAULT_CIPHERS)
+
+    # Setting the default here, as we may have no ssl module on import
+    cert_reqs = ssl.CERT_REQUIRED if cert_reqs is None else cert_reqs
+
+    if options is None:
+        options = 0
+        # SSLv2 is easily broken and is considered harmful and dangerous
+        options |= OP_NO_SSLv2
+        # SSLv3 has several problems and is now dangerous
+        options |= OP_NO_SSLv3
+        # Disable compression to prevent CRIME attacks for OpenSSL 1.0+
+        # (issue #309)
+        options |= OP_NO_COMPRESSION
+
+    context.options |= options
+
+    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
+    return context
+
+
+def ssl_wrap_socket(sock, keyfile=None, certfile=None, cert_reqs=None,
+                    ca_certs=None, server_hostname=None,
+                    ssl_version=None, ciphers=None, ssl_context=None,
+                    ca_cert_dir=None):
+    """
+    All arguments except for server_hostname, ssl_context, and ca_cert_dir have
+    the same meaning as they do when using :func:`ssl.wrap_socket`.
+
+    :param server_hostname:
+        When SNI is supported, the expected hostname of the certificate
+    :param ssl_context:
+        A pre-made :class:`SSLContext` object. If none is provided, one will
+        be created using :func:`create_urllib3_context`.
+    :param ciphers:
+        A string of ciphers we wish the client to support.
+    :param ca_cert_dir:
+        A directory containing CA certificates in multiple separate files, as
+        supported by OpenSSL's -CApath flag or the capath argument to
+        SSLContext.load_verify_locations().
+    """
+    context = ssl_context
+    if context is None:
+        # Note: This branch of code and all the variables in it are no longer
+        # used by urllib3 itself. We should consider deprecating and removing
+        # this code.
+        context = create_urllib3_context(ssl_version, cert_reqs,
+                                         ciphers=ciphers)
+
+    if ca_certs or ca_cert_dir:
+        try:
+            context.load_verify_locations(ca_certs, ca_cert_dir)
+        except IOError as e:  # Platform-specific: Python 2.7
+            raise SSLError(e)
+        # Py33 raises FileNotFoundError which subclasses OSError
+        # These are not equivalent unless we check the errno attribute
+        except OSError as e:  # Platform-specific: Python 3.3 and beyond
+            if e.errno == errno.ENOENT:
+                raise SSLError(e)
+            raise
+    elif getattr(context, 'load_default_certs', None) is not None:
+        # try to load OS default certs; works well on Windows (require Python3.4+)
+        context.load_default_certs()
+
+    if certfile:
+        context.load_cert_chain(certfile, keyfile)
+
+    # If we detect server_hostname is an IP address then the SNI
+    # extension should not be used according to RFC3546 Section 3.1
+    # We shouldn't warn the user if SNI isn't available but we would
+    # not be using SNI anyways due to IP address for server_hostname.
+    if ((server_hostname is not None and not is_ipaddress(server_hostname))
+            or IS_SECURETRANSPORT):
+        if HAS_SNI and server_hostname is not None:
+            return context.wrap_socket(sock, server_hostname=server_hostname)
+
+        warnings.warn(
+            'An HTTPS request has been made, but the SNI (Server Name '
+            'Indication) extension to TLS is not available on this platform. '
+            'This may cause the server to present an incorrect TLS '
+            'certificate, which can cause validation failures. You can upgrade to '
+            'a newer version of Python to solve this. For more information, see '
+            'https://urllib3.readthedocs.io/en/latest/advanced-usage.html'
+            '#ssl-warnings',
+            SNIMissingWarning
+        )
+
+    return context.wrap_socket(sock)
+
+
+def is_ipaddress(hostname):
+    """Detects whether the hostname given is an IP address.
+
+    :param str hostname: Hostname to examine.
+    :return: True if the hostname is an IP address, False otherwise.
+    """
+    if six.PY3 and isinstance(hostname, bytes):
+        # IDN A-label bytes are ASCII compatible.
+        hostname = hostname.decode('ascii')
+
+    families = [socket.AF_INET]
+    if hasattr(socket, 'AF_INET6'):
+        families.append(socket.AF_INET6)
+
+    for af in families:
+        try:
+            inet_pton(af, hostname)
+        except (socket.error, ValueError, OSError):
+            pass
+        else:
+            return True
+    return False
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/util/ssl_.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/util/ssl_.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..cd329f73ad4820cb7809f7e9886b4d8d6e1a30ae
GIT binary patch
literal 12270
zcmZSn%**AGdLky70SW{e7#JKJ7#NBVGBGfuFfgPrGUPBY<T5fuF)}cM_)H8rObk&>
zU^ym+9A<_nW*D1=A&LdYW@U(C1+$qMa@ZJh*%_kP8FD!oqBtO?urTCsGUReGL~$|X
zax+A6Gvx9xMDZ{%rm!-kurcKDGUW0xMDa1?@-sy7Gvo>|L<vCT*coyJ8FGafqJ$V2
zQ<xZ{L>N*<8KT6%q&S$AV8~=<NabQk;b1UJ<z`6XWH3wRVMyU(FpH98Na1E^VPJ@o
zVn~%{NM&J2;bBOXVrXV&h>~Hbv;jMpi6KXpAxaj^<^{2H<rt#m7;@zqqU0HJ6&Ruv
zARgcY%ZY*PW(?00WMD~EWXR@XD6(c`WMs@^WQeF#0Gq)NR;R=erNoe{%n+r_kgLKF
zrNY1%o~I1g(+JX&V#pA~1X32I%#b1kQUfw2Rh1!?l_5o#p_z%HXf9(aD?^qVLzEgr
zo)tqS#E~KlIqD3#8Vpey42&tFVDG6hgy%`YO}_><T?{G%GBib;Axo1XMS>wkk|9Nk
zAw`-YMTQ|omLWxsAw`}cMS&qjks(EiAw`)XMTH?nl_5oqAw``bU4WsPks(Tpp;83w
zGYzoML_l%C7@lVgw=bTFkr9?sv>Bqb8B#PEQgs;87#UKuK#pi;V2F$oVE{Ws8zc~=
z%aEc2X6P}b=z<yg3@J=VNROd~g(1oSNd#FI!q#VK;be$1WJoapn_vV|9IRo)z`&3R
zO4=HX3=9k<{0s~XiAlxzIi)43@tL^=`9&pu8cZM=b_NE9jMR#p%(Ti9P6h^s(mW_n
zgBc_ZB63qqOIR2f7>Y9z4NKS{3?oysOptzvDh>t)hTvcy*P^2Qq7rci1_sZ(;?(5Q
zqSSz##FDi9qTKMrqP)z!^b$}m3-<H$%`7g?%u9!gLYxS)sW`JDQvu|14G`hLz`&3U
zvV@g^fdS+IXHfo306B|+p@fm4h5-~YAO<6dA<@jpP|L(nVa`y(#8AQvlV)b90ZTVC
zF}TD^fznznGea#4Lk$x{4KqUx3xlJ7EfYhb1w(iZ6DZebGcg2%gQj>n0|Nt>f`WpA
zbAE0?Vo|C>NqN3PN@jX$aY?a4ewspRVQFHHLQZO4dP#;tW}ZTFeqM1&VqS?tNoH=U
z9v4_^NJc7LOKxd#i9%8;NNY)DL8?M=Ns)e1Wl3tW9$0BmYDsBPUa>+*QE93|W|~3?
zvev|s<P05!#Jm&*x5S*{RE7MKjMSp?%;HptUPx4f!l(okj)_UdU^*u?4@_5O7Jwrc
zWLsiUQDUVAC`d~{Nh1+VCV}I%D7CmWrvxmJ115_=@xTBkiVGMR81xH@GRqQ6QuWIc
zi}cg-b5c@^iuIFH^vjcy@^Vdci;WDE%+ssVEle%SbF!+;3_u_~Pd`MzAhSR>6BIf*
zIl69T9-hVlAR#c0FH6l!$uH6`Ey~HsOfuFlEy>K$FD}lB*DI(jkz-(BhzEyjd@>{w
z;vo?bpOl!K4NAt+p!5hze+=w0j2etWj3s=aWP_p@l1RB37#PZn5)0ys^OLhvOTYo*
z>>3mj@8|F53eF(`LH;5B&i+2}!NERdM#hkI3CbWIj=}N4ex3+(`~%|s{2|IpK;|O&
z#^5v#;XC{L1_ZeV2YdSafg*?zL@;GCFfcKIEzitLEr~BE$<KpW#0g6C1&JvsMXANb
z;B*g4`=ICqr+Ym}y02jbC4Eq-s0d2fS>QAaO8JZoc?_UrpTz<aZ)Sw1V!sklR3{cE
zXJ$eooeN}5F*q{vl2gI5pkz@DP5~*Y$@wX%L9!sbzzPfEp$-CP32>r_2Nwnz`NbvR
zgaIZ7By|MIFfcH<fZ`uiC^0bdGYT=n!wnR6;Beyw`GtWYixD0ypkxm%{XiO#k^?wK
z5<xKn(jKJDz`zis!oUE@0R!w&FOWw;&SGE$M}t+d1Oo#@h)=Mgv96<Qu&$A*nXbFD
zuWqo1qp^iaF(~IiB%M7Rojn|l40HqheIgBw4NO5wj7-hY^cxyk!1RM8L8;o+*~LTK
z(KXoJ*|!)Jj9@;@xMEOxMaYBHyLf2BWkGzfdPmn_ka-BzARe-;p^-%~C>|hY6@!vp
zP_QG+UQqUfa>1$;6a7Mcd?3tJFcVbjDf+sYLUIvEdvLIibADb)YDGy9DAM3<JWyV8
z0@Wdo3=9mZ44|f63In*-1m_}93yGNl)DmL_RiZ6S;HDfiSOFVIJe8dxg@pkm&cP5A
ztO0T~W_t5yU;w4G8U}`VSS=L~u8%+&lYt=~+&TowvV&?H5Q78MtN<}MVGJ%9gB!$v
zR7c<<gh7J`l$=53T|rTPNq%yE4mbycD+Nf&myw#B9S_Q#d5O8H;L^XiI44L9qzx46
zWvNA(X_fK0`6;R3eC(H>ms$ccFF7$jIkl*yxC9j9`2{7JpxO*9ky=!emYI_ZmdH-6
zgtL<~3o=rRiXkNfC>DxSbJ9u#7#J8}Zi_EVEh^5;&jZB*BohrtK>_w(e0*kJW=VW}
z87Lot9Ld1Q$;8RX!^jDR$)Mx`!k|nBE;>MgR>KHtNW?RM+Y1Z~@r;ldL6jjuhM-ac
z)ZPMD4?!j%E<z041_KcT<8x5MFDE}S1su2W$r*{6d5xd|07VxABPS!Kr$KRr?CBH+
zhHOrTA{9`pDh1q<Y64d^DGab0rdXGOfx+2PAtkdYHMu0eC^NNKAuqo~p}4dFR70nx
zfEq{O#)3jXWl2VUUNI!3^g$s7s@8%)ISC>L3O#U5l$;1oXCRs6#Dc_<43N79G7X6`
zFff2a5}Jc@@{<$6nWUA0fdO0|ff5uCjv5FaqTpbIq#h6%WDKfaKq(HKa7sYg8<MZ$
zi%T<0QU}`CpdzC<wIm+mrs8gpUqP;AU`z%jAyC@_gu&S*6;#H6YuXe>P-<yrVqnZ<
z17)8qW>A4@R>Q!M#ln!n%m8Mwf(lbG3tYH@S?r)*uvrZ=Lkc^CSuG1g2?wYwP2m6=
z!U<}v_cAgDYj83!F!&W4F)}bXDwKel%ZL(RAwMZAHMv9~6OslK%Mvql5|eUL^%O!f
zGK&=oic-r`^Gb>ppv_H%w4(f6P|H0nGrhDZGcR2sIM_!av7n$Rzn~~Hu_QI865Q&}
zO{`Q%PAn}>RR9%|iJ5s|b;<d8d8x_ZRG?6juaK6QnWLu=nO~}qoS3IjT996pn34*T
zNL0v6El({{fEI_K9sndKfFz6abIMW`N-{Ew^%UIlixhJ6i&7Ob^FZAua01g&C{9gP
z$S5f(D7MmvHIwy<QWH~3GE!6WlZ*8-^Yv5n^m7tRQj1IU6I03(^O93jbW4j9(^K^_
zN^*0Qi;Ht~%OPE`;vi5_1u3*Z84%nO1^FqyD7CN{+?WM5zM(FK@KcM*Qj6k?GgDF_
z$rV(`g3DBxnc$iP#0dgb9%wcMfr^J9O;BbB<spa>phN>s@j<GfR0AreiXqm(s;(e=
zkOV0IXO|}yr56uyP6z_Iy$_W9LA3${BO4<#8#@y-BNqZP`GFHAIAr4ELDg@3d<iJ5
z;z8AIX-;Z<e2^I^7|cNgxZtw_v1~wu7Ki}Zf$%4oH6YanxY<++@+`>tY>b@ToGkoo
zoXp_X4k$`M(Fe}+D<Q3&EbxF?3KM9!CX11wnSr4eTm(S6-nH=d4-=@PUds&Xc^3yV
zl(2#dgDf^s9&bjfT1wbKB3T?Db3k1i7La;KZ$FC@Bv{MJP{PGf!wM=8nwc1imx7IA
zVSpG_!VQuF83?uxT3xX+Kw50Y58>T<P*bTG)YVSUEKAK(NXyJiPc14a%FHWK$OUz{
zQ;Wf!a8Ny#lbM<V&ia{YnaPPIu<pH8L1Iy2E?B|}+=&Md7o--IK$R&Z7At^zSI}Y!
z(p!h>Lb4B`*$v4NiN&BX0#KoppQezJT9J~Oo>@|?11?>XKxITpYEf}PYEf}&ib7JQ
zLUMjiejaQvK^>HP!0iqt1_lOXQ}fdlGV{t3b23w)V;5Em)dsc2pp=QEtXLr>GX-3Y
zgM&g(!L_0wHMt};MM0_BpjJsoAw9oDL8;oXR!Pqf(kKOG{i4)@oJ44^GAF-0wI~Qw
zfq-i@5655+w@^Rlcwff=aI-W$wFF%8gR6T;X%_^lTEP6&JWxjz%!G9KOF(%8>rg-t
zs2&A3#=*r9s4N2)TS&oM0_wd$%!!AL*MKu=Mq+VBT4`P~xXX^DJRTfnU_(HrL5Cc`
z*%3?(NS-Va0*&Dn7pE4L#3Q+NF({XUizF@yMjl3fP{G6~$}Ger#KaG3-+=-L6sn-w
z8k}RJK{=KIR3B$^Fcb-ZMiYWdm_QY52{S1B7KJmEuz>PY4Ome#Gbk(9Fv2thLuFGK
zL0ZI{nLyHc;4V*a4X8;7YC#u2XM_%&1*L+kH%LZGEJ`oUO$7~*<trpA<dx>87G)-b
zDqrxhnT|qvMrLvbEOi$o7K74tNj^AVfd<2n25%I=(UzH?r=Oczl98VRsm4Kyii>j;
za`RJ4bD$$*E~#mWr8y<VpqkbyC9x#YDxtVIM-M*mlK{z*o@ok@LLd>A<ubu-h{WRJ
z(%jS(knSW<C7r4OD%U|3ILNYOP#+02;+L5RDk;D&waU#;0o#!Pb%#QJkwRuku|i@}
zQc-GICb&+ASgH}6uTTkXEfg1|CTFHqDkKEC28MbDxw<4MfW~N26H`EzC4k)vmx5^b
zOjF1#Q7=}=OU(q01}Y?g`f>>hdHF>Oa9@<CDnPuT0QFA}sNqlvaxE+Zz^;b-1Q7?2
z=6p^iXvh*C845^|0C5Gl{|R=UA2<^Rfh#spiVTtml|kV2P*Mc$J*KCYB$kvE1?j*V
zy^z*NVqQvSN@5A5w_221tN|*wz{J4hG|(t@5hUS4`c0sw(LPW{69Bo4n}?Bw2{hQm
z!zjkc!jwEPSqwBz4vxB<%<NPJ4CjKSz`+Y2)kKaT&>%fHeuBb54UY&A0gsiSNDwy)
z6iFce4q!|OGcYi~yoS^)y$X*D7PPnk6?34*35W(4ciTW|kO5Ry74U<~x-4*;05ty3
z!jJ`Sh!m)RinL}%21ZaR$IJjK7Hz>w*%<P`vj??|px%E9M5+ulY*Whw5-DM40L>lL
zFoF6hFcv3R3{)brFtB8Cfz<gk#dCpLG&L*?@!Sk0JfLO^Xr6}|GzAATmXo1q6GI6v
zNIaeoG>%)t!Vs(h@<Z`=76t~#oE!yM*;%ZRkqGWCq$(6A=B6s-rY3@BRzMAn1W?Hq
zkCZ_Z5}>mXPL&ENkaAE5+|hs+p9(4Ysl^J33OV^DpkfA8rh!c@&o9bWD9K1H0VgA{
z!FtI>sfi`2@lb<6RWWFUEg=D7Mt&Z&bFW~mXQHjA;8|h?nE}yNaLFtN^}vcjU8XW4
z9WZ4KnaltU>Vt;6GxPJnHt8w^r-F(~P<k#Y$^^GJic`UEgLDrRpdC?&*`8_O^0Pd%
zI0IBdr{;m|fte30SyS?@piTib&cOY>g3JOv=)8j-v?Hhons-ouOpPgkk{Z}OARWn&
zp+p5+urMqbpxR);prMJbUJp8krl4l4PzN$l4>BnLnp-f2I3LziOvwkA$Ka4J$yb1S
z11W42G>S`;ic2y}N=rbk!Gr{)nT3P|u+3@tMG6TCV8atYRR`F_oW$Z1g`CX1RE5N(
z{IXO{XmWtIKS7Ry_VW<!Pw<3QYH?;!YKj7E7!TfWEy-6XErxZa%QJIwV981WT1|t(
z3trxU9Ajh*t<}M*^HS6EOF+G9u<J51(=$?wOAyw85}ZO(en|${M<BDn2@>2d1oy%#
z^Gl1s)nZ~!4!9l#C0hT2)I3n99n?(EFDil5N>DF?n{S}f8{xt5j8t%KS(2|%lv-Gt
z37Xf-fOP9&jdt(|52%@+nV$z8H-M&kP%{GVI7qetSAFoB8QPqHS`SSE2+M=PwR~o>
z0?g4+6(Czui&K$;QvqT+BFz{jB<P@7jgT}>NYFvifs#N_g9I{ai*Qpoq}2r$Rsat=
zfqbcun3I!V4vr^i&MV1RC{E2uO@@VV5oEp+VURPZHB?jz&a{{VGUb^i848eA4yZ2$
z^*Go^Rz;xsP%BWzg^t^Ug+bG03_;qUu^tW300FpH3T`_DfvYc2zZpDl=i=(-80r%e
z@9Y`i;TjYSZh?TC{3vk~Bnhh3q(Fo;h%f*V;IRpC?Fa6FgDeA2lLgs<WNkqNSRH7X
z4%~!+mImND5ljqB69v@1f)>bVCDBt*-3am}gR&@-Ftaoh4<j2B7ZVpVFB3l#C!+*2
z4`VVH0|NtSq!Cn8f@?{4Mh1o&4u)DTh8ix=Ob4hA)B@FkHEf{1H>k1C&d|)nSjz>i
zor=vEYB(8+mVy>V)NnCmF@fr?8ct9Lf-$`C6az~MGk94@HUncVHv?k{3quVzsPEsz
z$N-jQ1<Njk$kuR!dhR7`3|Z_9*-Q*Yvq2RyTzwt`LlXl?S45sFsG<eAkO}0-X7FSU
zXmI)z$k~vg0Y*^G%fwLh7%T*?enEo}OblQNR**iBjz0|WQ39S~CdLvTh9WD*5?+QP
zb;cUFB6UWP*Z4q<hZJVWm;z&P2|q)Y0BGp4L=fy-kbPVXSzuM*Sy#~bNbzANXa@+j
z?oO>pPAw==02S7dTm_%0(E-;k(9{L393e9@@hO=_;7T8yDZnKnTE$<Iky@#clCMyn
zk(#Ga3R+pAU<K+Rfx97k$PEIt3IJTP!kvJ~$>AV_g8e)}qo~kgH8lm)bVyZ5g$)D1
z#_2#sFvwA$q83_!f*lGi0zs7w)K>`e9YN!;y1AgyQLE&f#NuKrP|XF+`w6hI5(UpR
zg}nT{RFEqQit@`cQ$UUY34kgSuqB{6A}Lh?k`q!;{SFa~N6Q|l1vIoZf$Xy467Vo^
zej2Q)p-`Tx0BK=>s)?LTXa^P=E~sTIBF2!7g!H8Hi$Fs(c_oRN;0BwsBY4;d8f3+w
zIg;GcoRZ9foK%J4RM5CmNvZ;94y0H|A+Z?lTd1{=5g%wRqF$_^>+A@cBvDAqNlXWI
zIKeRjo;QKF9Fgm2MDeVLbxuP=6XGxMU@ds$0jvyK3xYdE#X(M>lBNMP2%o3m5fTy*
z46aZ?HF^eU*ef+PPXQFgItodpCE$t#l%h0(!HG`650r*I^HQMItfoS0MM-KNXtEI0
zk_+((2E{sP770FruaFPwWP`@=p^J(@m1btK0%B+$<Y`E@0+~@zlv)gmtHeBo%)I3M
zBGBZN0?1&bl!`p&02$r~4~#+D7NFt$(xTMjK|iGLrvVxp0#|!MiJ&SAG^`A+tvvm~
zYqB8YY@h);|6s5HxYM3mRFszw9%6I#^LO<N2?E!HNgxA2Bh=tgyUgPFOxT(fa60e|
zjt_Qq4h?b*33Buc4)6~O2?DJ{01uA`fmUn<fhO03KoiH1VL@;&CO<hFX;uJSt%4>W
zz)1*F)q*Qn&|o1_fdLtTL*%I-@Y*j>cYDC+#X#*5kV}yYS7k;9hGNj<3WEq6BM%D?
zBM%b~BQv82BR?ZQGibPgpOK4Ef{B-jjZv6Ql97#3h*6k{jggt1iy1tG02(L(1sk|R
zUIgj3W-&4pX@Ta_YQSrIK+Ar#K-Cdw8Vx*PUdsTgkV{xW6=*smXe_RT9W;0c8Hz88
z0ChXFI6xwx>X8v#3syLTL|tO7LCfVT1;In<OdwN16L#TwvJ5OB^S~X|5?+QhNJT!C
zfsv81FrFczgpVP(FrFd2gr6Z8JZD?H7PJf}wInsUq!?5ML0Z=tsS5BK0y46eS*(zl
zr{Ec&09{dpRu`2N!8KSZc;pwCfCt(@-Jy!a+{`@aaGn*U)oF#YN)B!jx)nOuSIY%~
z7RP``fF0f9J^frm%rrm)J3*YFKnF!bK%_Bba0E2S5~K*q5#VVmP!57>0cWp_#A48R
z7B~+j78IoBr3B@H6oVEf!LnF>5qJ(LEHS4v6`c2iQb5*#vPDQyX=)It-3bmyu!CS;
z0dvw4b2D=?Q;SPL1GtH4;N~Wn7?3t+P&#O-C@7JGGCTvD1d|XGXuw&RiI<U?QIJuR
zk%fta5xg1%)N+TccGCdoYc9|-zWB7#lF}m3Bp7H=DF`%M3@$LhqxKoOiOG<uKu{J)
z%FF|=SOX93LnZ}4K@S?Q&&f;*0!2{}C;)>%4OnpSLK;?}H7nq<4l)l3G721!1&PVo
ziRr1u;24IKlb~<}hdsFX0+)53!SMl+{sFFj!NER38K8Ld1QDPyC`i%h2jYT8$snbj
z7>En%iGa%~Pw=W*NDQO(Gzviq!D#|iz#$DjKo;78e3F%)nHLlXN*Ex|6<0!*<3Z-K
zgF-?2LF4v8u^<+>h|dMFKrsUH2xMIZm^C0t102XUkYRT_Q2AWk#lXNIz{mrEOk#{O
zOfrlD%xsKc$jr>h&dAQl#lp$U$;ipf%*ewi!zjYY%gDma%&5S~%gDpX#mdjf!_3Sm
rz{JbS%g8It#>k8pg4BXc;9-)|<CNwU=M-RL<hSKyWMkxH<Z%K3Bh>zR

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/util/timeout.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/util/timeout.py
new file mode 100644
index 0000000..cec817e
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/util/timeout.py
@@ -0,0 +1,242 @@
+from __future__ import absolute_import
+# The default socket timeout, used by httplib to indicate that no timeout was
+# specified by the user
+from socket import _GLOBAL_DEFAULT_TIMEOUT
+import time
+
+from ..exceptions import TimeoutStateError
+
+# A sentinel value to indicate that no timeout was specified by the user in
+# urllib3
+_Default = object()
+
+
+# Use time.monotonic if available.
+current_time = getattr(time, "monotonic", time.time)
+
+
+class Timeout(object):
+    """ Timeout configuration.
+
+    Timeouts can be defined as a default for a pool::
+
+        timeout = Timeout(connect=2.0, read=7.0)
+        http = PoolManager(timeout=timeout)
+        response = http.request('GET', 'http://example.com/')
+
+    Or per-request (which overrides the default for the pool)::
+
+        response = http.request('GET', 'http://example.com/', timeout=Timeout(10))
+
+    Timeouts can be disabled by setting all the parameters to ``None``::
+
+        no_timeout = Timeout(connect=None, read=None)
+        response = http.request('GET', 'http://example.com/, timeout=no_timeout)
+
+
+    :param total:
+        This combines the connect and read timeouts into one; the read timeout
+        will be set to the time leftover from the connect attempt. In the
+        event that both a connect timeout and a total are specified, or a read
+        timeout and a total are specified, the shorter timeout will be applied.
+
+        Defaults to None.
+
+    :type total: integer, float, or None
+
+    :param connect:
+        The maximum amount of time to wait for a connection attempt to a server
+        to succeed. Omitting the parameter will default the connect timeout to
+        the system default, probably `the global default timeout in socket.py
+        <http://hg.python.org/cpython/file/603b4d593758/Lib/socket.py#l535>`_.
+        None will set an infinite timeout for connection attempts.
+
+    :type connect: integer, float, or None
+
+    :param read:
+        The maximum amount of time to wait between consecutive
+        read operations for a response from the server. Omitting
+        the parameter will default the read timeout to the system
+        default, probably `the global default timeout in socket.py
+        <http://hg.python.org/cpython/file/603b4d593758/Lib/socket.py#l535>`_.
+        None will set an infinite timeout.
+
+    :type read: integer, float, or None
+
+    .. note::
+
+        Many factors can affect the total amount of time for urllib3 to return
+        an HTTP response.
+
+        For example, Python's DNS resolver does not obey the timeout specified
+        on the socket. Other factors that can affect total request time include
+        high CPU load, high swap, the program running at a low priority level,
+        or other behaviors.
+
+        In addition, the read and total timeouts only measure the time between
+        read operations on the socket connecting the client and the server,
+        not the total amount of time for the request to return a complete
+        response. For most requests, the timeout is raised because the server
+        has not sent the first byte in the specified time. This is not always
+        the case; if a server streams one byte every fifteen seconds, a timeout
+        of 20 seconds will not trigger, even though the request will take
+        several minutes to complete.
+
+        If your goal is to cut off any request after a set amount of wall clock
+        time, consider having a second "watcher" thread to cut off a slow
+        request.
+    """
+
+    #: A sentinel object representing the default timeout value
+    DEFAULT_TIMEOUT = _GLOBAL_DEFAULT_TIMEOUT
+
+    def __init__(self, total=None, connect=_Default, read=_Default):
+        self._connect = self._validate_timeout(connect, 'connect')
+        self._read = self._validate_timeout(read, 'read')
+        self.total = self._validate_timeout(total, 'total')
+        self._start_connect = None
+
+    def __str__(self):
+        return '%s(connect=%r, read=%r, total=%r)' % (
+            type(self).__name__, self._connect, self._read, self.total)
+
+    @classmethod
+    def _validate_timeout(cls, value, name):
+        """ Check that a timeout attribute is valid.
+
+        :param value: The timeout value to validate
+        :param name: The name of the timeout attribute to validate. This is
+            used to specify in error messages.
+        :return: The validated and casted version of the given value.
+        :raises ValueError: If it is a numeric value less than or equal to
+            zero, or the type is not an integer, float, or None.
+        """
+        if value is _Default:
+            return cls.DEFAULT_TIMEOUT
+
+        if value is None or value is cls.DEFAULT_TIMEOUT:
+            return value
+
+        if isinstance(value, bool):
+            raise ValueError("Timeout cannot be a boolean value. It must "
+                             "be an int, float or None.")
+        try:
+            float(value)
+        except (TypeError, ValueError):
+            raise ValueError("Timeout value %s was %s, but it must be an "
+                             "int, float or None." % (name, value))
+
+        try:
+            if value <= 0:
+                raise ValueError("Attempted to set %s timeout to %s, but the "
+                                 "timeout cannot be set to a value less "
+                                 "than or equal to 0." % (name, value))
+        except TypeError:  # Python 3
+            raise ValueError("Timeout value %s was %s, but it must be an "
+                             "int, float or None." % (name, value))
+
+        return value
+
+    @classmethod
+    def from_float(cls, timeout):
+        """ Create a new Timeout from a legacy timeout value.
+
+        The timeout value used by httplib.py sets the same timeout on the
+        connect(), and recv() socket requests. This creates a :class:`Timeout`
+        object that sets the individual timeouts to the ``timeout`` value
+        passed to this function.
+
+        :param timeout: The legacy timeout value.
+        :type timeout: integer, float, sentinel default object, or None
+        :return: Timeout object
+        :rtype: :class:`Timeout`
+        """
+        return Timeout(read=timeout, connect=timeout)
+
+    def clone(self):
+        """ Create a copy of the timeout object
+
+        Timeout properties are stored per-pool but each request needs a fresh
+        Timeout object to ensure each one has its own start/stop configured.
+
+        :return: a copy of the timeout object
+        :rtype: :class:`Timeout`
+        """
+        # We can't use copy.deepcopy because that will also create a new object
+        # for _GLOBAL_DEFAULT_TIMEOUT, which socket.py uses as a sentinel to
+        # detect the user default.
+        return Timeout(connect=self._connect, read=self._read,
+                       total=self.total)
+
+    def start_connect(self):
+        """ Start the timeout clock, used during a connect() attempt
+
+        :raises urllib3.exceptions.TimeoutStateError: if you attempt
+            to start a timer that has been started already.
+        """
+        if self._start_connect is not None:
+            raise TimeoutStateError("Timeout timer has already been started.")
+        self._start_connect = current_time()
+        return self._start_connect
+
+    def get_connect_duration(self):
+        """ Gets the time elapsed since the call to :meth:`start_connect`.
+
+        :return: Elapsed time.
+        :rtype: float
+        :raises urllib3.exceptions.TimeoutStateError: if you attempt
+            to get duration for a timer that hasn't been started.
+        """
+        if self._start_connect is None:
+            raise TimeoutStateError("Can't get connect duration for timer "
+                                    "that has not started.")
+        return current_time() - self._start_connect
+
+    @property
+    def connect_timeout(self):
+        """ Get the value to use when setting a connection timeout.
+
+        This will be a positive float or integer, the value None
+        (never timeout), or the default system timeout.
+
+        :return: Connect timeout.
+        :rtype: int, float, :attr:`Timeout.DEFAULT_TIMEOUT` or None
+        """
+        if self.total is None:
+            return self._connect
+
+        if self._connect is None or self._connect is self.DEFAULT_TIMEOUT:
+            return self.total
+
+        return min(self._connect, self.total)
+
+    @property
+    def read_timeout(self):
+        """ Get the value for the read timeout.
+
+        This assumes some time has elapsed in the connection timeout and
+        computes the read timeout appropriately.
+
+        If self.total is set, the read timeout is dependent on the amount of
+        time taken by the connect timeout. If the connection time has not been
+        established, a :exc:`~urllib3.exceptions.TimeoutStateError` will be
+        raised.
+
+        :return: Value to use for the read timeout.
+        :rtype: int, float, :attr:`Timeout.DEFAULT_TIMEOUT` or None
+        :raises urllib3.exceptions.TimeoutStateError: If :meth:`start_connect`
+            has not yet been called on this object.
+        """
+        if (self.total is not None and
+                self.total is not self.DEFAULT_TIMEOUT and
+                self._read is not None and
+                self._read is not self.DEFAULT_TIMEOUT):
+            # In case the connect timeout has not yet been established.
+            if self._start_connect is None:
+                return self._read
+            return max(0, min(self.total - self.get_connect_duration(),
+                              self._read))
+        elif self.total is not None and self.total is not self.DEFAULT_TIMEOUT:
+            return max(0, self.total - self.get_connect_duration())
+        else:
+            return self._read
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/util/timeout.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/util/timeout.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..7d467cbf7d02af083a0bc6bc52135439fe0bc385
GIT binary patch
literal 10233
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
AiU0rr

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/util/url.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/util/url.py
new file mode 100644
index 0000000..6b6f996
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/util/url.py
@@ -0,0 +1,230 @@
+from __future__ import absolute_import
+from collections import namedtuple
+
+from ..exceptions import LocationParseError
+
+
+url_attrs = ['scheme', 'auth', 'host', 'port', 'path', 'query', 'fragment']
+
+# We only want to normalize urls with an HTTP(S) scheme.
+# urllib3 infers URLs without a scheme (None) to be http.
+NORMALIZABLE_SCHEMES = ('http', 'https', None)
+
+
+class Url(namedtuple('Url', url_attrs)):
+    """
+    Datastructure for representing an HTTP URL. Used as a return value for
+    :func:`parse_url`. Both the scheme and host are normalized as they are
+    both case-insensitive according to RFC 3986.
+    """
+    __slots__ = ()
+
+    def __new__(cls, scheme=None, auth=None, host=None, port=None, path=None,
+                query=None, fragment=None):
+        if path and not path.startswith('/'):
+            path = '/' + path
+        if scheme:
+            scheme = scheme.lower()
+        if host and scheme in NORMALIZABLE_SCHEMES:
+            host = host.lower()
+        return super(Url, cls).__new__(cls, scheme, auth, host, port, path,
+                                       query, fragment)
+
+    @property
+    def hostname(self):
+        """For backwards-compatibility with urlparse. We're nice like that."""
+        return self.host
+
+    @property
+    def request_uri(self):
+        """Absolute path including the query string."""
+        uri = self.path or '/'
+
+        if self.query is not None:
+            uri += '?' + self.query
+
+        return uri
+
+    @property
+    def netloc(self):
+        """Network location including host and port"""
+        if self.port:
+            return '%s:%d' % (self.host, self.port)
+        return self.host
+
+    @property
+    def url(self):
+        """
+        Convert self into a url
+
+        This function should more or less round-trip with :func:`.parse_url`. The
+        returned url may not be exactly the same as the url inputted to
+        :func:`.parse_url`, but it should be equivalent by the RFC (e.g., urls
+        with a blank port will have : removed).
+
+        Example: ::
+
+            >>> U = parse_url('http://google.com/mail/')
+            >>> U.url
+            'http://google.com/mail/'
+            >>> Url('http', 'username:password', 'host.com', 80,
+            ... '/path', 'query', 'fragment').url
+            'http://username:password@host.com:80/path?query#fragment'
+        """
+        scheme, auth, host, port, path, query, fragment = self
+        url = ''
+
+        # We use "is not None" we want things to happen with empty strings (or 0 port)
+        if scheme is not None:
+            url += scheme + '://'
+        if auth is not None:
+            url += auth + '@'
+        if host is not None:
+            url += host
+        if port is not None:
+            url += ':' + str(port)
+        if path is not None:
+            url += path
+        if query is not None:
+            url += '?' + query
+        if fragment is not None:
+            url += '#' + fragment
+
+        return url
+
+    def __str__(self):
+        return self.url
+
+
+def split_first(s, delims):
+    """
+    Given a string and an iterable of delimiters, split on the first found
+    delimiter. Return two split parts and the matched delimiter.
+
+    If not found, then the first part is the full input string.
+
+    Example::
+
+        >>> split_first('foo/bar?baz', '?/=')
+        ('foo', 'bar?baz', '/')
+        >>> split_first('foo/bar?baz', '123')
+        ('foo/bar?baz', '', None)
+
+    Scales linearly with number of delims. Not ideal for large number of delims.
+    """
+    min_idx = None
+    min_delim = None
+    for d in delims:
+        idx = s.find(d)
+        if idx < 0:
+            continue
+
+        if min_idx is None or idx < min_idx:
+            min_idx = idx
+            min_delim = d
+
+    if min_idx is None or min_idx < 0:
+        return s, '', None
+
+    return s[:min_idx], s[min_idx + 1:], min_delim
+
+
+def 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.
+
+    Partly backwards-compatible with :mod:`urlparse`.
+
+    Example::
+
+        >>> parse_url('http://google.com/mail/')
+        Url(scheme='http', host='google.com', port=None, path='/mail/', ...)
+        >>> parse_url('google.com:80')
+        Url(scheme=None, host='google.com', port=80, path=None, ...)
+        >>> parse_url('/foo?bar')
+        Url(scheme=None, host=None, port=None, path='/foo', query='bar', ...)
+    """
+
+    # While this code has overlap with stdlib's urlparse, it is much
+    # simplified for our needs and less annoying.
+    # Additionally, this implementations does silly things to be optimal
+    # on CPython.
+
+    if not url:
+        # Empty
+        return Url()
+
+    scheme = None
+    auth = None
+    host = None
+    port = None
+    path = None
+    fragment = None
+    query = None
+
+    # Scheme
+    if '://' in url:
+        scheme, url = url.split('://', 1)
+
+    # Find the earliest Authority Terminator
+    # (http://tools.ietf.org/html/rfc3986#section-3.2)
+    url, path_, delim = split_first(url, ['/', '?', '#'])
+
+    if delim:
+        # Reassemble the path
+        path = delim + path_
+
+    # Auth
+    if '@' in url:
+        # Last '@' denotes end of auth part
+        auth, url = url.rsplit('@', 1)
+
+    # IPv6
+    if url and url[0] == '[':
+        host, url = url.split(']', 1)
+        host += ']'
+
+    # Port
+    if ':' in url:
+        _host, port = url.split(':', 1)
+
+        if not host:
+            host = _host
+
+        if port:
+            # If given, ports must be integers. No whitespace, no plus or
+            # minus prefixes, no non-integer digits such as ^2 (superscript).
+            if not port.isdigit():
+                raise LocationParseError(url)
+            try:
+                port = int(port)
+            except ValueError:
+                raise LocationParseError(url)
+        else:
+            # Blank ports are cool, too. (rfc3986#section-3.2.3)
+            port = None
+
+    elif not host and url:
+        host = url
+
+    if not path:
+        return Url(scheme, auth, host, port, path, query, fragment)
+
+    # Fragment
+    if '#' in path:
+        path, fragment = path.split('#', 1)
+
+    # Query
+    if '?' in path:
+        path, query = path.split('?', 1)
+
+    return Url(scheme, auth, host, port, path, query, fragment)
+
+
+def get_host(url):
+    """
+    Deprecated. Use :func:`parse_url` instead.
+    """
+    p = parse_url(url)
+    return p.scheme or 'http', p.hostname, p.port
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/util/url.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/util/url.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..4806b6a62618eef7caae9d3abf80c7bf32744c34
GIT binary patch
literal 6910
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
BT=@V1

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/util/wait.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/util/wait.py
new file mode 100644
index 0000000..4db71ba
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/util/wait.py
@@ -0,0 +1,150 @@
+import errno
+from functools import partial
+import select
+import sys
+try:
+    from time import monotonic
+except ImportError:
+    from time import time as monotonic
+
+__all__ = ["NoWayToWaitForSocketError", "wait_for_read", "wait_for_write"]
+
+
+class NoWayToWaitForSocketError(Exception):
+    pass
+
+
+# How should we wait on sockets?
+#
+# There are two types of APIs you can use for waiting on sockets: the fancy
+# modern stateful APIs like epoll/kqueue, and the older stateless APIs like
+# select/poll. The stateful APIs are more efficient when you have a lots of
+# sockets to keep track of, because you can set them up once and then use them
+# lots of times. But we only ever want to wait on a single socket at a time
+# and don't want to keep track of state, so the stateless APIs are actually
+# more efficient. So we want to use select() or poll().
+#
+# Now, how do we choose between select() and poll()? On traditional Unixes,
+# select() has a strange calling convention that makes it slow, or fail
+# altogether, for high-numbered file descriptors. The point of poll() is to fix
+# that, so on Unixes, we prefer poll().
+#
+# On Windows, there is no poll() (or at least Python doesn't provide a wrapper
+# for it), but that's OK, because on Windows, select() doesn't have this
+# strange calling convention; plain select() works fine.
+#
+# So: on Windows we use select(), and everywhere else we use poll(). We also
+# fall back to select() in case poll() is somehow broken or missing.
+
+if sys.version_info >= (3, 5):
+    # Modern Python, that retries syscalls by default
+    def _retry_on_intr(fn, timeout):
+        return fn(timeout)
+else:
+    # Old and broken Pythons.
+    def _retry_on_intr(fn, timeout):
+        if timeout is None:
+            deadline = float("inf")
+        else:
+            deadline = monotonic() + timeout
+
+        while True:
+            try:
+                return fn(timeout)
+            # OSError for 3 <= pyver < 3.5, select.error for pyver <= 2.7
+            except (OSError, select.error) as e:
+                # 'e.args[0]' incantation works for both OSError and select.error
+                if e.args[0] != errno.EINTR:
+                    raise
+                else:
+                    timeout = deadline - monotonic()
+                    if timeout < 0:
+                        timeout = 0
+                    if timeout == float("inf"):
+                        timeout = None
+                    continue
+
+
+def select_wait_for_socket(sock, read=False, write=False, timeout=None):
+    if not read and not write:
+        raise RuntimeError("must specify at least one of read=True, write=True")
+    rcheck = []
+    wcheck = []
+    if read:
+        rcheck.append(sock)
+    if write:
+        wcheck.append(sock)
+    # When doing a non-blocking connect, most systems signal success by
+    # marking the socket writable. Windows, though, signals success by marked
+    # it as "exceptional". We paper over the difference by checking the write
+    # sockets for both conditions. (The stdlib selectors module does the same
+    # thing.)
+    fn = partial(select.select, rcheck, wcheck, wcheck)
+    rready, wready, xready = _retry_on_intr(fn, timeout)
+    return bool(rready or wready or xready)
+
+
+def poll_wait_for_socket(sock, read=False, write=False, timeout=None):
+    if not read and not write:
+        raise RuntimeError("must specify at least one of read=True, write=True")
+    mask = 0
+    if read:
+        mask |= select.POLLIN
+    if write:
+        mask |= select.POLLOUT
+    poll_obj = select.poll()
+    poll_obj.register(sock, mask)
+
+    # For some reason, poll() takes timeout in milliseconds
+    def do_poll(t):
+        if t is not None:
+            t *= 1000
+        return poll_obj.poll(t)
+
+    return bool(_retry_on_intr(do_poll, timeout))
+
+
+def null_wait_for_socket(*args, **kwargs):
+    raise NoWayToWaitForSocketError("no select-equivalent available")
+
+
+def _have_working_poll():
+    # Apparently some systems have a select.poll that fails as soon as you try
+    # to use it, either due to strange configuration or broken monkeypatching
+    # from libraries like eventlet/greenlet.
+    try:
+        poll_obj = select.poll()
+        _retry_on_intr(poll_obj.poll, 0)
+    except (AttributeError, OSError):
+        return False
+    else:
+        return True
+
+
+def wait_for_socket(*args, **kwargs):
+    # We delay choosing which implementation to use until the first time we're
+    # called. We could do it at import time, but then we might make the wrong
+    # decision if someone goes wild with monkeypatching select.poll after
+    # we're imported.
+    global wait_for_socket
+    if _have_working_poll():
+        wait_for_socket = poll_wait_for_socket
+    elif hasattr(select, "select"):
+        wait_for_socket = select_wait_for_socket
+    else:  # Platform-specific: Appengine.
+        wait_for_socket = null_wait_for_socket
+    return wait_for_socket(*args, **kwargs)
+
+
+def wait_for_read(sock, timeout=None):
+    """ Waits for reading to be available on a given socket.
+    Returns True if the socket is readable, or False if the timeout expired.
+    """
+    return wait_for_socket(sock, read=True, timeout=timeout)
+
+
+def wait_for_write(sock, timeout=None):
+    """ Waits for writing to be available on a given socket.
+    Returns True if the socket is readable, or False if the timeout expired.
+    """
+    return wait_for_socket(sock, write=True, timeout=timeout)
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/util/wait.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/urllib3/util/wait.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..617211378130b5f62f7d1be4ad86e418fe8db672
GIT binary patch
literal 4842
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
UhlNvINLWaOlZBI)lb?qj07@K4t^fc4

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/webencodings/__init__.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/webencodings/__init__.py
new file mode 100644
index 0000000..d21d697
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/webencodings/__init__.py
@@ -0,0 +1,342 @@
+# coding: utf-8
+"""
+
+    webencodings
+    ~~~~~~~~~~~~
+
+    This is a Python implementation of the `WHATWG Encoding standard
+    <http://encoding.spec.whatwg.org/>`. See README for details.
+
+    :copyright: Copyright 2012 by Simon Sapin
+    :license: BSD, see LICENSE for details.
+
+"""
+
+from __future__ import unicode_literals
+
+import codecs
+
+from .labels import LABELS
+
+
+VERSION = '0.5.1'
+
+
+# Some names in Encoding are not valid Python aliases. Remap these.
+PYTHON_NAMES = {
+    'iso-8859-8-i': 'iso-8859-8',
+    'x-mac-cyrillic': 'mac-cyrillic',
+    'macintosh': 'mac-roman',
+    'windows-874': 'cp874'}
+
+CACHE = {}
+
+
+def ascii_lower(string):
+    r"""Transform (only) ASCII letters to lower case: A-Z is mapped to a-z.
+
+    :param string: An Unicode string.
+    :returns: A new Unicode string.
+
+    This is used for `ASCII case-insensitive
+    <http://encoding.spec.whatwg.org/#ascii-case-insensitive>`_
+    matching of encoding labels.
+    The same matching is also used, among other things,
+    for `CSS keywords <http://dev.w3.org/csswg/css-values/#keywords>`_.
+
+    This is different from the :meth:`~py:str.lower` method of Unicode strings
+    which also affect non-ASCII characters,
+    sometimes mapping them into the ASCII range:
+
+        >>> keyword = u'Bac\N{KELVIN SIGN}ground'
+        >>> assert keyword.lower() == u'background'
+        >>> assert ascii_lower(keyword) != keyword.lower()
+        >>> assert ascii_lower(keyword) == u'bac\N{KELVIN SIGN}ground'
+
+    """
+    # This turns out to be faster than unicode.translate()
+    return string.encode('utf8').lower().decode('utf8')
+
+
+def lookup(label):
+    """
+    Look for an encoding by its label.
+    This is the spec’s `get an encoding
+    <http://encoding.spec.whatwg.org/#concept-encoding-get>`_ algorithm.
+    Supported labels are listed there.
+
+    :param label: A string.
+    :returns:
+        An :class:`Encoding` object, or :obj:`None` for an unknown label.
+
+    """
+    # Only strip ASCII whitespace: U+0009, U+000A, U+000C, U+000D, and U+0020.
+    label = ascii_lower(label.strip('\t\n\f\r '))
+    name = LABELS.get(label)
+    if name is None:
+        return None
+    encoding = CACHE.get(name)
+    if encoding is None:
+        if name == 'x-user-defined':
+            from .x_user_defined import codec_info
+        else:
+            python_name = PYTHON_NAMES.get(name, name)
+            # Any python_name value that gets to here should be valid.
+            codec_info = codecs.lookup(python_name)
+        encoding = Encoding(name, codec_info)
+        CACHE[name] = encoding
+    return encoding
+
+
+def _get_encoding(encoding_or_label):
+    """
+    Accept either an encoding object or label.
+
+    :param encoding: An :class:`Encoding` object or a label string.
+    :returns: An :class:`Encoding` object.
+    :raises: :exc:`~exceptions.LookupError` for an unknown label.
+
+    """
+    if hasattr(encoding_or_label, 'codec_info'):
+        return encoding_or_label
+
+    encoding = lookup(encoding_or_label)
+    if encoding is None:
+        raise LookupError('Unknown encoding label: %r' % encoding_or_label)
+    return encoding
+
+
+class Encoding(object):
+    """Reresents a character encoding such as UTF-8,
+    that can be used for decoding or encoding.
+
+    .. attribute:: name
+
+        Canonical name of the encoding
+
+    .. attribute:: codec_info
+
+        The actual implementation of the encoding,
+        a stdlib :class:`~codecs.CodecInfo` object.
+        See :func:`codecs.register`.
+
+    """
+    def __init__(self, name, codec_info):
+        self.name = name
+        self.codec_info = codec_info
+
+    def __repr__(self):
+        return '<Encoding %s>' % self.name
+
+
+#: The UTF-8 encoding. Should be used for new content and formats.
+UTF8 = lookup('utf-8')
+
+_UTF16LE = lookup('utf-16le')
+_UTF16BE = lookup('utf-16be')
+
+
+def decode(input, fallback_encoding, errors='replace'):
+    """
+    Decode a single string.
+
+    :param input: A byte string
+    :param fallback_encoding:
+        An :class:`Encoding` object or a label string.
+        The encoding to use if :obj:`input` does note have a BOM.
+    :param errors: Type of error handling. See :func:`codecs.register`.
+    :raises: :exc:`~exceptions.LookupError` for an unknown encoding label.
+    :return:
+        A ``(output, encoding)`` tuple of an Unicode string
+        and an :obj:`Encoding`.
+
+    """
+    # Fail early if `encoding` is an invalid label.
+    fallback_encoding = _get_encoding(fallback_encoding)
+    bom_encoding, input = _detect_bom(input)
+    encoding = bom_encoding or fallback_encoding
+    return encoding.codec_info.decode(input, errors)[0], encoding
+
+
+def _detect_bom(input):
+    """Return (bom_encoding, input), with any BOM removed from the input."""
+    if input.startswith(b'\xFF\xFE'):
+        return _UTF16LE, input[2:]
+    if input.startswith(b'\xFE\xFF'):
+        return _UTF16BE, input[2:]
+    if input.startswith(b'\xEF\xBB\xBF'):
+        return UTF8, input[3:]
+    return None, input
+
+
+def encode(input, encoding=UTF8, errors='strict'):
+    """
+    Encode a single string.
+
+    :param input: An Unicode string.
+    :param encoding: An :class:`Encoding` object or a label string.
+    :param errors: Type of error handling. See :func:`codecs.register`.
+    :raises: :exc:`~exceptions.LookupError` for an unknown encoding label.
+    :return: A byte string.
+
+    """
+    return _get_encoding(encoding).codec_info.encode(input, errors)[0]
+
+
+def iter_decode(input, fallback_encoding, errors='replace'):
+    """
+    "Pull"-based decoder.
+
+    :param input:
+        An iterable of byte strings.
+
+        The input is first consumed just enough to determine the encoding
+        based on the precense of a BOM,
+        then consumed on demand when the return value is.
+    :param fallback_encoding:
+        An :class:`Encoding` object or a label string.
+        The encoding to use if :obj:`input` does note have a BOM.
+    :param errors: Type of error handling. See :func:`codecs.register`.
+    :raises: :exc:`~exceptions.LookupError` for an unknown encoding label.
+    :returns:
+        An ``(output, encoding)`` tuple.
+        :obj:`output` is an iterable of Unicode strings,
+        :obj:`encoding` is the :obj:`Encoding` that is being used.
+
+    """
+
+    decoder = IncrementalDecoder(fallback_encoding, errors)
+    generator = _iter_decode_generator(input, decoder)
+    encoding = next(generator)
+    return generator, encoding
+
+
+def _iter_decode_generator(input, decoder):
+    """Return a generator that first yields the :obj:`Encoding`,
+    then yields output chukns as Unicode strings.
+
+    """
+    decode = decoder.decode
+    input = iter(input)
+    for chunck in input:
+        output = decode(chunck)
+        if output:
+            assert decoder.encoding is not None
+            yield decoder.encoding
+            yield output
+            break
+    else:
+        # Input exhausted without determining the encoding
+        output = decode(b'', final=True)
+        assert decoder.encoding is not None
+        yield decoder.encoding
+        if output:
+            yield output
+        return
+
+    for chunck in input:
+        output = decode(chunck)
+        if output:
+            yield output
+    output = decode(b'', final=True)
+    if output:
+        yield output
+
+
+def iter_encode(input, encoding=UTF8, errors='strict'):
+    """
+    “Pull”-based encoder.
+
+    :param input: An iterable of Unicode strings.
+    :param encoding: An :class:`Encoding` object or a label string.
+    :param errors: Type of error handling. See :func:`codecs.register`.
+    :raises: :exc:`~exceptions.LookupError` for an unknown encoding label.
+    :returns: An iterable of byte strings.
+
+    """
+    # Fail early if `encoding` is an invalid label.
+    encode = IncrementalEncoder(encoding, errors).encode
+    return _iter_encode_generator(input, encode)
+
+
+def _iter_encode_generator(input, encode):
+    for chunck in input:
+        output = encode(chunck)
+        if output:
+            yield output
+    output = encode('', final=True)
+    if output:
+        yield output
+
+
+class IncrementalDecoder(object):
+    """
+    “Push”-based decoder.
+
+    :param fallback_encoding:
+        An :class:`Encoding` object or a label string.
+        The encoding to use if :obj:`input` does note have a BOM.
+    :param errors: Type of error handling. See :func:`codecs.register`.
+    :raises: :exc:`~exceptions.LookupError` for an unknown encoding label.
+
+    """
+    def __init__(self, fallback_encoding, errors='replace'):
+        # Fail early if `encoding` is an invalid label.
+        self._fallback_encoding = _get_encoding(fallback_encoding)
+        self._errors = errors
+        self._buffer = b''
+        self._decoder = None
+        #: The actual :class:`Encoding` that is being used,
+        #: or :obj:`None` if that is not determined yet.
+        #: (Ie. if there is not enough input yet to determine
+        #: if there is a BOM.)
+        self.encoding = None  # Not known yet.
+
+    def decode(self, input, final=False):
+        """Decode one chunk of the input.
+
+        :param input: A byte string.
+        :param final:
+            Indicate that no more input is available.
+            Must be :obj:`True` if this is the last call.
+        :returns: An Unicode string.
+
+        """
+        decoder = self._decoder
+        if decoder is not None:
+            return decoder(input, final)
+
+        input = self._buffer + input
+        encoding, input = _detect_bom(input)
+        if encoding is None:
+            if len(input) < 3 and not final:  # Not enough data yet.
+                self._buffer = input
+                return ''
+            else:  # No BOM
+                encoding = self._fallback_encoding
+        decoder = encoding.codec_info.incrementaldecoder(self._errors).decode
+        self._decoder = decoder
+        self.encoding = encoding
+        return decoder(input, final)
+
+
+class IncrementalEncoder(object):
+    """
+    “Push”-based encoder.
+
+    :param encoding: An :class:`Encoding` object or a label string.
+    :param errors: Type of error handling. See :func:`codecs.register`.
+    :raises: :exc:`~exceptions.LookupError` for an unknown encoding label.
+
+    .. method:: encode(input, final=False)
+
+        :param input: An Unicode string.
+        :param final:
+            Indicate that no more input is available.
+            Must be :obj:`True` if this is the last call.
+        :returns: A byte string.
+
+    """
+    def __init__(self, encoding=UTF8, errors='strict'):
+        encoding = _get_encoding(encoding)
+        self.encode = encoding.codec_info.incrementalencoder(errors).encode
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/webencodings/__init__.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/webencodings/__init__.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..c5db4691e87540dacbcbbce3f4fd40c68fd439b0
GIT binary patch
literal 12364
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
D&C{yN

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/webencodings/labels.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/webencodings/labels.py
new file mode 100644
index 0000000..29cbf91
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/webencodings/labels.py
@@ -0,0 +1,231 @@
+"""
+
+    webencodings.labels
+    ~~~~~~~~~~~~~~~~~~~
+
+    Map encoding labels to their name.
+
+    :copyright: Copyright 2012 by Simon Sapin
+    :license: BSD, see LICENSE for details.
+
+"""
+
+# XXX Do not edit!
+# This file is automatically generated by mklabels.py
+
+LABELS = {
+    'unicode-1-1-utf-8':   'utf-8',
+    'utf-8':               'utf-8',
+    'utf8':                'utf-8',
+    '866':                 'ibm866',
+    'cp866':               'ibm866',
+    'csibm866':            'ibm866',
+    'ibm866':              'ibm866',
+    'csisolatin2':         'iso-8859-2',
+    'iso-8859-2':          'iso-8859-2',
+    'iso-ir-101':          'iso-8859-2',
+    'iso8859-2':           'iso-8859-2',
+    'iso88592':            'iso-8859-2',
+    'iso_8859-2':          'iso-8859-2',
+    'iso_8859-2:1987':     'iso-8859-2',
+    'l2':                  'iso-8859-2',
+    'latin2':              'iso-8859-2',
+    'csisolatin3':         'iso-8859-3',
+    'iso-8859-3':          'iso-8859-3',
+    'iso-ir-109':          'iso-8859-3',
+    'iso8859-3':           'iso-8859-3',
+    'iso88593':            'iso-8859-3',
+    'iso_8859-3':          'iso-8859-3',
+    'iso_8859-3:1988':     'iso-8859-3',
+    'l3':                  'iso-8859-3',
+    'latin3':              'iso-8859-3',
+    'csisolatin4':         'iso-8859-4',
+    'iso-8859-4':          'iso-8859-4',
+    'iso-ir-110':          'iso-8859-4',
+    'iso8859-4':           'iso-8859-4',
+    'iso88594':            'iso-8859-4',
+    'iso_8859-4':          'iso-8859-4',
+    'iso_8859-4:1988':     'iso-8859-4',
+    'l4':                  'iso-8859-4',
+    'latin4':              'iso-8859-4',
+    'csisolatincyrillic':  'iso-8859-5',
+    'cyrillic':            'iso-8859-5',
+    'iso-8859-5':          'iso-8859-5',
+    'iso-ir-144':          'iso-8859-5',
+    'iso8859-5':           'iso-8859-5',
+    'iso88595':            'iso-8859-5',
+    'iso_8859-5':          'iso-8859-5',
+    'iso_8859-5:1988':     'iso-8859-5',
+    'arabic':              'iso-8859-6',
+    'asmo-708':            'iso-8859-6',
+    'csiso88596e':         'iso-8859-6',
+    'csiso88596i':         'iso-8859-6',
+    'csisolatinarabic':    'iso-8859-6',
+    'ecma-114':            'iso-8859-6',
+    'iso-8859-6':          'iso-8859-6',
+    'iso-8859-6-e':        'iso-8859-6',
+    'iso-8859-6-i':        'iso-8859-6',
+    'iso-ir-127':          'iso-8859-6',
+    'iso8859-6':           'iso-8859-6',
+    'iso88596':            'iso-8859-6',
+    'iso_8859-6':          'iso-8859-6',
+    'iso_8859-6:1987':     'iso-8859-6',
+    'csisolatingreek':     'iso-8859-7',
+    'ecma-118':            'iso-8859-7',
+    'elot_928':            'iso-8859-7',
+    'greek':               'iso-8859-7',
+    'greek8':              'iso-8859-7',
+    'iso-8859-7':          'iso-8859-7',
+    'iso-ir-126':          'iso-8859-7',
+    'iso8859-7':           'iso-8859-7',
+    'iso88597':            'iso-8859-7',
+    'iso_8859-7':          'iso-8859-7',
+    'iso_8859-7:1987':     'iso-8859-7',
+    'sun_eu_greek':        'iso-8859-7',
+    'csiso88598e':         'iso-8859-8',
+    'csisolatinhebrew':    'iso-8859-8',
+    'hebrew':              'iso-8859-8',
+    'iso-8859-8':          'iso-8859-8',
+    'iso-8859-8-e':        'iso-8859-8',
+    'iso-ir-138':          'iso-8859-8',
+    'iso8859-8':           'iso-8859-8',
+    'iso88598':            'iso-8859-8',
+    'iso_8859-8':          'iso-8859-8',
+    'iso_8859-8:1988':     'iso-8859-8',
+    'visual':              'iso-8859-8',
+    'csiso88598i':         'iso-8859-8-i',
+    'iso-8859-8-i':        'iso-8859-8-i',
+    'logical':             'iso-8859-8-i',
+    'csisolatin6':         'iso-8859-10',
+    'iso-8859-10':         'iso-8859-10',
+    'iso-ir-157':          'iso-8859-10',
+    'iso8859-10':          'iso-8859-10',
+    'iso885910':           'iso-8859-10',
+    'l6':                  'iso-8859-10',
+    'latin6':              'iso-8859-10',
+    'iso-8859-13':         'iso-8859-13',
+    'iso8859-13':          'iso-8859-13',
+    'iso885913':           'iso-8859-13',
+    'iso-8859-14':         'iso-8859-14',
+    'iso8859-14':          'iso-8859-14',
+    'iso885914':           'iso-8859-14',
+    'csisolatin9':         'iso-8859-15',
+    'iso-8859-15':         'iso-8859-15',
+    'iso8859-15':          'iso-8859-15',
+    'iso885915':           'iso-8859-15',
+    'iso_8859-15':         'iso-8859-15',
+    'l9':                  'iso-8859-15',
+    'iso-8859-16':         'iso-8859-16',
+    'cskoi8r':             'koi8-r',
+    'koi':                 'koi8-r',
+    'koi8':                'koi8-r',
+    'koi8-r':              'koi8-r',
+    'koi8_r':              'koi8-r',
+    'koi8-u':              'koi8-u',
+    'csmacintosh':         'macintosh',
+    'mac':                 'macintosh',
+    'macintosh':           'macintosh',
+    'x-mac-roman':         'macintosh',
+    'dos-874':             'windows-874',
+    'iso-8859-11':         'windows-874',
+    'iso8859-11':          'windows-874',
+    'iso885911':           'windows-874',
+    'tis-620':             'windows-874',
+    'windows-874':         'windows-874',
+    'cp1250':              'windows-1250',
+    'windows-1250':        'windows-1250',
+    'x-cp1250':            'windows-1250',
+    'cp1251':              'windows-1251',
+    'windows-1251':        'windows-1251',
+    'x-cp1251':            'windows-1251',
+    'ansi_x3.4-1968':      'windows-1252',
+    'ascii':               'windows-1252',
+    'cp1252':              'windows-1252',
+    'cp819':               'windows-1252',
+    'csisolatin1':         'windows-1252',
+    'ibm819':              'windows-1252',
+    'iso-8859-1':          'windows-1252',
+    'iso-ir-100':          'windows-1252',
+    'iso8859-1':           'windows-1252',
+    'iso88591':            'windows-1252',
+    'iso_8859-1':          'windows-1252',
+    'iso_8859-1:1987':     'windows-1252',
+    'l1':                  'windows-1252',
+    'latin1':              'windows-1252',
+    'us-ascii':            'windows-1252',
+    'windows-1252':        'windows-1252',
+    'x-cp1252':            'windows-1252',
+    'cp1253':              'windows-1253',
+    'windows-1253':        'windows-1253',
+    'x-cp1253':            'windows-1253',
+    'cp1254':              'windows-1254',
+    'csisolatin5':         'windows-1254',
+    'iso-8859-9':          'windows-1254',
+    'iso-ir-148':          'windows-1254',
+    'iso8859-9':           'windows-1254',
+    'iso88599':            'windows-1254',
+    'iso_8859-9':          'windows-1254',
+    'iso_8859-9:1989':     'windows-1254',
+    'l5':                  'windows-1254',
+    'latin5':              'windows-1254',
+    'windows-1254':        'windows-1254',
+    'x-cp1254':            'windows-1254',
+    'cp1255':              'windows-1255',
+    'windows-1255':        'windows-1255',
+    'x-cp1255':            'windows-1255',
+    'cp1256':              'windows-1256',
+    'windows-1256':        'windows-1256',
+    'x-cp1256':            'windows-1256',
+    'cp1257':              'windows-1257',
+    'windows-1257':        'windows-1257',
+    'x-cp1257':            'windows-1257',
+    'cp1258':              'windows-1258',
+    'windows-1258':        'windows-1258',
+    'x-cp1258':            'windows-1258',
+    'x-mac-cyrillic':      'x-mac-cyrillic',
+    'x-mac-ukrainian':     'x-mac-cyrillic',
+    'chinese':             'gbk',
+    'csgb2312':            'gbk',
+    'csiso58gb231280':     'gbk',
+    'gb2312':              'gbk',
+    'gb_2312':             'gbk',
+    'gb_2312-80':          'gbk',
+    'gbk':                 'gbk',
+    'iso-ir-58':           'gbk',
+    'x-gbk':               'gbk',
+    'gb18030':             'gb18030',
+    'hz-gb-2312':          'hz-gb-2312',
+    'big5':                'big5',
+    'big5-hkscs':          'big5',
+    'cn-big5':             'big5',
+    'csbig5':              'big5',
+    'x-x-big5':            'big5',
+    'cseucpkdfmtjapanese': 'euc-jp',
+    'euc-jp':              'euc-jp',
+    'x-euc-jp':            'euc-jp',
+    'csiso2022jp':         'iso-2022-jp',
+    'iso-2022-jp':         'iso-2022-jp',
+    'csshiftjis':          'shift_jis',
+    'ms_kanji':            'shift_jis',
+    'shift-jis':           'shift_jis',
+    'shift_jis':           'shift_jis',
+    'sjis':                'shift_jis',
+    'windows-31j':         'shift_jis',
+    'x-sjis':              'shift_jis',
+    'cseuckr':             'euc-kr',
+    'csksc56011987':       'euc-kr',
+    'euc-kr':              'euc-kr',
+    'iso-ir-149':          'euc-kr',
+    'korean':              'euc-kr',
+    'ks_c_5601-1987':      'euc-kr',
+    'ks_c_5601-1989':      'euc-kr',
+    'ksc5601':             'euc-kr',
+    'ksc_5601':            'euc-kr',
+    'windows-949':         'euc-kr',
+    'csiso2022kr':         'iso-2022-kr',
+    'iso-2022-kr':         'iso-2022-kr',
+    'utf-16be':            'utf-16be',
+    'utf-16':              'utf-16le',
+    'utf-16le':            'utf-16le',
+    'x-user-defined':      'x-user-defined',
+}
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/webencodings/labels.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/webencodings/labels.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..a5a6d417a8db625f48dc210890cf3767f24d6330
GIT binary patch
literal 5361
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
R$iTqH%FM_<3WrDt000S~+#vt}

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/webencodings/mklabels.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/webencodings/mklabels.py
new file mode 100644
index 0000000..295dc92
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/webencodings/mklabels.py
@@ -0,0 +1,59 @@
+"""
+
+    webencodings.mklabels
+    ~~~~~~~~~~~~~~~~~~~~~
+
+    Regenarate the webencodings.labels module.
+
+    :copyright: Copyright 2012 by Simon Sapin
+    :license: BSD, see LICENSE for details.
+
+"""
+
+import json
+try:
+    from urllib import urlopen
+except ImportError:
+    from urllib.request import urlopen
+
+
+def assert_lower(string):
+    assert string == string.lower()
+    return string
+
+
+def generate(url):
+    parts = ['''\
+"""
+
+    webencodings.labels
+    ~~~~~~~~~~~~~~~~~~~
+
+    Map encoding labels to their name.
+
+    :copyright: Copyright 2012 by Simon Sapin
+    :license: BSD, see LICENSE for details.
+
+"""
+
+# XXX Do not edit!
+# This file is automatically generated by mklabels.py
+
+LABELS = {
+''']
+    labels = [
+        (repr(assert_lower(label)).lstrip('u'),
+         repr(encoding['name']).lstrip('u'))
+        for category in json.loads(urlopen(url).read().decode('ascii'))
+        for encoding in category['encodings']
+        for label in encoding['labels']]
+    max_len = max(len(label) for label, name in labels)
+    parts.extend(
+        '    %s:%s %s,\n' % (label, ' ' * (max_len - len(label)), name)
+        for label, name in labels)
+    parts.append('}')
+    return ''.join(parts)
+
+
+if __name__ == '__main__':
+    print(generate('http://encoding.spec.whatwg.org/encodings.json'))
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/webencodings/mklabels.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/webencodings/mklabels.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..a3f3e739163c8af0ae8de6ba3be957798110a4a6
GIT binary patch
literal 2486
zcmZSn%**AGdLky70SZ_d7#JKF7#NDH7#J8*7#N}$7*ZG+QkWQW7#X4%87f7<TxNzG
zCWc&QhA3tR#_&8v29{J7hHNf|B2NZJMn;f&W`-PAn1Vb;hKLjvh86~fC^m)^RxpE|
zA(ew6g^eMbiJ_>BA(fpWg`J_9k-^;~j{#&^um%Un4Tl&Q7`V6;6ciN7Q<GBjlJiqC
z^U{m;a<g+1lTvev!7_E&07O$zYI<s3Vo_pAszOOdDykU}6BKguQ%ZAE^&sl4lJg5H
zi!#$QN~{!|VN3-h14AQ)q)LV0%-sAuh2X@3%sjBgRymo;sd>ezRtiqRE;<Uusi_J+
zp3bg*!LABv`9%sTsU?Y-ImLQhT$%s>|Nrl&!N|bCP{Pi@z))J0lV6aUmkbgBVI~F!
z24|3WWf&M3YQQLqfuWfJ6gb5a3?+;VO^hJ%V6YK>8X)y0pm@s3FHbEh;bUN6a4arP
zEh@>(&vPv*$}a+|D`5i}SyGglm#zVdTQE^v!oa|wUr>};mRORiUzS*;pO&AKl3G-(
zpOm6so|KfAYnoeZWSC^0UX^ZPYEhn(Rb^%X0_l1BA^HWG1-hAe#U+V3Il69T9-hVl
zAR#c0FH6l!$uH7JjwgLsJn0owmhdnzFeHLq84q^02*`CTAcrwZFoJ^u<X%v$GlOLA
zf>IwNLpmcvEh9rZ149V|Llz@L2@@zBni(0gm_gx_#R5tz&5WRw;}RRgP|L(n!^Dun
z%pmC!>&;Nh%uvJ3kir7uSuxbIFqE(|l&~?>uz-|<%wPv4#%4y4I7lHIgCw$O8WTet
z3qzq7L!k{rp&mmmD?<qfD3!J_Fx0RzxIk>}WMHUaWXR%VXlGzZV`NC-U}!^@W&}xc
zF{E&UtYl2#V#wkKsc&Xv2-e_cU|{eo7G`8%P*PHYq(9`q(}N^Xa7x3H!XX-b6AKhz
z*+K!LL7^lcl-M(i6!H>tX`HaZ4p&x)h=@>d$ydnBFHuNM$t+RiQdS7b$ShV!%gjkt
z$ShV!EG@~;O)SYwPRz-vR7g+FO9f@g6i}W*N+DcaK8{YVKEVpM3e{ZT<egZYoS9j|
z$-uw>^J6hMQA0dh0?In2C7>h(@+mk8fszgg7lV?JA|yA(iZjG8fl^T|6DSqcfKy8t
zV<9uBbc1CnkXa=lojIv_8X&p^l*#lA!0rIs7X)$#I1hn|0n13mAa~e+0<of?$j%7l
zQIJ#F7~lZ_Dq@U5;%3kQ&_M)13OK!{Ffw$2vlJvSBt&YM7}A&-#2}%<#1IS)f?`m?
z0xEk|i>*|P6;z9LxWHkq04d6XxEL51zzTyvNjV6V!6AVJ4or|MauX}!K>-TN<%1-^
zOh5qx4lqWrXKFzOB7+9V@!+JCRh*v(iS+!$l;R+e%faGBsfj7z#FvtqoS%{k6)PwT
z0;NB&L{4!@QDy-+5#=UUfQ3>kN>cM6+7b&2KunP8to+P84NzeRR$E$>1GcXqv8bfD
z1XTVdCzhn9=NDCiIk1!u30_d3f|DP(gbxBm(13+2*m<CI2+GWopkNgPg_aN}6El+r
zBOjw5qZlI_BM&1tBQGOZZG3!gVrE`^e6bz_14BkhNr9EVKFoW1#RaL!dgU33CFSXQ
z`9<k)iDErajA(!oJ-F_Sk59=@j*kx#1XZS>KrAiF$;nKDL=-3;dgd177nOjkL2%6o
zk=H9qEi6qfE&)eZkUU5;D5&G(K}AP=JS0p(&IhvwHcV|GZ4x_>Z;FK&7#P@?co>-(
QMHqP*MVL8RITd*r0d(nOJOBUy

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/webencodings/tests.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/webencodings/tests.py
new file mode 100644
index 0000000..e12c10d
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/webencodings/tests.py
@@ -0,0 +1,153 @@
+# coding: utf-8
+"""
+
+    webencodings.tests
+    ~~~~~~~~~~~~~~~~~~
+
+    A basic test suite for Encoding.
+
+    :copyright: Copyright 2012 by Simon Sapin
+    :license: BSD, see LICENSE for details.
+
+"""
+
+from __future__ import unicode_literals
+
+from . import (lookup, LABELS, decode, encode, iter_decode, iter_encode,
+               IncrementalDecoder, IncrementalEncoder, UTF8)
+
+
+def assert_raises(exception, function, *args, **kwargs):
+    try:
+        function(*args, **kwargs)
+    except exception:
+        return
+    else:  # pragma: no cover
+        raise AssertionError('Did not raise %s.' % exception)
+
+
+def test_labels():
+    assert lookup('utf-8').name == 'utf-8'
+    assert lookup('Utf-8').name == 'utf-8'
+    assert lookup('UTF-8').name == 'utf-8'
+    assert lookup('utf8').name == 'utf-8'
+    assert lookup('utf8').name == 'utf-8'
+    assert lookup('utf8 ').name == 'utf-8'
+    assert lookup(' \r\nutf8\t').name == 'utf-8'
+    assert lookup('u8') is None  # Python label.
+    assert lookup('utf-8 ') is None  # Non-ASCII white space.
+
+    assert lookup('US-ASCII').name == 'windows-1252'
+    assert lookup('iso-8859-1').name == 'windows-1252'
+    assert lookup('latin1').name == 'windows-1252'
+    assert lookup('LATIN1').name == 'windows-1252'
+    assert lookup('latin-1') is None
+    assert lookup('LATİN1') is None  # ASCII-only case insensitivity.
+
+
+def test_all_labels():
+    for label in LABELS:
+        assert decode(b'', label) == ('', lookup(label))
+        assert encode('', label) == b''
+        for repeat in [0, 1, 12]:
+            output, _ = iter_decode([b''] * repeat, label)
+            assert list(output) == []
+            assert list(iter_encode([''] * repeat, label)) == []
+        decoder = IncrementalDecoder(label)
+        assert decoder.decode(b'') == ''
+        assert decoder.decode(b'', final=True) == ''
+        encoder = IncrementalEncoder(label)
+        assert encoder.encode('') == b''
+        assert encoder.encode('', final=True) == b''
+    # All encoding names are valid labels too:
+    for name in set(LABELS.values()):
+        assert lookup(name).name == name
+
+
+def test_invalid_label():
+    assert_raises(LookupError, decode, b'\xEF\xBB\xBF\xc3\xa9', 'invalid')
+    assert_raises(LookupError, encode, 'é', 'invalid')
+    assert_raises(LookupError, iter_decode, [], 'invalid')
+    assert_raises(LookupError, iter_encode, [], 'invalid')
+    assert_raises(LookupError, IncrementalDecoder, 'invalid')
+    assert_raises(LookupError, IncrementalEncoder, 'invalid')
+
+
+def test_decode():
+    assert decode(b'\x80', 'latin1') == ('€', lookup('latin1'))
+    assert decode(b'\x80', lookup('latin1')) == ('€', lookup('latin1'))
+    assert decode(b'\xc3\xa9', 'utf8') == ('é', lookup('utf8'))
+    assert decode(b'\xc3\xa9', UTF8) == ('é', lookup('utf8'))
+    assert decode(b'\xc3\xa9', 'ascii') == ('é', lookup('ascii'))
+    assert decode(b'\xEF\xBB\xBF\xc3\xa9', 'ascii') == ('é', lookup('utf8'))  # UTF-8 with BOM
+
+    assert decode(b'\xFE\xFF\x00\xe9', 'ascii') == ('é', lookup('utf-16be'))  # UTF-16-BE with BOM
+    assert decode(b'\xFF\xFE\xe9\x00', 'ascii') == ('é', lookup('utf-16le'))  # UTF-16-LE with BOM
+    assert decode(b'\xFE\xFF\xe9\x00', 'ascii') == ('\ue900', lookup('utf-16be'))
+    assert decode(b'\xFF\xFE\x00\xe9', 'ascii') == ('\ue900', lookup('utf-16le'))
+
+    assert decode(b'\x00\xe9', 'UTF-16BE') == ('é', lookup('utf-16be'))
+    assert decode(b'\xe9\x00', 'UTF-16LE') == ('é', lookup('utf-16le'))
+    assert decode(b'\xe9\x00', 'UTF-16') == ('é', lookup('utf-16le'))
+
+    assert decode(b'\xe9\x00', 'UTF-16BE') == ('\ue900', lookup('utf-16be'))
+    assert decode(b'\x00\xe9', 'UTF-16LE') == ('\ue900', lookup('utf-16le'))
+    assert decode(b'\x00\xe9', 'UTF-16') == ('\ue900', lookup('utf-16le'))
+
+
+def test_encode():
+    assert encode('é', 'latin1') == b'\xe9'
+    assert encode('é', 'utf8') == b'\xc3\xa9'
+    assert encode('é', 'utf8') == b'\xc3\xa9'
+    assert encode('é', 'utf-16') == b'\xe9\x00'
+    assert encode('é', 'utf-16le') == b'\xe9\x00'
+    assert encode('é', 'utf-16be') == b'\x00\xe9'
+
+
+def test_iter_decode():
+    def iter_decode_to_string(input, fallback_encoding):
+        output, _encoding = iter_decode(input, fallback_encoding)
+        return ''.join(output)
+    assert iter_decode_to_string([], 'latin1') == ''
+    assert iter_decode_to_string([b''], 'latin1') == ''
+    assert iter_decode_to_string([b'\xe9'], 'latin1') == 'é'
+    assert iter_decode_to_string([b'hello'], 'latin1') == 'hello'
+    assert iter_decode_to_string([b'he', b'llo'], 'latin1') == 'hello'
+    assert iter_decode_to_string([b'hell', b'o'], 'latin1') == 'hello'
+    assert iter_decode_to_string([b'\xc3\xa9'], 'latin1') == 'é'
+    assert iter_decode_to_string([b'\xEF\xBB\xBF\xc3\xa9'], 'latin1') == 'é'
+    assert iter_decode_to_string([
+        b'\xEF\xBB\xBF', b'\xc3', b'\xa9'], 'latin1') == 'é'
+    assert iter_decode_to_string([
+        b'\xEF\xBB\xBF', b'a', b'\xc3'], 'latin1') == 'a\uFFFD'
+    assert iter_decode_to_string([
+        b'', b'\xEF', b'', b'', b'\xBB\xBF\xc3', b'\xa9'], 'latin1') == 'é'
+    assert iter_decode_to_string([b'\xEF\xBB\xBF'], 'latin1') == ''
+    assert iter_decode_to_string([b'\xEF\xBB'], 'latin1') == 'ï»'
+    assert iter_decode_to_string([b'\xFE\xFF\x00\xe9'], 'latin1') == 'é'
+    assert iter_decode_to_string([b'\xFF\xFE\xe9\x00'], 'latin1') == 'é'
+    assert iter_decode_to_string([
+        b'', b'\xFF', b'', b'', b'\xFE\xe9', b'\x00'], 'latin1') == 'é'
+    assert iter_decode_to_string([
+        b'', b'h\xe9', b'llo'], 'x-user-defined') == 'h\uF7E9llo'
+
+
+def test_iter_encode():
+    assert b''.join(iter_encode([], 'latin1')) == b''
+    assert b''.join(iter_encode([''], 'latin1')) == b''
+    assert b''.join(iter_encode(['é'], 'latin1')) == b'\xe9'
+    assert b''.join(iter_encode(['', 'é', '', ''], 'latin1')) == b'\xe9'
+    assert b''.join(iter_encode(['', 'é', '', ''], 'utf-16')) == b'\xe9\x00'
+    assert b''.join(iter_encode(['', 'é', '', ''], 'utf-16le')) == b'\xe9\x00'
+    assert b''.join(iter_encode(['', 'é', '', ''], 'utf-16be')) == b'\x00\xe9'
+    assert b''.join(iter_encode([
+        '', 'h\uF7E9', '', 'llo'], 'x-user-defined')) == b'h\xe9llo'
+
+
+def test_x_user_defined():
+    encoded = b'2,\x0c\x0b\x1aO\xd9#\xcb\x0f\xc9\xbbt\xcf\xa8\xca'
+    decoded = '2,\x0c\x0b\x1aO\uf7d9#\uf7cb\x0f\uf7c9\uf7bbt\uf7cf\uf7a8\uf7ca'
+    encoded = b'aa'
+    decoded = 'aa'
+    assert decode(encoded, 'x-user-defined') == (decoded, lookup('x-user-defined'))
+    assert encode(decoded, 'x-user-defined') == encoded
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/webencodings/tests.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/webencodings/tests.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..5f8b2a751920078f9da0826d266b14b0af6bef59
GIT binary patch
literal 7341
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
QPGL??PBBhSP8m)f0GT)q-~a#s

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/webencodings/x_user_defined.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/webencodings/x_user_defined.py
new file mode 100644
index 0000000..d16e326
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/webencodings/x_user_defined.py
@@ -0,0 +1,325 @@
+# coding: utf-8
+"""
+
+    webencodings.x_user_defined
+    ~~~~~~~~~~~~~~~~~~~~~~~~~~~
+
+    An implementation of the x-user-defined encoding.
+
+    :copyright: Copyright 2012 by Simon Sapin
+    :license: BSD, see LICENSE for details.
+
+"""
+
+from __future__ import unicode_literals
+
+import codecs
+
+
+### Codec APIs
+
+class Codec(codecs.Codec):
+
+    def encode(self, input, errors='strict'):
+        return codecs.charmap_encode(input, errors, encoding_table)
+
+    def decode(self, input, errors='strict'):
+        return codecs.charmap_decode(input, errors, decoding_table)
+
+
+class IncrementalEncoder(codecs.IncrementalEncoder):
+    def encode(self, input, final=False):
+        return codecs.charmap_encode(input, self.errors, encoding_table)[0]
+
+
+class IncrementalDecoder(codecs.IncrementalDecoder):
+    def decode(self, input, final=False):
+        return codecs.charmap_decode(input, self.errors, decoding_table)[0]
+
+
+class StreamWriter(Codec, codecs.StreamWriter):
+    pass
+
+
+class StreamReader(Codec, codecs.StreamReader):
+    pass
+
+
+### encodings module API
+
+codec_info = codecs.CodecInfo(
+    name='x-user-defined',
+    encode=Codec().encode,
+    decode=Codec().decode,
+    incrementalencoder=IncrementalEncoder,
+    incrementaldecoder=IncrementalDecoder,
+    streamreader=StreamReader,
+    streamwriter=StreamWriter,
+)
+
+
+### Decoding Table
+
+# Python 3:
+# for c in range(256): print('    %r' % chr(c if c < 128 else c + 0xF700))
+decoding_table = (
+    '\x00'
+    '\x01'
+    '\x02'
+    '\x03'
+    '\x04'
+    '\x05'
+    '\x06'
+    '\x07'
+    '\x08'
+    '\t'
+    '\n'
+    '\x0b'
+    '\x0c'
+    '\r'
+    '\x0e'
+    '\x0f'
+    '\x10'
+    '\x11'
+    '\x12'
+    '\x13'
+    '\x14'
+    '\x15'
+    '\x16'
+    '\x17'
+    '\x18'
+    '\x19'
+    '\x1a'
+    '\x1b'
+    '\x1c'
+    '\x1d'
+    '\x1e'
+    '\x1f'
+    ' '
+    '!'
+    '"'
+    '#'
+    '$'
+    '%'
+    '&'
+    "'"
+    '('
+    ')'
+    '*'
+    '+'
+    ','
+    '-'
+    '.'
+    '/'
+    '0'
+    '1'
+    '2'
+    '3'
+    '4'
+    '5'
+    '6'
+    '7'
+    '8'
+    '9'
+    ':'
+    ';'
+    '<'
+    '='
+    '>'
+    '?'
+    '@'
+    'A'
+    'B'
+    'C'
+    'D'
+    'E'
+    'F'
+    'G'
+    'H'
+    'I'
+    'J'
+    'K'
+    'L'
+    'M'
+    'N'
+    'O'
+    'P'
+    'Q'
+    'R'
+    'S'
+    'T'
+    'U'
+    'V'
+    'W'
+    'X'
+    'Y'
+    'Z'
+    '['
+    '\\'
+    ']'
+    '^'
+    '_'
+    '`'
+    'a'
+    'b'
+    'c'
+    'd'
+    'e'
+    'f'
+    'g'
+    'h'
+    'i'
+    'j'
+    'k'
+    'l'
+    'm'
+    'n'
+    'o'
+    'p'
+    'q'
+    'r'
+    's'
+    't'
+    'u'
+    'v'
+    'w'
+    'x'
+    'y'
+    'z'
+    '{'
+    '|'
+    '}'
+    '~'
+    '\x7f'
+    '\uf780'
+    '\uf781'
+    '\uf782'
+    '\uf783'
+    '\uf784'
+    '\uf785'
+    '\uf786'
+    '\uf787'
+    '\uf788'
+    '\uf789'
+    '\uf78a'
+    '\uf78b'
+    '\uf78c'
+    '\uf78d'
+    '\uf78e'
+    '\uf78f'
+    '\uf790'
+    '\uf791'
+    '\uf792'
+    '\uf793'
+    '\uf794'
+    '\uf795'
+    '\uf796'
+    '\uf797'
+    '\uf798'
+    '\uf799'
+    '\uf79a'
+    '\uf79b'
+    '\uf79c'
+    '\uf79d'
+    '\uf79e'
+    '\uf79f'
+    '\uf7a0'
+    '\uf7a1'
+    '\uf7a2'
+    '\uf7a3'
+    '\uf7a4'
+    '\uf7a5'
+    '\uf7a6'
+    '\uf7a7'
+    '\uf7a8'
+    '\uf7a9'
+    '\uf7aa'
+    '\uf7ab'
+    '\uf7ac'
+    '\uf7ad'
+    '\uf7ae'
+    '\uf7af'
+    '\uf7b0'
+    '\uf7b1'
+    '\uf7b2'
+    '\uf7b3'
+    '\uf7b4'
+    '\uf7b5'
+    '\uf7b6'
+    '\uf7b7'
+    '\uf7b8'
+    '\uf7b9'
+    '\uf7ba'
+    '\uf7bb'
+    '\uf7bc'
+    '\uf7bd'
+    '\uf7be'
+    '\uf7bf'
+    '\uf7c0'
+    '\uf7c1'
+    '\uf7c2'
+    '\uf7c3'
+    '\uf7c4'
+    '\uf7c5'
+    '\uf7c6'
+    '\uf7c7'
+    '\uf7c8'
+    '\uf7c9'
+    '\uf7ca'
+    '\uf7cb'
+    '\uf7cc'
+    '\uf7cd'
+    '\uf7ce'
+    '\uf7cf'
+    '\uf7d0'
+    '\uf7d1'
+    '\uf7d2'
+    '\uf7d3'
+    '\uf7d4'
+    '\uf7d5'
+    '\uf7d6'
+    '\uf7d7'
+    '\uf7d8'
+    '\uf7d9'
+    '\uf7da'
+    '\uf7db'
+    '\uf7dc'
+    '\uf7dd'
+    '\uf7de'
+    '\uf7df'
+    '\uf7e0'
+    '\uf7e1'
+    '\uf7e2'
+    '\uf7e3'
+    '\uf7e4'
+    '\uf7e5'
+    '\uf7e6'
+    '\uf7e7'
+    '\uf7e8'
+    '\uf7e9'
+    '\uf7ea'
+    '\uf7eb'
+    '\uf7ec'
+    '\uf7ed'
+    '\uf7ee'
+    '\uf7ef'
+    '\uf7f0'
+    '\uf7f1'
+    '\uf7f2'
+    '\uf7f3'
+    '\uf7f4'
+    '\uf7f5'
+    '\uf7f6'
+    '\uf7f7'
+    '\uf7f8'
+    '\uf7f9'
+    '\uf7fa'
+    '\uf7fb'
+    '\uf7fc'
+    '\uf7fd'
+    '\uf7fe'
+    '\uf7ff'
+)
+
+### Encoding table
+encoding_table = codecs.charmap_build(decoding_table)
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/webencodings/x_user_defined.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pip/_vendor/webencodings/x_user_defined.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..6d794a202aec7544e3db1ae77f4d14342702b7b2
GIT binary patch
literal 3842
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

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pkg_resources/__init__.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pkg_resources/__init__.py
new file mode 100644
index 0000000..97e08d6
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pkg_resources/__init__.py
@@ -0,0 +1,3286 @@
+# coding: utf-8
+"""
+Package resource API
+--------------------
+
+A resource is a logical file contained within a package, or a logical
+subdirectory thereof.  The package resource API expects resource names
+to have their path parts separated with ``/``, *not* whatever the local
+path separator is.  Do not use os.path operations to manipulate resource
+names being passed into the API.
+
+The package resource API is designed to work with normal filesystem packages,
+.egg files, and unpacked .egg files.  It can also work in a limited way with
+.zip files and with custom PEP 302 loaders that support the ``get_data()``
+method.
+"""
+
+from __future__ import absolute_import
+
+import sys
+import os
+import io
+import time
+import re
+import types
+import zipfile
+import zipimport
+import warnings
+import stat
+import functools
+import pkgutil
+import operator
+import platform
+import collections
+import plistlib
+import email.parser
+import errno
+import tempfile
+import textwrap
+import itertools
+import inspect
+import ntpath
+import posixpath
+from pkgutil import get_importer
+
+try:
+    import _imp
+except ImportError:
+    # Python 3.2 compatibility
+    import imp as _imp
+
+try:
+    FileExistsError
+except NameError:
+    FileExistsError = OSError
+
+from pkg_resources.extern import six
+from pkg_resources.extern.six.moves import urllib, map, filter
+
+# capture these to bypass sandboxing
+from os import utime
+try:
+    from os import mkdir, rename, unlink
+    WRITE_SUPPORT = True
+except ImportError:
+    # no write support, probably under GAE
+    WRITE_SUPPORT = False
+
+from os import open as os_open
+from os.path import isdir, split
+
+try:
+    import importlib.machinery as importlib_machinery
+    # access attribute to force import under delayed import mechanisms.
+    importlib_machinery.__name__
+except ImportError:
+    importlib_machinery = None
+
+from . import py31compat
+from pkg_resources.extern import appdirs
+from pkg_resources.extern import packaging
+__import__('pkg_resources.extern.packaging.version')
+__import__('pkg_resources.extern.packaging.specifiers')
+__import__('pkg_resources.extern.packaging.requirements')
+__import__('pkg_resources.extern.packaging.markers')
+
+
+__metaclass__ = type
+
+
+if (3, 0) < sys.version_info < (3, 4):
+    raise RuntimeError("Python 3.4 or later is required")
+
+if six.PY2:
+    # Those builtin exceptions are only defined in Python 3
+    PermissionError = None
+    NotADirectoryError = None
+
+# declare some globals that will be defined later to
+# satisfy the linters.
+require = None
+working_set = None
+add_activation_listener = None
+resources_stream = None
+cleanup_resources = None
+resource_dir = None
+resource_stream = None
+set_extraction_path = None
+resource_isdir = None
+resource_string = None
+iter_entry_points = None
+resource_listdir = None
+resource_filename = None
+resource_exists = None
+_distribution_finders = None
+_namespace_handlers = None
+_namespace_packages = None
+
+
+class PEP440Warning(RuntimeWarning):
+    """
+    Used when there is an issue with a version or specifier not complying with
+    PEP 440.
+    """
+
+
+def parse_version(v):
+    try:
+        return packaging.version.Version(v)
+    except packaging.version.InvalidVersion:
+        return packaging.version.LegacyVersion(v)
+
+
+_state_vars = {}
+
+
+def _declare_state(vartype, **kw):
+    globals().update(kw)
+    _state_vars.update(dict.fromkeys(kw, vartype))
+
+
+def __getstate__():
+    state = {}
+    g = globals()
+    for k, v in _state_vars.items():
+        state[k] = g['_sget_' + v](g[k])
+    return state
+
+
+def __setstate__(state):
+    g = globals()
+    for k, v in state.items():
+        g['_sset_' + _state_vars[k]](k, g[k], v)
+    return state
+
+
+def _sget_dict(val):
+    return val.copy()
+
+
+def _sset_dict(key, ob, state):
+    ob.clear()
+    ob.update(state)
+
+
+def _sget_object(val):
+    return val.__getstate__()
+
+
+def _sset_object(key, ob, state):
+    ob.__setstate__(state)
+
+
+_sget_none = _sset_none = lambda *args: None
+
+
+def get_supported_platform():
+    """Return this platform's maximum compatible version.
+
+    distutils.util.get_platform() normally reports the minimum version
+    of Mac OS X that would be required to *use* extensions produced by
+    distutils.  But what we want when checking compatibility is to know the
+    version of Mac OS X that we are *running*.  To allow usage of packages that
+    explicitly require a newer version of Mac OS X, we must also know the
+    current version of the OS.
+
+    If this condition occurs for any other platform with a version in its
+    platform strings, this function should be extended accordingly.
+    """
+    plat = get_build_platform()
+    m = macosVersionString.match(plat)
+    if m is not None and sys.platform == "darwin":
+        try:
+            plat = 'macosx-%s-%s' % ('.'.join(_macosx_vers()[:2]), m.group(3))
+        except ValueError:
+            # not Mac OS X
+            pass
+    return plat
+
+
+__all__ = [
+    # Basic resource access and distribution/entry point discovery
+    'require', 'run_script', 'get_provider', 'get_distribution',
+    'load_entry_point', 'get_entry_map', 'get_entry_info',
+    'iter_entry_points',
+    'resource_string', 'resource_stream', 'resource_filename',
+    'resource_listdir', 'resource_exists', 'resource_isdir',
+
+    # Environmental control
+    'declare_namespace', 'working_set', 'add_activation_listener',
+    'find_distributions', 'set_extraction_path', 'cleanup_resources',
+    'get_default_cache',
+
+    # Primary implementation classes
+    'Environment', 'WorkingSet', 'ResourceManager',
+    'Distribution', 'Requirement', 'EntryPoint',
+
+    # Exceptions
+    'ResolutionError', 'VersionConflict', 'DistributionNotFound',
+    'UnknownExtra', 'ExtractionError',
+
+    # Warnings
+    'PEP440Warning',
+
+    # Parsing functions and string utilities
+    'parse_requirements', 'parse_version', 'safe_name', 'safe_version',
+    'get_platform', 'compatible_platforms', 'yield_lines', 'split_sections',
+    'safe_extra', 'to_filename', 'invalid_marker', 'evaluate_marker',
+
+    # filesystem utilities
+    'ensure_directory', 'normalize_path',
+
+    # Distribution "precedence" constants
+    'EGG_DIST', 'BINARY_DIST', 'SOURCE_DIST', 'CHECKOUT_DIST', 'DEVELOP_DIST',
+
+    # "Provider" interfaces, implementations, and registration/lookup APIs
+    'IMetadataProvider', 'IResourceProvider', 'FileMetadata',
+    'PathMetadata', 'EggMetadata', 'EmptyProvider', 'empty_provider',
+    'NullProvider', 'EggProvider', 'DefaultProvider', 'ZipProvider',
+    'register_finder', 'register_namespace_handler', 'register_loader_type',
+    'fixup_namespace_packages', 'get_importer',
+
+    # Warnings
+    'PkgResourcesDeprecationWarning',
+
+    # Deprecated/backward compatibility only
+    'run_main', 'AvailableDistributions',
+]
+
+
+class ResolutionError(Exception):
+    """Abstract base for dependency resolution errors"""
+
+    def __repr__(self):
+        return self.__class__.__name__ + repr(self.args)
+
+
+class VersionConflict(ResolutionError):
+    """
+    An already-installed version conflicts with the requested version.
+
+    Should be initialized with the installed Distribution and the requested
+    Requirement.
+    """
+
+    _template = "{self.dist} is installed but {self.req} is required"
+
+    @property
+    def dist(self):
+        return self.args[0]
+
+    @property
+    def req(self):
+        return self.args[1]
+
+    def report(self):
+        return self._template.format(**locals())
+
+    def with_context(self, required_by):
+        """
+        If required_by is non-empty, return a version of self that is a
+        ContextualVersionConflict.
+        """
+        if not required_by:
+            return self
+        args = self.args + (required_by,)
+        return ContextualVersionConflict(*args)
+
+
+class ContextualVersionConflict(VersionConflict):
+    """
+    A VersionConflict that accepts a third parameter, the set of the
+    requirements that required the installed Distribution.
+    """
+
+    _template = VersionConflict._template + ' by {self.required_by}'
+
+    @property
+    def required_by(self):
+        return self.args[2]
+
+
+class DistributionNotFound(ResolutionError):
+    """A requested distribution was not found"""
+
+    _template = ("The '{self.req}' distribution was not found "
+                 "and is required by {self.requirers_str}")
+
+    @property
+    def req(self):
+        return self.args[0]
+
+    @property
+    def requirers(self):
+        return self.args[1]
+
+    @property
+    def requirers_str(self):
+        if not self.requirers:
+            return 'the application'
+        return ', '.join(self.requirers)
+
+    def report(self):
+        return self._template.format(**locals())
+
+    def __str__(self):
+        return self.report()
+
+
+class UnknownExtra(ResolutionError):
+    """Distribution doesn't have an "extra feature" of the given name"""
+
+
+_provider_factories = {}
+
+PY_MAJOR = sys.version[:3]
+EGG_DIST = 3
+BINARY_DIST = 2
+SOURCE_DIST = 1
+CHECKOUT_DIST = 0
+DEVELOP_DIST = -1
+
+
+def register_loader_type(loader_type, provider_factory):
+    """Register `provider_factory` to make providers for `loader_type`
+
+    `loader_type` is the type or class of a PEP 302 ``module.__loader__``,
+    and `provider_factory` is a function that, passed a *module* object,
+    returns an ``IResourceProvider`` for that module.
+    """
+    _provider_factories[loader_type] = provider_factory
+
+
+def get_provider(moduleOrReq):
+    """Return an IResourceProvider for the named module or requirement"""
+    if isinstance(moduleOrReq, Requirement):
+        return working_set.find(moduleOrReq) or require(str(moduleOrReq))[0]
+    try:
+        module = sys.modules[moduleOrReq]
+    except KeyError:
+        __import__(moduleOrReq)
+        module = sys.modules[moduleOrReq]
+    loader = getattr(module, '__loader__', None)
+    return _find_adapter(_provider_factories, loader)(module)
+
+
+def _macosx_vers(_cache=[]):
+    if not _cache:
+        version = platform.mac_ver()[0]
+        # fallback for MacPorts
+        if version == '':
+            plist = '/System/Library/CoreServices/SystemVersion.plist'
+            if os.path.exists(plist):
+                if hasattr(plistlib, 'readPlist'):
+                    plist_content = plistlib.readPlist(plist)
+                    if 'ProductVersion' in plist_content:
+                        version = plist_content['ProductVersion']
+
+        _cache.append(version.split('.'))
+    return _cache[0]
+
+
+def _macosx_arch(machine):
+    return {'PowerPC': 'ppc', 'Power_Macintosh': 'ppc'}.get(machine, machine)
+
+
+def get_build_platform():
+    """Return this platform's string for platform-specific distributions
+
+    XXX Currently this is the same as ``distutils.util.get_platform()``, but it
+    needs some hacks for Linux and Mac OS X.
+    """
+    from sysconfig import get_platform
+
+    plat = get_platform()
+    if sys.platform == "darwin" and not plat.startswith('macosx-'):
+        try:
+            version = _macosx_vers()
+            machine = os.uname()[4].replace(" ", "_")
+            return "macosx-%d.%d-%s" % (
+                int(version[0]), int(version[1]),
+                _macosx_arch(machine),
+            )
+        except ValueError:
+            # if someone is running a non-Mac darwin system, this will fall
+            # through to the default implementation
+            pass
+    return plat
+
+
+macosVersionString = re.compile(r"macosx-(\d+)\.(\d+)-(.*)")
+darwinVersionString = re.compile(r"darwin-(\d+)\.(\d+)\.(\d+)-(.*)")
+# XXX backward compat
+get_platform = get_build_platform
+
+
+def compatible_platforms(provided, required):
+    """Can code for the `provided` platform run on the `required` platform?
+
+    Returns true if either platform is ``None``, or the platforms are equal.
+
+    XXX Needs compatibility checks for Linux and other unixy OSes.
+    """
+    if provided is None or required is None or provided == required:
+        # easy case
+        return True
+
+    # Mac OS X special cases
+    reqMac = macosVersionString.match(required)
+    if reqMac:
+        provMac = macosVersionString.match(provided)
+
+        # is this a Mac package?
+        if not provMac:
+            # this is backwards compatibility for packages built before
+            # setuptools 0.6. All packages built after this point will
+            # use the new macosx designation.
+            provDarwin = darwinVersionString.match(provided)
+            if provDarwin:
+                dversion = int(provDarwin.group(1))
+                macosversion = "%s.%s" % (reqMac.group(1), reqMac.group(2))
+                if dversion == 7 and macosversion >= "10.3" or \
+                        dversion == 8 and macosversion >= "10.4":
+                    return True
+            # egg isn't macosx or legacy darwin
+            return False
+
+        # are they the same major version and machine type?
+        if provMac.group(1) != reqMac.group(1) or \
+                provMac.group(3) != reqMac.group(3):
+            return False
+
+        # is the required OS major update >= the provided one?
+        if int(provMac.group(2)) > int(reqMac.group(2)):
+            return False
+
+        return True
+
+    # XXX Linux and other platforms' special cases should go here
+    return False
+
+
+def run_script(dist_spec, script_name):
+    """Locate distribution `dist_spec` and run its `script_name` script"""
+    ns = sys._getframe(1).f_globals
+    name = ns['__name__']
+    ns.clear()
+    ns['__name__'] = name
+    require(dist_spec)[0].run_script(script_name, ns)
+
+
+# backward compatibility
+run_main = run_script
+
+
+def get_distribution(dist):
+    """Return a current distribution object for a Requirement or string"""
+    if isinstance(dist, six.string_types):
+        dist = Requirement.parse(dist)
+    if isinstance(dist, Requirement):
+        dist = get_provider(dist)
+    if not isinstance(dist, Distribution):
+        raise TypeError("Expected string, Requirement, or Distribution", dist)
+    return dist
+
+
+def load_entry_point(dist, group, name):
+    """Return `name` entry point of `group` for `dist` or raise ImportError"""
+    return get_distribution(dist).load_entry_point(group, name)
+
+
+def get_entry_map(dist, group=None):
+    """Return the entry point map for `group`, or the full entry map"""
+    return get_distribution(dist).get_entry_map(group)
+
+
+def get_entry_info(dist, group, name):
+    """Return the EntryPoint object for `group`+`name`, or ``None``"""
+    return get_distribution(dist).get_entry_info(group, name)
+
+
+class IMetadataProvider:
+    def has_metadata(name):
+        """Does the package's distribution contain the named metadata?"""
+
+    def get_metadata(name):
+        """The named metadata resource as a string"""
+
+    def get_metadata_lines(name):
+        """Yield named metadata resource as list of non-blank non-comment lines
+
+       Leading and trailing whitespace is stripped from each line, and lines
+       with ``#`` as the first non-blank character are omitted."""
+
+    def metadata_isdir(name):
+        """Is the named metadata a directory?  (like ``os.path.isdir()``)"""
+
+    def metadata_listdir(name):
+        """List of metadata names in the directory (like ``os.listdir()``)"""
+
+    def run_script(script_name, namespace):
+        """Execute the named script in the supplied namespace dictionary"""
+
+
+class IResourceProvider(IMetadataProvider):
+    """An object that provides access to package resources"""
+
+    def get_resource_filename(manager, resource_name):
+        """Return a true filesystem path for `resource_name`
+
+        `manager` must be an ``IResourceManager``"""
+
+    def get_resource_stream(manager, resource_name):
+        """Return a readable file-like object for `resource_name`
+
+        `manager` must be an ``IResourceManager``"""
+
+    def get_resource_string(manager, resource_name):
+        """Return a string containing the contents of `resource_name`
+
+        `manager` must be an ``IResourceManager``"""
+
+    def has_resource(resource_name):
+        """Does the package contain the named resource?"""
+
+    def resource_isdir(resource_name):
+        """Is the named resource a directory?  (like ``os.path.isdir()``)"""
+
+    def resource_listdir(resource_name):
+        """List of resource names in the directory (like ``os.listdir()``)"""
+
+
+class WorkingSet:
+    """A collection of active distributions on sys.path (or a similar list)"""
+
+    def __init__(self, entries=None):
+        """Create working set from list of path entries (default=sys.path)"""
+        self.entries = []
+        self.entry_keys = {}
+        self.by_key = {}
+        self.callbacks = []
+
+        if entries is None:
+            entries = sys.path
+
+        for entry in entries:
+            self.add_entry(entry)
+
+    @classmethod
+    def _build_master(cls):
+        """
+        Prepare the master working set.
+        """
+        ws = cls()
+        try:
+            from __main__ import __requires__
+        except ImportError:
+            # The main program does not list any requirements
+            return ws
+
+        # ensure the requirements are met
+        try:
+            ws.require(__requires__)
+        except VersionConflict:
+            return cls._build_from_requirements(__requires__)
+
+        return ws
+
+    @classmethod
+    def _build_from_requirements(cls, req_spec):
+        """
+        Build a working set from a requirement spec. Rewrites sys.path.
+        """
+        # try it without defaults already on sys.path
+        # by starting with an empty path
+        ws = cls([])
+        reqs = parse_requirements(req_spec)
+        dists = ws.resolve(reqs, Environment())
+        for dist in dists:
+            ws.add(dist)
+
+        # add any missing entries from sys.path
+        for entry in sys.path:
+            if entry not in ws.entries:
+                ws.add_entry(entry)
+
+        # then copy back to sys.path
+        sys.path[:] = ws.entries
+        return ws
+
+    def add_entry(self, entry):
+        """Add a path item to ``.entries``, finding any distributions on it
+
+        ``find_distributions(entry, True)`` is used to find distributions
+        corresponding to the path entry, and they are added.  `entry` is
+        always appended to ``.entries``, even if it is already present.
+        (This is because ``sys.path`` can contain the same value more than
+        once, and the ``.entries`` of the ``sys.path`` WorkingSet should always
+        equal ``sys.path``.)
+        """
+        self.entry_keys.setdefault(entry, [])
+        self.entries.append(entry)
+        for dist in find_distributions(entry, True):
+            self.add(dist, entry, False)
+
+    def __contains__(self, dist):
+        """True if `dist` is the active distribution for its project"""
+        return self.by_key.get(dist.key) == dist
+
+    def find(self, req):
+        """Find a distribution matching requirement `req`
+
+        If there is an active distribution for the requested project, this
+        returns it as long as it meets the version requirement specified by
+        `req`.  But, if there is an active distribution for the project and it
+        does *not* meet the `req` requirement, ``VersionConflict`` is raised.
+        If there is no active distribution for the requested project, ``None``
+        is returned.
+        """
+        dist = self.by_key.get(req.key)
+        if dist is not None and dist not in req:
+            # XXX add more info
+            raise VersionConflict(dist, req)
+        return dist
+
+    def iter_entry_points(self, group, name=None):
+        """Yield entry point objects from `group` matching `name`
+
+        If `name` is None, yields all entry points in `group` from all
+        distributions in the working set, otherwise only ones matching
+        both `group` and `name` are yielded (in distribution order).
+        """
+        return (
+            entry
+            for dist in self
+            for entry in dist.get_entry_map(group).values()
+            if name is None or name == entry.name
+        )
+
+    def run_script(self, requires, script_name):
+        """Locate distribution for `requires` and run `script_name` script"""
+        ns = sys._getframe(1).f_globals
+        name = ns['__name__']
+        ns.clear()
+        ns['__name__'] = name
+        self.require(requires)[0].run_script(script_name, ns)
+
+    def __iter__(self):
+        """Yield distributions for non-duplicate projects in the working set
+
+        The yield order is the order in which the items' path entries were
+        added to the working set.
+        """
+        seen = {}
+        for item in self.entries:
+            if item not in self.entry_keys:
+                # workaround a cache issue
+                continue
+
+            for key in self.entry_keys[item]:
+                if key not in seen:
+                    seen[key] = 1
+                    yield self.by_key[key]
+
+    def add(self, dist, entry=None, insert=True, replace=False):
+        """Add `dist` to working set, associated with `entry`
+
+        If `entry` is unspecified, it defaults to the ``.location`` of `dist`.
+        On exit from this routine, `entry` is added to the end of the working
+        set's ``.entries`` (if it wasn't already present).
+
+        `dist` is only added to the working set if it's for a project that
+        doesn't already have a distribution in the set, unless `replace=True`.
+        If it's added, any callbacks registered with the ``subscribe()`` method
+        will be called.
+        """
+        if insert:
+            dist.insert_on(self.entries, entry, replace=replace)
+
+        if entry is None:
+            entry = dist.location
+        keys = self.entry_keys.setdefault(entry, [])
+        keys2 = self.entry_keys.setdefault(dist.location, [])
+        if not replace and dist.key in self.by_key:
+            # ignore hidden distros
+            return
+
+        self.by_key[dist.key] = dist
+        if dist.key not in keys:
+            keys.append(dist.key)
+        if dist.key not in keys2:
+            keys2.append(dist.key)
+        self._added_new(dist)
+
+    def resolve(self, requirements, env=None, installer=None,
+                replace_conflicting=False, extras=None):
+        """List all distributions needed to (recursively) meet `requirements`
+
+        `requirements` must be a sequence of ``Requirement`` objects.  `env`,
+        if supplied, should be an ``Environment`` instance.  If
+        not supplied, it defaults to all distributions available within any
+        entry or distribution in the working set.  `installer`, if supplied,
+        will be invoked with each requirement that cannot be met by an
+        already-installed distribution; it should return a ``Distribution`` or
+        ``None``.
+
+        Unless `replace_conflicting=True`, raises a VersionConflict exception
+        if
+        any requirements are found on the path that have the correct name but
+        the wrong version.  Otherwise, if an `installer` is supplied it will be
+        invoked to obtain the correct version of the requirement and activate
+        it.
+
+        `extras` is a list of the extras to be used with these requirements.
+        This is important because extra requirements may look like `my_req;
+        extra = "my_extra"`, which would otherwise be interpreted as a purely
+        optional requirement.  Instead, we want to be able to assert that these
+        requirements are truly required.
+        """
+
+        # set up the stack
+        requirements = list(requirements)[::-1]
+        # set of processed requirements
+        processed = {}
+        # key -> dist
+        best = {}
+        to_activate = []
+
+        req_extras = _ReqExtras()
+
+        # Mapping of requirement to set of distributions that required it;
+        # useful for reporting info about conflicts.
+        required_by = collections.defaultdict(set)
+
+        while requirements:
+            # process dependencies breadth-first
+            req = requirements.pop(0)
+            if req in processed:
+                # Ignore cyclic or redundant dependencies
+                continue
+
+            if not req_extras.markers_pass(req, extras):
+                continue
+
+            dist = best.get(req.key)
+            if dist is None:
+                # Find the best distribution and add it to the map
+                dist = self.by_key.get(req.key)
+                if dist is None or (dist not in req and replace_conflicting):
+                    ws = self
+                    if env is None:
+                        if dist is None:
+                            env = Environment(self.entries)
+                        else:
+                            # Use an empty environment and workingset to avoid
+                            # any further conflicts with the conflicting
+                            # distribution
+                            env = Environment([])
+                            ws = WorkingSet([])
+                    dist = best[req.key] = env.best_match(
+                        req, ws, installer,
+                        replace_conflicting=replace_conflicting
+                    )
+                    if dist is None:
+                        requirers = required_by.get(req, None)
+                        raise DistributionNotFound(req, requirers)
+                to_activate.append(dist)
+            if dist not in req:
+                # Oops, the "best" so far conflicts with a dependency
+                dependent_req = required_by[req]
+                raise VersionConflict(dist, req).with_context(dependent_req)
+
+            # push the new requirements onto the stack
+            new_requirements = dist.requires(req.extras)[::-1]
+            requirements.extend(new_requirements)
+
+            # Register the new requirements needed by req
+            for new_requirement in new_requirements:
+                required_by[new_requirement].add(req.project_name)
+                req_extras[new_requirement] = req.extras
+
+            processed[req] = True
+
+        # return list of distros to activate
+        return to_activate
+
+    def find_plugins(
+            self, plugin_env, full_env=None, installer=None, fallback=True):
+        """Find all activatable distributions in `plugin_env`
+
+        Example usage::
+
+            distributions, errors = working_set.find_plugins(
+                Environment(plugin_dirlist)
+            )
+            # add plugins+libs to sys.path
+            map(working_set.add, distributions)
+            # display errors
+            print('Could not load', errors)
+
+        The `plugin_env` should be an ``Environment`` instance that contains
+        only distributions that are in the project's "plugin directory" or
+        directories. The `full_env`, if supplied, should be an ``Environment``
+        contains all currently-available distributions.  If `full_env` is not
+        supplied, one is created automatically from the ``WorkingSet`` this
+        method is called on, which will typically mean that every directory on
+        ``sys.path`` will be scanned for distributions.
+
+        `installer` is a standard installer callback as used by the
+        ``resolve()`` method. The `fallback` flag indicates whether we should
+        attempt to resolve older versions of a plugin if the newest version
+        cannot be resolved.
+
+        This method returns a 2-tuple: (`distributions`, `error_info`), where
+        `distributions` is a list of the distributions found in `plugin_env`
+        that were loadable, along with any other distributions that are needed
+        to resolve their dependencies.  `error_info` is a dictionary mapping
+        unloadable plugin distributions to an exception instance describing the
+        error that occurred. Usually this will be a ``DistributionNotFound`` or
+        ``VersionConflict`` instance.
+        """
+
+        plugin_projects = list(plugin_env)
+        # scan project names in alphabetic order
+        plugin_projects.sort()
+
+        error_info = {}
+        distributions = {}
+
+        if full_env is None:
+            env = Environment(self.entries)
+            env += plugin_env
+        else:
+            env = full_env + plugin_env
+
+        shadow_set = self.__class__([])
+        # put all our entries in shadow_set
+        list(map(shadow_set.add, self))
+
+        for project_name in plugin_projects:
+
+            for dist in plugin_env[project_name]:
+
+                req = [dist.as_requirement()]
+
+                try:
+                    resolvees = shadow_set.resolve(req, env, installer)
+
+                except ResolutionError as v:
+                    # save error info
+                    error_info[dist] = v
+                    if fallback:
+                        # try the next older version of project
+                        continue
+                    else:
+                        # give up on this project, keep going
+                        break
+
+                else:
+                    list(map(shadow_set.add, resolvees))
+                    distributions.update(dict.fromkeys(resolvees))
+
+                    # success, no need to try any more versions of this project
+                    break
+
+        distributions = list(distributions)
+        distributions.sort()
+
+        return distributions, error_info
+
+    def require(self, *requirements):
+        """Ensure that distributions matching `requirements` are activated
+
+        `requirements` must be a string or a (possibly-nested) sequence
+        thereof, specifying the distributions and versions required.  The
+        return value is a sequence of the distributions that needed to be
+        activated to fulfill the requirements; all relevant distributions are
+        included, even if they were already activated in this working set.
+        """
+        needed = self.resolve(parse_requirements(requirements))
+
+        for dist in needed:
+            self.add(dist)
+
+        return needed
+
+    def subscribe(self, callback, existing=True):
+        """Invoke `callback` for all distributions
+
+        If `existing=True` (default),
+        call on all existing ones, as well.
+        """
+        if callback in self.callbacks:
+            return
+        self.callbacks.append(callback)
+        if not existing:
+            return
+        for dist in self:
+            callback(dist)
+
+    def _added_new(self, dist):
+        for callback in self.callbacks:
+            callback(dist)
+
+    def __getstate__(self):
+        return (
+            self.entries[:], self.entry_keys.copy(), self.by_key.copy(),
+            self.callbacks[:]
+        )
+
+    def __setstate__(self, e_k_b_c):
+        entries, keys, by_key, callbacks = e_k_b_c
+        self.entries = entries[:]
+        self.entry_keys = keys.copy()
+        self.by_key = by_key.copy()
+        self.callbacks = callbacks[:]
+
+
+class _ReqExtras(dict):
+    """
+    Map each requirement to the extras that demanded it.
+    """
+
+    def markers_pass(self, req, extras=None):
+        """
+        Evaluate markers for req against each extra that
+        demanded it.
+
+        Return False if the req has a marker and fails
+        evaluation. Otherwise, return True.
+        """
+        extra_evals = (
+            req.marker.evaluate({'extra': extra})
+            for extra in self.get(req, ()) + (extras or (None,))
+        )
+        return not req.marker or any(extra_evals)
+
+
+class Environment:
+    """Searchable snapshot of distributions on a search path"""
+
+    def __init__(
+            self, search_path=None, platform=get_supported_platform(),
+            python=PY_MAJOR):
+        """Snapshot distributions available on a search path
+
+        Any distributions found on `search_path` are added to the environment.
+        `search_path` should be a sequence of ``sys.path`` items.  If not
+        supplied, ``sys.path`` is used.
+
+        `platform` is an optional string specifying the name of the platform
+        that platform-specific distributions must be compatible with.  If
+        unspecified, it defaults to the current platform.  `python` is an
+        optional string naming the desired version of Python (e.g. ``'3.6'``);
+        it defaults to the current version.
+
+        You may explicitly set `platform` (and/or `python`) to ``None`` if you
+        wish to map *all* distributions, not just those compatible with the
+        running platform or Python version.
+        """
+        self._distmap = {}
+        self.platform = platform
+        self.python = python
+        self.scan(search_path)
+
+    def can_add(self, dist):
+        """Is distribution `dist` acceptable for this environment?
+
+        The distribution must match the platform and python version
+        requirements specified when this environment was created, or False
+        is returned.
+        """
+        py_compat = (
+            self.python is None
+            or dist.py_version is None
+            or dist.py_version == self.python
+        )
+        return py_compat and compatible_platforms(dist.platform, self.platform)
+
+    def remove(self, dist):
+        """Remove `dist` from the environment"""
+        self._distmap[dist.key].remove(dist)
+
+    def scan(self, search_path=None):
+        """Scan `search_path` for distributions usable in this environment
+
+        Any distributions found are added to the environment.
+        `search_path` should be a sequence of ``sys.path`` items.  If not
+        supplied, ``sys.path`` is used.  Only distributions conforming to
+        the platform/python version defined at initialization are added.
+        """
+        if search_path is None:
+            search_path = sys.path
+
+        for item in search_path:
+            for dist in find_distributions(item):
+                self.add(dist)
+
+    def __getitem__(self, project_name):
+        """Return a newest-to-oldest list of distributions for `project_name`
+
+        Uses case-insensitive `project_name` comparison, assuming all the
+        project's distributions use their project's name converted to all
+        lowercase as their key.
+
+        """
+        distribution_key = project_name.lower()
+        return self._distmap.get(distribution_key, [])
+
+    def add(self, dist):
+        """Add `dist` if we ``can_add()`` it and it has not already been added
+        """
+        if self.can_add(dist) and dist.has_version():
+            dists = self._distmap.setdefault(dist.key, [])
+            if dist not in dists:
+                dists.append(dist)
+                dists.sort(key=operator.attrgetter('hashcmp'), reverse=True)
+
+    def best_match(
+            self, req, working_set, installer=None, replace_conflicting=False):
+        """Find distribution best matching `req` and usable on `working_set`
+
+        This calls the ``find(req)`` method of the `working_set` to see if a
+        suitable distribution is already active.  (This may raise
+        ``VersionConflict`` if an unsuitable version of the project is already
+        active in the specified `working_set`.)  If a suitable distribution
+        isn't active, this method returns the newest distribution in the
+        environment that meets the ``Requirement`` in `req`.  If no suitable
+        distribution is found, and `installer` is supplied, then the result of
+        calling the environment's ``obtain(req, installer)`` method will be
+        returned.
+        """
+        try:
+            dist = working_set.find(req)
+        except VersionConflict:
+            if not replace_conflicting:
+                raise
+            dist = None
+        if dist is not None:
+            return dist
+        for dist in self[req.key]:
+            if dist in req:
+                return dist
+        # try to download/install
+        return self.obtain(req, installer)
+
+    def obtain(self, requirement, installer=None):
+        """Obtain a distribution matching `requirement` (e.g. via download)
+
+        Obtain a distro that matches requirement (e.g. via download).  In the
+        base ``Environment`` class, this routine just returns
+        ``installer(requirement)``, unless `installer` is None, in which case
+        None is returned instead.  This method is a hook that allows subclasses
+        to attempt other ways of obtaining a distribution before falling back
+        to the `installer` argument."""
+        if installer is not None:
+            return installer(requirement)
+
+    def __iter__(self):
+        """Yield the unique project names of the available distributions"""
+        for key in self._distmap.keys():
+            if self[key]:
+                yield key
+
+    def __iadd__(self, other):
+        """In-place addition of a distribution or environment"""
+        if isinstance(other, Distribution):
+            self.add(other)
+        elif isinstance(other, Environment):
+            for project in other:
+                for dist in other[project]:
+                    self.add(dist)
+        else:
+            raise TypeError("Can't add %r to environment" % (other,))
+        return self
+
+    def __add__(self, other):
+        """Add an environment or distribution to an environment"""
+        new = self.__class__([], platform=None, python=None)
+        for env in self, other:
+            new += env
+        return new
+
+
+# XXX backward compatibility
+AvailableDistributions = Environment
+
+
+class ExtractionError(RuntimeError):
+    """An error occurred extracting a resource
+
+    The following attributes are available from instances of this exception:
+
+    manager
+        The resource manager that raised this exception
+
+    cache_path
+        The base directory for resource extraction
+
+    original_error
+        The exception instance that caused extraction to fail
+    """
+
+
+class ResourceManager:
+    """Manage resource extraction and packages"""
+    extraction_path = None
+
+    def __init__(self):
+        self.cached_files = {}
+
+    def resource_exists(self, package_or_requirement, resource_name):
+        """Does the named resource exist?"""
+        return get_provider(package_or_requirement).has_resource(resource_name)
+
+    def resource_isdir(self, package_or_requirement, resource_name):
+        """Is the named resource an existing directory?"""
+        return get_provider(package_or_requirement).resource_isdir(
+            resource_name
+        )
+
+    def resource_filename(self, package_or_requirement, resource_name):
+        """Return a true filesystem path for specified resource"""
+        return get_provider(package_or_requirement).get_resource_filename(
+            self, resource_name
+        )
+
+    def resource_stream(self, package_or_requirement, resource_name):
+        """Return a readable file-like object for specified resource"""
+        return get_provider(package_or_requirement).get_resource_stream(
+            self, resource_name
+        )
+
+    def resource_string(self, package_or_requirement, resource_name):
+        """Return specified resource as a string"""
+        return get_provider(package_or_requirement).get_resource_string(
+            self, resource_name
+        )
+
+    def resource_listdir(self, package_or_requirement, resource_name):
+        """List the contents of the named resource directory"""
+        return get_provider(package_or_requirement).resource_listdir(
+            resource_name
+        )
+
+    def extraction_error(self):
+        """Give an error message for problems extracting file(s)"""
+
+        old_exc = sys.exc_info()[1]
+        cache_path = self.extraction_path or get_default_cache()
+
+        tmpl = textwrap.dedent("""
+            Can't extract file(s) to egg cache
+
+            The following error occurred while trying to extract file(s)
+            to the Python egg cache:
+
+              {old_exc}
+
+            The Python egg cache directory is currently set to:
+
+              {cache_path}
+
+            Perhaps your account does not have write access to this directory?
+            You can change the cache directory by setting the PYTHON_EGG_CACHE
+            environment variable to point to an accessible directory.
+            """).lstrip()
+        err = ExtractionError(tmpl.format(**locals()))
+        err.manager = self
+        err.cache_path = cache_path
+        err.original_error = old_exc
+        raise err
+
+    def get_cache_path(self, archive_name, names=()):
+        """Return absolute location in cache for `archive_name` and `names`
+
+        The parent directory of the resulting path will be created if it does
+        not already exist.  `archive_name` should be the base filename of the
+        enclosing egg (which may not be the name of the enclosing zipfile!),
+        including its ".egg" extension.  `names`, if provided, should be a
+        sequence of path name parts "under" the egg's extraction location.
+
+        This method should only be called by resource providers that need to
+        obtain an extraction location, and only for names they intend to
+        extract, as it tracks the generated names for possible cleanup later.
+        """
+        extract_path = self.extraction_path or get_default_cache()
+        target_path = os.path.join(extract_path, archive_name + '-tmp', *names)
+        try:
+            _bypass_ensure_directory(target_path)
+        except Exception:
+            self.extraction_error()
+
+        self._warn_unsafe_extraction_path(extract_path)
+
+        self.cached_files[target_path] = 1
+        return target_path
+
+    @staticmethod
+    def _warn_unsafe_extraction_path(path):
+        """
+        If the default extraction path is overridden and set to an insecure
+        location, such as /tmp, it opens up an opportunity for an attacker to
+        replace an extracted file with an unauthorized payload. Warn the user
+        if a known insecure location is used.
+
+        See Distribute #375 for more details.
+        """
+        if os.name == 'nt' and not path.startswith(os.environ['windir']):
+            # On Windows, permissions are generally restrictive by default
+            #  and temp directories are not writable by other users, so
+            #  bypass the warning.
+            return
+        mode = os.stat(path).st_mode
+        if mode & stat.S_IWOTH or mode & stat.S_IWGRP:
+            msg = (
+                "%s is writable by group/others and vulnerable to attack "
+                "when "
+                "used with get_resource_filename. Consider a more secure "
+                "location (set with .set_extraction_path or the "
+                "PYTHON_EGG_CACHE environment variable)." % path
+            )
+            warnings.warn(msg, UserWarning)
+
+    def postprocess(self, tempname, filename):
+        """Perform any platform-specific postprocessing of `tempname`
+
+        This is where Mac header rewrites should be done; other platforms don't
+        have anything special they should do.
+
+        Resource providers should call this method ONLY after successfully
+        extracting a compressed resource.  They must NOT call it on resources
+        that are already in the filesystem.
+
+        `tempname` is the current (temporary) name of the file, and `filename`
+        is the name it will be renamed to by the caller after this routine
+        returns.
+        """
+
+        if os.name == 'posix':
+            # Make the resource executable
+            mode = ((os.stat(tempname).st_mode) | 0o555) & 0o7777
+            os.chmod(tempname, mode)
+
+    def set_extraction_path(self, path):
+        """Set the base path where resources will be extracted to, if needed.
+
+        If you do not call this routine before any extractions take place, the
+        path defaults to the return value of ``get_default_cache()``.  (Which
+        is based on the ``PYTHON_EGG_CACHE`` environment variable, with various
+        platform-specific fallbacks.  See that routine's documentation for more
+        details.)
+
+        Resources are extracted to subdirectories of this path based upon
+        information given by the ``IResourceProvider``.  You may set this to a
+        temporary directory, but then you must call ``cleanup_resources()`` to
+        delete the extracted files when done.  There is no guarantee that
+        ``cleanup_resources()`` will be able to remove all extracted files.
+
+        (Note: you may not change the extraction path for a given resource
+        manager once resources have been extracted, unless you first call
+        ``cleanup_resources()``.)
+        """
+        if self.cached_files:
+            raise ValueError(
+                "Can't change extraction path, files already extracted"
+            )
+
+        self.extraction_path = path
+
+    def cleanup_resources(self, force=False):
+        """
+        Delete all extracted resource files and directories, returning a list
+        of the file and directory names that could not be successfully removed.
+        This function does not have any concurrency protection, so it should
+        generally only be called when the extraction path is a temporary
+        directory exclusive to a single process.  This method is not
+        automatically called; you must call it explicitly or register it as an
+        ``atexit`` function if you wish to ensure cleanup of a temporary
+        directory used for extractions.
+        """
+        # XXX
+
+
+def get_default_cache():
+    """
+    Return the ``PYTHON_EGG_CACHE`` environment variable
+    or a platform-relevant user cache dir for an app
+    named "Python-Eggs".
+    """
+    return (
+        os.environ.get('PYTHON_EGG_CACHE')
+        or appdirs.user_cache_dir(appname='Python-Eggs')
+    )
+
+
+def safe_name(name):
+    """Convert an arbitrary string to a standard distribution name
+
+    Any runs of non-alphanumeric/. characters are replaced with a single '-'.
+    """
+    return re.sub('[^A-Za-z0-9.]+', '-', name)
+
+
+def safe_version(version):
+    """
+    Convert an arbitrary string to a standard version string
+    """
+    try:
+        # normalize the version
+        return str(packaging.version.Version(version))
+    except packaging.version.InvalidVersion:
+        version = version.replace(' ', '.')
+        return re.sub('[^A-Za-z0-9.]+', '-', version)
+
+
+def safe_extra(extra):
+    """Convert an arbitrary string to a standard 'extra' name
+
+    Any runs of non-alphanumeric characters are replaced with a single '_',
+    and the result is always lowercased.
+    """
+    return re.sub('[^A-Za-z0-9.-]+', '_', extra).lower()
+
+
+def to_filename(name):
+    """Convert a project or version name to its filename-escaped form
+
+    Any '-' characters are currently replaced with '_'.
+    """
+    return name.replace('-', '_')
+
+
+def invalid_marker(text):
+    """
+    Validate text as a PEP 508 environment marker; return an exception
+    if invalid or False otherwise.
+    """
+    try:
+        evaluate_marker(text)
+    except SyntaxError as e:
+        e.filename = None
+        e.lineno = None
+        return e
+    return False
+
+
+def evaluate_marker(text, extra=None):
+    """
+    Evaluate a PEP 508 environment marker.
+    Return a boolean indicating the marker result in this environment.
+    Raise SyntaxError if marker is invalid.
+
+    This implementation uses the 'pyparsing' module.
+    """
+    try:
+        marker = packaging.markers.Marker(text)
+        return marker.evaluate()
+    except packaging.markers.InvalidMarker as e:
+        raise SyntaxError(e)
+
+
+class NullProvider:
+    """Try to implement resources and metadata for arbitrary PEP 302 loaders"""
+
+    egg_name = None
+    egg_info = None
+    loader = None
+
+    def __init__(self, module):
+        self.loader = getattr(module, '__loader__', None)
+        self.module_path = os.path.dirname(getattr(module, '__file__', ''))
+
+    def get_resource_filename(self, manager, resource_name):
+        return self._fn(self.module_path, resource_name)
+
+    def get_resource_stream(self, manager, resource_name):
+        return io.BytesIO(self.get_resource_string(manager, resource_name))
+
+    def get_resource_string(self, manager, resource_name):
+        return self._get(self._fn(self.module_path, resource_name))
+
+    def has_resource(self, resource_name):
+        return self._has(self._fn(self.module_path, resource_name))
+
+    def _get_metadata_path(self, name):
+        return self._fn(self.egg_info, name)
+
+    def has_metadata(self, name):
+        if not self.egg_info:
+            return self.egg_info
+
+        path = self._get_metadata_path(name)
+        return self._has(path)
+
+    def get_metadata(self, name):
+        if not self.egg_info:
+            return ""
+        value = self._get(self._fn(self.egg_info, name))
+        return value.decode('utf-8') if six.PY3 else value
+
+    def get_metadata_lines(self, name):
+        return yield_lines(self.get_metadata(name))
+
+    def resource_isdir(self, resource_name):
+        return self._isdir(self._fn(self.module_path, resource_name))
+
+    def metadata_isdir(self, name):
+        return self.egg_info and self._isdir(self._fn(self.egg_info, name))
+
+    def resource_listdir(self, resource_name):
+        return self._listdir(self._fn(self.module_path, resource_name))
+
+    def metadata_listdir(self, name):
+        if self.egg_info:
+            return self._listdir(self._fn(self.egg_info, name))
+        return []
+
+    def run_script(self, script_name, namespace):
+        script = 'scripts/' + script_name
+        if not self.has_metadata(script):
+            raise ResolutionError(
+                "Script {script!r} not found in metadata at {self.egg_info!r}"
+                .format(**locals()),
+            )
+        script_text = self.get_metadata(script).replace('\r\n', '\n')
+        script_text = script_text.replace('\r', '\n')
+        script_filename = self._fn(self.egg_info, script)
+        namespace['__file__'] = script_filename
+        if os.path.exists(script_filename):
+            source = open(script_filename).read()
+            code = compile(source, script_filename, 'exec')
+            exec(code, namespace, namespace)
+        else:
+            from linecache import cache
+            cache[script_filename] = (
+                len(script_text), 0, script_text.split('\n'), script_filename
+            )
+            script_code = compile(script_text, script_filename, 'exec')
+            exec(script_code, namespace, namespace)
+
+    def _has(self, path):
+        raise NotImplementedError(
+            "Can't perform this operation for unregistered loader type"
+        )
+
+    def _isdir(self, path):
+        raise NotImplementedError(
+            "Can't perform this operation for unregistered loader type"
+        )
+
+    def _listdir(self, path):
+        raise NotImplementedError(
+            "Can't perform this operation for unregistered loader type"
+        )
+
+    def _fn(self, base, resource_name):
+        self._validate_resource_path(resource_name)
+        if resource_name:
+            return os.path.join(base, *resource_name.split('/'))
+        return base
+
+    @staticmethod
+    def _validate_resource_path(path):
+        """
+        Validate the resource paths according to the docs.
+        https://setuptools.readthedocs.io/en/latest/pkg_resources.html#basic-resource-access
+
+        >>> warned = getfixture('recwarn')
+        >>> warnings.simplefilter('always')
+        >>> vrp = NullProvider._validate_resource_path
+        >>> vrp('foo/bar.txt')
+        >>> bool(warned)
+        False
+        >>> vrp('../foo/bar.txt')
+        >>> bool(warned)
+        True
+        >>> warned.clear()
+        >>> vrp('/foo/bar.txt')
+        >>> bool(warned)
+        True
+        >>> vrp('foo/../../bar.txt')
+        >>> bool(warned)
+        True
+        >>> warned.clear()
+        >>> vrp('foo/f../bar.txt')
+        >>> bool(warned)
+        False
+
+        Windows path separators are straight-up disallowed.
+        >>> vrp(r'\\foo/bar.txt')
+        Traceback (most recent call last):
+        ...
+        ValueError: Use of .. or absolute path in a resource path \
+is not allowed.
+
+        >>> vrp(r'C:\\foo/bar.txt')
+        Traceback (most recent call last):
+        ...
+        ValueError: Use of .. or absolute path in a resource path \
+is not allowed.
+
+        Blank values are allowed
+
+        >>> vrp('')
+        >>> bool(warned)
+        False
+
+        Non-string values are not.
+
+        >>> vrp(None)
+        Traceback (most recent call last):
+        ...
+        AttributeError: ...
+        """
+        invalid = (
+            os.path.pardir in path.split(posixpath.sep) or
+            posixpath.isabs(path) or
+            ntpath.isabs(path)
+        )
+        if not invalid:
+            return
+
+        msg = "Use of .. or absolute path in a resource path is not allowed."
+
+        # Aggressively disallow Windows absolute paths
+        if ntpath.isabs(path) and not posixpath.isabs(path):
+            raise ValueError(msg)
+
+        # for compatibility, warn; in future
+        # raise ValueError(msg)
+        warnings.warn(
+            msg[:-1] + " and will raise exceptions in a future release.",
+            DeprecationWarning,
+            stacklevel=4,
+        )
+
+    def _get(self, path):
+        if hasattr(self.loader, 'get_data'):
+            return self.loader.get_data(path)
+        raise NotImplementedError(
+            "Can't perform this operation for loaders without 'get_data()'"
+        )
+
+
+register_loader_type(object, NullProvider)
+
+
+class EggProvider(NullProvider):
+    """Provider based on a virtual filesystem"""
+
+    def __init__(self, module):
+        NullProvider.__init__(self, module)
+        self._setup_prefix()
+
+    def _setup_prefix(self):
+        # we assume here that our metadata may be nested inside a "basket"
+        # of multiple eggs; that's why we use module_path instead of .archive
+        path = self.module_path
+        old = None
+        while path != old:
+            if _is_egg_path(path):
+                self.egg_name = os.path.basename(path)
+                self.egg_info = os.path.join(path, 'EGG-INFO')
+                self.egg_root = path
+                break
+            old = path
+            path, base = os.path.split(path)
+
+
+class DefaultProvider(EggProvider):
+    """Provides access to package resources in the filesystem"""
+
+    def _has(self, path):
+        return os.path.exists(path)
+
+    def _isdir(self, path):
+        return os.path.isdir(path)
+
+    def _listdir(self, path):
+        return os.listdir(path)
+
+    def get_resource_stream(self, manager, resource_name):
+        return open(self._fn(self.module_path, resource_name), 'rb')
+
+    def _get(self, path):
+        with open(path, 'rb') as stream:
+            return stream.read()
+
+    @classmethod
+    def _register(cls):
+        loader_names = 'SourceFileLoader', 'SourcelessFileLoader',
+        for name in loader_names:
+            loader_cls = getattr(importlib_machinery, name, type(None))
+            register_loader_type(loader_cls, cls)
+
+
+DefaultProvider._register()
+
+
+class EmptyProvider(NullProvider):
+    """Provider that returns nothing for all requests"""
+
+    module_path = None
+
+    _isdir = _has = lambda self, path: False
+
+    def _get(self, path):
+        return ''
+
+    def _listdir(self, path):
+        return []
+
+    def __init__(self):
+        pass
+
+
+empty_provider = EmptyProvider()
+
+
+class ZipManifests(dict):
+    """
+    zip manifest builder
+    """
+
+    @classmethod
+    def build(cls, path):
+        """
+        Build a dictionary similar to the zipimport directory
+        caches, except instead of tuples, store ZipInfo objects.
+
+        Use a platform-specific path separator (os.sep) for the path keys
+        for compatibility with pypy on Windows.
+        """
+        with zipfile.ZipFile(path) as zfile:
+            items = (
+                (
+                    name.replace('/', os.sep),
+                    zfile.getinfo(name),
+                )
+                for name in zfile.namelist()
+            )
+            return dict(items)
+
+    load = build
+
+
+class MemoizedZipManifests(ZipManifests):
+    """
+    Memoized zipfile manifests.
+    """
+    manifest_mod = collections.namedtuple('manifest_mod', 'manifest mtime')
+
+    def load(self, path):
+        """
+        Load a manifest at path or return a suitable manifest already loaded.
+        """
+        path = os.path.normpath(path)
+        mtime = os.stat(path).st_mtime
+
+        if path not in self or self[path].mtime != mtime:
+            manifest = self.build(path)
+            self[path] = self.manifest_mod(manifest, mtime)
+
+        return self[path].manifest
+
+
+class ZipProvider(EggProvider):
+    """Resource support for zips and eggs"""
+
+    eagers = None
+    _zip_manifests = MemoizedZipManifests()
+
+    def __init__(self, module):
+        EggProvider.__init__(self, module)
+        self.zip_pre = self.loader.archive + os.sep
+
+    def _zipinfo_name(self, fspath):
+        # Convert a virtual filename (full path to file) into a zipfile subpath
+        # usable with the zipimport directory cache for our target archive
+        fspath = fspath.rstrip(os.sep)
+        if fspath == self.loader.archive:
+            return ''
+        if fspath.startswith(self.zip_pre):
+            return fspath[len(self.zip_pre):]
+        raise AssertionError(
+            "%s is not a subpath of %s" % (fspath, self.zip_pre)
+        )
+
+    def _parts(self, zip_path):
+        # Convert a zipfile subpath into an egg-relative path part list.
+        # pseudo-fs path
+        fspath = self.zip_pre + zip_path
+        if fspath.startswith(self.egg_root + os.sep):
+            return fspath[len(self.egg_root) + 1:].split(os.sep)
+        raise AssertionError(
+            "%s is not a subpath of %s" % (fspath, self.egg_root)
+        )
+
+    @property
+    def zipinfo(self):
+        return self._zip_manifests.load(self.loader.archive)
+
+    def get_resource_filename(self, manager, resource_name):
+        if not self.egg_name:
+            raise NotImplementedError(
+                "resource_filename() only supported for .egg, not .zip"
+            )
+        # no need to lock for extraction, since we use temp names
+        zip_path = self._resource_to_zip(resource_name)
+        eagers = self._get_eager_resources()
+        if '/'.join(self._parts(zip_path)) in eagers:
+            for name in eagers:
+                self._extract_resource(manager, self._eager_to_zip(name))
+        return self._extract_resource(manager, zip_path)
+
+    @staticmethod
+    def _get_date_and_size(zip_stat):
+        size = zip_stat.file_size
+        # ymdhms+wday, yday, dst
+        date_time = zip_stat.date_time + (0, 0, -1)
+        # 1980 offset already done
+        timestamp = time.mktime(date_time)
+        return timestamp, size
+
+    def _extract_resource(self, manager, zip_path):
+
+        if zip_path in self._index():
+            for name in self._index()[zip_path]:
+                last = self._extract_resource(
+                    manager, os.path.join(zip_path, name)
+                )
+            # return the extracted directory name
+            return os.path.dirname(last)
+
+        timestamp, size = self._get_date_and_size(self.zipinfo[zip_path])
+
+        if not WRITE_SUPPORT:
+            raise IOError('"os.rename" and "os.unlink" are not supported '
+                          'on this platform')
+        try:
+
+            real_path = manager.get_cache_path(
+                self.egg_name, self._parts(zip_path)
+            )
+
+            if self._is_current(real_path, zip_path):
+                return real_path
+
+            outf, tmpnam = _mkstemp(
+                ".$extract",
+                dir=os.path.dirname(real_path),
+            )
+            os.write(outf, self.loader.get_data(zip_path))
+            os.close(outf)
+            utime(tmpnam, (timestamp, timestamp))
+            manager.postprocess(tmpnam, real_path)
+
+            try:
+                rename(tmpnam, real_path)
+
+            except os.error:
+                if os.path.isfile(real_path):
+                    if self._is_current(real_path, zip_path):
+                        # the file became current since it was checked above,
+                        #  so proceed.
+                        return real_path
+                    # Windows, del old file and retry
+                    elif os.name == 'nt':
+                        unlink(real_path)
+                        rename(tmpnam, real_path)
+                        return real_path
+                raise
+
+        except os.error:
+            # report a user-friendly error
+            manager.extraction_error()
+
+        return real_path
+
+    def _is_current(self, file_path, zip_path):
+        """
+        Return True if the file_path is current for this zip_path
+        """
+        timestamp, size = self._get_date_and_size(self.zipinfo[zip_path])
+        if not os.path.isfile(file_path):
+            return False
+        stat = os.stat(file_path)
+        if stat.st_size != size or stat.st_mtime != timestamp:
+            return False
+        # check that the contents match
+        zip_contents = self.loader.get_data(zip_path)
+        with open(file_path, 'rb') as f:
+            file_contents = f.read()
+        return zip_contents == file_contents
+
+    def _get_eager_resources(self):
+        if self.eagers is None:
+            eagers = []
+            for name in ('native_libs.txt', 'eager_resources.txt'):
+                if self.has_metadata(name):
+                    eagers.extend(self.get_metadata_lines(name))
+            self.eagers = eagers
+        return self.eagers
+
+    def _index(self):
+        try:
+            return self._dirindex
+        except AttributeError:
+            ind = {}
+            for path in self.zipinfo:
+                parts = path.split(os.sep)
+                while parts:
+                    parent = os.sep.join(parts[:-1])
+                    if parent in ind:
+                        ind[parent].append(parts[-1])
+                        break
+                    else:
+                        ind[parent] = [parts.pop()]
+            self._dirindex = ind
+            return ind
+
+    def _has(self, fspath):
+        zip_path = self._zipinfo_name(fspath)
+        return zip_path in self.zipinfo or zip_path in self._index()
+
+    def _isdir(self, fspath):
+        return self._zipinfo_name(fspath) in self._index()
+
+    def _listdir(self, fspath):
+        return list(self._index().get(self._zipinfo_name(fspath), ()))
+
+    def _eager_to_zip(self, resource_name):
+        return self._zipinfo_name(self._fn(self.egg_root, resource_name))
+
+    def _resource_to_zip(self, resource_name):
+        return self._zipinfo_name(self._fn(self.module_path, resource_name))
+
+
+register_loader_type(zipimport.zipimporter, ZipProvider)
+
+
+class FileMetadata(EmptyProvider):
+    """Metadata handler for standalone PKG-INFO files
+
+    Usage::
+
+        metadata = FileMetadata("/path/to/PKG-INFO")
+
+    This provider rejects all data and metadata requests except for PKG-INFO,
+    which is treated as existing, and will be the contents of the file at
+    the provided location.
+    """
+
+    def __init__(self, path):
+        self.path = path
+
+    def _get_metadata_path(self, name):
+        return self.path
+
+    def has_metadata(self, name):
+        return name == 'PKG-INFO' and os.path.isfile(self.path)
+
+    def get_metadata(self, name):
+        if name != 'PKG-INFO':
+            raise KeyError("No metadata except PKG-INFO is available")
+
+        with io.open(self.path, encoding='utf-8', errors="replace") as f:
+            metadata = f.read()
+        self._warn_on_replacement(metadata)
+        return metadata
+
+    def _warn_on_replacement(self, metadata):
+        # Python 2.7 compat for: replacement_char = '�'
+        replacement_char = b'\xef\xbf\xbd'.decode('utf-8')
+        if replacement_char in metadata:
+            tmpl = "{self.path} could not be properly decoded in UTF-8"
+            msg = tmpl.format(**locals())
+            warnings.warn(msg)
+
+    def get_metadata_lines(self, name):
+        return yield_lines(self.get_metadata(name))
+
+
+class PathMetadata(DefaultProvider):
+    """Metadata provider for egg directories
+
+    Usage::
+
+        # Development eggs:
+
+        egg_info = "/path/to/PackageName.egg-info"
+        base_dir = os.path.dirname(egg_info)
+        metadata = PathMetadata(base_dir, egg_info)
+        dist_name = os.path.splitext(os.path.basename(egg_info))[0]
+        dist = Distribution(basedir, project_name=dist_name, metadata=metadata)
+
+        # Unpacked egg directories:
+
+        egg_path = "/path/to/PackageName-ver-pyver-etc.egg"
+        metadata = PathMetadata(egg_path, os.path.join(egg_path,'EGG-INFO'))
+        dist = Distribution.from_filename(egg_path, metadata=metadata)
+    """
+
+    def __init__(self, path, egg_info):
+        self.module_path = path
+        self.egg_info = egg_info
+
+
+class EggMetadata(ZipProvider):
+    """Metadata provider for .egg files"""
+
+    def __init__(self, importer):
+        """Create a metadata provider from a zipimporter"""
+
+        self.zip_pre = importer.archive + os.sep
+        self.loader = importer
+        if importer.prefix:
+            self.module_path = os.path.join(importer.archive, importer.prefix)
+        else:
+            self.module_path = importer.archive
+        self._setup_prefix()
+
+
+_declare_state('dict', _distribution_finders={})
+
+
+def register_finder(importer_type, distribution_finder):
+    """Register `distribution_finder` to find distributions in sys.path items
+
+    `importer_type` is the type or class of a PEP 302 "Importer" (sys.path item
+    handler), and `distribution_finder` is a callable that, passed a path
+    item and the importer instance, yields ``Distribution`` instances found on
+    that path item.  See ``pkg_resources.find_on_path`` for an example."""
+    _distribution_finders[importer_type] = distribution_finder
+
+
+def find_distributions(path_item, only=False):
+    """Yield distributions accessible via `path_item`"""
+    importer = get_importer(path_item)
+    finder = _find_adapter(_distribution_finders, importer)
+    return finder(importer, path_item, only)
+
+
+def find_eggs_in_zip(importer, path_item, only=False):
+    """
+    Find eggs in zip files; possibly multiple nested eggs.
+    """
+    if importer.archive.endswith('.whl'):
+        # wheels are not supported with this finder
+        # they don't have PKG-INFO metadata, and won't ever contain eggs
+        return
+    metadata = EggMetadata(importer)
+    if metadata.has_metadata('PKG-INFO'):
+        yield Distribution.from_filename(path_item, metadata=metadata)
+    if only:
+        # don't yield nested distros
+        return
+    for subitem in metadata.resource_listdir(''):
+        if _is_egg_path(subitem):
+            subpath = os.path.join(path_item, subitem)
+            dists = find_eggs_in_zip(zipimport.zipimporter(subpath), subpath)
+            for dist in dists:
+                yield dist
+        elif subitem.lower().endswith('.dist-info'):
+            subpath = os.path.join(path_item, subitem)
+            submeta = EggMetadata(zipimport.zipimporter(subpath))
+            submeta.egg_info = subpath
+            yield Distribution.from_location(path_item, subitem, submeta)
+
+
+register_finder(zipimport.zipimporter, find_eggs_in_zip)
+
+
+def find_nothing(importer, path_item, only=False):
+    return ()
+
+
+register_finder(object, find_nothing)
+
+
+def _by_version_descending(names):
+    """
+    Given a list of filenames, return them in descending order
+    by version number.
+
+    >>> names = 'bar', 'foo', 'Python-2.7.10.egg', 'Python-2.7.2.egg'
+    >>> _by_version_descending(names)
+    ['Python-2.7.10.egg', 'Python-2.7.2.egg', 'foo', 'bar']
+    >>> names = 'Setuptools-1.2.3b1.egg', 'Setuptools-1.2.3.egg'
+    >>> _by_version_descending(names)
+    ['Setuptools-1.2.3.egg', 'Setuptools-1.2.3b1.egg']
+    >>> names = 'Setuptools-1.2.3b1.egg', 'Setuptools-1.2.3.post1.egg'
+    >>> _by_version_descending(names)
+    ['Setuptools-1.2.3.post1.egg', 'Setuptools-1.2.3b1.egg']
+    """
+    def _by_version(name):
+        """
+        Parse each component of the filename
+        """
+        name, ext = os.path.splitext(name)
+        parts = itertools.chain(name.split('-'), [ext])
+        return [packaging.version.parse(part) for part in parts]
+
+    return sorted(names, key=_by_version, reverse=True)
+
+
+def find_on_path(importer, path_item, only=False):
+    """Yield distributions accessible on a sys.path directory"""
+    path_item = _normalize_cached(path_item)
+
+    if _is_unpacked_egg(path_item):
+        yield Distribution.from_filename(
+            path_item, metadata=PathMetadata(
+                path_item, os.path.join(path_item, 'EGG-INFO')
+            )
+        )
+        return
+
+    entries = safe_listdir(path_item)
+
+    # for performance, before sorting by version,
+    # screen entries for only those that will yield
+    # distributions
+    filtered = (
+        entry
+        for entry in entries
+        if dist_factory(path_item, entry, only)
+    )
+
+    # scan for .egg and .egg-info in directory
+    path_item_entries = _by_version_descending(filtered)
+    for entry in path_item_entries:
+        fullpath = os.path.join(path_item, entry)
+        factory = dist_factory(path_item, entry, only)
+        for dist in factory(fullpath):
+            yield dist
+
+
+def dist_factory(path_item, entry, only):
+    """
+    Return a dist_factory for a path_item and entry
+    """
+    lower = entry.lower()
+    is_meta = any(map(lower.endswith, ('.egg-info', '.dist-info')))
+    return (
+        distributions_from_metadata
+        if is_meta else
+        find_distributions
+        if not only and _is_egg_path(entry) else
+        resolve_egg_link
+        if not only and lower.endswith('.egg-link') else
+        NoDists()
+    )
+
+
+class NoDists:
+    """
+    >>> bool(NoDists())
+    False
+
+    >>> list(NoDists()('anything'))
+    []
+    """
+    def __bool__(self):
+        return False
+    if six.PY2:
+        __nonzero__ = __bool__
+
+    def __call__(self, fullpath):
+        return iter(())
+
+
+def safe_listdir(path):
+    """
+    Attempt to list contents of path, but suppress some exceptions.
+    """
+    try:
+        return os.listdir(path)
+    except (PermissionError, NotADirectoryError):
+        pass
+    except OSError as e:
+        # Ignore the directory if does not exist, not a directory or
+        # permission denied
+        ignorable = (
+            e.errno in (errno.ENOTDIR, errno.EACCES, errno.ENOENT)
+            # Python 2 on Windows needs to be handled this way :(
+            or getattr(e, "winerror", None) == 267
+        )
+        if not ignorable:
+            raise
+    return ()
+
+
+def distributions_from_metadata(path):
+    root = os.path.dirname(path)
+    if os.path.isdir(path):
+        if len(os.listdir(path)) == 0:
+            # empty metadata dir; skip
+            return
+        metadata = PathMetadata(root, path)
+    else:
+        metadata = FileMetadata(path)
+    entry = os.path.basename(path)
+    yield Distribution.from_location(
+        root, entry, metadata, precedence=DEVELOP_DIST,
+    )
+
+
+def non_empty_lines(path):
+    """
+    Yield non-empty lines from file at path
+    """
+    with open(path) as f:
+        for line in f:
+            line = line.strip()
+            if line:
+                yield line
+
+
+def resolve_egg_link(path):
+    """
+    Given a path to an .egg-link, resolve distributions
+    present in the referenced path.
+    """
+    referenced_paths = non_empty_lines(path)
+    resolved_paths = (
+        os.path.join(os.path.dirname(path), ref)
+        for ref in referenced_paths
+    )
+    dist_groups = map(find_distributions, resolved_paths)
+    return next(dist_groups, ())
+
+
+register_finder(pkgutil.ImpImporter, find_on_path)
+
+if hasattr(importlib_machinery, 'FileFinder'):
+    register_finder(importlib_machinery.FileFinder, find_on_path)
+
+_declare_state('dict', _namespace_handlers={})
+_declare_state('dict', _namespace_packages={})
+
+
+def register_namespace_handler(importer_type, namespace_handler):
+    """Register `namespace_handler` to declare namespace packages
+
+    `importer_type` is the type or class of a PEP 302 "Importer" (sys.path item
+    handler), and `namespace_handler` is a callable like this::
+
+        def namespace_handler(importer, path_entry, moduleName, module):
+            # return a path_entry to use for child packages
+
+    Namespace handlers are only called if the importer object has already
+    agreed that it can handle the relevant path item, and they should only
+    return a subpath if the module __path__ does not already contain an
+    equivalent subpath.  For an example namespace handler, see
+    ``pkg_resources.file_ns_handler``.
+    """
+    _namespace_handlers[importer_type] = namespace_handler
+
+
+def _handle_ns(packageName, path_item):
+    """Ensure that named package includes a subpath of path_item (if needed)"""
+
+    importer = get_importer(path_item)
+    if importer is None:
+        return None
+
+    # capture warnings due to #1111
+    with warnings.catch_warnings():
+        warnings.simplefilter("ignore")
+        loader = importer.find_module(packageName)
+
+    if loader is None:
+        return None
+    module = sys.modules.get(packageName)
+    if module is None:
+        module = sys.modules[packageName] = types.ModuleType(packageName)
+        module.__path__ = []
+        _set_parent_ns(packageName)
+    elif not hasattr(module, '__path__'):
+        raise TypeError("Not a package:", packageName)
+    handler = _find_adapter(_namespace_handlers, importer)
+    subpath = handler(importer, path_item, packageName, module)
+    if subpath is not None:
+        path = module.__path__
+        path.append(subpath)
+        loader.load_module(packageName)
+        _rebuild_mod_path(path, packageName, module)
+    return subpath
+
+
+def _rebuild_mod_path(orig_path, package_name, module):
+    """
+    Rebuild module.__path__ ensuring that all entries are ordered
+    corresponding to their sys.path order
+    """
+    sys_path = [_normalize_cached(p) for p in sys.path]
+
+    def safe_sys_path_index(entry):
+        """
+        Workaround for #520 and #513.
+        """
+        try:
+            return sys_path.index(entry)
+        except ValueError:
+            return float('inf')
+
+    def position_in_sys_path(path):
+        """
+        Return the ordinal of the path based on its position in sys.path
+        """
+        path_parts = path.split(os.sep)
+        module_parts = package_name.count('.') + 1
+        parts = path_parts[:-module_parts]
+        return safe_sys_path_index(_normalize_cached(os.sep.join(parts)))
+
+    new_path = sorted(orig_path, key=position_in_sys_path)
+    new_path = [_normalize_cached(p) for p in new_path]
+
+    if isinstance(module.__path__, list):
+        module.__path__[:] = new_path
+    else:
+        module.__path__ = new_path
+
+
+def declare_namespace(packageName):
+    """Declare that package 'packageName' is a namespace package"""
+
+    _imp.acquire_lock()
+    try:
+        if packageName in _namespace_packages:
+            return
+
+        path = sys.path
+        parent, _, _ = packageName.rpartition('.')
+
+        if parent:
+            declare_namespace(parent)
+            if parent not in _namespace_packages:
+                __import__(parent)
+            try:
+                path = sys.modules[parent].__path__
+            except AttributeError:
+                raise TypeError("Not a package:", parent)
+
+        # Track what packages are namespaces, so when new path items are added,
+        # they can be updated
+        _namespace_packages.setdefault(parent or None, []).append(packageName)
+        _namespace_packages.setdefault(packageName, [])
+
+        for path_item in path:
+            # Ensure all the parent's path items are reflected in the child,
+            # if they apply
+            _handle_ns(packageName, path_item)
+
+    finally:
+        _imp.release_lock()
+
+
+def fixup_namespace_packages(path_item, parent=None):
+    """Ensure that previously-declared namespace packages include path_item"""
+    _imp.acquire_lock()
+    try:
+        for package in _namespace_packages.get(parent, ()):
+            subpath = _handle_ns(package, path_item)
+            if subpath:
+                fixup_namespace_packages(subpath, package)
+    finally:
+        _imp.release_lock()
+
+
+def file_ns_handler(importer, path_item, packageName, module):
+    """Compute an ns-package subpath for a filesystem or zipfile importer"""
+
+    subpath = os.path.join(path_item, packageName.split('.')[-1])
+    normalized = _normalize_cached(subpath)
+    for item in module.__path__:
+        if _normalize_cached(item) == normalized:
+            break
+    else:
+        # Only return the path if it's not already there
+        return subpath
+
+
+register_namespace_handler(pkgutil.ImpImporter, file_ns_handler)
+register_namespace_handler(zipimport.zipimporter, file_ns_handler)
+
+if hasattr(importlib_machinery, 'FileFinder'):
+    register_namespace_handler(importlib_machinery.FileFinder, file_ns_handler)
+
+
+def null_ns_handler(importer, path_item, packageName, module):
+    return None
+
+
+register_namespace_handler(object, null_ns_handler)
+
+
+def normalize_path(filename):
+    """Normalize a file/dir name for comparison purposes"""
+    return os.path.normcase(os.path.realpath(os.path.normpath(_cygwin_patch(filename))))
+
+
+def _cygwin_patch(filename):  # pragma: nocover
+    """
+    Contrary to POSIX 2008, on Cygwin, getcwd (3) contains
+    symlink components. Using
+    os.path.abspath() works around this limitation. A fix in os.getcwd()
+    would probably better, in Cygwin even more so, except
+    that this seems to be by design...
+    """
+    return os.path.abspath(filename) if sys.platform == 'cygwin' else filename
+
+
+def _normalize_cached(filename, _cache={}):
+    try:
+        return _cache[filename]
+    except KeyError:
+        _cache[filename] = result = normalize_path(filename)
+        return result
+
+
+def _is_egg_path(path):
+    """
+    Determine if given path appears to be an egg.
+    """
+    return path.lower().endswith('.egg')
+
+
+def _is_unpacked_egg(path):
+    """
+    Determine if given path appears to be an unpacked egg.
+    """
+    return (
+        _is_egg_path(path) and
+        os.path.isfile(os.path.join(path, 'EGG-INFO', 'PKG-INFO'))
+    )
+
+
+def _set_parent_ns(packageName):
+    parts = packageName.split('.')
+    name = parts.pop()
+    if parts:
+        parent = '.'.join(parts)
+        setattr(sys.modules[parent], name, sys.modules[packageName])
+
+
+def yield_lines(strs):
+    """Yield non-empty/non-comment lines of a string or sequence"""
+    if isinstance(strs, six.string_types):
+        for s in strs.splitlines():
+            s = s.strip()
+            # skip blank lines/comments
+            if s and not s.startswith('#'):
+                yield s
+    else:
+        for ss in strs:
+            for s in yield_lines(ss):
+                yield s
+
+
+MODULE = re.compile(r"\w+(\.\w+)*$").match
+EGG_NAME = re.compile(
+    r"""
+    (?P<name>[^-]+) (
+        -(?P<ver>[^-]+) (
+            -py(?P<pyver>[^-]+) (
+                -(?P<plat>.+)
+            )?
+        )?
+    )?
+    """,
+    re.VERBOSE | re.IGNORECASE,
+).match
+
+
+class EntryPoint:
+    """Object representing an advertised importable object"""
+
+    def __init__(self, name, module_name, attrs=(), extras=(), dist=None):
+        if not MODULE(module_name):
+            raise ValueError("Invalid module name", module_name)
+        self.name = name
+        self.module_name = module_name
+        self.attrs = tuple(attrs)
+        self.extras = tuple(extras)
+        self.dist = dist
+
+    def __str__(self):
+        s = "%s = %s" % (self.name, self.module_name)
+        if self.attrs:
+            s += ':' + '.'.join(self.attrs)
+        if self.extras:
+            s += ' [%s]' % ','.join(self.extras)
+        return s
+
+    def __repr__(self):
+        return "EntryPoint.parse(%r)" % str(self)
+
+    def load(self, require=True, *args, **kwargs):
+        """
+        Require packages for this EntryPoint, then resolve it.
+        """
+        if not require or args or kwargs:
+            warnings.warn(
+                "Parameters to load are deprecated.  Call .resolve and "
+                ".require separately.",
+                PkgResourcesDeprecationWarning,
+                stacklevel=2,
+            )
+        if require:
+            self.require(*args, **kwargs)
+        return self.resolve()
+
+    def resolve(self):
+        """
+        Resolve the entry point from its module and attrs.
+        """
+        module = __import__(self.module_name, fromlist=['__name__'], level=0)
+        try:
+            return functools.reduce(getattr, self.attrs, module)
+        except AttributeError as exc:
+            raise ImportError(str(exc))
+
+    def require(self, env=None, installer=None):
+        if self.extras and not self.dist:
+            raise UnknownExtra("Can't require() without a distribution", self)
+
+        # Get the requirements for this entry point with all its extras and
+        # then resolve them. We have to pass `extras` along when resolving so
+        # that the working set knows what extras we want. Otherwise, for
+        # dist-info distributions, the working set will assume that the
+        # requirements for that extra are purely optional and skip over them.
+        reqs = self.dist.requires(self.extras)
+        items = working_set.resolve(reqs, env, installer, extras=self.extras)
+        list(map(working_set.add, items))
+
+    pattern = re.compile(
+        r'\s*'
+        r'(?P<name>.+?)\s*'
+        r'=\s*'
+        r'(?P<module>[\w.]+)\s*'
+        r'(:\s*(?P<attr>[\w.]+))?\s*'
+        r'(?P<extras>\[.*\])?\s*$'
+    )
+
+    @classmethod
+    def parse(cls, src, dist=None):
+        """Parse a single entry point from string `src`
+
+        Entry point syntax follows the form::
+
+            name = some.module:some.attr [extra1, extra2]
+
+        The entry name and module name are required, but the ``:attrs`` and
+        ``[extras]`` parts are optional
+        """
+        m = cls.pattern.match(src)
+        if not m:
+            msg = "EntryPoint must be in 'name=module:attrs [extras]' format"
+            raise ValueError(msg, src)
+        res = m.groupdict()
+        extras = cls._parse_extras(res['extras'])
+        attrs = res['attr'].split('.') if res['attr'] else ()
+        return cls(res['name'], res['module'], attrs, extras, dist)
+
+    @classmethod
+    def _parse_extras(cls, extras_spec):
+        if not extras_spec:
+            return ()
+        req = Requirement.parse('x' + extras_spec)
+        if req.specs:
+            raise ValueError()
+        return req.extras
+
+    @classmethod
+    def parse_group(cls, group, lines, dist=None):
+        """Parse an entry point group"""
+        if not MODULE(group):
+            raise ValueError("Invalid group name", group)
+        this = {}
+        for line in yield_lines(lines):
+            ep = cls.parse(line, dist)
+            if ep.name in this:
+                raise ValueError("Duplicate entry point", group, ep.name)
+            this[ep.name] = ep
+        return this
+
+    @classmethod
+    def parse_map(cls, data, dist=None):
+        """Parse a map of entry point groups"""
+        if isinstance(data, dict):
+            data = data.items()
+        else:
+            data = split_sections(data)
+        maps = {}
+        for group, lines in data:
+            if group is None:
+                if not lines:
+                    continue
+                raise ValueError("Entry points must be listed in groups")
+            group = group.strip()
+            if group in maps:
+                raise ValueError("Duplicate group name", group)
+            maps[group] = cls.parse_group(group, lines, dist)
+        return maps
+
+
+def _remove_md5_fragment(location):
+    if not location:
+        return ''
+    parsed = urllib.parse.urlparse(location)
+    if parsed[-1].startswith('md5='):
+        return urllib.parse.urlunparse(parsed[:-1] + ('',))
+    return location
+
+
+def _version_from_file(lines):
+    """
+    Given an iterable of lines from a Metadata file, return
+    the value of the Version field, if present, or None otherwise.
+    """
+    def is_version_line(line):
+        return line.lower().startswith('version:')
+    version_lines = filter(is_version_line, lines)
+    line = next(iter(version_lines), '')
+    _, _, value = line.partition(':')
+    return safe_version(value.strip()) or None
+
+
+class Distribution:
+    """Wrap an actual or potential sys.path entry w/metadata"""
+    PKG_INFO = 'PKG-INFO'
+
+    def __init__(
+            self, location=None, metadata=None, project_name=None,
+            version=None, py_version=PY_MAJOR, platform=None,
+            precedence=EGG_DIST):
+        self.project_name = safe_name(project_name or 'Unknown')
+        if version is not None:
+            self._version = safe_version(version)
+        self.py_version = py_version
+        self.platform = platform
+        self.location = location
+        self.precedence = precedence
+        self._provider = metadata or empty_provider
+
+    @classmethod
+    def from_location(cls, location, basename, metadata=None, **kw):
+        project_name, version, py_version, platform = [None] * 4
+        basename, ext = os.path.splitext(basename)
+        if ext.lower() in _distributionImpl:
+            cls = _distributionImpl[ext.lower()]
+
+            match = EGG_NAME(basename)
+            if match:
+                project_name, version, py_version, platform = match.group(
+                    'name', 'ver', 'pyver', 'plat'
+                )
+        return cls(
+            location, metadata, project_name=project_name, version=version,
+            py_version=py_version, platform=platform, **kw
+        )._reload_version()
+
+    def _reload_version(self):
+        return self
+
+    @property
+    def hashcmp(self):
+        return (
+            self.parsed_version,
+            self.precedence,
+            self.key,
+            _remove_md5_fragment(self.location),
+            self.py_version or '',
+            self.platform or '',
+        )
+
+    def __hash__(self):
+        return hash(self.hashcmp)
+
+    def __lt__(self, other):
+        return self.hashcmp < other.hashcmp
+
+    def __le__(self, other):
+        return self.hashcmp <= other.hashcmp
+
+    def __gt__(self, other):
+        return self.hashcmp > other.hashcmp
+
+    def __ge__(self, other):
+        return self.hashcmp >= other.hashcmp
+
+    def __eq__(self, other):
+        if not isinstance(other, self.__class__):
+            # It's not a Distribution, so they are not equal
+            return False
+        return self.hashcmp == other.hashcmp
+
+    def __ne__(self, other):
+        return not self == other
+
+    # These properties have to be lazy so that we don't have to load any
+    # metadata until/unless it's actually needed.  (i.e., some distributions
+    # may not know their name or version without loading PKG-INFO)
+
+    @property
+    def key(self):
+        try:
+            return self._key
+        except AttributeError:
+            self._key = key = self.project_name.lower()
+            return key
+
+    @property
+    def parsed_version(self):
+        if not hasattr(self, "_parsed_version"):
+            self._parsed_version = parse_version(self.version)
+
+        return self._parsed_version
+
+    def _warn_legacy_version(self):
+        LV = packaging.version.LegacyVersion
+        is_legacy = isinstance(self._parsed_version, LV)
+        if not is_legacy:
+            return
+
+        # While an empty version is technically a legacy version and
+        # is not a valid PEP 440 version, it's also unlikely to
+        # actually come from someone and instead it is more likely that
+        # it comes from setuptools attempting to parse a filename and
+        # including it in the list. So for that we'll gate this warning
+        # on if the version is anything at all or not.
+        if not self.version:
+            return
+
+        tmpl = textwrap.dedent("""
+            '{project_name} ({version})' is being parsed as a legacy,
+            non PEP 440,
+            version. You may find odd behavior and sort order.
+            In particular it will be sorted as less than 0.0. It
+            is recommended to migrate to PEP 440 compatible
+            versions.
+            """).strip().replace('\n', ' ')
+
+        warnings.warn(tmpl.format(**vars(self)), PEP440Warning)
+
+    @property
+    def version(self):
+        try:
+            return self._version
+        except AttributeError:
+            version = self._get_version()
+            if version is None:
+                path = self._get_metadata_path_for_display(self.PKG_INFO)
+                msg = (
+                    "Missing 'Version:' header and/or {} file at path: {}"
+                ).format(self.PKG_INFO, path)
+                raise ValueError(msg, self)
+
+            return version
+
+    @property
+    def _dep_map(self):
+        """
+        A map of extra to its list of (direct) requirements
+        for this distribution, including the null extra.
+        """
+        try:
+            return self.__dep_map
+        except AttributeError:
+            self.__dep_map = self._filter_extras(self._build_dep_map())
+        return self.__dep_map
+
+    @staticmethod
+    def _filter_extras(dm):
+        """
+        Given a mapping of extras to dependencies, strip off
+        environment markers and filter out any dependencies
+        not matching the markers.
+        """
+        for extra in list(filter(None, dm)):
+            new_extra = extra
+            reqs = dm.pop(extra)
+            new_extra, _, marker = extra.partition(':')
+            fails_marker = marker and (
+                invalid_marker(marker)
+                or not evaluate_marker(marker)
+            )
+            if fails_marker:
+                reqs = []
+            new_extra = safe_extra(new_extra) or None
+
+            dm.setdefault(new_extra, []).extend(reqs)
+        return dm
+
+    def _build_dep_map(self):
+        dm = {}
+        for name in 'requires.txt', 'depends.txt':
+            for extra, reqs in split_sections(self._get_metadata(name)):
+                dm.setdefault(extra, []).extend(parse_requirements(reqs))
+        return dm
+
+    def requires(self, extras=()):
+        """List of Requirements needed for this distro if `extras` are used"""
+        dm = self._dep_map
+        deps = []
+        deps.extend(dm.get(None, ()))
+        for ext in extras:
+            try:
+                deps.extend(dm[safe_extra(ext)])
+            except KeyError:
+                raise UnknownExtra(
+                    "%s has no such extra feature %r" % (self, ext)
+                )
+        return deps
+
+    def _get_metadata_path_for_display(self, name):
+        """
+        Return the path to the given metadata file, if available.
+        """
+        try:
+            # We need to access _get_metadata_path() on the provider object
+            # directly rather than through this class's __getattr__()
+            # since _get_metadata_path() is marked private.
+            path = self._provider._get_metadata_path(name)
+
+        # Handle exceptions e.g. in case the distribution's metadata
+        # provider doesn't support _get_metadata_path().
+        except Exception:
+            return '[could not detect]'
+
+        return path
+
+    def _get_metadata(self, name):
+        if self.has_metadata(name):
+            for line in self.get_metadata_lines(name):
+                yield line
+
+    def _get_version(self):
+        lines = self._get_metadata(self.PKG_INFO)
+        version = _version_from_file(lines)
+
+        return version
+
+    def activate(self, path=None, replace=False):
+        """Ensure distribution is importable on `path` (default=sys.path)"""
+        if path is None:
+            path = sys.path
+        self.insert_on(path, replace=replace)
+        if path is sys.path:
+            fixup_namespace_packages(self.location)
+            for pkg in self._get_metadata('namespace_packages.txt'):
+                if pkg in sys.modules:
+                    declare_namespace(pkg)
+
+    def egg_name(self):
+        """Return what this distribution's standard .egg filename should be"""
+        filename = "%s-%s-py%s" % (
+            to_filename(self.project_name), to_filename(self.version),
+            self.py_version or PY_MAJOR
+        )
+
+        if self.platform:
+            filename += '-' + self.platform
+        return filename
+
+    def __repr__(self):
+        if self.location:
+            return "%s (%s)" % (self, self.location)
+        else:
+            return str(self)
+
+    def __str__(self):
+        try:
+            version = getattr(self, 'version', None)
+        except ValueError:
+            version = None
+        version = version or "[unknown version]"
+        return "%s %s" % (self.project_name, version)
+
+    def __getattr__(self, attr):
+        """Delegate all unrecognized public attributes to .metadata provider"""
+        if attr.startswith('_'):
+            raise AttributeError(attr)
+        return getattr(self._provider, attr)
+
+    def __dir__(self):
+        return list(
+            set(super(Distribution, self).__dir__())
+            | set(
+                attr for attr in self._provider.__dir__()
+                if not attr.startswith('_')
+            )
+        )
+
+    if not hasattr(object, '__dir__'):
+        # python 2.7 not supported
+        del __dir__
+
+    @classmethod
+    def from_filename(cls, filename, metadata=None, **kw):
+        return cls.from_location(
+            _normalize_cached(filename), os.path.basename(filename), metadata,
+            **kw
+        )
+
+    def as_requirement(self):
+        """Return a ``Requirement`` that matches this distribution exactly"""
+        if isinstance(self.parsed_version, packaging.version.Version):
+            spec = "%s==%s" % (self.project_name, self.parsed_version)
+        else:
+            spec = "%s===%s" % (self.project_name, self.parsed_version)
+
+        return Requirement.parse(spec)
+
+    def load_entry_point(self, group, name):
+        """Return the `name` entry point of `group` or raise ImportError"""
+        ep = self.get_entry_info(group, name)
+        if ep is None:
+            raise ImportError("Entry point %r not found" % ((group, name),))
+        return ep.load()
+
+    def get_entry_map(self, group=None):
+        """Return the entry point map for `group`, or the full entry map"""
+        try:
+            ep_map = self._ep_map
+        except AttributeError:
+            ep_map = self._ep_map = EntryPoint.parse_map(
+                self._get_metadata('entry_points.txt'), self
+            )
+        if group is not None:
+            return ep_map.get(group, {})
+        return ep_map
+
+    def get_entry_info(self, group, name):
+        """Return the EntryPoint object for `group`+`name`, or ``None``"""
+        return self.get_entry_map(group).get(name)
+
+    def insert_on(self, path, loc=None, replace=False):
+        """Ensure self.location is on path
+
+        If replace=False (default):
+            - If location is already in path anywhere, do nothing.
+            - Else:
+              - If it's an egg and its parent directory is on path,
+                insert just ahead of the parent.
+              - Else: add to the end of path.
+        If replace=True:
+            - If location is already on path anywhere (not eggs)
+              or higher priority than its parent (eggs)
+              do nothing.
+            - Else:
+              - If it's an egg and its parent directory is on path,
+                insert just ahead of the parent,
+                removing any lower-priority entries.
+              - Else: add it to the front of path.
+        """
+
+        loc = loc or self.location
+        if not loc:
+            return
+
+        nloc = _normalize_cached(loc)
+        bdir = os.path.dirname(nloc)
+        npath = [(p and _normalize_cached(p) or p) for p in path]
+
+        for p, item in enumerate(npath):
+            if item == nloc:
+                if replace:
+                    break
+                else:
+                    # don't modify path (even removing duplicates) if
+                    # found and not replace
+                    return
+            elif item == bdir and self.precedence == EGG_DIST:
+                # if it's an .egg, give it precedence over its directory
+                # UNLESS it's already been added to sys.path and replace=False
+                if (not replace) and nloc in npath[p:]:
+                    return
+                if path is sys.path:
+                    self.check_version_conflict()
+                path.insert(p, loc)
+                npath.insert(p, nloc)
+                break
+        else:
+            if path is sys.path:
+                self.check_version_conflict()
+            if replace:
+                path.insert(0, loc)
+            else:
+                path.append(loc)
+            return
+
+        # p is the spot where we found or inserted loc; now remove duplicates
+        while True:
+            try:
+                np = npath.index(nloc, p + 1)
+            except ValueError:
+                break
+            else:
+                del npath[np], path[np]
+                # ha!
+                p = np
+
+        return
+
+    def check_version_conflict(self):
+        if self.key == 'setuptools':
+            # ignore the inevitable setuptools self-conflicts  :(
+            return
+
+        nsp = dict.fromkeys(self._get_metadata('namespace_packages.txt'))
+        loc = normalize_path(self.location)
+        for modname in self._get_metadata('top_level.txt'):
+            if (modname not in sys.modules or modname in nsp
+                    or modname in _namespace_packages):
+                continue
+            if modname in ('pkg_resources', 'setuptools', 'site'):
+                continue
+            fn = getattr(sys.modules[modname], '__file__', None)
+            if fn and (normalize_path(fn).startswith(loc) or
+                       fn.startswith(self.location)):
+                continue
+            issue_warning(
+                "Module %s was already imported from %s, but %s is being added"
+                " to sys.path" % (modname, fn, self.location),
+            )
+
+    def has_version(self):
+        try:
+            self.version
+        except ValueError:
+            issue_warning("Unbuilt egg for " + repr(self))
+            return False
+        return True
+
+    def clone(self, **kw):
+        """Copy this distribution, substituting in any changed keyword args"""
+        names = 'project_name version py_version platform location precedence'
+        for attr in names.split():
+            kw.setdefault(attr, getattr(self, attr, None))
+        kw.setdefault('metadata', self._provider)
+        return self.__class__(**kw)
+
+    @property
+    def extras(self):
+        return [dep for dep in self._dep_map if dep]
+
+
+class EggInfoDistribution(Distribution):
+    def _reload_version(self):
+        """
+        Packages installed by distutils (e.g. numpy or scipy),
+        which uses an old safe_version, and so
+        their version numbers can get mangled when
+        converted to filenames (e.g., 1.11.0.dev0+2329eae to
+        1.11.0.dev0_2329eae). These distributions will not be
+        parsed properly
+        downstream by Distribution and safe_version, so
+        take an extra step and try to get the version number from
+        the metadata file itself instead of the filename.
+        """
+        md_version = self._get_version()
+        if md_version:
+            self._version = md_version
+        return self
+
+
+class DistInfoDistribution(Distribution):
+    """
+    Wrap an actual or potential sys.path entry
+    w/metadata, .dist-info style.
+    """
+    PKG_INFO = 'METADATA'
+    EQEQ = re.compile(r"([\(,])\s*(\d.*?)\s*([,\)])")
+
+    @property
+    def _parsed_pkg_info(self):
+        """Parse and cache metadata"""
+        try:
+            return self._pkg_info
+        except AttributeError:
+            metadata = self.get_metadata(self.PKG_INFO)
+            self._pkg_info = email.parser.Parser().parsestr(metadata)
+            return self._pkg_info
+
+    @property
+    def _dep_map(self):
+        try:
+            return self.__dep_map
+        except AttributeError:
+            self.__dep_map = self._compute_dependencies()
+            return self.__dep_map
+
+    def _compute_dependencies(self):
+        """Recompute this distribution's dependencies."""
+        dm = self.__dep_map = {None: []}
+
+        reqs = []
+        # Including any condition expressions
+        for req in self._parsed_pkg_info.get_all('Requires-Dist') or []:
+            reqs.extend(parse_requirements(req))
+
+        def reqs_for_extra(extra):
+            for req in reqs:
+                if not req.marker or req.marker.evaluate({'extra': extra}):
+                    yield req
+
+        common = frozenset(reqs_for_extra(None))
+        dm[None].extend(common)
+
+        for extra in self._parsed_pkg_info.get_all('Provides-Extra') or []:
+            s_extra = safe_extra(extra.strip())
+            dm[s_extra] = list(frozenset(reqs_for_extra(extra)) - common)
+
+        return dm
+
+
+_distributionImpl = {
+    '.egg': Distribution,
+    '.egg-info': EggInfoDistribution,
+    '.dist-info': DistInfoDistribution,
+}
+
+
+def issue_warning(*args, **kw):
+    level = 1
+    g = globals()
+    try:
+        # find the first stack frame that is *not* code in
+        # the pkg_resources module, to use for the warning
+        while sys._getframe(level).f_globals is g:
+            level += 1
+    except ValueError:
+        pass
+    warnings.warn(stacklevel=level + 1, *args, **kw)
+
+
+class RequirementParseError(ValueError):
+    def __str__(self):
+        return ' '.join(self.args)
+
+
+def parse_requirements(strs):
+    """Yield ``Requirement`` objects for each specification in `strs`
+
+    `strs` must be a string, or a (possibly-nested) iterable thereof.
+    """
+    # create a steppable iterator, so we can handle \-continuations
+    lines = iter(yield_lines(strs))
+
+    for line in lines:
+        # Drop comments -- a hash without a space may be in a URL.
+        if ' #' in line:
+            line = line[:line.find(' #')]
+        # If there is a line continuation, drop it, and append the next line.
+        if line.endswith('\\'):
+            line = line[:-2].strip()
+            try:
+                line += next(lines)
+            except StopIteration:
+                return
+        yield Requirement(line)
+
+
+class Requirement(packaging.requirements.Requirement):
+    def __init__(self, requirement_string):
+        """DO NOT CALL THIS UNDOCUMENTED METHOD; use Requirement.parse()!"""
+        try:
+            super(Requirement, self).__init__(requirement_string)
+        except packaging.requirements.InvalidRequirement as e:
+            raise RequirementParseError(str(e))
+        self.unsafe_name = self.name
+        project_name = safe_name(self.name)
+        self.project_name, self.key = project_name, project_name.lower()
+        self.specs = [
+            (spec.operator, spec.version) for spec in self.specifier]
+        self.extras = tuple(map(safe_extra, self.extras))
+        self.hashCmp = (
+            self.key,
+            self.specifier,
+            frozenset(self.extras),
+            str(self.marker) if self.marker else None,
+        )
+        self.__hash = hash(self.hashCmp)
+
+    def __eq__(self, other):
+        return (
+            isinstance(other, Requirement) and
+            self.hashCmp == other.hashCmp
+        )
+
+    def __ne__(self, other):
+        return not self == other
+
+    def __contains__(self, item):
+        if isinstance(item, Distribution):
+            if item.key != self.key:
+                return False
+
+            item = item.version
+
+        # Allow prereleases always in order to match the previous behavior of
+        # this method. In the future this should be smarter and follow PEP 440
+        # more accurately.
+        return self.specifier.contains(item, prereleases=True)
+
+    def __hash__(self):
+        return self.__hash
+
+    def __repr__(self):
+        return "Requirement.parse(%r)" % str(self)
+
+    @staticmethod
+    def parse(s):
+        req, = parse_requirements(s)
+        return req
+
+
+def _always_object(classes):
+    """
+    Ensure object appears in the mro even
+    for old-style classes.
+    """
+    if object not in classes:
+        return classes + (object,)
+    return classes
+
+
+def _find_adapter(registry, ob):
+    """Return an adapter factory for `ob` from `registry`"""
+    types = _always_object(inspect.getmro(getattr(ob, '__class__', type(ob))))
+    for t in types:
+        if t in registry:
+            return registry[t]
+
+
+def ensure_directory(path):
+    """Ensure that the parent directory of `path` exists"""
+    dirname = os.path.dirname(path)
+    py31compat.makedirs(dirname, exist_ok=True)
+
+
+def _bypass_ensure_directory(path):
+    """Sandbox-bypassing version of ensure_directory()"""
+    if not WRITE_SUPPORT:
+        raise IOError('"os.mkdir" not supported on this platform.')
+    dirname, filename = split(path)
+    if dirname and filename and not isdir(dirname):
+        _bypass_ensure_directory(dirname)
+        try:
+            mkdir(dirname, 0o755)
+        except FileExistsError:
+            pass
+
+
+def split_sections(s):
+    """Split a string or iterable thereof into (section, content) pairs
+
+    Each ``section`` is a stripped version of the section header ("[section]")
+    and each ``content`` is a list of stripped lines excluding blank lines and
+    comment-only lines.  If there are any such lines before the first section
+    header, they're returned in a first ``section`` of ``None``.
+    """
+    section = None
+    content = []
+    for line in yield_lines(s):
+        if line.startswith("["):
+            if line.endswith("]"):
+                if section or content:
+                    yield section, content
+                section = line[1:-1].strip()
+                content = []
+            else:
+                raise ValueError("Invalid section heading", line)
+        else:
+            content.append(line)
+
+    # wrap up last segment
+    yield section, content
+
+
+def _mkstemp(*args, **kw):
+    old_open = os.open
+    try:
+        # temporarily bypass sandboxing
+        os.open = os_open
+        return tempfile.mkstemp(*args, **kw)
+    finally:
+        # and then put it back
+        os.open = old_open
+
+
+# Silence the PEP440Warning by default, so that end users don't get hit by it
+# randomly just because they use pkg_resources. We want to append the rule
+# because we want earlier uses of filterwarnings to take precedence over this
+# one.
+warnings.filterwarnings("ignore", category=PEP440Warning, append=True)
+
+
+# from jaraco.functools 1.3
+def _call_aside(f, *args, **kwargs):
+    f(*args, **kwargs)
+    return f
+
+
+@_call_aside
+def _initialize(g=globals()):
+    "Set up global resource manager (deliberately not state-saved)"
+    manager = ResourceManager()
+    g['_manager'] = manager
+    g.update(
+        (name, getattr(manager, name))
+        for name in dir(manager)
+        if not name.startswith('_')
+    )
+
+
+@_call_aside
+def _initialize_master_working_set():
+    """
+    Prepare the master working set and make the ``require()``
+    API available.
+
+    This function has explicit effects on the global state
+    of pkg_resources. It is intended to be invoked once at
+    the initialization of this module.
+
+    Invocation by other packages is unsupported and done
+    at their own risk.
+    """
+    working_set = WorkingSet._build_master()
+    _declare_state('object', working_set=working_set)
+
+    require = working_set.require
+    iter_entry_points = working_set.iter_entry_points
+    add_activation_listener = working_set.subscribe
+    run_script = working_set.run_script
+    # backward compatibility
+    run_main = run_script
+    # Activate all distributions already on sys.path with replace=False and
+    # ensure that all distributions added to the working set in the future
+    # (e.g. by calling ``require()``) will get activated as well,
+    # with higher priority (replace=True).
+    tuple(
+        dist.activate(replace=False)
+        for dist in working_set
+    )
+    add_activation_listener(
+        lambda dist: dist.activate(replace=True),
+        existing=False,
+    )
+    working_set.entries = []
+    # match order
+    list(map(working_set.add_entry, sys.path))
+    globals().update(locals())
+
+class PkgResourcesDeprecationWarning(Warning):
+    """
+    Base class for warning about deprecations in ``pkg_resources``
+
+    This class is not derived from ``DeprecationWarning``, and as such is
+    visible by default.
+    """
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pkg_resources/__init__.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pkg_resources/__init__.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..a696e69d4e3abc3c4d53de63e05f19c628797e43
GIT binary patch
literal 136325
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
VjgyyCij!ZGg_D(;QHYyg9RPka2QmNv

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pkg_resources/_vendor/__init__.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pkg_resources/_vendor/__init__.py
new file mode 100644
index 0000000..e69de29
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pkg_resources/_vendor/__init__.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pkg_resources/_vendor/__init__.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..c0b23a51a9bce3d6a040b2948d7c7107754b61d7
GIT binary patch
literal 207
zcmZSn%**AGdLky70SXuy7#JKF7#NCK7#J8*7#M;zKq7t`AZawBxPpO!LBF6Vvn;VB
zRlh8;NIxw<CndG0SU)L6zdR`^FV{4;*vK%+JiRL2!qlQXC#%ZL00h$W^h5LuG7EGw
z^NLFnb8>Xu$~-)c1N4hiOG*n$^7C_w^$W7o<BL*@^Gl18Q;YTE%Tn`F@{9E2<1_Oz
dOXB183MxxD7#J9Aa`RJ4b5iX<PAmqw5CG!eHb(#e

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pkg_resources/_vendor/appdirs.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pkg_resources/_vendor/appdirs.py
new file mode 100644
index 0000000..ae67001
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pkg_resources/_vendor/appdirs.py
@@ -0,0 +1,608 @@
+#!/usr/bin/env python
+# -*- coding: utf-8 -*-
+# Copyright (c) 2005-2010 ActiveState Software Inc.
+# Copyright (c) 2013 Eddy Petrișor
+
+"""Utilities for determining application-specific dirs.
+
+See <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_info__ = (1, 4, 3)
+__version__ = '.'.join(map(str, __version_info__))
+
+
+import sys
+import os
+
+PY3 = sys.version_info[0] == 3
+
+if PY3:
+    unicode = str
+
+if sys.platform.startswith('java'):
+    import platform
+    os_name = platform.java_ver()[3][0]
+    if os_name.startswith('Windows'): # "Windows XP", "Windows 7", etc.
+        system = 'win32'
+    elif os_name.startswith('Mac'): # "Mac OS X", etc.
+        system = 'darwin'
+    else: # "Linux", "SunOS", "FreeBSD", etc.
+        # Setting this to "linux2" is not ideal, but only Windows or Mac
+        # are actually checked for and the rest of the module expects
+        # *sys.platform* style strings.
+        system = 'linux2'
+else:
+    system = sys.platform
+
+
+
+def user_data_dir(appname=None, appauthor=None, version=None, roaming=False):
+    r"""Return full path to the user-specific data dir for this application.
+
+        "appname" is the name of application.
+            If None, just the system directory is returned.
+        "appauthor" (only used on Windows) is the name of the
+            appauthor or distributing body for this application. Typically
+            it is the owning company name. This falls back to appname. You may
+            pass False to disable it.
+        "version" is an optional version path element to append to the
+            path. You might want to use this if you want multiple versions
+            of your app to be able to run independently. If used, this
+            would typically be "<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>
+        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.sep.join([x, appname]) for x in pathlist]
+
+        if multipath:
+            path = os.pathsep.join(pathlist)
+        else:
+            path = pathlist[0]
+        return path
+
+    if appname and version:
+        path = os.path.join(path, version)
+    return path
+
+
+def user_config_dir(appname=None, appauthor=None, version=None, roaming=False):
+    r"""Return full path to the user-specific config dir for this application.
+
+        "appname" is the name of application.
+            If None, just the system directory is returned.
+        "appauthor" (only used on Windows) is the name of the
+            appauthor or distributing body for this application. Typically
+            it is the owning company name. This falls back to appname. You may
+            pass False to disable it.
+        "version" is an optional version path element to append to the
+            path. You might want to use this if you want multiple versions
+            of your app to be able to run independently. If used, this
+            would typically be "<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
+
+
+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
+        # only first, if multipath is False
+        path = os.getenv('XDG_CONFIG_DIRS', '/etc/xdg')
+        pathlist = [os.path.expanduser(x.rstrip(os.sep)) for x in path.split(os.pathsep)]
+        if appname:
+            if version:
+                appname = os.path.join(appname, version)
+            pathlist = [os.sep.join([x, appname]) for x in pathlist]
+
+        if multipath:
+            path = os.pathsep.join(pathlist)
+        else:
+            path = pathlist[0]
+    return path
+
+
+def user_cache_dir(appname=None, appauthor=None, version=None, opinion=True):
+    r"""Return full path to the user-specific cache dir for this application.
+
+        "appname" is the name of application.
+            If None, just the system directory is returned.
+        "appauthor" (only used on Windows) is the name of the
+            appauthor or distributing body for this application. Typically
+            it is the owning company name. This falls back to appname. You may
+            pass False to disable it.
+        "version" is an optional version path element to append to the
+            path. You might want to use this if you want multiple versions
+            of your app to be able to run independently. If used, this
+            would typically be "<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"))
+        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:
+        import win32com.shell
+        _get_win_folder = _get_win_folder_with_pywin32
+    except ImportError:
+        try:
+            from ctypes import windll
+            _get_win_folder = _get_win_folder_with_ctypes
+        except ImportError:
+            try:
+                import com.sun.jna
+                _get_win_folder = _get_win_folder_with_jna
+            except ImportError:
+                _get_win_folder = _get_win_folder_from_registry
+
+
+#---- self test code
+
+if __name__ == "__main__":
+    appname = "MyApp"
+    appauthor = "MyCompany"
+
+    props = ("user_data_dir",
+             "user_config_dir",
+             "user_cache_dir",
+             "user_state_dir",
+             "user_log_dir",
+             "site_data_dir",
+             "site_config_dir")
+
+    print("-- app dirs %s --" % __version__)
+
+    print("-- app dirs (with optional 'version')")
+    dirs = AppDirs(appname, appauthor, version="1.0")
+    for prop in props:
+        print("%s: %s" % (prop, getattr(dirs, prop)))
+
+    print("\n-- app dirs (without optional 'version')")
+    dirs = AppDirs(appname, appauthor)
+    for prop in props:
+        print("%s: %s" % (prop, getattr(dirs, prop)))
+
+    print("\n-- app dirs (without optional 'appauthor')")
+    dirs = AppDirs(appname)
+    for prop in props:
+        print("%s: %s" % (prop, getattr(dirs, prop)))
+
+    print("\n-- app dirs (with disabled 'appauthor')")
+    dirs = AppDirs(appname, appauthor=False)
+    for prop in props:
+        print("%s: %s" % (prop, getattr(dirs, prop)))
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pkg_resources/_vendor/appdirs.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pkg_resources/_vendor/appdirs.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..1082bca43ad291f24c96e644bcd252ceafc45d1f
GIT binary patch
literal 24415
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

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pkg_resources/_vendor/packaging/__about__.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pkg_resources/_vendor/packaging/__about__.py
new file mode 100644
index 0000000..95d330e
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pkg_resources/_vendor/packaging/__about__.py
@@ -0,0 +1,21 @@
+# This file is dual licensed under the terms of the Apache License, Version
+# 2.0, and the BSD License. See the LICENSE file in the root of this repository
+# for complete details.
+from __future__ import absolute_import, division, print_function
+
+__all__ = [
+    "__title__", "__summary__", "__uri__", "__version__", "__author__",
+    "__email__", "__license__", "__copyright__",
+]
+
+__title__ = "packaging"
+__summary__ = "Core utilities for Python packages"
+__uri__ = "https://github.com/pypa/packaging"
+
+__version__ = "16.8"
+
+__author__ = "Donald Stufft and individual contributors"
+__email__ = "donald@stufft.io"
+
+__license__ = "BSD or Apache License, Version 2.0"
+__copyright__ = "Copyright 2014-2016 %s" % __author__
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pkg_resources/_vendor/packaging/__about__.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pkg_resources/_vendor/packaging/__about__.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..aa8eb368cd9f70c66e2132f8653fd6c2c200b63f
GIT binary patch
literal 846
zcmZSn%**AGdLky70SY)67#JK97#WI-7#J8*7#LC*8FCmHav2$-7#VVz7^0XMa+w*T
zm>C#Tm>5!+8B$mnQdk*M*cejS8B#bHQaBmXIT)f?7*e<xqF5PHxEZ3@7*co`qSzTy
zcp0KN7*hBcqBt2+_!*+O7*YfnqPQ7S1Q}8}8N{M^7*d27f;EI07#K1^ZqZ<7U|=ZW
zXJBAROe)ULDJ@Bj&&(~zFDfYkIWZ-(EVDQ>Kd*$3fq|i*C^N4lKCLt_xdbG{$-ux6
zA77GLl9L)AU&0OM6_@7bCKgr3$Ct2!`K3jfaJjP7B9Kw>@g-bfxx~_vjQpbb_!5Xg
zskw=nIdH`}naQbn#UO)u!HSdf3o45;(=$q->I)K+vlG)Z^U{lz7#J9w^NUgyN=q_x
zGD|X3ixtxHixdJXOEU8F6d>wSi;EQ*7#K22N(zdt^!3v-OEOB6^pf*)^$RKs67?a9
zK!&j}FfbUJ=~)zOGB7Z><mV;kq$mWJl%}PXC?w{kC}ie=0wkq0F-IXeKd+=HGpV#B
zzo@ua02GN})egmA)q0uvV23#cyC~!rDL57+CTFB7_&_|RqYwrO3I!uQgJLnT`=P#5
zFfuSS(KRwKG*eJ5_R|3Q9U59`r6r|Bsqyhaphyd1WME(jVgkh+B%Bj-a^mBIKv5Y4
z@<I?RNS+NufaHTfQ5ggZ<{(heYk-VE5XH?53=H}OMVV!ZC8_#liADNp`8g@6MaB9_
zDf;C}NqM=Zxy43?N#^NQ=@zCI<vCeZW(FXTo~Iw8Uyxa#o0(T!l9-dD>sIFBX&j(m
zoLW*^P?DdYQ><T*ogQD5TAW{6l$=_uA77T5my%zE2ygxP_{60A(vtXiy@E<`g0soZ
iPbtkwwFCL0ScHLrL57*1k)N53k&Tg!iH!+NG6Dejz}A%j

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pkg_resources/_vendor/packaging/__init__.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pkg_resources/_vendor/packaging/__init__.py
new file mode 100644
index 0000000..5ee6220
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pkg_resources/_vendor/packaging/__init__.py
@@ -0,0 +1,14 @@
+# This file is dual licensed under the terms of the Apache License, Version
+# 2.0, and the BSD License. See the LICENSE file in the root of this repository
+# for complete details.
+from __future__ import absolute_import, division, print_function
+
+from .__about__ import (
+    __author__, __copyright__, __email__, __license__, __summary__, __title__,
+    __uri__, __version__
+)
+
+__all__ = [
+    "__title__", "__summary__", "__uri__", "__version__", "__author__",
+    "__email__", "__license__", "__copyright__",
+]
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pkg_resources/_vendor/packaging/__init__.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pkg_resources/_vendor/packaging/__init__.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..f9c46a333f275ee75724a980c8b49ca766f5524f
GIT binary patch
literal 668
zcmZSn%**AGdLky70SY)67#JK97#WHy7#J8*7#LC*8FCmHav2$-7#VVz7^0XMa+w*T
zm>C#Tm>5!+8FE+{a#<OoSQ&EJ7^2u1a@iT8*coy;7@{~Bayc2II2m%e7^1isa=96z
zxEXSJ7@~L>7*kjnQdk*M*cejS8B#bHQaBk>xENBn8PYizqIelnco>2;co`TNGC?lV
zU}j)oDB)*dU`R|V&d(_=NsZ6UEyyn_DFHb&C9^EEI5R)5gpYxNp`a);uOvRLG%vX%
zGe0krk%56h1Ei>gi-Cb5K0dLuBqP5lKE4EGc6@wtenDkXW_m_Re0&KfSV3xTVrEW!
zd<i$0my?;Cnpd0(=NFge<|Y<Z!c~`KmgInB*}<wyi!$LV%TkL#Zi<f&0@)q}QV;~P
zAqeD-Adr88SQ!`?g4jR=3j+g#p9aYJP-mu<mXsEy#>WSNd>;hzL=Y1w2tX#p$0sJ`
zmzKoGLrekbMKTI(5!gzQTCi;;AhG!P#GIV?cny$&2%@-&fq_B4peVB}u_RT$EU`#G
zEk7qEwWwG>DMi0LDJd`4G`HBuFv&c<D&4}=qC6+7%FF-+()08~^b0ZzbTjjcOA>Q(
zblu84JdFeNi&INV3rh0ybBgr~veV;>Qj7CTi;`1|_2bJ@^HTDQ^a~P`vlG)Z^V0R>
k<1_OzOXB183M#?TXp@_tQks)$2l7xcC|G2etl0P&0SjxC%m4rY

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pkg_resources/_vendor/packaging/_compat.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pkg_resources/_vendor/packaging/_compat.py
new file mode 100644
index 0000000..210bb80
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pkg_resources/_vendor/packaging/_compat.py
@@ -0,0 +1,30 @@
+# This file is dual licensed under the terms of the Apache License, Version
+# 2.0, and the BSD License. See the LICENSE file in the root of this repository
+# for complete details.
+from __future__ import absolute_import, division, print_function
+
+import sys
+
+
+PY2 = sys.version_info[0] == 2
+PY3 = sys.version_info[0] == 3
+
+# flake8: noqa
+
+if PY3:
+    string_types = str,
+else:
+    string_types = basestring,
+
+
+def with_metaclass(meta, *bases):
+    """
+    Create a base class with a metaclass.
+    """
+    # This requires a bit of explanation: the basic idea is to make a dummy
+    # metaclass for one level of class instantiation that replaces itself with
+    # the actual metaclass.
+    class metaclass(meta):
+        def __new__(cls, name, this_bases, d):
+            return meta(name, bases, d)
+    return type.__new__(metaclass, 'temporary_class', (), {})
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pkg_resources/_vendor/packaging/_compat.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pkg_resources/_vendor/packaging/_compat.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..d1bd737b5990b5d4ad7cdfed3a73854b37093a0e
GIT binary patch
literal 1472
zcmZSn%**AGdLky70ScHH7#JK97#WJo7#J8*7#LC*8FCmHav2$-7#VVz7^0XMa+w*T
zm>C#Ba!d?4EDTXB45=&(S*#${k}1p#*-Q*kY{)_^U?FyfRCb1<1cp=&hBQWoC{Bhv
zPKH!2C_9Cfp@o4Vikl&Yi6K~nje&t76XYHZW(Ed^5`G2-hQy@e{G8H~)cDNYg8ZVA
z5)P2-GRrcHGxPIG_!t-%3W_rGO5)Q>^O8$4^Yi>NLH@`DX-{TkU|;|-SQ!`?*g-xs
z1?gpE=wJj{-p;_#&d89)1hTn}fuWg!A+nZ<p@e}Ui;<y*i6MoVA%z9xm}VA+U=5HF
z#rg~k3|tBd3JT6esfi`23W*9yiN&c3$vKI|#R}z_B^e5d3c0BziC_Ueu*won1_lPW
z7)n?(fm|fTz`&5o019G+a~K%f7(l@t6s!UAK{5*i0|N{TgER>+Fo66}!^qIVz)-`?
z(9FyLQR=4w4m*(I5|GD}bBaqqoV>)`)DkXGh-PFK$AcVQTmmvWMFSLAB_Pj11VM^H
zt_7P@+{nPdpkGjwS(aFms$Z5^q@R|blag9gte=#kU!Ihdmus3^Y-E^Zo?ex1VQNvH
zlT~GA00QZG`XTxSnFYF;dBr7(IXSv+Wgec!0s6(MC8Y%=`T04;`UTnP@kOb{`K3k4
zsm1#7WvO{7`9=B#iOJcC>6v-y`tiy6xdn+OdIgmw><kPH@$q@7<?-<{3=9m#ASW|0
zLJ|llF~rA%ycZu2_F#N`ZhlH>PHKF75Xiq^e}Fw11X3CViVd*X;P6`zD3YXMo?>GJ
zC-{<7P(n{Es*DGxBd~M9UI0gBNo7GQ#A_hEU=KmO2I3;rLc~Dc9UMLd=TuM@i3cSw
zu*XC|{stvD26lO74IWVH1VveVd|GKqX%Q#}L5VpClum;{aSl$=#g)Y+Af;ugMW6y8
zJ~J;ZA1o0NX#}N>!E|v+5m;eyNl|8AdORrDioq!alF&hdL7?IV5@aBoz^p+MTA;*g
c14+qtpdcy+6?8I8Jj}w3!YpizJWQO-0N(my5dZ)H

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pkg_resources/_vendor/packaging/_structures.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pkg_resources/_vendor/packaging/_structures.py
new file mode 100644
index 0000000..ccc2786
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pkg_resources/_vendor/packaging/_structures.py
@@ -0,0 +1,68 @@
+# This file is dual licensed under the terms of the Apache License, Version
+# 2.0, and the BSD License. See the LICENSE file in the root of this repository
+# for complete details.
+from __future__ import absolute_import, division, print_function
+
+
+class Infinity(object):
+
+    def __repr__(self):
+        return "Infinity"
+
+    def __hash__(self):
+        return hash(repr(self))
+
+    def __lt__(self, other):
+        return False
+
+    def __le__(self, other):
+        return False
+
+    def __eq__(self, other):
+        return isinstance(other, self.__class__)
+
+    def __ne__(self, other):
+        return not isinstance(other, self.__class__)
+
+    def __gt__(self, other):
+        return True
+
+    def __ge__(self, other):
+        return True
+
+    def __neg__(self):
+        return NegativeInfinity
+
+Infinity = Infinity()
+
+
+class NegativeInfinity(object):
+
+    def __repr__(self):
+        return "-Infinity"
+
+    def __hash__(self):
+        return hash(repr(self))
+
+    def __lt__(self, other):
+        return True
+
+    def __le__(self, other):
+        return True
+
+    def __eq__(self, other):
+        return isinstance(other, self.__class__)
+
+    def __ne__(self, other):
+        return not isinstance(other, self.__class__)
+
+    def __gt__(self, other):
+        return False
+
+    def __ge__(self, other):
+        return False
+
+    def __neg__(self):
+        return Infinity
+
+NegativeInfinity = NegativeInfinity()
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pkg_resources/_vendor/packaging/_structures.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pkg_resources/_vendor/packaging/_structures.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..ab726244413278feed27629b90741fee79442887
GIT binary patch
literal 5370
zcmZSn%**AGdLky70ScHI7#JK97#WJ=7#J8*7#LC*8FCmHav2$-7#VVz7^0XMa+w*T
zm>C#Tm>5!77}6LSQkWT97#Nxv7$T!s8B$q6tSDB76c(5?D_ok5A(ag*&Bl<z#t^K*
z&cMKs39?rMWNQgO0|P^1QgMDxX-R5)W^O@#QAr60$Q7AonZ=p;c_n-d3=9QDnRzAg
zX{C9|B_JV?yk}loW?p7VCEO2;3=9lTAU{MhFfgPtfSjJf0CGhX6UaX;3?L7rFo8u_
zpzen_86?HVkOFpc6g$Y3AQ29R6n3y;PKFc?FoTOBC|HA&fq@|zWETuOgY0AhxtNh5
zSc8dyfx#~b<TDMhA3>^0K(fWDIcX3fka%$`0|SG8K~ZK|Vo9ogSz?iXT7FJSYEiL%
zQi^_gQc_;7X>PHRVUl@zRl0?#MR`tEm6-tur03~}=oe%b=w{{>mn7!o=(?48cp3-j
z7pIn#7L?@Y=M?J~WT(d$r55Lx7A2<^>&KU+=B4Bp=@%p>XD6m-=B4Y$7nc;3CYO{J
zr55WIRDuILKE5cmpeQ~b<hf#y7Z@1fegydi>_-6x28I#_h7v}G8U}`DMi2_t0Qt`k
z>}#+uGZKq4zzmRiV96km=LfOJK`xGu=V4%AfO#C`e-H+F4eW7{4@wvqV4ekum#{K0
zFt{b=6sLmy4)!EiEWacpwP;X!myLmeAwE8*Bt9OL<w)^t5GMlz1Hzv{Tp%te6@&db
zh>|kYi>dMPLRjJxJt5aHf)a8TBSSM2JZ?epUIOx8W-&N}<t3+<aDoFaIVZ8WI6i*p
z1Vd_Je7q>WU=W1lXXIeufu(U!I0W%BFfasxir=B*>AckVcnK_?2IX0tc^Q<yLyAg~
zvhrY0;^`&v@zNxEGYAylLnkKFQ{&_1kh}<rK^Vpvlb|ZfFEu@}B(p3P)<78KwGgN|
z6d#|LnjRmoi14lkHz;$0+Bxy@d5O8H@$ukNDLy_oKczG$H9kHFQ~?En6a;~k27xND
zAW*>`1PX&7Q27@m49dTtA^==YBZ$FMVuKq>pb#hqIhc)!lNl8TiGW&LpsEIhLD4@*
zT6o2vN<kN%#6Yea-02LQUNjL2jO6BB5U6qu0>#xJ_b4b&=pcC%RF#1+DD~hfIEG5u
z2+r&J!_{-3GRz2z=ZI~%4XFkTxUe?G=UY&HUBbXHJlbdAYRLkNckyORP$@eEnk?Yz
z)_S;l4%CdWL-HIb#$Xs{feOmAgS?^uwTv7Q{sK3-g2X^=CUFokJQ`S_29!F;lh_+r
ze&FFaXxlQa6f`IlA0Gs2&IEy?I0#g6mVj#h{G_bZ<Pvau4csV0v?jr<!PBG!k7wCH
Wn#p#co?S7hK_J5{Cd<hzCJO)s&L+?R

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pkg_resources/_vendor/packaging/markers.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pkg_resources/_vendor/packaging/markers.py
new file mode 100644
index 0000000..892e578
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pkg_resources/_vendor/packaging/markers.py
@@ -0,0 +1,301 @@
+# This file is dual licensed under the terms of the Apache License, Version
+# 2.0, and the BSD License. See the LICENSE file in the root of this repository
+# for complete details.
+from __future__ import absolute_import, division, print_function
+
+import operator
+import os
+import platform
+import sys
+
+from pkg_resources.extern.pyparsing import ParseException, ParseResults, stringStart, stringEnd
+from pkg_resources.extern.pyparsing import ZeroOrMore, Group, Forward, QuotedString
+from pkg_resources.extern.pyparsing import Literal as L  # noqa
+
+from ._compat import string_types
+from .specifiers import Specifier, InvalidSpecifier
+
+
+__all__ = [
+    "InvalidMarker", "UndefinedComparison", "UndefinedEnvironmentName",
+    "Marker", "default_environment",
+]
+
+
+class InvalidMarker(ValueError):
+    """
+    An invalid marker was found, users should refer to PEP 508.
+    """
+
+
+class UndefinedComparison(ValueError):
+    """
+    An invalid operation was attempted on a value that doesn't support it.
+    """
+
+
+class UndefinedEnvironmentName(ValueError):
+    """
+    A name was attempted to be used that does not exist inside of the
+    environment.
+    """
+
+
+class Node(object):
+
+    def __init__(self, value):
+        self.value = value
+
+    def __str__(self):
+        return str(self.value)
+
+    def __repr__(self):
+        return "<{0}({1!r})>".format(self.__class__.__name__, str(self))
+
+    def serialize(self):
+        raise NotImplementedError
+
+
+class Variable(Node):
+
+    def serialize(self):
+        return str(self)
+
+
+class Value(Node):
+
+    def serialize(self):
+        return '"{0}"'.format(self)
+
+
+class Op(Node):
+
+    def serialize(self):
+        return str(self)
+
+
+VARIABLE = (
+    L("implementation_version") |
+    L("platform_python_implementation") |
+    L("implementation_name") |
+    L("python_full_version") |
+    L("platform_release") |
+    L("platform_version") |
+    L("platform_machine") |
+    L("platform_system") |
+    L("python_version") |
+    L("sys_platform") |
+    L("os_name") |
+    L("os.name") |  # PEP-345
+    L("sys.platform") |  # PEP-345
+    L("platform.version") |  # PEP-345
+    L("platform.machine") |  # PEP-345
+    L("platform.python_implementation") |  # PEP-345
+    L("python_implementation") |  # undocumented setuptools legacy
+    L("extra")
+)
+ALIASES = {
+    'os.name': 'os_name',
+    'sys.platform': 'sys_platform',
+    'platform.version': 'platform_version',
+    'platform.machine': 'platform_machine',
+    'platform.python_implementation': 'platform_python_implementation',
+    'python_implementation': 'platform_python_implementation'
+}
+VARIABLE.setParseAction(lambda s, l, t: Variable(ALIASES.get(t[0], t[0])))
+
+VERSION_CMP = (
+    L("===") |
+    L("==") |
+    L(">=") |
+    L("<=") |
+    L("!=") |
+    L("~=") |
+    L(">") |
+    L("<")
+)
+
+MARKER_OP = VERSION_CMP | L("not in") | L("in")
+MARKER_OP.setParseAction(lambda s, l, t: Op(t[0]))
+
+MARKER_VALUE = QuotedString("'") | QuotedString('"')
+MARKER_VALUE.setParseAction(lambda s, l, t: Value(t[0]))
+
+BOOLOP = L("and") | L("or")
+
+MARKER_VAR = VARIABLE | MARKER_VALUE
+
+MARKER_ITEM = Group(MARKER_VAR + MARKER_OP + MARKER_VAR)
+MARKER_ITEM.setParseAction(lambda s, l, t: tuple(t[0]))
+
+LPAREN = L("(").suppress()
+RPAREN = L(")").suppress()
+
+MARKER_EXPR = Forward()
+MARKER_ATOM = MARKER_ITEM | Group(LPAREN + MARKER_EXPR + RPAREN)
+MARKER_EXPR << MARKER_ATOM + ZeroOrMore(BOOLOP + MARKER_EXPR)
+
+MARKER = stringStart + MARKER_EXPR + stringEnd
+
+
+def _coerce_parse_result(results):
+    if isinstance(results, ParseResults):
+        return [_coerce_parse_result(i) for i in results]
+    else:
+        return results
+
+
+def _format_marker(marker, first=True):
+    assert isinstance(marker, (list, tuple, string_types))
+
+    # Sometimes we have a structure like [[...]] which is a single item list
+    # where the single item is itself it's own list. In that case we want skip
+    # the rest of this function so that we don't get extraneous () on the
+    # outside.
+    if (isinstance(marker, list) and len(marker) == 1 and
+            isinstance(marker[0], (list, tuple))):
+        return _format_marker(marker[0])
+
+    if isinstance(marker, list):
+        inner = (_format_marker(m, first=False) for m in marker)
+        if first:
+            return " ".join(inner)
+        else:
+            return "(" + " ".join(inner) + ")"
+    elif isinstance(marker, tuple):
+        return " ".join([m.serialize() for m in marker])
+    else:
+        return marker
+
+
+_operators = {
+    "in": lambda lhs, rhs: lhs in rhs,
+    "not in": lambda lhs, rhs: lhs not in rhs,
+    "<": operator.lt,
+    "<=": operator.le,
+    "==": operator.eq,
+    "!=": operator.ne,
+    ">=": operator.ge,
+    ">": operator.gt,
+}
+
+
+def _eval_op(lhs, op, rhs):
+    try:
+        spec = Specifier("".join([op.serialize(), rhs]))
+    except InvalidSpecifier:
+        pass
+    else:
+        return spec.contains(lhs)
+
+    oper = _operators.get(op.serialize())
+    if oper is None:
+        raise UndefinedComparison(
+            "Undefined {0!r} on {1!r} and {2!r}.".format(op, lhs, rhs)
+        )
+
+    return oper(lhs, rhs)
+
+
+_undefined = object()
+
+
+def _get_env(environment, name):
+    value = environment.get(name, _undefined)
+
+    if value is _undefined:
+        raise UndefinedEnvironmentName(
+            "{0!r} does not exist in evaluation environment.".format(name)
+        )
+
+    return value
+
+
+def _evaluate_markers(markers, environment):
+    groups = [[]]
+
+    for marker in markers:
+        assert isinstance(marker, (list, tuple, string_types))
+
+        if isinstance(marker, list):
+            groups[-1].append(_evaluate_markers(marker, environment))
+        elif isinstance(marker, tuple):
+            lhs, op, rhs = marker
+
+            if isinstance(lhs, Variable):
+                lhs_value = _get_env(environment, lhs.value)
+                rhs_value = rhs.value
+            else:
+                lhs_value = lhs.value
+                rhs_value = _get_env(environment, rhs.value)
+
+            groups[-1].append(_eval_op(lhs_value, op, rhs_value))
+        else:
+            assert marker in ["and", "or"]
+            if marker == "or":
+                groups.append([])
+
+    return any(all(item) for item in groups)
+
+
+def format_full_version(info):
+    version = '{0.major}.{0.minor}.{0.micro}'.format(info)
+    kind = info.releaselevel
+    if kind != 'final':
+        version += kind[0] + str(info.serial)
+    return version
+
+
+def default_environment():
+    if hasattr(sys, 'implementation'):
+        iver = format_full_version(sys.implementation.version)
+        implementation_name = sys.implementation.name
+    else:
+        iver = '0'
+        implementation_name = ''
+
+    return {
+        "implementation_name": implementation_name,
+        "implementation_version": iver,
+        "os_name": os.name,
+        "platform_machine": platform.machine(),
+        "platform_release": platform.release(),
+        "platform_system": platform.system(),
+        "platform_version": platform.version(),
+        "python_full_version": platform.python_version(),
+        "platform_python_implementation": platform.python_implementation(),
+        "python_version": platform.python_version()[:3],
+        "sys_platform": sys.platform,
+    }
+
+
+class Marker(object):
+
+    def __init__(self, marker):
+        try:
+            self._markers = _coerce_parse_result(MARKER.parseString(marker))
+        except ParseException as e:
+            err_str = "Invalid marker: {0!r}, parse error at {1!r}".format(
+                marker, marker[e.loc:e.loc + 8])
+            raise InvalidMarker(err_str)
+
+    def __str__(self):
+        return _format_marker(self._markers)
+
+    def __repr__(self):
+        return "<Marker({0!r})>".format(str(self))
+
+    def evaluate(self, environment=None):
+        """Evaluate a marker.
+
+        Return the boolean from evaluating the given marker against the
+        environment. environment is an optional argument to override all or
+        part of the determined environment.
+
+        The environment is determined from the current Python process.
+        """
+        current_environment = default_environment()
+        if environment is not None:
+            current_environment.update(environment)
+
+        return _evaluate_markers(self._markers, current_environment)
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pkg_resources/_vendor/packaging/markers.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pkg_resources/_vendor/packaging/markers.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..7f36b3683d135b5154dfa47ec0da8bd7cf76f75e
GIT binary patch
literal 13962
zcmZSn%**AGdLky70SZ_d7#JK97#WI7Sr`~n7#LC*8FCmHav2$-7#VVz7^0XMa+w*T
zm>C#Ba!d?4EDTXBV0BCkIjjs(tS~kkLlhf~&CU?T4rVhm<Zv+Laxz45GUReGL~$|X
zax+A6Gvx9xMDajOWC5$-Wr*Ts$mL^*;$z6=XNclw$Q59S5`d^+1*;Hbh!SF8Okrb4
zVQ0t@X2=y`h!TPDIT&(88FIxKqQn?-#TlZ+85mPI8B(|yQn(pXco<T68PZu9q9hnn
zI2lqU8PXUTQur8J7#Nxv7$T#jK<c2P{BTiekXERu09;gtAw`fORTgZ55L{G_Aw`%W
zRSqmF0vDBMND+mJiorz{7*fPxq7raXMTS%%h7?JLW=1eW3dC>%2}#3QGH{kGoFxZm
z$-`L+aF!yRr37aw!&xeDmMWa324|_mSsHMbCY+@OW<@D6WU?`&C^Mv}Fqow%F{G$6
zn5D=uq^L2NrN}d+s56+QNHL^nKqyTHvnXYTR3(Ni6^0aTu*Vr07(rgt0T~8j=z<tv
zU+ckH`f!#3oMi}S8Npe`U{;hWL#iq`1Wmwvkg29%R+Jh;sv6jCGq~LX3@PRy$y5P`
z6blf;DN3CoRUNF#60S;!A;k(L2{OwX#Bhqz0Qn<Toxv$elOdIlAypG(ws@*0gLpF|
zLzEUnsutJ`8)P$VL0Yr4K}jx32kb;UBoSSPRDQ6O9!N9DOdW<)JqGbqU9g!>QTiZm
zsy;(1FGH#Zhz+tz+>SAo8_Y@NVGxfpU`VkCSs7)>kZQz`;=s_t$Pi`BkjcT2;s_E?
zF=a4IaRReU7|c>x7_v+lQj8%iQ-&0M2+NEiMHj*{XGk%Cuq+r-^dKxth7=<PvnVTu
z6lah@QP!Z`(9FOPWy6r-0v54lNO1)->=;tqzzlna6n8Mg0hAY^xyJ(}0?vPq3@J<u
z!5W?n3=El|;z)y;fq|ifpMilPF{wB|r?ezBJ~Ou<zo?{ygMon|C9^EEI5R)5gpYxN
zp`a);uOvRLG%vX%Ge6Hyg9W4$BoUBURGjKsk(^opk|^O}U|;|X1*I03=9Cnda5FG4
z6qgib=A{RhBo>vFaKibnc_|QMxEL51qEd_U{fm6_i&9HKC8T>%erZ7oI|BoQTYgb_
zVo?g%;K0)SlGK!7uxT2MAQymC_+*x(7A59nf&?I<AV)y#j4!DyNG;Z20;vVr99)o^
zoSBxHT2vyyz`)>{SC*KQnSv1HMF{#P7G<Xvl?XF1Fofo%q^4!&rKULN=N2RuWfte>
zl}I3qyXKW;7Uk#VrskFSCFZ7<urV+&An8v@O-n4zDTz--D1%oAAV)iassm71rZRwP
zffNQ%Ef5q8_DiuV0|Nt>f`WpAW1d1L#Jvi+V7DohCl)KD<(KBA=qQvHrxq0}6ldg@
z=A<YTrKY78DU{?Z1h@t$m>O8<f%QWo8x*ne@p*~4sqyh8pn#8$&&^LM%>i*iff*m4
zlAjzOuK`XTaH6=8fq_B4peVB}u_RT$EU`#GEk7qEwWwG>DMi0LDJd`4G`HBuFv&c<
zD&4}=qC6+7%FF-+()08~^b0ZzbTjjcOA>Q(blu84JdFeNi&INV3rh0ybBgr~veV;>
zQj7CTi;`1|_2bJ@^HTDQ^a~P`vlG)Z^V0Ppo-NiZs0;$7R7p_!0mUa9Gx32KfF%&~
z3sQ>`L1`8oj)^5DsksFusVNHic?yXNWr;bZsR|_-i6sgt`KiTu>Lm)rr3Ij@p^#aE
z6rMpM3=9lGq98(yfq`Lg1{)};%aapqG4Nnh0HqkTfGWvXNJ<5zyc9%0DdgpsD5O?o
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

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pkg_resources/_vendor/packaging/requirements.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pkg_resources/_vendor/packaging/requirements.py
new file mode 100644
index 0000000..0c8c4a3
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pkg_resources/_vendor/packaging/requirements.py
@@ -0,0 +1,127 @@
+# This file is dual licensed under the terms of the Apache License, Version
+# 2.0, and the BSD License. See the LICENSE file in the root of this repository
+# for complete details.
+from __future__ import absolute_import, division, print_function
+
+import string
+import re
+
+from pkg_resources.extern.pyparsing import stringStart, stringEnd, originalTextFor, ParseException
+from pkg_resources.extern.pyparsing import ZeroOrMore, Word, Optional, Regex, Combine
+from pkg_resources.extern.pyparsing import Literal as L  # noqa
+from pkg_resources.extern.six.moves.urllib import parse as urlparse
+
+from .markers import MARKER_EXPR, Marker
+from .specifiers import LegacySpecifier, Specifier, SpecifierSet
+
+
+class InvalidRequirement(ValueError):
+    """
+    An invalid requirement was found, users should refer to PEP 508.
+    """
+
+
+ALPHANUM = Word(string.ascii_letters + string.digits)
+
+LBRACKET = L("[").suppress()
+RBRACKET = L("]").suppress()
+LPAREN = L("(").suppress()
+RPAREN = L(")").suppress()
+COMMA = L(",").suppress()
+SEMICOLON = L(";").suppress()
+AT = L("@").suppress()
+
+PUNCTUATION = Word("-_.")
+IDENTIFIER_END = ALPHANUM | (ZeroOrMore(PUNCTUATION) + ALPHANUM)
+IDENTIFIER = Combine(ALPHANUM + ZeroOrMore(IDENTIFIER_END))
+
+NAME = IDENTIFIER("name")
+EXTRA = IDENTIFIER
+
+URI = Regex(r'[^ ]+')("url")
+URL = (AT + URI)
+
+EXTRAS_LIST = EXTRA + ZeroOrMore(COMMA + EXTRA)
+EXTRAS = (LBRACKET + Optional(EXTRAS_LIST) + RBRACKET)("extras")
+
+VERSION_PEP440 = Regex(Specifier._regex_str, re.VERBOSE | re.IGNORECASE)
+VERSION_LEGACY = Regex(LegacySpecifier._regex_str, re.VERBOSE | re.IGNORECASE)
+
+VERSION_ONE = VERSION_PEP440 ^ VERSION_LEGACY
+VERSION_MANY = Combine(VERSION_ONE + ZeroOrMore(COMMA + VERSION_ONE),
+                       joinString=",", adjacent=False)("_raw_spec")
+_VERSION_SPEC = Optional(((LPAREN + VERSION_MANY + RPAREN) | VERSION_MANY))
+_VERSION_SPEC.setParseAction(lambda s, l, t: t._raw_spec or '')
+
+VERSION_SPEC = originalTextFor(_VERSION_SPEC)("specifier")
+VERSION_SPEC.setParseAction(lambda s, l, t: t[1])
+
+MARKER_EXPR = originalTextFor(MARKER_EXPR())("marker")
+MARKER_EXPR.setParseAction(
+    lambda s, l, t: Marker(s[t._original_start:t._original_end])
+)
+MARKER_SEPERATOR = SEMICOLON
+MARKER = MARKER_SEPERATOR + MARKER_EXPR
+
+VERSION_AND_MARKER = VERSION_SPEC + Optional(MARKER)
+URL_AND_MARKER = URL + Optional(MARKER)
+
+NAMED_REQUIREMENT = \
+    NAME + Optional(EXTRAS) + (URL_AND_MARKER | VERSION_AND_MARKER)
+
+REQUIREMENT = stringStart + NAMED_REQUIREMENT + stringEnd
+
+
+class Requirement(object):
+    """Parse a requirement.
+
+    Parse a given requirement string into its parts, such as name, specifier,
+    URL, and extras. Raises InvalidRequirement on a badly-formed requirement
+    string.
+    """
+
+    # TODO: Can we test whether something is contained within a requirement?
+    #       If so how do we do that? Do we need to test against the _name_ of
+    #       the thing as well as the version? What about the markers?
+    # TODO: Can we normalize the name and extra name?
+
+    def __init__(self, requirement_string):
+        try:
+            req = REQUIREMENT.parseString(requirement_string)
+        except ParseException as e:
+            raise InvalidRequirement(
+                "Invalid requirement, parse error at \"{0!r}\"".format(
+                    requirement_string[e.loc:e.loc + 8]))
+
+        self.name = req.name
+        if req.url:
+            parsed_url = urlparse.urlparse(req.url)
+            if not (parsed_url.scheme and parsed_url.netloc) or (
+                    not parsed_url.scheme and not parsed_url.netloc):
+                raise InvalidRequirement("Invalid URL given")
+            self.url = req.url
+        else:
+            self.url = None
+        self.extras = set(req.extras.asList() if req.extras else [])
+        self.specifier = SpecifierSet(req.specifier)
+        self.marker = req.marker if req.marker else None
+
+    def __str__(self):
+        parts = [self.name]
+
+        if self.extras:
+            parts.append("[{0}]".format(",".join(sorted(self.extras))))
+
+        if self.specifier:
+            parts.append(str(self.specifier))
+
+        if self.url:
+            parts.append("@ {0}".format(self.url))
+
+        if self.marker:
+            parts.append("; {0}".format(self.marker))
+
+        return "".join(parts)
+
+    def __repr__(self):
+        return "<Requirement({0!r})>".format(str(self))
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pkg_resources/_vendor/packaging/requirements.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pkg_resources/_vendor/packaging/requirements.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..dbf0df8ef9b1ea21b2ea9140bd154bf0e98ef2fe
GIT binary patch
literal 5683
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

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pkg_resources/_vendor/packaging/specifiers.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pkg_resources/_vendor/packaging/specifiers.py
new file mode 100644
index 0000000..7f5a76c
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pkg_resources/_vendor/packaging/specifiers.py
@@ -0,0 +1,774 @@
+# This file is dual licensed under the terms of the Apache License, Version
+# 2.0, and the BSD License. See the LICENSE file in the root of this repository
+# for complete details.
+from __future__ import absolute_import, division, print_function
+
+import abc
+import functools
+import itertools
+import re
+
+from ._compat import string_types, with_metaclass
+from .version import Version, LegacyVersion, parse
+
+
+class InvalidSpecifier(ValueError):
+    """
+    An invalid specifier was found, users should refer to PEP 440.
+    """
+
+
+class BaseSpecifier(with_metaclass(abc.ABCMeta, object)):
+
+    @abc.abstractmethod
+    def __str__(self):
+        """
+        Returns the str representation of this Specifier like object. This
+        should be representative of the Specifier itself.
+        """
+
+    @abc.abstractmethod
+    def __hash__(self):
+        """
+        Returns a hash value for this Specifier like object.
+        """
+
+    @abc.abstractmethod
+    def __eq__(self, other):
+        """
+        Returns a boolean representing whether or not the two Specifier like
+        objects are equal.
+        """
+
+    @abc.abstractmethod
+    def __ne__(self, other):
+        """
+        Returns a boolean representing whether or not the two Specifier like
+        objects are not equal.
+        """
+
+    @abc.abstractproperty
+    def prereleases(self):
+        """
+        Returns whether or not pre-releases as a whole are allowed by this
+        specifier.
+        """
+
+    @prereleases.setter
+    def prereleases(self, value):
+        """
+        Sets whether or not pre-releases as a whole are allowed by this
+        specifier.
+        """
+
+    @abc.abstractmethod
+    def contains(self, item, prereleases=None):
+        """
+        Determines if the given item is contained within this specifier.
+        """
+
+    @abc.abstractmethod
+    def filter(self, iterable, prereleases=None):
+        """
+        Takes an iterable of items and filters them so that only items which
+        are contained within this specifier are allowed in it.
+        """
+
+
+class _IndividualSpecifier(BaseSpecifier):
+
+    _operators = {}
+
+    def __init__(self, spec="", prereleases=None):
+        match = self._regex.search(spec)
+        if not match:
+            raise InvalidSpecifier("Invalid specifier: '{0}'".format(spec))
+
+        self._spec = (
+            match.group("operator").strip(),
+            match.group("version").strip(),
+        )
+
+        # Store whether or not this Specifier should accept prereleases
+        self._prereleases = prereleases
+
+    def __repr__(self):
+        pre = (
+            ", prereleases={0!r}".format(self.prereleases)
+            if self._prereleases is not None
+            else ""
+        )
+
+        return "<{0}({1!r}{2})>".format(
+            self.__class__.__name__,
+            str(self),
+            pre,
+        )
+
+    def __str__(self):
+        return "{0}{1}".format(*self._spec)
+
+    def __hash__(self):
+        return hash(self._spec)
+
+    def __eq__(self, other):
+        if isinstance(other, string_types):
+            try:
+                other = self.__class__(other)
+            except InvalidSpecifier:
+                return NotImplemented
+        elif not isinstance(other, self.__class__):
+            return NotImplemented
+
+        return self._spec == other._spec
+
+    def __ne__(self, other):
+        if isinstance(other, string_types):
+            try:
+                other = self.__class__(other)
+            except InvalidSpecifier:
+                return NotImplemented
+        elif not isinstance(other, self.__class__):
+            return NotImplemented
+
+        return self._spec != other._spec
+
+    def _get_operator(self, op):
+        return getattr(self, "_compare_{0}".format(self._operators[op]))
+
+    def _coerce_version(self, version):
+        if not isinstance(version, (LegacyVersion, Version)):
+            version = parse(version)
+        return version
+
+    @property
+    def operator(self):
+        return self._spec[0]
+
+    @property
+    def version(self):
+        return self._spec[1]
+
+    @property
+    def prereleases(self):
+        return self._prereleases
+
+    @prereleases.setter
+    def prereleases(self, value):
+        self._prereleases = value
+
+    def __contains__(self, item):
+        return self.contains(item)
+
+    def contains(self, item, prereleases=None):
+        # Determine if prereleases are to be allowed or not.
+        if prereleases is None:
+            prereleases = self.prereleases
+
+        # Normalize item to a Version or LegacyVersion, this allows us to have
+        # a shortcut for ``"2.0" in Specifier(">=2")
+        item = self._coerce_version(item)
+
+        # Determine if we should be supporting prereleases in this specifier
+        # or not, if we do not support prereleases than we can short circuit
+        # logic if this version is a prereleases.
+        if item.is_prerelease and not prereleases:
+            return False
+
+        # Actually do the comparison to determine if this item is contained
+        # within this Specifier or not.
+        return self._get_operator(self.operator)(item, self.version)
+
+    def filter(self, iterable, prereleases=None):
+        yielded = False
+        found_prereleases = []
+
+        kw = {"prereleases": prereleases if prereleases is not None else True}
+
+        # Attempt to iterate over all the values in the iterable and if any of
+        # them match, yield them.
+        for version in iterable:
+            parsed_version = self._coerce_version(version)
+
+            if self.contains(parsed_version, **kw):
+                # If our version is a prerelease, and we were not set to allow
+                # prereleases, then we'll store it for later incase nothing
+                # else matches this specifier.
+                if (parsed_version.is_prerelease and not
+                        (prereleases or self.prereleases)):
+                    found_prereleases.append(version)
+                # Either this is not a prerelease, or we should have been
+                # accepting prereleases from the begining.
+                else:
+                    yielded = True
+                    yield version
+
+        # Now that we've iterated over everything, determine if we've yielded
+        # any values, and if we have not and we have any prereleases stored up
+        # then we will go ahead and yield the prereleases.
+        if not yielded and found_prereleases:
+            for version in found_prereleases:
+                yield version
+
+
+class LegacySpecifier(_IndividualSpecifier):
+
+    _regex_str = (
+        r"""
+        (?P<operator>(==|!=|<=|>=|<|>))
+        \s*
+        (?P<version>
+            [^,;\s)]* # Since this is a "legacy" specifier, and the version
+                      # string can be just about anything, we match everything
+                      # except for whitespace, a semi-colon for marker support,
+                      # a closing paren since versions can be enclosed in
+                      # them, and a comma since it's a version separator.
+        )
+        """
+    )
+
+    _regex = re.compile(
+        r"^\s*" + _regex_str + r"\s*$", re.VERBOSE | re.IGNORECASE)
+
+    _operators = {
+        "==": "equal",
+        "!=": "not_equal",
+        "<=": "less_than_equal",
+        ">=": "greater_than_equal",
+        "<": "less_than",
+        ">": "greater_than",
+    }
+
+    def _coerce_version(self, version):
+        if not isinstance(version, LegacyVersion):
+            version = LegacyVersion(str(version))
+        return version
+
+    def _compare_equal(self, prospective, spec):
+        return prospective == self._coerce_version(spec)
+
+    def _compare_not_equal(self, prospective, spec):
+        return prospective != self._coerce_version(spec)
+
+    def _compare_less_than_equal(self, prospective, spec):
+        return prospective <= self._coerce_version(spec)
+
+    def _compare_greater_than_equal(self, prospective, spec):
+        return prospective >= self._coerce_version(spec)
+
+    def _compare_less_than(self, prospective, spec):
+        return prospective < self._coerce_version(spec)
+
+    def _compare_greater_than(self, prospective, spec):
+        return prospective > self._coerce_version(spec)
+
+
+def _require_version_compare(fn):
+    @functools.wraps(fn)
+    def wrapped(self, prospective, spec):
+        if not isinstance(prospective, Version):
+            return False
+        return fn(self, prospective, spec)
+    return wrapped
+
+
+class Specifier(_IndividualSpecifier):
+
+    _regex_str = (
+        r"""
+        (?P<operator>(~=|==|!=|<=|>=|<|>|===))
+        (?P<version>
+            (?:
+                # The identity operators allow for an escape hatch that will
+                # do an exact string match of the version you wish to install.
+                # This will not be parsed by PEP 440 and we cannot determine
+                # any semantic meaning from it. This operator is discouraged
+                # but included entirely as an escape hatch.
+                (?<====)  # Only match for the identity operator
+                \s*
+                [^\s]*    # We just match everything, except for whitespace
+                          # since we are only testing for strict identity.
+            )
+            |
+            (?:
+                # The (non)equality operators allow for wild card and local
+                # versions to be specified so we have to define these two
+                # operators separately to enable that.
+                (?<===|!=)            # Only match for equals and not equals
+
+                \s*
+                v?
+                (?:[0-9]+!)?          # epoch
+                [0-9]+(?:\.[0-9]+)*   # release
+                (?:                   # pre release
+                    [-_\.]?
+                    (a|b|c|rc|alpha|beta|pre|preview)
+                    [-_\.]?
+                    [0-9]*
+                )?
+                (?:                   # post release
+                    (?:-[0-9]+)|(?:[-_\.]?(post|rev|r)[-_\.]?[0-9]*)
+                )?
+
+                # You cannot use a wild card and a dev or local version
+                # together so group them with a | and make them optional.
+                (?:
+                    (?:[-_\.]?dev[-_\.]?[0-9]*)?         # dev release
+                    (?:\+[a-z0-9]+(?:[-_\.][a-z0-9]+)*)? # local
+                    |
+                    \.\*  # Wild card syntax of .*
+                )?
+            )
+            |
+            (?:
+                # The compatible operator requires at least two digits in the
+                # release segment.
+                (?<=~=)               # Only match for the compatible operator
+
+                \s*
+                v?
+                (?:[0-9]+!)?          # epoch
+                [0-9]+(?:\.[0-9]+)+   # release  (We have a + instead of a *)
+                (?:                   # pre release
+                    [-_\.]?
+                    (a|b|c|rc|alpha|beta|pre|preview)
+                    [-_\.]?
+                    [0-9]*
+                )?
+                (?:                                   # post release
+                    (?:-[0-9]+)|(?:[-_\.]?(post|rev|r)[-_\.]?[0-9]*)
+                )?
+                (?:[-_\.]?dev[-_\.]?[0-9]*)?          # dev release
+            )
+            |
+            (?:
+                # All other operators only allow a sub set of what the
+                # (non)equality operators do. Specifically they do not allow
+                # local versions to be specified nor do they allow the prefix
+                # matching wild cards.
+                (?<!==|!=|~=)         # We have special cases for these
+                                      # operators so we want to make sure they
+                                      # don't match here.
+
+                \s*
+                v?
+                (?:[0-9]+!)?          # epoch
+                [0-9]+(?:\.[0-9]+)*   # release
+                (?:                   # pre release
+                    [-_\.]?
+                    (a|b|c|rc|alpha|beta|pre|preview)
+                    [-_\.]?
+                    [0-9]*
+                )?
+                (?:                                   # post release
+                    (?:-[0-9]+)|(?:[-_\.]?(post|rev|r)[-_\.]?[0-9]*)
+                )?
+                (?:[-_\.]?dev[-_\.]?[0-9]*)?          # dev release
+            )
+        )
+        """
+    )
+
+    _regex = re.compile(
+        r"^\s*" + _regex_str + r"\s*$", re.VERBOSE | re.IGNORECASE)
+
+    _operators = {
+        "~=": "compatible",
+        "==": "equal",
+        "!=": "not_equal",
+        "<=": "less_than_equal",
+        ">=": "greater_than_equal",
+        "<": "less_than",
+        ">": "greater_than",
+        "===": "arbitrary",
+    }
+
+    @_require_version_compare
+    def _compare_compatible(self, prospective, spec):
+        # Compatible releases have an equivalent combination of >= and ==. That
+        # is that ~=2.2 is equivalent to >=2.2,==2.*. This allows us to
+        # implement this in terms of the other specifiers instead of
+        # implementing it ourselves. The only thing we need to do is construct
+        # the other specifiers.
+
+        # We want everything but the last item in the version, but we want to
+        # ignore post and dev releases and we want to treat the pre-release as
+        # it's own separate segment.
+        prefix = ".".join(
+            list(
+                itertools.takewhile(
+                    lambda x: (not x.startswith("post") and not
+                               x.startswith("dev")),
+                    _version_split(spec),
+                )
+            )[:-1]
+        )
+
+        # Add the prefix notation to the end of our string
+        prefix += ".*"
+
+        return (self._get_operator(">=")(prospective, spec) and
+                self._get_operator("==")(prospective, prefix))
+
+    @_require_version_compare
+    def _compare_equal(self, prospective, spec):
+        # We need special logic to handle prefix matching
+        if spec.endswith(".*"):
+            # In the case of prefix matching we want to ignore local segment.
+            prospective = Version(prospective.public)
+            # Split the spec out by dots, and pretend that there is an implicit
+            # dot in between a release segment and a pre-release segment.
+            spec = _version_split(spec[:-2])  # Remove the trailing .*
+
+            # Split the prospective version out by dots, and pretend that there
+            # is an implicit dot in between a release segment and a pre-release
+            # segment.
+            prospective = _version_split(str(prospective))
+
+            # Shorten the prospective version to be the same length as the spec
+            # so that we can determine if the specifier is a prefix of the
+            # prospective version or not.
+            prospective = prospective[:len(spec)]
+
+            # Pad out our two sides with zeros so that they both equal the same
+            # length.
+            spec, prospective = _pad_version(spec, prospective)
+        else:
+            # Convert our spec string into a Version
+            spec = Version(spec)
+
+            # If the specifier does not have a local segment, then we want to
+            # act as if the prospective version also does not have a local
+            # segment.
+            if not spec.local:
+                prospective = Version(prospective.public)
+
+        return prospective == spec
+
+    @_require_version_compare
+    def _compare_not_equal(self, prospective, spec):
+        return not self._compare_equal(prospective, spec)
+
+    @_require_version_compare
+    def _compare_less_than_equal(self, prospective, spec):
+        return prospective <= Version(spec)
+
+    @_require_version_compare
+    def _compare_greater_than_equal(self, prospective, spec):
+        return prospective >= Version(spec)
+
+    @_require_version_compare
+    def _compare_less_than(self, prospective, spec):
+        # Convert our spec to a Version instance, since we'll want to work with
+        # it as a version.
+        spec = Version(spec)
+
+        # Check to see if the prospective version is less than the spec
+        # version. If it's not we can short circuit and just return False now
+        # instead of doing extra unneeded work.
+        if not prospective < spec:
+            return False
+
+        # This special case is here so that, unless the specifier itself
+        # includes is a pre-release version, that we do not accept pre-release
+        # versions for the version mentioned in the specifier (e.g. <3.1 should
+        # not match 3.1.dev0, but should match 3.0.dev0).
+        if not spec.is_prerelease and prospective.is_prerelease:
+            if Version(prospective.base_version) == Version(spec.base_version):
+                return False
+
+        # If we've gotten to here, it means that prospective version is both
+        # less than the spec version *and* it's not a pre-release of the same
+        # version in the spec.
+        return True
+
+    @_require_version_compare
+    def _compare_greater_than(self, prospective, spec):
+        # Convert our spec to a Version instance, since we'll want to work with
+        # it as a version.
+        spec = Version(spec)
+
+        # Check to see if the prospective version is greater than the spec
+        # version. If it's not we can short circuit and just return False now
+        # instead of doing extra unneeded work.
+        if not prospective > spec:
+            return False
+
+        # This special case is here so that, unless the specifier itself
+        # includes is a post-release version, that we do not accept
+        # post-release versions for the version mentioned in the specifier
+        # (e.g. >3.1 should not match 3.0.post0, but should match 3.2.post0).
+        if not spec.is_postrelease and prospective.is_postrelease:
+            if Version(prospective.base_version) == Version(spec.base_version):
+                return False
+
+        # Ensure that we do not allow a local version of the version mentioned
+        # in the specifier, which is techincally greater than, to match.
+        if prospective.local is not None:
+            if Version(prospective.base_version) == Version(spec.base_version):
+                return False
+
+        # If we've gotten to here, it means that prospective version is both
+        # greater than the spec version *and* it's not a pre-release of the
+        # same version in the spec.
+        return True
+
+    def _compare_arbitrary(self, prospective, spec):
+        return str(prospective).lower() == str(spec).lower()
+
+    @property
+    def prereleases(self):
+        # If there is an explicit prereleases set for this, then we'll just
+        # blindly use that.
+        if self._prereleases is not None:
+            return self._prereleases
+
+        # Look at all of our specifiers and determine if they are inclusive
+        # operators, and if they are if they are including an explicit
+        # prerelease.
+        operator, version = self._spec
+        if operator in ["==", ">=", "<=", "~=", "==="]:
+            # The == specifier can include a trailing .*, if it does we
+            # want to remove before parsing.
+            if operator == "==" and version.endswith(".*"):
+                version = version[:-2]
+
+            # Parse the version, and if it is a pre-release than this
+            # specifier allows pre-releases.
+            if parse(version).is_prerelease:
+                return True
+
+        return False
+
+    @prereleases.setter
+    def prereleases(self, value):
+        self._prereleases = value
+
+
+_prefix_regex = re.compile(r"^([0-9]+)((?:a|b|c|rc)[0-9]+)$")
+
+
+def _version_split(version):
+    result = []
+    for item in version.split("."):
+        match = _prefix_regex.search(item)
+        if match:
+            result.extend(match.groups())
+        else:
+            result.append(item)
+    return result
+
+
+def _pad_version(left, right):
+    left_split, right_split = [], []
+
+    # Get the release segment of our versions
+    left_split.append(list(itertools.takewhile(lambda x: x.isdigit(), left)))
+    right_split.append(list(itertools.takewhile(lambda x: x.isdigit(), right)))
+
+    # Get the rest of our versions
+    left_split.append(left[len(left_split[0]):])
+    right_split.append(right[len(right_split[0]):])
+
+    # Insert our padding
+    left_split.insert(
+        1,
+        ["0"] * max(0, len(right_split[0]) - len(left_split[0])),
+    )
+    right_split.insert(
+        1,
+        ["0"] * max(0, len(left_split[0]) - len(right_split[0])),
+    )
+
+    return (
+        list(itertools.chain(*left_split)),
+        list(itertools.chain(*right_split)),
+    )
+
+
+class SpecifierSet(BaseSpecifier):
+
+    def __init__(self, specifiers="", prereleases=None):
+        # Split on , to break each indidivual specifier into it's own item, and
+        # strip each item to remove leading/trailing whitespace.
+        specifiers = [s.strip() for s in specifiers.split(",") if s.strip()]
+
+        # Parsed each individual specifier, attempting first to make it a
+        # Specifier and falling back to a LegacySpecifier.
+        parsed = set()
+        for specifier in specifiers:
+            try:
+                parsed.add(Specifier(specifier))
+            except InvalidSpecifier:
+                parsed.add(LegacySpecifier(specifier))
+
+        # Turn our parsed specifiers into a frozen set and save them for later.
+        self._specs = frozenset(parsed)
+
+        # Store our prereleases value so we can use it later to determine if
+        # we accept prereleases or not.
+        self._prereleases = prereleases
+
+    def __repr__(self):
+        pre = (
+            ", prereleases={0!r}".format(self.prereleases)
+            if self._prereleases is not None
+            else ""
+        )
+
+        return "<SpecifierSet({0!r}{1})>".format(str(self), pre)
+
+    def __str__(self):
+        return ",".join(sorted(str(s) for s in self._specs))
+
+    def __hash__(self):
+        return hash(self._specs)
+
+    def __and__(self, other):
+        if isinstance(other, string_types):
+            other = SpecifierSet(other)
+        elif not isinstance(other, SpecifierSet):
+            return NotImplemented
+
+        specifier = SpecifierSet()
+        specifier._specs = frozenset(self._specs | other._specs)
+
+        if self._prereleases is None and other._prereleases is not None:
+            specifier._prereleases = other._prereleases
+        elif self._prereleases is not None and other._prereleases is None:
+            specifier._prereleases = self._prereleases
+        elif self._prereleases == other._prereleases:
+            specifier._prereleases = self._prereleases
+        else:
+            raise ValueError(
+                "Cannot combine SpecifierSets with True and False prerelease "
+                "overrides."
+            )
+
+        return specifier
+
+    def __eq__(self, other):
+        if isinstance(other, string_types):
+            other = SpecifierSet(other)
+        elif isinstance(other, _IndividualSpecifier):
+            other = SpecifierSet(str(other))
+        elif not isinstance(other, SpecifierSet):
+            return NotImplemented
+
+        return self._specs == other._specs
+
+    def __ne__(self, other):
+        if isinstance(other, string_types):
+            other = SpecifierSet(other)
+        elif isinstance(other, _IndividualSpecifier):
+            other = SpecifierSet(str(other))
+        elif not isinstance(other, SpecifierSet):
+            return NotImplemented
+
+        return self._specs != other._specs
+
+    def __len__(self):
+        return len(self._specs)
+
+    def __iter__(self):
+        return iter(self._specs)
+
+    @property
+    def prereleases(self):
+        # If we have been given an explicit prerelease modifier, then we'll
+        # pass that through here.
+        if self._prereleases is not None:
+            return self._prereleases
+
+        # If we don't have any specifiers, and we don't have a forced value,
+        # then we'll just return None since we don't know if this should have
+        # pre-releases or not.
+        if not self._specs:
+            return None
+
+        # Otherwise we'll see if any of the given specifiers accept
+        # prereleases, if any of them do we'll return True, otherwise False.
+        return any(s.prereleases for s in self._specs)
+
+    @prereleases.setter
+    def prereleases(self, value):
+        self._prereleases = value
+
+    def __contains__(self, item):
+        return self.contains(item)
+
+    def contains(self, item, prereleases=None):
+        # Ensure that our item is a Version or LegacyVersion instance.
+        if not isinstance(item, (LegacyVersion, Version)):
+            item = parse(item)
+
+        # Determine if we're forcing a prerelease or not, if we're not forcing
+        # one for this particular filter call, then we'll use whatever the
+        # SpecifierSet thinks for whether or not we should support prereleases.
+        if prereleases is None:
+            prereleases = self.prereleases
+
+        # We can determine if we're going to allow pre-releases by looking to
+        # see if any of the underlying items supports them. If none of them do
+        # and this item is a pre-release then we do not allow it and we can
+        # short circuit that here.
+        # Note: This means that 1.0.dev1 would not be contained in something
+        #       like >=1.0.devabc however it would be in >=1.0.debabc,>0.0.dev0
+        if not prereleases and item.is_prerelease:
+            return False
+
+        # We simply dispatch to the underlying specs here to make sure that the
+        # given version is contained within all of them.
+        # Note: This use of all() here means that an empty set of specifiers
+        #       will always return True, this is an explicit design decision.
+        return all(
+            s.contains(item, prereleases=prereleases)
+            for s in self._specs
+        )
+
+    def filter(self, iterable, prereleases=None):
+        # Determine if we're forcing a prerelease or not, if we're not forcing
+        # one for this particular filter call, then we'll use whatever the
+        # SpecifierSet thinks for whether or not we should support prereleases.
+        if prereleases is None:
+            prereleases = self.prereleases
+
+        # If we have any specifiers, then we want to wrap our iterable in the
+        # filter method for each one, this will act as a logical AND amongst
+        # each specifier.
+        if self._specs:
+            for spec in self._specs:
+                iterable = spec.filter(iterable, prereleases=bool(prereleases))
+            return iterable
+        # If we do not have any specifiers, then we need to have a rough filter
+        # which will filter out any pre-releases, unless there are no final
+        # releases, and which will filter out LegacyVersion in general.
+        else:
+            filtered = []
+            found_prereleases = []
+
+            for item in iterable:
+                # Ensure that we some kind of Version class for this item.
+                if not isinstance(item, (LegacyVersion, Version)):
+                    parsed_version = parse(item)
+                else:
+                    parsed_version = item
+
+                # Filter out any item which is parsed as a LegacyVersion
+                if isinstance(parsed_version, LegacyVersion):
+                    continue
+
+                # Store any item which is a pre-release for later unless we've
+                # already found a final version or we are accepting prereleases
+                if parsed_version.is_prerelease and not prereleases:
+                    if not filtered:
+                        found_prereleases.append(item)
+                else:
+                    filtered.append(item)
+
+            # If we've found no items except for pre-releases, then we'll go
+            # ahead and use the pre-releases
+            if not filtered and found_prereleases and prereleases is None:
+                return found_prereleases
+
+            return filtered
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pkg_resources/_vendor/packaging/specifiers.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pkg_resources/_vendor/packaging/specifiers.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..fea7ebcf641bccec8490f0111494d41cc7e0ba57
GIT binary patch
literal 29374
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
R%!HFu>_3ALKj_#vX#fY<<NyEw

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pkg_resources/_vendor/packaging/utils.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pkg_resources/_vendor/packaging/utils.py
new file mode 100644
index 0000000..942387c
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pkg_resources/_vendor/packaging/utils.py
@@ -0,0 +1,14 @@
+# This file is dual licensed under the terms of the Apache License, Version
+# 2.0, and the BSD License. See the LICENSE file in the root of this repository
+# for complete details.
+from __future__ import absolute_import, division, print_function
+
+import re
+
+
+_canonicalize_regex = re.compile(r"[-_.]+")
+
+
+def canonicalize_name(name):
+    # This is taken from PEP 503.
+    return _canonicalize_regex.sub("-", name).lower()
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pkg_resources/_vendor/packaging/utils.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pkg_resources/_vendor/packaging/utils.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..a2f97d15ff133cdd9c800bb892cf7ce86b4468dc
GIT binary patch
literal 708
zcmZSn%**AGdLky70ScHH7#JK97#WIP7#J8*7#LC*8FCmHav2$-7#VVz7^0XMa+w*T
zm>C#Ba!d?4EDTXB45=&(S*#2x%nZ$p3{h+hDJ%>v3=C213@J<u!5XX#3=Ekd(>0hG
z7#K?U85kH6lZx|mN=s7XGjj{_i%Lp3Kz3!8Wfo`V=auj=FfbGpW#*N{r<LX<mt^MW
z`4zJ<Ffc^x#_PpuCo?iIFn}<~FlUfM#XzPqFk~@;+*-rH(9Fb;#l+Cez!0nf@{C^z
zNVP7+a$yDrhWO;fy!^b(<iwoJs?_+R)b!Mf5|ClVrAZ|qx8~%Rrxs~|G?lP0FfimL
z=B8?Zoev_4>lqjr^b3kI%Mwdc^~(~A^waWlQc{bG^^;Qc%afAwa!qrKjSQ2_)2q@g
zOfAZDvZ~AsKp;I&KSaMEvp_d9uec;JCr8(<%)`?-K)*P(q_m(UKR>5fzaTq3z9_Xg
zzqBYhwOBvCEHy7Bzev9zF*!RiJu@#|zqBMXr&zC`vP6)9fdR!6AUE<bFfbH@Jj}qP
z0SeC&E|6d2(@IN9i&Ep`gFvni0{JQkq^JZ$6s4B1gN(}0Ey&DC4FdT#2&5I^T`+4<
b_!;Cbo80`A(wtN~kVC;qLWYTlnV%T|1S77E

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pkg_resources/_vendor/packaging/version.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pkg_resources/_vendor/packaging/version.py
new file mode 100644
index 0000000..83b5ee8
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pkg_resources/_vendor/packaging/version.py
@@ -0,0 +1,393 @@
+# This file is dual licensed under the terms of the Apache License, Version
+# 2.0, and the BSD License. See the LICENSE file in the root of this repository
+# for complete details.
+from __future__ import absolute_import, division, print_function
+
+import collections
+import itertools
+import re
+
+from ._structures import Infinity
+
+
+__all__ = [
+    "parse", "Version", "LegacyVersion", "InvalidVersion", "VERSION_PATTERN"
+]
+
+
+_Version = collections.namedtuple(
+    "_Version",
+    ["epoch", "release", "dev", "pre", "post", "local"],
+)
+
+
+def parse(version):
+    """
+    Parse the given version string and return either a :class:`Version` object
+    or a :class:`LegacyVersion` object depending on if the given version is
+    a valid PEP 440 version or a legacy version.
+    """
+    try:
+        return Version(version)
+    except InvalidVersion:
+        return LegacyVersion(version)
+
+
+class InvalidVersion(ValueError):
+    """
+    An invalid version was found, users should refer to PEP 440.
+    """
+
+
+class _BaseVersion(object):
+
+    def __hash__(self):
+        return hash(self._key)
+
+    def __lt__(self, other):
+        return self._compare(other, lambda s, o: s < o)
+
+    def __le__(self, other):
+        return self._compare(other, lambda s, o: s <= o)
+
+    def __eq__(self, other):
+        return self._compare(other, lambda s, o: s == o)
+
+    def __ge__(self, other):
+        return self._compare(other, lambda s, o: s >= o)
+
+    def __gt__(self, other):
+        return self._compare(other, lambda s, o: s > o)
+
+    def __ne__(self, other):
+        return self._compare(other, lambda s, o: s != o)
+
+    def _compare(self, other, method):
+        if not isinstance(other, _BaseVersion):
+            return NotImplemented
+
+        return method(self._key, other._key)
+
+
+class LegacyVersion(_BaseVersion):
+
+    def __init__(self, version):
+        self._version = str(version)
+        self._key = _legacy_cmpkey(self._version)
+
+    def __str__(self):
+        return self._version
+
+    def __repr__(self):
+        return "<LegacyVersion({0})>".format(repr(str(self)))
+
+    @property
+    def public(self):
+        return self._version
+
+    @property
+    def base_version(self):
+        return self._version
+
+    @property
+    def local(self):
+        return None
+
+    @property
+    def is_prerelease(self):
+        return False
+
+    @property
+    def is_postrelease(self):
+        return False
+
+
+_legacy_version_component_re = re.compile(
+    r"(\d+ | [a-z]+ | \.| -)", re.VERBOSE,
+)
+
+_legacy_version_replacement_map = {
+    "pre": "c", "preview": "c", "-": "final-", "rc": "c", "dev": "@",
+}
+
+
+def _parse_version_parts(s):
+    for part in _legacy_version_component_re.split(s):
+        part = _legacy_version_replacement_map.get(part, part)
+
+        if not part or part == ".":
+            continue
+
+        if part[:1] in "0123456789":
+            # pad for numeric comparison
+            yield part.zfill(8)
+        else:
+            yield "*" + part
+
+    # ensure that alpha/beta/candidate are before final
+    yield "*final"
+
+
+def _legacy_cmpkey(version):
+    # We hardcode an epoch of -1 here. A PEP 440 version can only have a epoch
+    # greater than or equal to 0. This will effectively put the LegacyVersion,
+    # which uses the defacto standard originally implemented by setuptools,
+    # as before all PEP 440 versions.
+    epoch = -1
+
+    # This scheme is taken from pkg_resources.parse_version setuptools prior to
+    # it's adoption of the packaging library.
+    parts = []
+    for part in _parse_version_parts(version.lower()):
+        if part.startswith("*"):
+            # remove "-" before a prerelease tag
+            if part < "*final":
+                while parts and parts[-1] == "*final-":
+                    parts.pop()
+
+            # remove trailing zeros from each series of numeric parts
+            while parts and parts[-1] == "00000000":
+                parts.pop()
+
+        parts.append(part)
+    parts = tuple(parts)
+
+    return epoch, parts
+
+# Deliberately not anchored to the start and end of the string, to make it
+# easier for 3rd party code to reuse
+VERSION_PATTERN = r"""
+    v?
+    (?:
+        (?:(?P<epoch>[0-9]+)!)?                           # epoch
+        (?P<release>[0-9]+(?:\.[0-9]+)*)                  # release segment
+        (?P<pre>                                          # pre-release
+            [-_\.]?
+            (?P<pre_l>(a|b|c|rc|alpha|beta|pre|preview))
+            [-_\.]?
+            (?P<pre_n>[0-9]+)?
+        )?
+        (?P<post>                                         # post release
+            (?:-(?P<post_n1>[0-9]+))
+            |
+            (?:
+                [-_\.]?
+                (?P<post_l>post|rev|r)
+                [-_\.]?
+                (?P<post_n2>[0-9]+)?
+            )
+        )?
+        (?P<dev>                                          # dev release
+            [-_\.]?
+            (?P<dev_l>dev)
+            [-_\.]?
+            (?P<dev_n>[0-9]+)?
+        )?
+    )
+    (?:\+(?P<local>[a-z0-9]+(?:[-_\.][a-z0-9]+)*))?       # local version
+"""
+
+
+class Version(_BaseVersion):
+
+    _regex = re.compile(
+        r"^\s*" + VERSION_PATTERN + r"\s*$",
+        re.VERBOSE | re.IGNORECASE,
+    )
+
+    def __init__(self, version):
+        # Validate the version and parse it into pieces
+        match = self._regex.search(version)
+        if not match:
+            raise InvalidVersion("Invalid version: '{0}'".format(version))
+
+        # Store the parsed out pieces of the version
+        self._version = _Version(
+            epoch=int(match.group("epoch")) if match.group("epoch") else 0,
+            release=tuple(int(i) for i in match.group("release").split(".")),
+            pre=_parse_letter_version(
+                match.group("pre_l"),
+                match.group("pre_n"),
+            ),
+            post=_parse_letter_version(
+                match.group("post_l"),
+                match.group("post_n1") or match.group("post_n2"),
+            ),
+            dev=_parse_letter_version(
+                match.group("dev_l"),
+                match.group("dev_n"),
+            ),
+            local=_parse_local_version(match.group("local")),
+        )
+
+        # Generate a key which will be used for sorting
+        self._key = _cmpkey(
+            self._version.epoch,
+            self._version.release,
+            self._version.pre,
+            self._version.post,
+            self._version.dev,
+            self._version.local,
+        )
+
+    def __repr__(self):
+        return "<Version({0})>".format(repr(str(self)))
+
+    def __str__(self):
+        parts = []
+
+        # Epoch
+        if self._version.epoch != 0:
+            parts.append("{0}!".format(self._version.epoch))
+
+        # Release segment
+        parts.append(".".join(str(x) for x in self._version.release))
+
+        # Pre-release
+        if self._version.pre is not None:
+            parts.append("".join(str(x) for x in self._version.pre))
+
+        # Post-release
+        if self._version.post is not None:
+            parts.append(".post{0}".format(self._version.post[1]))
+
+        # Development release
+        if self._version.dev is not None:
+            parts.append(".dev{0}".format(self._version.dev[1]))
+
+        # Local version segment
+        if self._version.local is not None:
+            parts.append(
+                "+{0}".format(".".join(str(x) for x in self._version.local))
+            )
+
+        return "".join(parts)
+
+    @property
+    def public(self):
+        return str(self).split("+", 1)[0]
+
+    @property
+    def base_version(self):
+        parts = []
+
+        # Epoch
+        if self._version.epoch != 0:
+            parts.append("{0}!".format(self._version.epoch))
+
+        # Release segment
+        parts.append(".".join(str(x) for x in self._version.release))
+
+        return "".join(parts)
+
+    @property
+    def local(self):
+        version_string = str(self)
+        if "+" in version_string:
+            return version_string.split("+", 1)[1]
+
+    @property
+    def is_prerelease(self):
+        return bool(self._version.dev or self._version.pre)
+
+    @property
+    def is_postrelease(self):
+        return bool(self._version.post)
+
+
+def _parse_letter_version(letter, number):
+    if letter:
+        # We consider there to be an implicit 0 in a pre-release if there is
+        # not a numeral associated with it.
+        if number is None:
+            number = 0
+
+        # We normalize any letters to their lower case form
+        letter = letter.lower()
+
+        # We consider some words to be alternate spellings of other words and
+        # in those cases we want to normalize the spellings to our preferred
+        # spelling.
+        if letter == "alpha":
+            letter = "a"
+        elif letter == "beta":
+            letter = "b"
+        elif letter in ["c", "pre", "preview"]:
+            letter = "rc"
+        elif letter in ["rev", "r"]:
+            letter = "post"
+
+        return letter, int(number)
+    if not letter and number:
+        # We assume if we are given a number, but we are not given a letter
+        # then this is using the implicit post release syntax (e.g. 1.0-1)
+        letter = "post"
+
+        return letter, int(number)
+
+
+_local_version_seperators = re.compile(r"[\._-]")
+
+
+def _parse_local_version(local):
+    """
+    Takes a string like abc.1.twelve and turns it into ("abc", 1, "twelve").
+    """
+    if local is not None:
+        return tuple(
+            part.lower() if not part.isdigit() else int(part)
+            for part in _local_version_seperators.split(local)
+        )
+
+
+def _cmpkey(epoch, release, pre, post, dev, local):
+    # When we compare a release version, we want to compare it with all of the
+    # trailing zeros removed. So we'll use a reverse the list, drop all the now
+    # leading zeros until we come to something non zero, then take the rest
+    # re-reverse it back into the correct order and make it a tuple and use
+    # that for our sorting key.
+    release = tuple(
+        reversed(list(
+            itertools.dropwhile(
+                lambda x: x == 0,
+                reversed(release),
+            )
+        ))
+    )
+
+    # We need to "trick" the sorting algorithm to put 1.0.dev0 before 1.0a0.
+    # We'll do this by abusing the pre segment, but we _only_ want to do this
+    # if there is not a pre or a post segment. If we have one of those then
+    # the normal sorting rules will handle this case correctly.
+    if pre is None and post is None and dev is not None:
+        pre = -Infinity
+    # Versions without a pre-release (except as noted above) should sort after
+    # those with one.
+    elif pre is None:
+        pre = Infinity
+
+    # Versions without a post segment should sort before those with one.
+    if post is None:
+        post = -Infinity
+
+    # Versions without a development segment should sort after those with one.
+    if dev is None:
+        dev = Infinity
+
+    if local is None:
+        # Versions without a local segment should sort before those with one.
+        local = -Infinity
+    else:
+        # Versions with a local segment need that segment parsed to implement
+        # the sorting rules in PEP440.
+        # - Alpha numeric segments sort before numeric segments
+        # - Alpha numeric segments sort lexicographically
+        # - Numeric segments sort numerically
+        # - Shorter versions sort before longer versions when the prefixes
+        #   match exactly
+        local = tuple(
+            (i, "") if isinstance(i, int) else (-Infinity, i)
+            for i in local
+        )
+
+    return epoch, release, pre, post, dev, local
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pkg_resources/_vendor/packaging/version.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pkg_resources/_vendor/packaging/version.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..fe9c217e75dbc1fc126069b40b4af9f7c033d957
GIT binary patch
literal 17248
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
T!YRmU$;K>}%_+~%%*hP^53-xq

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pkg_resources/_vendor/pyparsing.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pkg_resources/_vendor/pyparsing.py
new file mode 100644
index 0000000..cf75e1e
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pkg_resources/_vendor/pyparsing.py
@@ -0,0 +1,5742 @@
+# module pyparsing.py
+#
+# Copyright (c) 2003-2018  Paul T. McGuire
+#
+# Permission is hereby granted, free of charge, to any person obtaining
+# a copy of this software and associated documentation files (the
+# "Software"), to deal in the Software without restriction, including
+# without limitation the rights to use, copy, modify, merge, publish,
+# distribute, sublicense, and/or sell copies of the Software, and to
+# permit persons to whom the Software is furnished to do so, subject to
+# the following conditions:
+#
+# The above copyright notice and this permission notice shall be
+# included in all copies or substantial portions of the Software.
+#
+# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
+# EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
+# MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
+# IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY
+# CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,
+# TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
+# SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
+#
+
+__doc__ = \
+"""
+pyparsing module - Classes and methods to define and execute parsing grammars
+=============================================================================
+
+The pyparsing module is an alternative approach to creating and executing simple grammars,
+vs. the traditional lex/yacc approach, or the use of regular expressions.  With pyparsing, you
+don't need to learn a new syntax for defining grammars or matching expressions - the parsing module
+provides a library of classes that you use to construct the grammar directly in Python.
+
+Here is a program to parse "Hello, World!" (or any greeting of the form 
+C{"<salutation>, <addressee>!"}), built up using L{Word}, L{Literal}, and L{And} elements 
+(L{'+'<ParserElement.__add__>} operator gives L{And} expressions, strings are auto-converted to
+L{Literal} expressions)::
+
+    from pyparsing import Word, alphas
+
+    # define grammar of a greeting
+    greet = Word(alphas) + "," + Word(alphas) + "!"
+
+    hello = "Hello, World!"
+    print (hello, "->", greet.parseString(hello))
+
+The program outputs the following::
+
+    Hello, World! -> ['Hello', ',', 'World', '!']
+
+The Python representation of the grammar is quite readable, owing to the self-explanatory
+class names, and the use of '+', '|' and '^' operators.
+
+The L{ParseResults} object returned from L{ParserElement.parseString<ParserElement.parseString>} can be accessed as a nested list, a dictionary, or an
+object with named attributes.
+
+The pyparsing module handles some of the problems that are typically vexing when writing text parsers:
+ - extra or missing whitespace (the above program will also handle "Hello,World!", "Hello  ,  World  !", etc.)
+ - quoted strings
+ - embedded comments
+
+
+Getting Started -
+-----------------
+Visit the classes L{ParserElement} and L{ParseResults} to see the base classes that most other pyparsing
+classes inherit from. Use the docstrings for examples of how to:
+ - construct literal match expressions from L{Literal} and L{CaselessLiteral} classes
+ - construct character word-group expressions using the L{Word} class
+ - see how to create repetitive expressions using L{ZeroOrMore} and L{OneOrMore} classes
+ - use L{'+'<And>}, L{'|'<MatchFirst>}, L{'^'<Or>}, and L{'&'<Each>} operators to combine simple expressions into more complex ones
+ - associate names with your parsed results using L{ParserElement.setResultsName}
+ - find some helpful expression short-cuts like L{delimitedList} and L{oneOf}
+ - find more useful common expressions in the L{pyparsing_common} namespace class
+"""
+
+__version__ = "2.2.1"
+__versionTime__ = "18 Sep 2018 00:49 UTC"
+__author__ = "Paul McGuire <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
+
+try:
+    from _thread import RLock
+except ImportError:
+    from threading import RLock
+
+try:
+    # Python 3
+    from collections.abc import Iterable
+    from collections.abc import MutableMapping
+except ImportError:
+    # Python 2.7
+    from collections import Iterable
+    from collections import MutableMapping
+
+try:
+    from collections import OrderedDict as _OrderedDict
+except ImportError:
+    try:
+        from ordereddict import OrderedDict as _OrderedDict
+    except ImportError:
+        _OrderedDict = None
+
+#~ sys.stderr.write( "testing pyparsing module, version %s, %s\n" % (__version__,__versionTime__ ) )
+
+__all__ = [
+'And', 'CaselessKeyword', 'CaselessLiteral', 'CharsNotIn', 'Combine', 'Dict', 'Each', 'Empty',
+'FollowedBy', 'Forward', 'GoToColumn', 'Group', 'Keyword', 'LineEnd', 'LineStart', 'Literal',
+'MatchFirst', 'NoMatch', 'NotAny', 'OneOrMore', 'OnlyOnce', 'Optional', 'Or',
+'ParseBaseException', 'ParseElementEnhance', 'ParseException', 'ParseExpression', 'ParseFatalException',
+'ParseResults', 'ParseSyntaxException', 'ParserElement', 'QuotedString', 'RecursiveGrammarException',
+'Regex', 'SkipTo', 'StringEnd', 'StringStart', 'Suppress', 'Token', 'TokenConverter', 
+'White', 'Word', 'WordEnd', 'WordStart', 'ZeroOrMore',
+'alphanums', 'alphas', 'alphas8bit', 'anyCloseTag', 'anyOpenTag', 'cStyleComment', 'col',
+'commaSeparatedList', 'commonHTMLEntity', 'countedArray', 'cppStyleComment', 'dblQuotedString',
+'dblSlashComment', 'delimitedList', 'dictOf', 'downcaseTokens', 'empty', 'hexnums',
+'htmlComment', 'javaStyleComment', 'line', 'lineEnd', 'lineStart', 'lineno',
+'makeHTMLTags', 'makeXMLTags', 'matchOnlyAtCol', 'matchPreviousExpr', 'matchPreviousLiteral',
+'nestedExpr', 'nullDebugAction', 'nums', 'oneOf', 'opAssoc', 'operatorPrecedence', 'printables',
+'punc8bit', 'pythonStyleComment', 'quotedString', 'removeQuotes', 'replaceHTMLEntity', 
+'replaceWith', 'restOfLine', 'sglQuotedString', 'srange', 'stringEnd',
+'stringStart', 'traceParseAction', 'unicodeString', 'upcaseTokens', 'withAttribute',
+'indentedBlock', 'originalTextFor', 'ungroup', 'infixNotation','locatedExpr', 'withClass',
+'CloseMatch', 'tokenMap', 'pyparsing_common',
+]
+
+system_version = tuple(sys.version_info)[:3]
+PY_3 = system_version[0] == 3
+if PY_3:
+    _MAX_INT = sys.maxsize
+    basestring = str
+    unichr = chr
+    _ustr = str
+
+    # build list of single arg builtins, that can be used as parse actions
+    singleArgBuiltins = [sum, len, sorted, reversed, list, tuple, set, any, all, min, max]
+
+else:
+    _MAX_INT = sys.maxint
+    range = xrange
+
+    def _ustr(obj):
+        """Drop-in replacement for str(obj) that tries to be Unicode friendly. It first tries
+           str(obj). If that fails with a UnicodeEncodeError, then it tries unicode(obj). It
+           then < returns the unicode object | encodes it with the default encoding | ... >.
+        """
+        if isinstance(obj,unicode):
+            return obj
+
+        try:
+            # If this works, then _ustr(obj) has the same behaviour as str(obj), so
+            # it won't break any existing code.
+            return str(obj)
+
+        except UnicodeEncodeError:
+            # Else encode it
+            ret = unicode(obj).encode(sys.getdefaultencoding(), 'xmlcharrefreplace')
+            xmlcharref = Regex(r'&#\d+;')
+            xmlcharref.setParseAction(lambda t: '\\u' + hex(int(t[0][2:-1]))[2:])
+            return xmlcharref.transformString(ret)
+
+    # build list of single arg builtins, tolerant of Python version, that can be used as parse actions
+    singleArgBuiltins = []
+    import __builtin__
+    for fname in "sum len sorted reversed list tuple set any all min max".split():
+        try:
+            singleArgBuiltins.append(getattr(__builtin__,fname))
+        except AttributeError:
+            continue
+            
+_generatorType = type((y for y in range(1)))
+ 
+def _xml_escape(data):
+    """Escape &, <, >, ", ', etc. in a string of data."""
+
+    # ampersand must be replaced first
+    from_symbols = '&><"\''
+    to_symbols = ('&'+s+';' for s in "amp gt lt quot apos".split())
+    for from_,to_ in zip(from_symbols, to_symbols):
+        data = data.replace(from_, to_)
+    return data
+
+class _Constants(object):
+    pass
+
+alphas     = string.ascii_uppercase + string.ascii_lowercase
+nums       = "0123456789"
+hexnums    = nums + "ABCDEFabcdef"
+alphanums  = alphas + nums
+_bslash    = chr(92)
+printables = "".join(c for c in string.printable if c not in string.whitespace)
+
+class ParseBaseException(Exception):
+    """base exception class for all parsing runtime exceptions"""
+    # Performance tuning: we construct a *lot* of these, so keep this
+    # constructor as small and fast as possible
+    def __init__( self, pstr, loc=0, msg=None, elem=None ):
+        self.loc = loc
+        if msg is None:
+            self.msg = pstr
+            self.pstr = ""
+        else:
+            self.msg = msg
+            self.pstr = pstr
+        self.parserElement = elem
+        self.args = (pstr, loc, msg)
+
+    @classmethod
+    def _from_exception(cls, pe):
+        """
+        internal factory method to simplify creating one type of ParseException 
+        from another - avoids having __init__ signature conflicts among subclasses
+        """
+        return cls(pe.pstr, pe.loc, pe.msg, pe.parserElement)
+
+    def __getattr__( self, aname ):
+        """supported attributes by name are:
+            - lineno - returns the line number of the exception text
+            - col - returns the column number of the exception text
+            - line - returns the line containing the exception text
+        """
+        if( aname == "lineno" ):
+            return lineno( self.loc, self.pstr )
+        elif( aname in ("col", "column") ):
+            return col( self.loc, self.pstr )
+        elif( aname == "line" ):
+            return line( self.loc, self.pstr )
+        else:
+            raise AttributeError(aname)
+
+    def __str__( self ):
+        return "%s (at char %d), (line:%d, col:%d)" % \
+                ( self.msg, self.loc, self.lineno, self.column )
+    def __repr__( self ):
+        return _ustr(self)
+    def markInputline( self, markerString = ">!<" ):
+        """Extracts the exception line from the input string, and marks
+           the location of the exception with a special symbol.
+        """
+        line_str = self.line
+        line_column = self.column - 1
+        if markerString:
+            line_str = "".join((line_str[:line_column],
+                                markerString, line_str[line_column:]))
+        return line_str.strip()
+    def __dir__(self):
+        return "lineno col line".split() + dir(type(self))
+
+class ParseException(ParseBaseException):
+    """
+    Exception thrown when parse expressions don't match class;
+    supported attributes by name are:
+     - lineno - returns the line number of the exception text
+     - col - returns the column number of the exception text
+     - line - returns the line containing the exception text
+        
+    Example::
+        try:
+            Word(nums).setName("integer").parseString("ABC")
+        except ParseException as pe:
+            print(pe)
+            print("column: {}".format(pe.col))
+            
+    prints::
+       Expected integer (at char 0), (line:1, col:1)
+        column: 1
+    """
+    pass
+
+class ParseFatalException(ParseBaseException):
+    """user-throwable exception thrown when inconsistent parse content
+       is found; stops all parsing immediately"""
+    pass
+
+class ParseSyntaxException(ParseFatalException):
+    """just like L{ParseFatalException}, but thrown internally when an
+       L{ErrorStop<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 L{ParserElement.validate} if the grammar could be improperly recursive"""
+    def __init__( self, parseElementList ):
+        self.parseElementTrace = parseElementList
+
+    def __str__( self ):
+        return "RecursiveGrammarException: %s" % self.parseElementTrace
+
+class _ParseResultsWithOffset(object):
+    def __init__(self,p1,p2):
+        self.tup = (p1,p2)
+    def __getitem__(self,i):
+        return self.tup[i]
+    def __repr__(self):
+        return repr(self.tup[0])
+    def setOffset(self,i):
+        self.tup = (self.tup[0],i)
+
+class ParseResults(object):
+    """
+    Structured parse results, to provide multiple means of access to the parsed data:
+       - as a list (C{len(results)})
+       - by list index (C{results[0], results[1]}, etc.)
+       - by attribute (C{results.<resultsName>} - see L{ParserElement.setResultsName})
+
+    Example::
+        integer = Word(nums)
+        date_str = (integer.setResultsName("year") + '/' 
+                        + integer.setResultsName("month") + '/' 
+                        + integer.setResultsName("day"))
+        # equivalent form:
+        # date_str = integer("year") + '/' + integer("month") + '/' + integer("day")
+
+        # parseString returns a ParseResults object
+        result = date_str.parseString("1999/12/31")
+
+        def test(s, fn=repr):
+            print("%s -> %s" % (s, fn(eval(s))))
+        test("list(result)")
+        test("result[0]")
+        test("result['month']")
+        test("result.day")
+        test("'month' in result")
+        test("'minutes' in result")
+        test("result.dump()", str)
+    prints::
+        list(result) -> ['1999', '/', '12', '/', '31']
+        result[0] -> '1999'
+        result['month'] -> '12'
+        result.day -> '31'
+        'month' in result -> True
+        'minutes' in result -> False
+        result.dump() -> ['1999', '/', '12', '/', '31']
+        - day: 31
+        - month: 12
+        - year: 1999
+    """
+    def __new__(cls, toklist=None, name=None, asList=True, modal=True ):
+        if isinstance(toklist, cls):
+            return toklist
+        retobj = object.__new__(cls)
+        retobj.__doinit = True
+        return retobj
+
+    # Performance tuning: we construct a *lot* of these, so keep this
+    # constructor as small and fast as possible
+    def __init__( self, toklist=None, name=None, asList=True, modal=True, isinstance=isinstance ):
+        if self.__doinit:
+            self.__doinit = False
+            self.__name = None
+            self.__parent = None
+            self.__accumNames = {}
+            self.__asList = asList
+            self.__modal = modal
+            if toklist is None:
+                toklist = []
+            if isinstance(toklist, list):
+                self.__toklist = toklist[:]
+            elif isinstance(toklist, _generatorType):
+                self.__toklist = list(toklist)
+            else:
+                self.__toklist = [toklist]
+            self.__tokdict = dict()
+
+        if name is not None and name:
+            if not modal:
+                self.__accumNames[name] = 0
+            if isinstance(name,int):
+                name = _ustr(name) # will always return a str, but use _ustr for consistency
+            self.__name = name
+            if not (isinstance(toklist, (type(None), basestring, list)) and toklist in (None,'',[])):
+                if isinstance(toklist,basestring):
+                    toklist = [ toklist ]
+                if asList:
+                    if isinstance(toklist,ParseResults):
+                        self[name] = _ParseResultsWithOffset(toklist.copy(),0)
+                    else:
+                        self[name] = _ParseResultsWithOffset(ParseResults(toklist[0]),0)
+                    self[name].__name = name
+                else:
+                    try:
+                        self[name] = toklist[0]
+                    except (KeyError,TypeError,IndexError):
+                        self[name] = toklist
+
+    def __getitem__( self, i ):
+        if isinstance( i, (int,slice) ):
+            return self.__toklist[i]
+        else:
+            if i not in self.__accumNames:
+                return self.__tokdict[i][-1][0]
+            else:
+                return ParseResults([ v[0] for v in self.__tokdict[i] ])
+
+    def __setitem__( self, k, v, isinstance=isinstance ):
+        if isinstance(v,_ParseResultsWithOffset):
+            self.__tokdict[k] = self.__tokdict.get(k,list()) + [v]
+            sub = v[0]
+        elif isinstance(k,(int,slice)):
+            self.__toklist[k] = v
+            sub = v
+        else:
+            self.__tokdict[k] = self.__tokdict.get(k,list()) + [_ParseResultsWithOffset(v,0)]
+            sub = v
+        if isinstance(sub,ParseResults):
+            sub.__parent = wkref(self)
+
+    def __delitem__( self, i ):
+        if isinstance(i,(int,slice)):
+            mylen = len( self.__toklist )
+            del self.__toklist[i]
+
+            # convert int to slice
+            if isinstance(i, int):
+                if i < 0:
+                    i += mylen
+                i = slice(i, i+1)
+            # get removed indices
+            removed = list(range(*i.indices(mylen)))
+            removed.reverse()
+            # fixup indices in token dictionary
+            for name,occurrences in self.__tokdict.items():
+                for j in removed:
+                    for k, (value, position) in enumerate(occurrences):
+                        occurrences[k] = _ParseResultsWithOffset(value, position - (position > j))
+        else:
+            del self.__tokdict[i]
+
+    def __contains__( self, k ):
+        return k in self.__tokdict
+
+    def __len__( self ): return len( self.__toklist )
+    def __bool__(self): return ( not not self.__toklist )
+    __nonzero__ = __bool__
+    def __iter__( self ): return iter( self.__toklist )
+    def __reversed__( self ): return iter( self.__toklist[::-1] )
+    def _iterkeys( self ):
+        if hasattr(self.__tokdict, "iterkeys"):
+            return self.__tokdict.iterkeys()
+        else:
+            return iter(self.__tokdict)
+
+    def _itervalues( self ):
+        return (self[k] for k in self._iterkeys())
+            
+    def _iteritems( self ):
+        return ((k, self[k]) for k in self._iterkeys())
+
+    if PY_3:
+        keys = _iterkeys       
+        """Returns an iterator of all named result keys (Python 3.x only)."""
+
+        values = _itervalues
+        """Returns an iterator of all named result values (Python 3.x only)."""
+
+        items = _iteritems
+        """Returns an iterator of all named result key-value tuples (Python 3.x only)."""
+
+    else:
+        iterkeys = _iterkeys
+        """Returns an iterator of all named result keys (Python 2.x only)."""
+
+        itervalues = _itervalues
+        """Returns an iterator of all named result values (Python 2.x only)."""
+
+        iteritems = _iteritems
+        """Returns an iterator of all named result key-value tuples (Python 2.x only)."""
+
+        def keys( self ):
+            """Returns all named result keys (as a list in Python 2.x, as an iterator in Python 3.x)."""
+            return list(self.iterkeys())
+
+        def values( self ):
+            """Returns all named result values (as a list in Python 2.x, as an iterator in Python 3.x)."""
+            return list(self.itervalues())
+                
+        def items( self ):
+            """Returns all named result key-values (as a list of tuples in Python 2.x, as an iterator in Python 3.x)."""
+            return list(self.iteritems())
+
+    def haskeys( self ):
+        """Since keys() returns an iterator, this method is helpful in bypassing
+           code that looks for the existence of any defined results names."""
+        return bool(self.__tokdict)
+        
+    def pop( self, *args, **kwargs):
+        """
+        Removes and returns item at specified index (default=C{last}).
+        Supports both C{list} and C{dict} semantics for C{pop()}. If passed no
+        argument or an integer argument, it will use C{list} semantics
+        and pop tokens from the list of parsed tokens. If passed a 
+        non-integer argument (most likely a string), it will use C{dict}
+        semantics and pop the corresponding value from any defined 
+        results names. A second default return value argument is 
+        supported, just as in C{dict.pop()}.
+
+        Example::
+            def remove_first(tokens):
+                tokens.pop(0)
+            print(OneOrMore(Word(nums)).parseString("0 123 321")) # -> ['0', '123', '321']
+            print(OneOrMore(Word(nums)).addParseAction(remove_first).parseString("0 123 321")) # -> ['123', '321']
+
+            label = Word(alphas)
+            patt = label("LABEL") + OneOrMore(Word(nums))
+            print(patt.parseString("AAB 123 321").dump())
+
+            # Use pop() in a parse action to remove named result (note that corresponding value is not
+            # removed from list form of results)
+            def remove_LABEL(tokens):
+                tokens.pop("LABEL")
+                return tokens
+            patt.addParseAction(remove_LABEL)
+            print(patt.parseString("AAB 123 321").dump())
+        prints::
+            ['AAB', '123', '321']
+            - LABEL: AAB
+
+            ['AAB', '123', '321']
+        """
+        if not args:
+            args = [-1]
+        for k,v in kwargs.items():
+            if k == 'default':
+                args = (args[0], v)
+            else:
+                raise TypeError("pop() got an unexpected keyword argument '%s'" % k)
+        if (isinstance(args[0], int) or 
+                        len(args) == 1 or 
+                        args[0] in self):
+            index = args[0]
+            ret = self[index]
+            del self[index]
+            return ret
+        else:
+            defaultvalue = args[1]
+            return defaultvalue
+
+    def get(self, key, defaultValue=None):
+        """
+        Returns named result matching the given key, or if there is no
+        such name, then returns the given C{defaultValue} or C{None} if no
+        C{defaultValue} is specified.
+
+        Similar to C{dict.get()}.
+        
+        Example::
+            integer = Word(nums)
+            date_str = integer("year") + '/' + integer("month") + '/' + integer("day")           
+
+            result = date_str.parseString("1999/12/31")
+            print(result.get("year")) # -> '1999'
+            print(result.get("hour", "not specified")) # -> 'not specified'
+            print(result.get("hour")) # -> None
+        """
+        if key in self:
+            return self[key]
+        else:
+            return defaultValue
+
+    def insert( self, index, insStr ):
+        """
+        Inserts new element at location index in the list of parsed tokens.
+        
+        Similar to C{list.insert()}.
+
+        Example::
+            print(OneOrMore(Word(nums)).parseString("0 123 321")) # -> ['0', '123', '321']
+
+            # use a parse action to insert the parse location in the front of the parsed results
+            def insert_locn(locn, tokens):
+                tokens.insert(0, locn)
+            print(OneOrMore(Word(nums)).addParseAction(insert_locn).parseString("0 123 321")) # -> [0, '0', '123', '321']
+        """
+        self.__toklist.insert(index, insStr)
+        # fixup indices in token dictionary
+        for name,occurrences in self.__tokdict.items():
+            for k, (value, position) in enumerate(occurrences):
+                occurrences[k] = _ParseResultsWithOffset(value, position + (position > index))
+
+    def append( self, item ):
+        """
+        Add single element to end of ParseResults list of elements.
+
+        Example::
+            print(OneOrMore(Word(nums)).parseString("0 123 321")) # -> ['0', '123', '321']
+            
+            # use a parse action to compute the sum of the parsed integers, and add it to the end
+            def append_sum(tokens):
+                tokens.append(sum(map(int, tokens)))
+            print(OneOrMore(Word(nums)).addParseAction(append_sum).parseString("0 123 321")) # -> ['0', '123', '321', 444]
+        """
+        self.__toklist.append(item)
+
+    def extend( self, itemseq ):
+        """
+        Add sequence of elements to end of ParseResults list of elements.
+
+        Example::
+            patt = OneOrMore(Word(alphas))
+            
+            # use a parse action to append the reverse of the matched strings, to make a palindrome
+            def make_palindrome(tokens):
+                tokens.extend(reversed([t[::-1] for t in tokens]))
+                return ''.join(tokens)
+            print(patt.addParseAction(make_palindrome).parseString("lskdj sdlkjf lksd")) # -> 'lskdjsdlkjflksddsklfjkldsjdksl'
+        """
+        if isinstance(itemseq, ParseResults):
+            self += itemseq
+        else:
+            self.__toklist.extend(itemseq)
+
+    def clear( self ):
+        """
+        Clear all elements and results names.
+        """
+        del self.__toklist[:]
+        self.__tokdict.clear()
+
+    def __getattr__( self, name ):
+        try:
+            return self[name]
+        except KeyError:
+            return ""
+            
+        if name in self.__tokdict:
+            if name not in self.__accumNames:
+                return self.__tokdict[name][-1][0]
+            else:
+                return ParseResults([ v[0] for v in self.__tokdict[name] ])
+        else:
+            return ""
+
+    def __add__( self, other ):
+        ret = self.copy()
+        ret += other
+        return ret
+
+    def __iadd__( self, other ):
+        if other.__tokdict:
+            offset = len(self.__toklist)
+            addoffset = lambda a: offset if a<0 else a+offset
+            otheritems = other.__tokdict.items()
+            otherdictitems = [(k, _ParseResultsWithOffset(v[0],addoffset(v[1])) )
+                                for (k,vlist) in otheritems for v in vlist]
+            for k,v in otherdictitems:
+                self[k] = v
+                if isinstance(v[0],ParseResults):
+                    v[0].__parent = wkref(self)
+            
+        self.__toklist += other.__toklist
+        self.__accumNames.update( other.__accumNames )
+        return self
+
+    def __radd__(self, other):
+        if isinstance(other,int) and other == 0:
+            # useful for merging many ParseResults using sum() builtin
+            return self.copy()
+        else:
+            # this may raise a TypeError - so be it
+            return other + self
+        
+    def __repr__( self ):
+        return "(%s, %s)" % ( repr( self.__toklist ), repr( self.__tokdict ) )
+
+    def __str__( self ):
+        return '[' + ', '.join(_ustr(i) if isinstance(i, ParseResults) else repr(i) for i in self.__toklist) + ']'
+
+    def _asStringList( self, sep='' ):
+        out = []
+        for item in self.__toklist:
+            if out and sep:
+                out.append(sep)
+            if isinstance( item, ParseResults ):
+                out += item._asStringList()
+            else:
+                out.append( _ustr(item) )
+        return out
+
+    def asList( self ):
+        """
+        Returns the parse results as a nested list of matching tokens, all converted to strings.
+
+        Example::
+            patt = OneOrMore(Word(alphas))
+            result = patt.parseString("sldkj lsdkj sldkj")
+            # even though the result prints in string-like form, it is actually a pyparsing ParseResults
+            print(type(result), result) # -> <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 C{ParseResults} object.
+        """
+        ret = ParseResults( self.__toklist )
+        ret.__tokdict = self.__tokdict.copy()
+        ret.__parent = self.__parent
+        ret.__accumNames.update( self.__accumNames )
+        ret.__name = self.__name
+        return ret
+
+    def asXML( self, doctag=None, namedItemsOnly=False, indent="", formatted=True ):
+        """
+        (Deprecated) Returns the parse results as XML. Tags are created for tokens and lists that have defined results names.
+        """
+        nl = "\n"
+        out = []
+        namedItems = dict((v[1],k) for (k,vlist) in self.__tokdict.items()
+                                                            for v in vlist)
+        nextLevelIndent = indent + "  "
+
+        # collapse out indents if formatting is not desired
+        if not formatted:
+            indent = ""
+            nextLevelIndent = ""
+            nl = ""
+
+        selfTag = None
+        if doctag is not None:
+            selfTag = doctag
+        else:
+            if self.__name:
+                selfTag = self.__name
+
+        if not selfTag:
+            if namedItemsOnly:
+                return ""
+            else:
+                selfTag = "ITEM"
+
+        out += [ nl, indent, "<", selfTag, ">" ]
+
+        for i,res in enumerate(self.__toklist):
+            if isinstance(res,ParseResults):
+                if i in namedItems:
+                    out += [ res.asXML(namedItems[i],
+                                        namedItemsOnly and doctag is None,
+                                        nextLevelIndent,
+                                        formatted)]
+                else:
+                    out += [ res.asXML(None,
+                                        namedItemsOnly and doctag is None,
+                                        nextLevelIndent,
+                                        formatted)]
+            else:
+                # individual token, see if there is a name for it
+                resTag = None
+                if i in namedItems:
+                    resTag = namedItems[i]
+                if not resTag:
+                    if namedItemsOnly:
+                        continue
+                    else:
+                        resTag = "ITEM"
+                xmlBodyText = _xml_escape(_ustr(res))
+                out += [ nl, nextLevelIndent, "<", resTag, ">",
+                                                xmlBodyText,
+                                                "</", 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='', depth=0, full=True):
+        """
+        Diagnostic method for listing out the contents of a C{ParseResults}.
+        Accepts an optional C{indent} argument so that this string can be embedded
+        in a nested display of other data.
+
+        Example::
+            integer = Word(nums)
+            date_str = integer("year") + '/' + integer("month") + '/' + integer("day")
+            
+            result = date_str.parseString('12/31/1999')
+            print(result.dump())
+        prints::
+            ['12', '/', '31', '/', '1999']
+            - day: 1999
+            - month: 31
+            - year: 12
+        """
+        out = []
+        NL = '\n'
+        out.append( indent+_ustr(self.asList()) )
+        if full:
+            if self.haskeys():
+                items = sorted((str(k), v) for k,v in self.items())
+                for k,v in items:
+                    if out:
+                        out.append(NL)
+                    out.append( "%s%s- %s: " % (indent,('  '*depth), k) )
+                    if isinstance(v,ParseResults):
+                        if v:
+                            out.append( v.dump(indent,depth+1) )
+                        else:
+                            out.append(_ustr(v))
+                    else:
+                        out.append(repr(v))
+            elif any(isinstance(vv,ParseResults) for vv in self):
+                v = self
+                for i,vv in enumerate(v):
+                    if isinstance(vv,ParseResults):
+                        out.append("\n%s%s[%d]:\n%s%s%s" % (indent,('  '*(depth)),i,indent,('  '*(depth+1)),vv.dump(indent,depth+1) ))
+                    else:
+                        out.append("\n%s%s[%d]:\n%s%s%s" % (indent,('  '*(depth)),i,indent,('  '*(depth+1)),_ustr(vv)))
+            
+        return "".join(out)
+
+    def pprint(self, *args, **kwargs):
+        """
+        Pretty-printer for parsed results as a list, using the C{pprint} module.
+        Accepts additional positional or keyword args as defined for the 
+        C{pprint.pprint} method. (U{http://docs.python.org/3/library/pprint.html#pprint.pprint})
+
+        Example::
+            ident = Word(alphas, alphanums)
+            num = Word(nums)
+            func = Forward()
+            term = ident | num | Group('(' + func + ')')
+            func <<= ident + Group(Optional(delimitedList(term)))
+            result = func.parseString("fna a,b,(fnb c,d,200),100")
+            result.pprint(width=40)
+        prints::
+            ['fna',
+             ['a',
+              'b',
+              ['(', 'fnb', ['c', 'd', '200'], ')'],
+              '100']]
+        """
+        pprint.pprint(self.asList(), *args, **kwargs)
+
+    # add support for pickle protocol
+    def __getstate__(self):
+        return ( self.__toklist,
+                 ( self.__tokdict.copy(),
+                   self.__parent is not None and self.__parent() or None,
+                   self.__accumNames,
+                   self.__name ) )
+
+    def __setstate__(self,state):
+        self.__toklist = state[0]
+        (self.__tokdict,
+         par,
+         inAccumNames,
+         self.__name) = state[1]
+        self.__accumNames = {}
+        self.__accumNames.update(inAccumNames)
+        if par is not None:
+            self.__parent = wkref(par)
+        else:
+            self.__parent = None
+
+    def __getnewargs__(self):
+        return self.__toklist, self.__name, self.__asList, self.__modal
+
+    def __dir__(self):
+        return (dir(type(self)) + list(self.keys()))
+
+MutableMapping.register(ParseResults)
+
+def col (loc,strg):
+    """Returns current column within a string, counting newlines as line separators.
+   The first column is number 1.
+
+   Note: the default parsing behavior is to expand tabs in the input string
+   before starting the parsing process.  See L{I{ParserElement.parseString}<ParserElement.parseString>} for more information
+   on parsing strings containing C{<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 L{I{ParserElement.parseString}<ParserElement.parseString>} for more information
+   on parsing strings containing C{<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:
+                        del tb
+
+                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
+
+    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 = ParserElement.DEFAULT_WHITE_CHARS
+        self.copyDefaultWhiteChars = True
+        self.mayReturnEmpty = False # used when checking for left-recursion
+        self.keepTabs = False
+        self.ignoreExprs = list()
+        self.debug = False
+        self.streamlined = False
+        self.mayIndexError = True # used to optimize exception handling for subclasses that don't advance parse index
+        self.errmsg = ""
+        self.modalResults = True # used to mark results names as modal (report only last) or cumulative (list all)
+        self.debugActions = ( None, None, None ) #custom debug actions
+        self.re = None
+        self.callPreparse = True # used to avoid redundant calls to preParse
+        self.callDuringTry = False
+
+    def copy( self ):
+        """
+        Make a copy of this C{ParserElement}.  Useful for defining different parse actions
+        for the same parsing pattern, using copies of the original parse element.
+        
+        Example::
+            integer = Word(nums).setParseAction(lambda toks: int(toks[0]))
+            integerK = integer.copy().addParseAction(lambda toks: toks[0]*1024) + Suppress("K")
+            integerM = integer.copy().addParseAction(lambda toks: toks[0]*1024*1024) + Suppress("M")
+            
+            print(OneOrMore(integerK | integerM | integer).parseString("5K 100 640K 256M"))
+        prints::
+            [5120, 100, 655360, 268435456]
+        Equivalent form of C{expr.copy()} is just C{expr()}::
+            integerM = integer().addParseAction(lambda toks: toks[0]*1024*1024) + Suppress("M")
+        """
+        cpy = copy.copy( self )
+        cpy.parseAction = self.parseAction[:]
+        cpy.ignoreExprs = self.ignoreExprs[:]
+        if self.copyDefaultWhiteChars:
+            cpy.whiteChars = ParserElement.DEFAULT_WHITE_CHARS
+        return cpy
+
+    def setName( self, name ):
+        """
+        Define name for this expression, makes debugging and exception messages clearer.
+        
+        Example::
+            Word(nums).parseString("ABC")  # -> Exception: Expected W:(0123...) (at char 0), (line:1, col:1)
+            Word(nums).setName("integer").parseString("ABC")  # -> Exception: Expected integer (at char 0), (line:1, col:1)
+        """
+        self.name = name
+        self.errmsg = "Expected " + self.name
+        if hasattr(self,"exception"):
+            self.exception.msg = self.errmsg
+        return self
+
+    def setResultsName( self, name, listAllMatches=False ):
+        """
+        Define name for referencing matching tokens as a nested attribute
+        of the returned parse results.
+        NOTE: this returns a *copy* of the original C{ParserElement} object;
+        this is so that the client can define a basic element, such as an
+        integer, and reference it in multiple places with different names.
+
+        You can also set results names using the abbreviated syntax,
+        C{expr("name")} in place of C{expr.setResultsName("name")} - 
+        see L{I{__call__}<__call__>}.
+
+        Example::
+            date_str = (integer.setResultsName("year") + '/' 
+                        + integer.setResultsName("month") + '/' 
+                        + integer.setResultsName("day"))
+
+            # equivalent form:
+            date_str = integer("year") + '/' + integer("month") + '/' + integer("day")
+        """
+        newself = self.copy()
+        if name.endswith("*"):
+            name = name[:-1]
+            listAllMatches=True
+        newself.resultsName = name
+        newself.modalResults = not listAllMatches
+        return newself
+
+    def setBreak(self,breakFlag = True):
+        """Method to invoke the Python pdb debugger when this element is
+           about to be parsed. Set C{breakFlag} to True to enable, False to
+           disable.
+        """
+        if breakFlag:
+            _parseMethod = self._parse
+            def breaker(instring, loc, doActions=True, callPreParse=True):
+                import pdb
+                pdb.set_trace()
+                return _parseMethod( instring, loc, doActions, callPreParse )
+            breaker._originalParseMethod = _parseMethod
+            self._parse = breaker
+        else:
+            if hasattr(self._parse,"_originalParseMethod"):
+                self._parse = self._parse._originalParseMethod
+        return self
+
+    def setParseAction( self, *fns, **kwargs ):
+        """
+        Define one or more actions to perform when successfully matching parse element definition.
+        Parse action fn is a callable method with 0-3 arguments, called as C{fn(s,loc,toks)},
+        C{fn(loc,toks)}, C{fn(toks)}, or just C{fn()}, where:
+         - s   = the original string being parsed (see note below)
+         - loc = the location of the matching substring
+         - toks = a list of the matched tokens, packaged as a C{L{ParseResults}} object
+        If the functions in fns modify the tokens, they can return them as the return
+        value from fn, and the modified list of tokens will replace the original.
+        Otherwise, fn does not need to return any value.
+
+        Optional keyword arguments:
+         - callDuringTry = (default=C{False}) indicate if parse action should be run during lookaheads and alternate testing
+
+        Note: the default parsing behavior is to expand tabs in the input string
+        before starting the parsing process.  See L{I{parseString}<parseString>} for more information
+        on parsing strings containing C{<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]
+        """
+        self.parseAction = list(map(_trim_arity, list(fns)))
+        self.callDuringTry = kwargs.get("callDuringTry", False)
+        return self
+
+    def addParseAction( self, *fns, **kwargs ):
+        """
+        Add one or more parse actions to expression's list of parse actions. See L{I{setParseAction}<setParseAction>}.
+        
+        See examples in L{I{copy}<copy>}.
+        """
+        self.parseAction += list(map(_trim_arity, list(fns)))
+        self.callDuringTry = self.callDuringTry or kwargs.get("callDuringTry", False)
+        return self
+
+    def addCondition(self, *fns, **kwargs):
+        """Add a boolean predicate function to expression's list of parse actions. See 
+        L{I{setParseAction}<setParseAction>} for function call signatures. Unlike C{setParseAction}, 
+        functions passed to C{addCondition} need to return boolean success/fail of the condition.
+
+        Optional keyword arguments:
+         - message = define a custom message to be used in the raised exception
+         - fatal   = if True, will raise ParseFatalException to stop parsing immediately; otherwise will raise ParseException
+         
+        Example::
+            integer = Word(nums).setParseAction(lambda toks: int(toks[0]))
+            year_int = integer.copy()
+            year_int.addCondition(lambda toks: toks[0] >= 2000, message="Only support years 2000 and later")
+            date_str = year_int + '/' + integer + '/' + integer
+
+            result = date_str.parseString("1999/12/31")  # -> Exception: Only support years 2000 and later (at char 0), (line:1, col:1)
+        """
+        msg = kwargs.get("message", "failed user-defined condition")
+        exc_type = ParseFatalException if kwargs.get("fatal", False) else ParseException
+        for fn in fns:
+            def pa(s,l,t):
+                if not bool(_trim_arity(fn)(s,l,t)):
+                    raise exc_type(s,l,msg)
+            self.parseAction.append(pa)
+        self.callDuringTry = self.callDuringTry or kwargs.get("callDuringTry", False)
+        return self
+
+    def setFailAction( self, fn ):
+        """Define action to perform if parsing fails at this expression.
+           Fail acton fn is a callable function that takes the arguments
+           C{fn(s,loc,expr,err)} where:
+            - s = string being parsed
+            - loc = location where expression match was attempted and failed
+            - expr = the parse expression that failed
+            - err = the exception thrown
+           The function returns no value.  It may throw C{L{ParseFatalException}}
+           if it is desired to stop parsing immediately."""
+        self.failAction = fn
+        return self
+
+    def _skipIgnorables( self, instring, loc ):
+        exprsFound = True
+        while exprsFound:
+            exprsFound = False
+            for e in self.ignoreExprs:
+                try:
+                    while 1:
+                        loc,dummy = e._parse( instring, loc )
+                        exprsFound = True
+                except ParseException:
+                    pass
+        return loc
+
+    def preParse( self, instring, loc ):
+        if self.ignoreExprs:
+            loc = self._skipIgnorables( instring, loc )
+
+        if self.skipWhitespace:
+            wt = self.whiteChars
+            instrlen = len(instring)
+            while loc < instrlen and instring[loc] in wt:
+                loc += 1
+
+        return loc
+
+    def parseImpl( self, instring, loc, doActions=True ):
+        return loc, []
+
+    def postParse( self, instring, loc, tokenlist ):
+        return tokenlist
+
+    #~ @profile
+    def _parseNoCache( self, instring, loc, doActions=True, callPreParse=True ):
+        debugging = ( self.debug ) #and doActions )
+
+        if debugging or self.failAction:
+            #~ print ("Match",self,"at loc",loc,"(%d,%d)" % ( lineno(loc,instring), col(loc,instring) ))
+            if (self.debugActions[0] ):
+                self.debugActions[0]( instring, loc, self )
+            if callPreParse and self.callPreparse:
+                preloc = self.preParse( instring, loc )
+            else:
+                preloc = loc
+            tokensStart = preloc
+            try:
+                try:
+                    loc,tokens = self.parseImpl( instring, preloc, doActions )
+                except IndexError:
+                    raise ParseException( instring, len(instring), self.errmsg, self )
+            except ParseBaseException as err:
+                #~ print ("Exception raised:", err)
+                if self.debugActions[2]:
+                    self.debugActions[2]( instring, tokensStart, self, err )
+                if self.failAction:
+                    self.failAction( instring, tokensStart, self, err )
+                raise
+        else:
+            if callPreParse and self.callPreparse:
+                preloc = self.preParse( instring, loc )
+            else:
+                preloc = loc
+            tokensStart = preloc
+            if self.mayIndexError or preloc >= len(instring):
+                try:
+                    loc,tokens = self.parseImpl( instring, preloc, doActions )
+                except IndexError:
+                    raise ParseException( instring, len(instring), self.errmsg, self )
+            else:
+                loc,tokens = self.parseImpl( instring, preloc, doActions )
+
+        tokens = self.postParse( instring, loc, tokens )
+
+        retTokens = ParseResults( tokens, self.resultsName, asList=self.saveAsList, modal=self.modalResults )
+        if self.parseAction and (doActions or self.callDuringTry):
+            if debugging:
+                try:
+                    for fn in self.parseAction:
+                        tokens = fn( instring, tokensStart, retTokens )
+                        if tokens is not None:
+                            retTokens = ParseResults( tokens,
+                                                      self.resultsName,
+                                                      asList=self.saveAsList and isinstance(tokens,(ParseResults,list)),
+                                                      modal=self.modalResults )
+                except ParseBaseException as err:
+                    #~ print "Exception raised in user parse action:", err
+                    if (self.debugActions[2] ):
+                        self.debugActions[2]( instring, tokensStart, self, err )
+                    raise
+            else:
+                for fn in self.parseAction:
+                    tokens = fn( instring, tokensStart, retTokens )
+                    if tokens is not None:
+                        retTokens = ParseResults( tokens,
+                                                  self.resultsName,
+                                                  asList=self.saveAsList and isinstance(tokens,(ParseResults,list)),
+                                                  modal=self.modalResults )
+        if debugging:
+            #~ print ("Matched",self,"->",retTokens.asList())
+            if (self.debugActions[1] ):
+                self.debugActions[1]( instring, tokensStart, loc, self, retTokens )
+
+        return loc, retTokens
+
+    def tryParse( self, instring, loc ):
+        try:
+            return self._parse( instring, loc, doActions=False )[0]
+        except ParseFatalException:
+            raise ParseException( instring, loc, self.errmsg, self)
+    
+    def canParseNext(self, instring, loc):
+        try:
+            self.tryParse(instring, loc)
+        except (ParseException, IndexError):
+            return False
+        else:
+            return True
+
+    class _UnboundedCache(object):
+        def __init__(self):
+            cache = {}
+            self.not_in_cache = not_in_cache = object()
+
+            def get(self, key):
+                return cache.get(key, not_in_cache)
+
+            def set(self, key, value):
+                cache[key] = value
+
+            def clear(self):
+                cache.clear()
+                
+            def cache_len(self):
+                return len(cache)
+
+            self.get = types.MethodType(get, self)
+            self.set = types.MethodType(set, self)
+            self.clear = types.MethodType(clear, self)
+            self.__len__ = types.MethodType(cache_len, self)
+
+    if _OrderedDict is not None:
+        class _FifoCache(object):
+            def __init__(self, size):
+                self.not_in_cache = not_in_cache = object()
+
+                cache = _OrderedDict()
+
+                def get(self, key):
+                    return cache.get(key, not_in_cache)
+
+                def set(self, key, value):
+                    cache[key] = value
+                    while len(cache) > size:
+                        try:
+                            cache.popitem(False)
+                        except KeyError:
+                            pass
+
+                def clear(self):
+                    cache.clear()
+
+                def cache_len(self):
+                    return len(cache)
+
+                self.get = types.MethodType(get, self)
+                self.set = types.MethodType(set, self)
+                self.clear = types.MethodType(clear, self)
+                self.__len__ = types.MethodType(cache_len, self)
+
+    else:
+        class _FifoCache(object):
+            def __init__(self, size):
+                self.not_in_cache = not_in_cache = object()
+
+                cache = {}
+                key_fifo = collections.deque([], size)
+
+                def get(self, key):
+                    return cache.get(key, not_in_cache)
+
+                def set(self, key, value):
+                    cache[key] = value
+                    while len(key_fifo) > size:
+                        cache.pop(key_fifo.popleft(), None)
+                    key_fifo.append(key)
+
+                def clear(self):
+                    cache.clear()
+                    key_fifo.clear()
+
+                def cache_len(self):
+                    return len(cache)
+
+                self.get = types.MethodType(get, self)
+                self.set = types.MethodType(set, self)
+                self.clear = types.MethodType(clear, self)
+                self.__len__ = types.MethodType(cache_len, self)
+
+    # argument cache for optimizing repeated calls when backtracking through recursive expressions
+    packrat_cache = {} # this is set later by enabledPackrat(); this is here so that resetCache() doesn't fail
+    packrat_cache_lock = RLock()
+    packrat_cache_stats = [0, 0]
+
+    # this method gets repeatedly called during backtracking with the same arguments -
+    # we can cache these arguments and save ourselves the trouble of re-parsing the contained expression
+    def _parseCache( self, instring, loc, doActions=True, callPreParse=True ):
+        HIT, MISS = 0, 1
+        lookup = (self, instring, loc, callPreParse, doActions)
+        with ParserElement.packrat_cache_lock:
+            cache = ParserElement.packrat_cache
+            value = cache.get(lookup)
+            if value is cache.not_in_cache:
+                ParserElement.packrat_cache_stats[MISS] += 1
+                try:
+                    value = self._parseNoCache(instring, loc, doActions, callPreParse)
+                except ParseBaseException as pe:
+                    # cache a copy of the exception, without the traceback
+                    cache.set(lookup, pe.__class__(*pe.args))
+                    raise
+                else:
+                    cache.set(lookup, (value[0], value[1].copy()))
+                    return value
+            else:
+                ParserElement.packrat_cache_stats[HIT] += 1
+                if isinstance(value, Exception):
+                    raise value
+                return (value[0], value[1].copy())
+
+    _parse = _parseNoCache
+
+    @staticmethod
+    def resetCache():
+        ParserElement.packrat_cache.clear()
+        ParserElement.packrat_cache_stats[:] = [0] * len(ParserElement.packrat_cache_stats)
+
+    _packratEnabled = False
+    @staticmethod
+    def enablePackrat(cache_size_limit=128):
+        """Enables "packrat" parsing, which adds memoizing to the parsing logic.
+           Repeated parse attempts at the same string location (which happens
+           often in many complex grammars) can immediately return a cached value,
+           instead of re-executing parsing/validating code.  Memoizing is done of
+           both valid results and parsing exceptions.
+           
+           Parameters:
+            - cache_size_limit - (default=C{128}) - if an integer value is provided
+              will limit the size of the packrat cache; if None is passed, then
+              the cache size will be unbounded; if 0 is passed, the cache will
+              be effectively disabled.
+            
+           This speedup may break existing programs that use parse actions that
+           have side-effects.  For this reason, packrat parsing is disabled when
+           you first import pyparsing.  To activate the packrat feature, your
+           program must call the class method C{ParserElement.enablePackrat()}.  If
+           your program uses C{psyco} to "compile as you go", you must call
+           C{enablePackrat} before calling C{psyco.full()}.  If you do not do this,
+           Python will crash.  For best results, call C{enablePackrat()} immediately
+           after importing pyparsing.
+           
+           Example::
+               import pyparsing
+               pyparsing.ParserElement.enablePackrat()
+        """
+        if not ParserElement._packratEnabled:
+            ParserElement._packratEnabled = True
+            if cache_size_limit is None:
+                ParserElement.packrat_cache = ParserElement._UnboundedCache()
+            else:
+                ParserElement.packrat_cache = ParserElement._FifoCache(cache_size_limit)
+            ParserElement._parse = ParserElement._parseCache
+
+    def parseString( self, instring, parseAll=False ):
+        """
+        Execute the parse expression with the given string.
+        This is the main interface to the client code, once the complete
+        expression has been built.
+
+        If you want the grammar to require that the entire input string be
+        successfully parsed, then set C{parseAll} to True (equivalent to ending
+        the grammar with C{L{StringEnd()}}).
+
+        Note: C{parseString} implicitly calls C{expandtabs()} on the input string,
+        in order to report proper column numbers in parse actions.
+        If the input string contains tabs and
+        the grammar uses parse actions that use the C{loc} argument to index into the
+        string being parsed, you can ensure you have a consistent view of the input
+        string by:
+         - calling C{parseWithTabs} on your grammar before calling C{parseString}
+           (see L{I{parseWithTabs}<parseWithTabs>})
+         - define your parse action using the full C{(s,loc,toks)} signature, and
+           reference the input string using the parse action's C{s} argument
+         - explictly expand the tabs in your input string before calling
+           C{parseString}
+        
+        Example::
+            Word('a').parseString('aaaaabaaa')  # -> ['aaaaa']
+            Word('a').parseString('aaaaabaaa', parseAll=True)  # -> Exception: Expected end of text
+        """
+        ParserElement.resetCache()
+        if not self.streamlined:
+            self.streamline()
+            #~ self.saveAsList = True
+        for e in self.ignoreExprs:
+            e.streamline()
+        if not self.keepTabs:
+            instring = instring.expandtabs()
+        try:
+            loc, tokens = self._parse( instring, 0 )
+            if parseAll:
+                loc = self.preParse( instring, loc )
+                se = Empty() + StringEnd()
+                se._parse( instring, loc )
+        except ParseBaseException as exc:
+            if ParserElement.verbose_stacktrace:
+                raise
+            else:
+                # catch and re-raise exception from here, clears out pyparsing internal stack trace
+                raise exc
+        else:
+            return tokens
+
+    def scanString( self, instring, maxMatches=_MAX_INT, overlap=False ):
+        """
+        Scan the input string for expression matches.  Each match will return the
+        matching tokens, start location, and end location.  May be called with optional
+        C{maxMatches} argument, to clip scanning after 'n' matches are found.  If
+        C{overlap} is specified, then overlapping matches will be reported.
+
+        Note that the start and end locations are reported relative to the string
+        being parsed.  See L{I{parseString}<parseString>} for more information on parsing
+        strings with embedded tabs.
+
+        Example::
+            source = "sldjf123lsdjjkf345sldkjf879lkjsfd987"
+            print(source)
+            for tokens,start,end in Word(alphas).scanString(source):
+                print(' '*start + '^'*(end-start))
+                print(' '*start + tokens[0])
+        
+        prints::
+        
+            sldjf123lsdjjkf345sldkjf879lkjsfd987
+            ^^^^^
+            sldjf
+                    ^^^^^^^
+                    lsdjjkf
+                              ^^^^^^
+                              sldkjf
+                                       ^^^^^^
+                                       lkjsfd
+        """
+        if not self.streamlined:
+            self.streamline()
+        for e in self.ignoreExprs:
+            e.streamline()
+
+        if not self.keepTabs:
+            instring = _ustr(instring).expandtabs()
+        instrlen = len(instring)
+        loc = 0
+        preparseFn = self.preParse
+        parseFn = self._parse
+        ParserElement.resetCache()
+        matches = 0
+        try:
+            while loc <= instrlen and matches < maxMatches:
+                try:
+                    preloc = preparseFn( instring, loc )
+                    nextLoc,tokens = parseFn( instring, preloc, callPreParse=False )
+                except ParseException:
+                    loc = preloc+1
+                else:
+                    if nextLoc > loc:
+                        matches += 1
+                        yield tokens, preloc, nextLoc
+                        if overlap:
+                            nextloc = preparseFn( instring, loc )
+                            if nextloc > loc:
+                                loc = nextLoc
+                            else:
+                                loc += 1
+                        else:
+                            loc = nextLoc
+                    else:
+                        loc = preloc+1
+        except ParseBaseException as exc:
+            if ParserElement.verbose_stacktrace:
+                raise
+            else:
+                # catch and re-raise exception from here, clears out pyparsing internal stack trace
+                raise exc
+
+    def transformString( self, instring ):
+        """
+        Extension to C{L{scanString}}, to modify matching text with modified tokens that may
+        be returned from a parse action.  To use C{transformString}, define a grammar and
+        attach a parse action to it that modifies the returned token list.
+        Invoking C{transformString()} on a target string will then scan for matches,
+        and replace the matched text patterns according to the logic in the parse
+        action.  C{transformString()} returns the resulting transformed string.
+        
+        Example::
+            wd = Word(alphas)
+            wd.setParseAction(lambda toks: toks[0].title())
+            
+            print(wd.transformString("now is the winter of our discontent made glorious summer by this sun of york."))
+        Prints::
+            Now Is The Winter Of Our Discontent Made Glorious Summer By This Sun Of York.
+        """
+        out = []
+        lastE = 0
+        # force preservation of <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, clears out pyparsing internal stack trace
+                raise exc
+
+    def searchString( self, instring, maxMatches=_MAX_INT ):
+        """
+        Another extension to C{L{scanString}}, simplifying the access to the tokens found
+        to match the given parse expression.  May be called with optional
+        C{maxMatches} argument, to clip searching after 'n' matches are found.
+        
+        Example::
+            # a capitalized word starts with an uppercase letter, followed by zero or more lowercase letters
+            cap_word = Word(alphas.upper(), alphas.lower())
+            
+            print(cap_word.searchString("More than Iron, more than Lead, more than Gold I need Electricity"))
+
+            # the sum() builtin can be used to merge results into a single ParseResults object
+            print(sum(cap_word.searchString("More than Iron, more than Lead, more than Gold I need Electricity")))
+        prints::
+            [['More'], ['Iron'], ['Lead'], ['Gold'], ['I'], ['Electricity']]
+            ['More', 'Iron', 'Lead', 'Gold', 'I', 'Electricity']
+        """
+        try:
+            return ParseResults([ t for t,s,e in self.scanString( instring, maxMatches ) ])
+        except ParseBaseException as exc:
+            if ParserElement.verbose_stacktrace:
+                raise
+            else:
+                # catch and re-raise exception from here, clears out pyparsing internal stack trace
+                raise exc
+
+    def split(self, instring, maxsplit=_MAX_INT, includeSeparators=False):
+        """
+        Generator method to split a string using the given expression as a separator.
+        May be called with optional C{maxsplit} argument, to limit the number of splits;
+        and the optional C{includeSeparators} argument (default=C{False}), if the separating
+        matching text should be included in the split results.
+        
+        Example::        
+            punc = oneOf(list(".,;:/-!?"))
+            print(list(punc.split("This, this?, this sentence, is badly punctuated!")))
+        prints::
+            ['This', ' this', '', ' this sentence', ' is badly punctuated', '']
+        """
+        splits = 0
+        last = 0
+        for t,s,e in self.scanString(instring, maxMatches=maxsplit):
+            yield instring[last:s]
+            if includeSeparators:
+                yield t[0]
+            last = e
+        yield instring[last:]
+
+    def __add__(self, other ):
+        """
+        Implementation of + operator - returns C{L{And}}. Adding strings to a ParserElement
+        converts them to L{Literal}s by default.
+        
+        Example::
+            greet = Word(alphas) + "," + Word(alphas) + "!"
+            hello = "Hello, World!"
+            print (hello, "->", greet.parseString(hello))
+        Prints::
+            Hello, World! -> ['Hello', ',', 'World', '!']
+        """
+        if isinstance( other, basestring ):
+            other = ParserElement._literalStringClass( other )
+        if not isinstance( other, ParserElement ):
+            warnings.warn("Cannot combine element of type %s with ParserElement" % type(other),
+                    SyntaxWarning, stacklevel=2)
+            return None
+        return And( [ self, other ] )
+
+    def __radd__(self, other ):
+        """
+        Implementation of + operator when left operand is not a C{L{ParserElement}}
+        """
+        if isinstance( other, basestring ):
+            other = ParserElement._literalStringClass( other )
+        if not isinstance( other, ParserElement ):
+            warnings.warn("Cannot combine element of type %s with ParserElement" % type(other),
+                    SyntaxWarning, stacklevel=2)
+            return None
+        return other + self
+
+    def __sub__(self, other):
+        """
+        Implementation of - operator, returns C{L{And}} with error stop
+        """
+        if isinstance( other, basestring ):
+            other = ParserElement._literalStringClass( other )
+        if not isinstance( other, ParserElement ):
+            warnings.warn("Cannot combine element of type %s with ParserElement" % type(other),
+                    SyntaxWarning, stacklevel=2)
+            return None
+        return self + And._ErrorStop() + other
+
+    def __rsub__(self, other ):
+        """
+        Implementation of - operator when left operand is not a C{L{ParserElement}}
+        """
+        if isinstance( other, basestring ):
+            other = ParserElement._literalStringClass( other )
+        if not isinstance( other, ParserElement ):
+            warnings.warn("Cannot combine element of type %s with ParserElement" % type(other),
+                    SyntaxWarning, stacklevel=2)
+            return None
+        return other - self
+
+    def __mul__(self,other):
+        """
+        Implementation of * operator, allows use of C{expr * 3} in place of
+        C{expr + expr + expr}.  Expressions may also me multiplied by a 2-integer
+        tuple, similar to C{{min,max}} multipliers in regular expressions.  Tuples
+        may also include C{None} as in:
+         - C{expr*(n,None)} or C{expr*(n,)} is equivalent
+              to C{expr*n + L{ZeroOrMore}(expr)}
+              (read as "at least n instances of C{expr}")
+         - C{expr*(None,n)} is equivalent to C{expr*(0,n)}
+              (read as "0 to n instances of C{expr}")
+         - C{expr*(None,None)} is equivalent to C{L{ZeroOrMore}(expr)}
+         - C{expr*(1,None)} is equivalent to C{L{OneOrMore}(expr)}
+
+        Note that C{expr*(None,n)} does not raise an exception if
+        more than n exprs exist in the input stream; that is,
+        C{expr*(None,n)} does not enforce a maximum number of expr
+        occurrences.  If this behavior is desired, then write
+        C{expr*(None,n) + ~expr}
+        """
+        if isinstance(other,int):
+            minElements, optElements = other,0
+        elif isinstance(other,tuple):
+            other = (other + (None, None))[:2]
+            if other[0] is None:
+                other = (0, other[1])
+            if isinstance(other[0],int) and other[1] is None:
+                if other[0] == 0:
+                    return ZeroOrMore(self)
+                if other[0] == 1:
+                    return OneOrMore(self)
+                else:
+                    return self*other[0] + ZeroOrMore(self)
+            elif isinstance(other[0],int) and isinstance(other[1],int):
+                minElements, optElements = other
+                optElements -= minElements
+            else:
+                raise TypeError("cannot multiply 'ParserElement' and ('%s','%s') objects", type(other[0]),type(other[1]))
+        else:
+            raise TypeError("cannot multiply 'ParserElement' and '%s' objects", type(other))
+
+        if minElements < 0:
+            raise ValueError("cannot multiply ParserElement by negative value")
+        if optElements < 0:
+            raise ValueError("second tuple value must be greater or equal to first tuple value")
+        if minElements == optElements == 0:
+            raise ValueError("cannot multiply ParserElement by 0 or (0,0)")
+
+        if (optElements):
+            def makeOptionalList(n):
+                if n>1:
+                    return Optional(self + makeOptionalList(n-1))
+                else:
+                    return Optional(self)
+            if minElements:
+                if minElements == 1:
+                    ret = self + makeOptionalList(optElements)
+                else:
+                    ret = And([self]*minElements) + makeOptionalList(optElements)
+            else:
+                ret = makeOptionalList(optElements)
+        else:
+            if minElements == 1:
+                ret = self
+            else:
+                ret = And([self]*minElements)
+        return ret
+
+    def __rmul__(self, other):
+        return self.__mul__(other)
+
+    def __or__(self, other ):
+        """
+        Implementation of | operator - returns C{L{MatchFirst}}
+        """
+        if isinstance( other, basestring ):
+            other = ParserElement._literalStringClass( other )
+        if not isinstance( other, ParserElement ):
+            warnings.warn("Cannot combine element of type %s with ParserElement" % type(other),
+                    SyntaxWarning, stacklevel=2)
+            return None
+        return MatchFirst( [ self, other ] )
+
+    def __ror__(self, other ):
+        """
+        Implementation of | operator when left operand is not a C{L{ParserElement}}
+        """
+        if isinstance( other, basestring ):
+            other = ParserElement._literalStringClass( other )
+        if not isinstance( other, ParserElement ):
+            warnings.warn("Cannot combine element of type %s with ParserElement" % type(other),
+                    SyntaxWarning, stacklevel=2)
+            return None
+        return other | self
+
+    def __xor__(self, other ):
+        """
+        Implementation of ^ operator - returns C{L{Or}}
+        """
+        if isinstance( other, basestring ):
+            other = ParserElement._literalStringClass( other )
+        if not isinstance( other, ParserElement ):
+            warnings.warn("Cannot combine element of type %s with ParserElement" % type(other),
+                    SyntaxWarning, stacklevel=2)
+            return None
+        return Or( [ self, other ] )
+
+    def __rxor__(self, other ):
+        """
+        Implementation of ^ operator when left operand is not a C{L{ParserElement}}
+        """
+        if isinstance( other, basestring ):
+            other = ParserElement._literalStringClass( other )
+        if not isinstance( other, ParserElement ):
+            warnings.warn("Cannot combine element of type %s with ParserElement" % type(other),
+                    SyntaxWarning, stacklevel=2)
+            return None
+        return other ^ self
+
+    def __and__(self, other ):
+        """
+        Implementation of & operator - returns C{L{Each}}
+        """
+        if isinstance( other, basestring ):
+            other = ParserElement._literalStringClass( other )
+        if not isinstance( other, ParserElement ):
+            warnings.warn("Cannot combine element of type %s with ParserElement" % type(other),
+                    SyntaxWarning, stacklevel=2)
+            return None
+        return Each( [ self, other ] )
+
+    def __rand__(self, other ):
+        """
+        Implementation of & operator when left operand is not a C{L{ParserElement}}
+        """
+        if isinstance( other, basestring ):
+            other = ParserElement._literalStringClass( other )
+        if not isinstance( other, ParserElement ):
+            warnings.warn("Cannot combine element of type %s with ParserElement" % type(other),
+                    SyntaxWarning, stacklevel=2)
+            return None
+        return other & self
+
+    def __invert__( self ):
+        """
+        Implementation of ~ operator - returns C{L{NotAny}}
+        """
+        return NotAny( self )
+
+    def __call__(self, name=None):
+        """
+        Shortcut for C{L{setResultsName}}, with C{listAllMatches=False}.
+        
+        If C{name} is given with a trailing C{'*'} character, then C{listAllMatches} will be
+        passed as C{True}.
+           
+        If C{name} is omitted, same as calling C{L{copy}}.
+
+        Example::
+            # these are equivalent
+            userdata = Word(alphas).setResultsName("name") + Word(nums+"-").setResultsName("socsecno")
+            userdata = Word(alphas)("name") + Word(nums+"-")("socsecno")             
+        """
+        if name is not None:
+            return self.setResultsName(name)
+        else:
+            return self.copy()
+
+    def suppress( self ):
+        """
+        Suppresses the output of this C{ParserElement}; useful to keep punctuation from
+        cluttering up returned output.
+        """
+        return Suppress( self )
+
+    def leaveWhitespace( self ):
+        """
+        Disables the skipping of whitespace before matching the characters in the
+        C{ParserElement}'s defined pattern.  This is normally only used internally by
+        the pyparsing module, but may be needed in some whitespace-sensitive grammars.
+        """
+        self.skipWhitespace = False
+        return self
+
+    def setWhitespaceChars( self, chars ):
+        """
+        Overrides the default whitespace chars
+        """
+        self.skipWhitespace = True
+        self.whiteChars = chars
+        self.copyDefaultWhiteChars = False
+        return self
+
+    def parseWithTabs( self ):
+        """
+        Overrides default behavior to expand C{<TAB>}s to spaces before parsing the input string.
+        Must be called before C{parseString} when the input grammar contains elements that
+        match C{<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 C{flag} to True to enable, False to disable.
+
+        Example::
+            wd = Word(alphas).setName("alphaword")
+            integer = Word(nums).setName("numword")
+            term = wd | integer
+            
+            # turn on debugging for wd
+            wd.setDebug()
+
+            OneOrMore(term).parseString("abc 123 xyz 890")
+        
+        prints::
+            Match alphaword at loc 0(1,1)
+            Matched alphaword -> ['abc']
+            Match alphaword at loc 3(1,4)
+            Exception raised:Expected alphaword (at char 4), (line:1, col:5)
+            Match alphaword at loc 7(1,8)
+            Matched alphaword -> ['xyz']
+            Match alphaword at loc 11(1,12)
+            Exception raised:Expected alphaword (at char 12), (line:1, col:13)
+            Match alphaword at loc 15(1,16)
+            Exception raised:Expected alphaword (at char 15), (line:1, col:16)
+
+        The output shown is that produced by the default debug actions - custom debug actions can be
+        specified using L{setDebugActions}. Prior to attempting
+        to match the C{wd} expression, the debugging message C{"Match <exprname> at loc <n>(<line>,<col>)"}
+        is shown. Then if the parse succeeds, a C{"Matched"} message is shown, or an C{"Exception raised"}
+        message is shown. Also note the use of L{setName} to assign a human-readable name to the expression,
+        which makes debugging and exception messages easier to understand - for instance, the default
+        name created for the C{Word} expression without calling C{setName} is C{"W:(ABCD...)"}.
+        """
+        if flag:
+            self.setDebugActions( _defaultStartDebugAction, _defaultSuccessDebugAction, _defaultExceptionDebugAction )
+        else:
+            self.debug = False
+        return self
+
+    def __str__( self ):
+        return self.name
+
+    def __repr__( self ):
+        return _ustr(self)
+
+    def streamline( self ):
+        self.streamlined = True
+        self.strRepr = None
+        return self
+
+    def checkRecursion( self, parseElementList ):
+        pass
+
+    def validate( self, validateTrace=[] ):
+        """
+        Check defined expressions for valid structure, check for infinite recursive definitions.
+        """
+        self.checkRecursion( [] )
+
+    def parseFile( self, file_or_filename, parseAll=False ):
+        """
+        Execute the parse expression on the given file or filename.
+        If a filename is specified (instead of a file object),
+        the entire file is opened, read, and closed before parsing.
+        """
+        try:
+            file_contents = file_or_filename.read()
+        except AttributeError:
+            with open(file_or_filename, "r") as f:
+                file_contents = f.read()
+        try:
+            return self.parseString(file_contents, parseAll)
+        except ParseBaseException as exc:
+            if ParserElement.verbose_stacktrace:
+                raise
+            else:
+                # catch and re-raise exception from here, clears out pyparsing internal stack trace
+                raise exc
+
+    def __eq__(self,other):
+        if isinstance(other, ParserElement):
+            return self is other or vars(self) == vars(other)
+        elif isinstance(other, basestring):
+            return self.matches(other)
+        else:
+            return super(ParserElement,self)==other
+
+    def __ne__(self,other):
+        return not (self == other)
+
+    def __hash__(self):
+        return hash(id(self))
+
+    def __req__(self,other):
+        return self == other
+
+    def __rne__(self,other):
+        return not (self == other)
+
+    def matches(self, testString, parseAll=True):
+        """
+        Method for quick testing of a parser against a test string. Good for simple 
+        inline microtests of sub expressions while building up larger parser.
+           
+        Parameters:
+         - testString - to test against this expression for a match
+         - parseAll - (default=C{True}) - flag to pass to C{L{parseString}} when running tests
+            
+        Example::
+            expr = Word(nums)
+            assert expr.matches("100")
+        """
+        try:
+            self.parseString(_ustr(testString), parseAll=parseAll)
+            return True
+        except ParseBaseException:
+            return False
+                
+    def runTests(self, tests, parseAll=True, comment='#', fullDump=True, printResults=True, failureTests=False):
+        """
+        Execute the parse expression on a series of test strings, showing each
+        test, the parsed results or where the parse failed. Quick and easy way to
+        run a parse expression against a list of sample strings.
+           
+        Parameters:
+         - tests - a list of separate test strings, or a multiline string of test strings
+         - parseAll - (default=C{True}) - flag to pass to C{L{parseString}} when running tests           
+         - comment - (default=C{'#'}) - expression for indicating embedded comments in the test 
+              string; pass None to disable comment filtering
+         - fullDump - (default=C{True}) - dump results as list followed by results names in nested outline;
+              if False, only dump nested list
+         - printResults - (default=C{True}) prints test output to stdout
+         - failureTests - (default=C{False}) indicates if these tests are expected to fail parsing
+
+        Returns: a (success, results) tuple, where success indicates that all tests succeeded
+        (or failed if C{failureTests} is True), and the results contain a list of lines of each 
+        test's output
+        
+        Example::
+            number_expr = pyparsing_common.number.copy()
+
+            result = number_expr.runTests('''
+                # unsigned integer
+                100
+                # negative integer
+                -100
+                # float with scientific notation
+                6.02e23
+                # integer with scientific notation
+                1e-12
+                ''')
+            print("Success" if result[0] else "Failed!")
+
+            result = number_expr.runTests('''
+                # stray character
+                100Z
+                # missing leading digit before '.'
+                -.100
+                # too many '.'
+                3.14.159
+                ''', failureTests=True)
+            print("Success" if result[0] else "Failed!")
+        prints::
+            # unsigned integer
+            100
+            [100]
+
+            # negative integer
+            -100
+            [-100]
+
+            # float with scientific notation
+            6.02e23
+            [6.02e+23]
+
+            # integer with scientific notation
+            1e-12
+            [1e-12]
+
+            Success
+            
+            # stray character
+            100Z
+               ^
+            FAIL: Expected end of text (at char 3), (line:1, col:4)
+
+            # missing leading digit before '.'
+            -.100
+            ^
+            FAIL: Expected {real number with scientific notation | real number | signed integer} (at char 0), (line:1, col:1)
+
+            # too many '.'
+            3.14.159
+                ^
+            FAIL: Expected end of text (at char 4), (line:1, col:5)
+
+            Success
+
+        Each test string must be on a single line. If you want to test a string that spans multiple
+        lines, create a test like this::
+
+            expr.runTest(r"this is a test\\n of strings that spans \\n 3 lines")
+        
+        (Note that this is a raw string literal, you must include the leading 'r'.)
+        """
+        if isinstance(tests, basestring):
+            tests = list(map(str.strip, tests.rstrip().splitlines()))
+        if isinstance(comment, basestring):
+            comment = Literal(comment)
+        allResults = []
+        comments = []
+        success = True
+        for t in tests:
+            if comment is not None and comment.matches(t, False) or comments and not t:
+                comments.append(t)
+                continue
+            if not t:
+                continue
+            out = ['\n'.join(comments), t]
+            comments = []
+            try:
+                t = t.replace(r'\n','\n')
+                result = self.parseString(t, parseAll=parseAll)
+                out.append(result.dump(full=fullDump))
+                success = success and not failureTests
+            except ParseBaseException as pe:
+                fatal = "(FATAL)" if isinstance(pe, ParseFatalException) else ""
+                if '\n' in t:
+                    out.append(line(pe.loc, t))
+                    out.append(' '*(col(pe.loc,t)-1) + '^' + fatal)
+                else:
+                    out.append(' '*pe.loc + '^' + fatal)
+                out.append("FAIL: " + str(pe))
+                success = success and failureTests
+                result = pe
+            except Exception as exc:
+                out.append("FAIL-EXCEPTION: " + str(exc))
+                success = success and failureTests
+                result = exc
+
+            if printResults:
+                if fullDump:
+                    out.append('')
+                print('\n'.join(out))
+
+            allResults.append((t, result))
+        
+        return success, allResults
+
+        
+class Token(ParserElement):
+    """
+    Abstract C{ParserElement} subclass, for defining atomic matching patterns.
+    """
+    def __init__( self ):
+        super(Token,self).__init__( savelist=False )
+
+
+class Empty(Token):
+    """
+    An empty token, will always match.
+    """
+    def __init__( self ):
+        super(Empty,self).__init__()
+        self.name = "Empty"
+        self.mayReturnEmpty = True
+        self.mayIndexError = False
+
+
+class NoMatch(Token):
+    """
+    A token that will never match.
+    """
+    def __init__( self ):
+        super(NoMatch,self).__init__()
+        self.name = "NoMatch"
+        self.mayReturnEmpty = True
+        self.mayIndexError = False
+        self.errmsg = "Unmatchable token"
+
+    def parseImpl( self, instring, loc, doActions=True ):
+        raise ParseException(instring, loc, self.errmsg, self)
+
+
+class Literal(Token):
+    """
+    Token to exactly match a specified string.
+    
+    Example::
+        Literal('blah').parseString('blah')  # -> ['blah']
+        Literal('blah').parseString('blahfooblah')  # -> ['blah']
+        Literal('blah').parseString('bla')  # -> Exception: Expected "blah"
+    
+    For case-insensitive matching, use L{CaselessLiteral}.
+    
+    For keyword matching (force word break before and after the matched string),
+    use L{Keyword} or L{CaselessKeyword}.
+    """
+    def __init__( self, matchString ):
+        super(Literal,self).__init__()
+        self.match = matchString
+        self.matchLen = len(matchString)
+        try:
+            self.firstMatchChar = matchString[0]
+        except IndexError:
+            warnings.warn("null string passed to Literal; use Empty() instead",
+                            SyntaxWarning, stacklevel=2)
+            self.__class__ = Empty
+        self.name = '"%s"' % _ustr(self.match)
+        self.errmsg = "Expected " + self.name
+        self.mayReturnEmpty = False
+        self.mayIndexError = False
+
+    # Performance tuning: this routine gets called a *lot*
+    # if this is a single character match string  and the first character matches,
+    # short-circuit as quickly as possible, and avoid calling startswith
+    #~ @profile
+    def parseImpl( self, instring, loc, doActions=True ):
+        if (instring[loc] == self.firstMatchChar and
+            (self.matchLen==1 or instring.startswith(self.match,loc)) ):
+            return loc+self.matchLen, self.match
+        raise ParseException(instring, loc, self.errmsg, self)
+_L = Literal
+ParserElement._literalStringClass = Literal
+
+class Keyword(Token):
+    """
+    Token to exactly match a specified string as a keyword, that is, it must be
+    immediately followed by a non-keyword character.  Compare with C{L{Literal}}:
+     - C{Literal("if")} will match the leading C{'if'} in C{'ifAndOnlyIf'}.
+     - C{Keyword("if")} will not; it will only match the leading C{'if'} in C{'if x=1'}, or C{'if(y==2)'}
+    Accepts two optional constructor arguments in addition to the keyword string:
+     - C{identChars} is a string of characters that would be valid identifier characters,
+          defaulting to all alphanumerics + "_" and "$"
+     - C{caseless} allows case-insensitive matching, default is C{False}.
+       
+    Example::
+        Keyword("start").parseString("start")  # -> ['start']
+        Keyword("start").parseString("starting")  # -> Exception
+
+    For case-insensitive matching, use L{CaselessKeyword}.
+    """
+    DEFAULT_KEYWORD_CHARS = alphanums+"_$"
+
+    def __init__( self, matchString, identChars=None, caseless=False ):
+        super(Keyword,self).__init__()
+        if identChars is None:
+            identChars = Keyword.DEFAULT_KEYWORD_CHARS
+        self.match = matchString
+        self.matchLen = len(matchString)
+        try:
+            self.firstMatchChar = matchString[0]
+        except IndexError:
+            warnings.warn("null string passed to Keyword; use Empty() instead",
+                            SyntaxWarning, stacklevel=2)
+        self.name = '"%s"' % self.match
+        self.errmsg = "Expected " + self.name
+        self.mayReturnEmpty = False
+        self.mayIndexError = False
+        self.caseless = caseless
+        if caseless:
+            self.caselessmatch = matchString.upper()
+            identChars = identChars.upper()
+        self.identChars = set(identChars)
+
+    def parseImpl( self, instring, loc, doActions=True ):
+        if self.caseless:
+            if ( (instring[ loc:loc+self.matchLen ].upper() == self.caselessmatch) and
+                 (loc >= len(instring)-self.matchLen or instring[loc+self.matchLen].upper() not in self.identChars) and
+                 (loc == 0 or instring[loc-1].upper() not in self.identChars) ):
+                return loc+self.matchLen, self.match
+        else:
+            if (instring[loc] == self.firstMatchChar and
+                (self.matchLen==1 or instring.startswith(self.match,loc)) and
+                (loc >= len(instring)-self.matchLen or instring[loc+self.matchLen] not in self.identChars) and
+                (loc == 0 or instring[loc-1] not in self.identChars) ):
+                return loc+self.matchLen, self.match
+        raise ParseException(instring, loc, self.errmsg, self)
+
+    def copy(self):
+        c = super(Keyword,self).copy()
+        c.identChars = Keyword.DEFAULT_KEYWORD_CHARS
+        return c
+
+    @staticmethod
+    def setDefaultKeywordChars( chars ):
+        """Overrides the default Keyword chars
+        """
+        Keyword.DEFAULT_KEYWORD_CHARS = chars
+
+class CaselessLiteral(Literal):
+    """
+    Token to match a specified string, ignoring case of letters.
+    Note: the matched results will always be in the case of the given
+    match string, NOT the case of the input text.
+
+    Example::
+        OneOrMore(CaselessLiteral("CMD")).parseString("cmd CMD Cmd10") # -> ['CMD', 'CMD', 'CMD']
+        
+    (Contrast with example for L{CaselessKeyword}.)
+    """
+    def __init__( self, matchString ):
+        super(CaselessLiteral,self).__init__( matchString.upper() )
+        # Preserve the defining literal.
+        self.returnString = matchString
+        self.name = "'%s'" % self.returnString
+        self.errmsg = "Expected " + self.name
+
+    def parseImpl( self, instring, loc, doActions=True ):
+        if instring[ loc:loc+self.matchLen ].upper() == self.match:
+            return loc+self.matchLen, self.returnString
+        raise ParseException(instring, loc, self.errmsg, self)
+
+class CaselessKeyword(Keyword):
+    """
+    Caseless version of L{Keyword}.
+
+    Example::
+        OneOrMore(CaselessKeyword("CMD")).parseString("cmd CMD Cmd10") # -> ['CMD', 'CMD']
+        
+    (Contrast with example for L{CaselessLiteral}.)
+    """
+    def __init__( self, matchString, identChars=None ):
+        super(CaselessKeyword,self).__init__( matchString, identChars, caseless=True )
+
+    def parseImpl( self, instring, loc, doActions=True ):
+        if ( (instring[ loc:loc+self.matchLen ].upper() == self.caselessmatch) and
+             (loc >= len(instring)-self.matchLen or instring[loc+self.matchLen].upper() not in self.identChars) ):
+            return loc+self.matchLen, self.match
+        raise ParseException(instring, loc, self.errmsg, self)
+
+class CloseMatch(Token):
+    """
+    A variation on L{Literal} which matches "close" matches, that is, 
+    strings with at most 'n' mismatching characters. C{CloseMatch} takes parameters:
+     - C{match_string} - string to be matched
+     - C{maxMismatches} - (C{default=1}) maximum number of mismatches allowed to count as a match
+    
+    The results from a successful parse will contain the matched text from the input string and the following named results:
+     - C{mismatches} - a list of the positions within the match_string where mismatches were found
+     - C{original} - the original match_string used to compare against the input string
+    
+    If C{mismatches} is an empty list, then the match was an exact match.
+    
+    Example::
+        patt = CloseMatch("ATCATCGAATGGA")
+        patt.parseString("ATCATCGAAXGGA") # -> (['ATCATCGAAXGGA'], {'mismatches': [[9]], 'original': ['ATCATCGAATGGA']})
+        patt.parseString("ATCAXCGAAXGGA") # -> Exception: Expected 'ATCATCGAATGGA' (with up to 1 mismatches) (at char 0), (line:1, col:1)
+
+        # exact match
+        patt.parseString("ATCATCGAATGGA") # -> (['ATCATCGAATGGA'], {'mismatches': [[]], 'original': ['ATCATCGAATGGA']})
+
+        # close match allowing up to 2 mismatches
+        patt = CloseMatch("ATCATCGAATGGA", maxMismatches=2)
+        patt.parseString("ATCAXCGAAXGGA") # -> (['ATCAXCGAAXGGA'], {'mismatches': [[4, 9]], 'original': ['ATCATCGAATGGA']})
+    """
+    def __init__(self, match_string, maxMismatches=1):
+        super(CloseMatch,self).__init__()
+        self.name = match_string
+        self.match_string = match_string
+        self.maxMismatches = maxMismatches
+        self.errmsg = "Expected %r (with up to %d mismatches)" % (self.match_string, self.maxMismatches)
+        self.mayIndexError = False
+        self.mayReturnEmpty = False
+
+    def parseImpl( self, instring, loc, doActions=True ):
+        start = loc
+        instrlen = len(instring)
+        maxloc = start + len(self.match_string)
+
+        if maxloc <= instrlen:
+            match_string = self.match_string
+            match_stringloc = 0
+            mismatches = []
+            maxMismatches = self.maxMismatches
+
+            for match_stringloc,s_m in enumerate(zip(instring[loc:maxloc], self.match_string)):
+                src,mat = s_m
+                if src != mat:
+                    mismatches.append(match_stringloc)
+                    if len(mismatches) > maxMismatches:
+                        break
+            else:
+                loc = match_stringloc + 1
+                results = ParseResults([instring[start:loc]])
+                results['original'] = self.match_string
+                results['mismatches'] = mismatches
+                return loc, results
+
+        raise ParseException(instring, loc, self.errmsg, self)
+
+
+class Word(Token):
+    """
+    Token for matching words composed of allowed character sets.
+    Defined with string containing all allowed initial characters,
+    an optional string containing allowed body characters (if omitted,
+    defaults to the initial character set), and an optional minimum,
+    maximum, and/or exact length.  The default value for C{min} is 1 (a
+    minimum value < 1 is not valid); the default values for C{max} and C{exact}
+    are 0, meaning no maximum or exact length restriction. An optional
+    C{excludeChars} parameter can list characters that might be found in 
+    the input C{bodyChars} string; useful to define a word of all printables
+    except for one or two characters, for instance.
+    
+    L{srange} is useful for defining custom character set strings for defining 
+    C{Word} expressions, using range notation from regular expression character sets.
+    
+    A common mistake is to use C{Word} to match a specific literal string, as in 
+    C{Word("Address")}. Remember that C{Word} uses the string argument to define
+    I{sets} of matchable characters. This expression would match "Add", "AAA",
+    "dAred", or any other word made up of the characters 'A', 'd', 'r', 'e', and 's'.
+    To match an exact literal string, use L{Literal} or L{Keyword}.
+
+    pyparsing includes helper strings for building Words:
+     - L{alphas}
+     - L{nums}
+     - L{alphanums}
+     - L{hexnums}
+     - L{alphas8bit} (alphabetic characters in ASCII range 128-255 - accented, tilded, umlauted, etc.)
+     - L{punc8bit} (non-alphabetic characters in ASCII range 128-255 - currency, symbols, superscripts, diacriticals, etc.)
+     - L{printables} (any non-whitespace character)
+
+    Example::
+        # a word composed of digits
+        integer = Word(nums) # equivalent to Word("0123456789") or Word(srange("0-9"))
+        
+        # a word with a leading capital, and zero or more lowercase
+        capital_word = Word(alphas.upper(), alphas.lower())
+
+        # hostnames are alphanumeric, with leading alpha, and '-'
+        hostname = Word(alphas, alphanums+'-')
+        
+        # roman numeral (not a strict parser, accepts invalid mix of characters)
+        roman = Word("IVXLCDM")
+        
+        # any string of non-whitespace characters, except for ','
+        csv_value = Word(printables, excludeChars=",")
+    """
+    def __init__( self, initChars, bodyChars=None, min=1, max=0, exact=0, asKeyword=False, excludeChars=None ):
+        super(Word,self).__init__()
+        if excludeChars:
+            initChars = ''.join(c for c in initChars if c not in excludeChars)
+            if bodyChars:
+                bodyChars = ''.join(c for c in bodyChars if c not in excludeChars)
+        self.initCharsOrig = initChars
+        self.initChars = set(initChars)
+        if bodyChars :
+            self.bodyCharsOrig = bodyChars
+            self.bodyChars = set(bodyChars)
+        else:
+            self.bodyCharsOrig = initChars
+            self.bodyChars = set(initChars)
+
+        self.maxSpecified = max > 0
+
+        if min < 1:
+            raise ValueError("cannot specify a minimum length < 1; use Optional(Word()) if zero-length word is permitted")
+
+        self.minLen = min
+
+        if max > 0:
+            self.maxLen = max
+        else:
+            self.maxLen = _MAX_INT
+
+        if exact > 0:
+            self.maxLen = exact
+            self.minLen = exact
+
+        self.name = _ustr(self)
+        self.errmsg = "Expected " + self.name
+        self.mayIndexError = False
+        self.asKeyword = asKeyword
+
+        if ' ' not in self.initCharsOrig+self.bodyCharsOrig and (min==1 and max==0 and exact==0):
+            if self.bodyCharsOrig == self.initCharsOrig:
+                self.reString = "[%s]+" % _escapeRegexRangeChars(self.initCharsOrig)
+            elif len(self.initCharsOrig) == 1:
+                self.reString = "%s[%s]*" % \
+                                      (re.escape(self.initCharsOrig),
+                                      _escapeRegexRangeChars(self.bodyCharsOrig),)
+            else:
+                self.reString = "[%s][%s]*" % \
+                                      (_escapeRegexRangeChars(self.initCharsOrig),
+                                      _escapeRegexRangeChars(self.bodyCharsOrig),)
+            if self.asKeyword:
+                self.reString = r"\b"+self.reString+r"\b"
+            try:
+                self.re = re.compile( self.reString )
+            except Exception:
+                self.re = None
+
+    def parseImpl( self, instring, loc, doActions=True ):
+        if self.re:
+            result = self.re.match(instring,loc)
+            if not result:
+                raise ParseException(instring, loc, self.errmsg, self)
+
+            loc = result.end()
+            return loc, result.group()
+
+        if not(instring[ loc ] in self.initChars):
+            raise ParseException(instring, loc, self.errmsg, self)
+
+        start = loc
+        loc += 1
+        instrlen = len(instring)
+        bodychars = self.bodyChars
+        maxloc = start + self.maxLen
+        maxloc = min( maxloc, instrlen )
+        while loc < maxloc and instring[loc] in bodychars:
+            loc += 1
+
+        throwException = False
+        if loc - start < self.minLen:
+            throwException = True
+        if self.maxSpecified and loc < instrlen and instring[loc] in bodychars:
+            throwException = True
+        if self.asKeyword:
+            if (start>0 and instring[start-1] in bodychars) or (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 Regex(Token):
+    r"""
+    Token for matching strings that match a given regular expression.
+    Defined with string specifying the regular expression in a form recognized by the inbuilt Python re module.
+    If the given regex contains named groups (defined using C{(?P<name>...)}), these will be preserved as 
+    named parse results.
+
+    Example::
+        realnum = Regex(r"[+-]?\d+\.\d*")
+        date = Regex(r'(?P<year>\d{4})-(?P<month>\d\d?)-(?P<day>\d\d?)')
+        # ref: http://stackoverflow.com/questions/267399/how-do-you-match-only-valid-roman-numerals-with-a-regular-expression
+        roman = Regex(r"M{0,4}(CM|CD|D?C{0,3})(XC|XL|L?X{0,3})(IX|IV|V?I{0,3})")
+    """
+    compiledREtype = type(re.compile("[A-Z]"))
+    def __init__( self, pattern, flags=0):
+        """The parameters C{pattern} and C{flags} are passed to the C{re.compile()} function as-is. See the Python C{re} module for an explanation of the acceptable patterns and flags."""
+        super(Regex,self).__init__()
+
+        if isinstance(pattern, basestring):
+            if not pattern:
+                warnings.warn("null string passed to Regex; use Empty() instead",
+                        SyntaxWarning, stacklevel=2)
+
+            self.pattern = pattern
+            self.flags = flags
+
+            try:
+                self.re = re.compile(self.pattern, self.flags)
+                self.reString = self.pattern
+            except sre_constants.error:
+                warnings.warn("invalid pattern (%s) passed to Regex" % pattern,
+                    SyntaxWarning, stacklevel=2)
+                raise
+
+        elif isinstance(pattern, Regex.compiledREtype):
+            self.re = pattern
+            self.pattern = \
+            self.reString = str(pattern)
+            self.flags = flags
+            
+        else:
+            raise ValueError("Regex may only be constructed with a string or a compiled RE object")
+
+        self.name = _ustr(self)
+        self.errmsg = "Expected " + self.name
+        self.mayIndexError = False
+        self.mayReturnEmpty = True
+
+    def parseImpl( self, instring, loc, doActions=True ):
+        result = self.re.match(instring,loc)
+        if not result:
+            raise ParseException(instring, loc, self.errmsg, self)
+
+        loc = result.end()
+        d = result.groupdict()
+        ret = ParseResults(result.group())
+        if d:
+            for k in d:
+                ret[k] = d[k]
+        return loc,ret
+
+    def __str__( self ):
+        try:
+            return super(Regex,self).__str__()
+        except Exception:
+            pass
+
+        if self.strRepr is None:
+            self.strRepr = "Re:(%s)" % repr(self.pattern)
+
+        return self.strRepr
+
+
+class QuotedString(Token):
+    r"""
+    Token for matching strings that are delimited by quoting characters.
+    
+    Defined with the following parameters:
+        - quoteChar - string of one or more characters defining the quote delimiting string
+        - escChar - character to escape quotes, typically backslash (default=C{None})
+        - escQuote - special quote sequence to escape an embedded quote string (such as SQL's "" to escape an embedded ") (default=C{None})
+        - multiline - boolean indicating whether quotes can span multiple lines (default=C{False})
+        - unquoteResults - boolean indicating whether the matched text should be unquoted (default=C{True})
+        - endQuoteChar - string of one or more characters defining the end of the quote delimited string (default=C{None} => same as quoteChar)
+        - convertWhitespaceEscapes - convert escaped whitespace (C{'\t'}, C{'\n'}, etc.) to actual whitespace (default=C{True})
+
+    Example::
+        qs = QuotedString('"')
+        print(qs.searchString('lsjdf "This is the quote" sldjf'))
+        complex_qs = QuotedString('{{', endQuoteChar='}}')
+        print(complex_qs.searchString('lsjdf {{This is the "quote"}} sldjf'))
+        sql_qs = QuotedString('"', escQuote='""')
+        print(sql_qs.searchString('lsjdf "This is the quote with ""embedded"" quotes" sldjf'))
+    prints::
+        [['This is the quote']]
+        [['This is the "quote"']]
+        [['This is the quote with "embedded" quotes']]
+    """
+    def __init__( self, quoteChar, escChar=None, escQuote=None, multiline=False, unquoteResults=True, endQuoteChar=None, convertWhitespaceEscapes=True):
+        super(QuotedString,self).__init__()
+
+        # remove white space from quote chars - wont work anyway
+        quoteChar = quoteChar.strip()
+        if not quoteChar:
+            warnings.warn("quoteChar cannot be the empty string",SyntaxWarning,stacklevel=2)
+            raise SyntaxError()
+
+        if endQuoteChar is None:
+            endQuoteChar = quoteChar
+        else:
+            endQuoteChar = endQuoteChar.strip()
+            if not endQuoteChar:
+                warnings.warn("endQuoteChar cannot be the empty string",SyntaxWarning,stacklevel=2)
+                raise SyntaxError()
+
+        self.quoteChar = quoteChar
+        self.quoteCharLen = len(quoteChar)
+        self.firstQuoteChar = quoteChar[0]
+        self.endQuoteChar = endQuoteChar
+        self.endQuoteCharLen = len(endQuoteChar)
+        self.escChar = escChar
+        self.escQuote = escQuote
+        self.unquoteResults = unquoteResults
+        self.convertWhitespaceEscapes = convertWhitespaceEscapes
+
+        if multiline:
+            self.flags = re.MULTILINE | re.DOTALL
+            self.pattern = r'%s(?:[^%s%s]' % \
+                ( re.escape(self.quoteChar),
+                  _escapeRegexRangeChars(self.endQuoteChar[0]),
+                  (escChar is not None and _escapeRegexRangeChars(escChar) or '') )
+        else:
+            self.flags = 0
+            self.pattern = r'%s(?:[^%s\n\r%s]' % \
+                ( re.escape(self.quoteChar),
+                  _escapeRegexRangeChars(self.endQuoteChar[0]),
+                  (escChar is not None and _escapeRegexRangeChars(escChar) or '') )
+        if len(self.endQuoteChar) > 1:
+            self.pattern += (
+                '|(?:' + ')|(?:'.join("%s[^%s]" % (re.escape(self.endQuoteChar[:i]),
+                                               _escapeRegexRangeChars(self.endQuoteChar[i]))
+                                    for i in range(len(self.endQuoteChar)-1,0,-1)) + ')'
+                )
+        if escQuote:
+            self.pattern += (r'|(?:%s)' % re.escape(escQuote))
+        if escChar:
+            self.pattern += (r'|(?:%s.)' % re.escape(escChar))
+            self.escCharReplacePattern = re.escape(self.escChar)+"(.)"
+        self.pattern += (r')*%s' % re.escape(self.endQuoteChar))
+
+        try:
+            self.re = re.compile(self.pattern, self.flags)
+            self.reString = self.pattern
+        except sre_constants.error:
+            warnings.warn("invalid pattern (%s) passed to Regex" % self.pattern,
+                SyntaxWarning, stacklevel=2)
+            raise
+
+        self.name = _ustr(self)
+        self.errmsg = "Expected " + self.name
+        self.mayIndexError = False
+        self.mayReturnEmpty = True
+
+    def parseImpl( self, instring, loc, doActions=True ):
+        result = instring[loc] == self.firstQuoteChar and self.re.match(instring,loc) or None
+        if not result:
+            raise ParseException(instring, loc, self.errmsg, self)
+
+        loc = result.end()
+        ret = result.group()
+
+        if self.unquoteResults:
+
+            # strip off quotes
+            ret = ret[self.quoteCharLen:-self.endQuoteCharLen]
+
+            if isinstance(ret,basestring):
+                # replace escaped whitespace
+                if '\\' in ret and self.convertWhitespaceEscapes:
+                    ws_map = {
+                        r'\t' : '\t',
+                        r'\n' : '\n',
+                        r'\f' : '\f',
+                        r'\r' : '\r',
+                    }
+                    for wslit,wschar in ws_map.items():
+                        ret = ret.replace(wslit, wschar)
+
+                # replace escaped characters
+                if self.escChar:
+                    ret = re.sub(self.escCharReplacePattern, r"\g<1>", ret)
+
+                # replace escaped quotes
+                if self.escQuote:
+                    ret = ret.replace(self.escQuote, self.endQuoteChar)
+
+        return loc, ret
+
+    def __str__( self ):
+        try:
+            return super(QuotedString,self).__str__()
+        except Exception:
+            pass
+
+        if self.strRepr is None:
+            self.strRepr = "quoted string, starting with %s ending with %s" % (self.quoteChar, self.endQuoteChar)
+
+        return self.strRepr
+
+
+class CharsNotIn(Token):
+    """
+    Token for matching words composed of characters I{not} in a given set (will
+    include whitespace in matched characters if not listed in the provided exclusion set - see example).
+    Defined with string containing all disallowed characters, and an optional
+    minimum, maximum, and/or exact length.  The default value for C{min} is 1 (a
+    minimum value < 1 is not valid); the default values for C{max} and C{exact}
+    are 0, meaning no maximum or exact length restriction.
+
+    Example::
+        # define a comma-separated-value as anything that is not a ','
+        csv_value = CharsNotIn(',')
+        print(delimitedList(csv_value).parseString("dkls,lsdkjf,s12 34,@!#,213"))
+    prints::
+        ['dkls', 'lsdkjf', 's12 34', '@!#', '213']
+    """
+    def __init__( self, notChars, min=1, max=0, exact=0 ):
+        super(CharsNotIn,self).__init__()
+        self.skipWhitespace = False
+        self.notChars = notChars
+
+        if min < 1:
+            raise ValueError("cannot specify a minimum length < 1; use Optional(CharsNotIn()) if zero-length char group is permitted")
+
+        self.minLen = min
+
+        if max > 0:
+            self.maxLen = max
+        else:
+            self.maxLen = _MAX_INT
+
+        if exact > 0:
+            self.maxLen = exact
+            self.minLen = exact
+
+        self.name = _ustr(self)
+        self.errmsg = "Expected " + self.name
+        self.mayReturnEmpty = ( self.minLen == 0 )
+        self.mayIndexError = False
+
+    def parseImpl( self, instring, loc, doActions=True ):
+        if instring[loc] in self.notChars:
+            raise ParseException(instring, loc, self.errmsg, self)
+
+        start = loc
+        loc += 1
+        notchars = self.notChars
+        maxlen = min( start+self.maxLen, len(instring) )
+        while loc < maxlen and \
+              (instring[loc] not in notchars):
+            loc += 1
+
+        if loc - start < self.minLen:
+            raise ParseException(instring, loc, self.errmsg, self)
+
+        return loc, instring[start:loc]
+
+    def __str__( self ):
+        try:
+            return super(CharsNotIn, self).__str__()
+        except Exception:
+            pass
+
+        if self.strRepr is None:
+            if len(self.notChars) > 4:
+                self.strRepr = "!W:(%s...)" % self.notChars[:4]
+            else:
+                self.strRepr = "!W:(%s)" % self.notChars
+
+        return self.strRepr
+
+class White(Token):
+    """
+    Special matching class for matching whitespace.  Normally, whitespace is ignored
+    by pyparsing grammars.  This class is included when some whitespace structures
+    are significant.  Define with a string containing the whitespace characters to be
+    matched; default is C{" \\t\\r\\n"}.  Also takes optional C{min}, C{max}, and C{exact} arguments,
+    as defined for the C{L{Word}} class.
+    """
+    whiteStrs = {
+        " " : "<SPC>",
+        "\t": "<TAB>",
+        "\n": "<LF>",
+        "\r": "<CR>",
+        "\f": "<FF>",
+        }
+    def __init__(self, ws=" \t\r\n", min=1, max=0, exact=0):
+        super(White,self).__init__()
+        self.matchWhite = ws
+        self.setWhitespaceChars( "".join(c for c in self.whiteChars if c not in self.matchWhite) )
+        #~ self.leaveWhitespace()
+        self.name = ("".join(White.whiteStrs[c] for c in self.matchWhite))
+        self.mayReturnEmpty = True
+        self.errmsg = "Expected " + self.name
+
+        self.minLen = min
+
+        if max > 0:
+            self.maxLen = max
+        else:
+            self.maxLen = _MAX_INT
+
+        if exact > 0:
+            self.maxLen = exact
+            self.minLen = exact
+
+    def parseImpl( self, instring, loc, doActions=True ):
+        if not(instring[ loc ] in self.matchWhite):
+            raise ParseException(instring, loc, self.errmsg, self)
+        start = loc
+        loc += 1
+        maxloc = start + self.maxLen
+        maxloc = min( maxloc, len(instring) )
+        while loc < maxloc and instring[loc] in self.matchWhite:
+            loc += 1
+
+        if loc - start < self.minLen:
+            raise ParseException(instring, loc, self.errmsg, self)
+
+        return loc, instring[start:loc]
+
+
+class _PositionToken(Token):
+    def __init__( self ):
+        super(_PositionToken,self).__init__()
+        self.name=self.__class__.__name__
+        self.mayReturnEmpty = True
+        self.mayIndexError = False
+
+class GoToColumn(_PositionToken):
+    """
+    Token to advance to a specific column of input text; useful for tabular report scraping.
+    """
+    def __init__( self, colno ):
+        super(GoToColumn,self).__init__()
+        self.col = colno
+
+    def preParse( self, instring, loc ):
+        if col(loc,instring) != self.col:
+            instrlen = len(instring)
+            if self.ignoreExprs:
+                loc = self._skipIgnorables( instring, loc )
+            while loc < instrlen and instring[loc].isspace() and col( loc, instring ) != self.col :
+                loc += 1
+        return loc
+
+    def parseImpl( self, instring, loc, doActions=True ):
+        thiscol = col( loc, instring )
+        if thiscol > self.col:
+            raise ParseException( instring, loc, "Text not in expected column", self )
+        newloc = loc + self.col - thiscol
+        ret = instring[ loc: newloc ]
+        return newloc, ret
+
+
+class LineStart(_PositionToken):
+    """
+    Matches if current position is at the beginning of a line within the parse string
+    
+    Example::
+    
+        test = '''\
+        AAA this line
+        AAA and this line
+          AAA but not this one
+        B AAA and definitely not this one
+        '''
+
+        for t in (LineStart() + 'AAA' + restOfLine).searchString(test):
+            print(t)
+    
+    Prints::
+        ['AAA', ' this line']
+        ['AAA', ' and this line']    
+
+    """
+    def __init__( self ):
+        super(LineStart,self).__init__()
+        self.errmsg = "Expected start of line"
+
+    def parseImpl( self, instring, loc, doActions=True ):
+        if col(loc, instring) == 1:
+            return loc, []
+        raise ParseException(instring, loc, self.errmsg, self)
+
+class LineEnd(_PositionToken):
+    """
+    Matches if current position is at the end of a line within the parse string
+    """
+    def __init__( self ):
+        super(LineEnd,self).__init__()
+        self.setWhitespaceChars( ParserElement.DEFAULT_WHITE_CHARS.replace("\n","") )
+        self.errmsg = "Expected end of line"
+
+    def parseImpl( self, instring, loc, doActions=True ):
+        if loc<len(instring):
+            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 C{wordChars}
+    (default=C{printables}). To emulate the C{\b} behavior of regular expressions,
+    use C{WordStart(alphanums)}. C{WordStart} will also match at the beginning of
+    the string being parsed, or at the beginning of a line.
+    """
+    def __init__(self, wordChars = printables):
+        super(WordStart,self).__init__()
+        self.wordChars = set(wordChars)
+        self.errmsg = "Not at the start of a word"
+
+    def parseImpl(self, instring, loc, doActions=True ):
+        if loc != 0:
+            if (instring[loc-1] in self.wordChars or
+                instring[loc] not in self.wordChars):
+                raise ParseException(instring, loc, self.errmsg, self)
+        return loc, []
+
+class WordEnd(_PositionToken):
+    """
+    Matches if the current position is at the end of a Word, and
+    is not followed by any character in a given set of C{wordChars}
+    (default=C{printables}). To emulate the C{\b} behavior of regular expressions,
+    use C{WordEnd(alphanums)}. C{WordEnd} will also match at the end of
+    the string being parsed, or at the end of a line.
+    """
+    def __init__(self, wordChars = printables):
+        super(WordEnd,self).__init__()
+        self.wordChars = set(wordChars)
+        self.skipWhitespace = False
+        self.errmsg = "Not at the end of a word"
+
+    def parseImpl(self, instring, loc, doActions=True ):
+        instrlen = len(instring)
+        if instrlen>0 and loc<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 = [ ParserElement._literalStringClass( exprs ) ]
+        elif isinstance( exprs, Iterable ):
+            exprs = list(exprs)
+            # if sequence of strings provided, wrap with Literal
+            if all(isinstance(expr, basestring) for expr in exprs):
+                exprs = map(ParserElement._literalStringClass, exprs)
+            self.exprs = list(exprs)
+        else:
+            try:
+                self.exprs = list( exprs )
+            except TypeError:
+                self.exprs = [ exprs ]
+        self.callPreparse = False
+
+    def __getitem__( self, i ):
+        return self.exprs[i]
+
+    def append( self, other ):
+        self.exprs.append( other )
+        self.strRepr = None
+        return self
+
+    def leaveWhitespace( self ):
+        """Extends C{leaveWhitespace} defined in base class, and also invokes C{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 setResultsName( self, name, listAllMatches=False ):
+        ret = super(ParseExpression,self).setResultsName(name,listAllMatches)
+        return ret
+
+    def validate( self, validateTrace=[] ):
+        tmp = validateTrace[:]+[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
+
+class And(ParseExpression):
+    """
+    Requires all given C{ParseExpression}s to be found in the given order.
+    Expressions may be separated by whitespace.
+    May be constructed using the C{'+'} operator.
+    May also be constructed using the C{'-'} 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 ):
+        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 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 = ParserElement._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 C{ParseExpression} is found.
+    If two expressions match, the expression that matches the longest string will be used.
+    May be constructed using the C{'^'} 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 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:
+            matches.sort(key=lambda x: -x[0])
+            for _,e in matches:
+                try:
+                    return e._parse( instring, loc, doActions )
+                except ParseException as err:
+                    err.__traceback__ = None
+                    if err.loc > maxExcLoc:
+                        maxException = err
+                        maxExcLoc = err.loc
+
+        if maxException is not None:
+            maxException.msg = self.errmsg
+            raise maxException
+        else:
+            raise ParseException(instring, loc, "no defined alternatives to match", self)
+
+
+    def __ixor__(self, other ):
+        if isinstance( other, basestring ):
+            other = ParserElement._literalStringClass( other )
+        return self.append( other ) #Or( [ self, other ] )
+
+    def __str__( self ):
+        if hasattr(self,"name"):
+            return self.name
+
+        if self.strRepr is None:
+            self.strRepr = "{" + " ^ ".join(_ustr(e) for e in self.exprs) + "}"
+
+        return self.strRepr
+
+    def checkRecursion( self, parseElementList ):
+        subRecCheckList = parseElementList[:] + [ self ]
+        for e in self.exprs:
+            e.checkRecursion( subRecCheckList )
+
+
+class MatchFirst(ParseExpression):
+    """
+    Requires that at least one C{ParseExpression} is found.
+    If two expressions match, the first one listed is the one that will match.
+    May be constructed using the C{'|'} operator.
+
+    Example::
+        # construct MatchFirst using '|' operator
+        
+        # watch the order of expressions to match
+        number = Word(nums) | Combine(Word(nums) + '.' + Word(nums))
+        print(number.searchString("123 3.1416 789")) #  Fail! -> [['123'], ['3'], ['1416'], ['789']]
+
+        # put more selective expression first
+        number = Combine(Word(nums) + '.' + Word(nums)) | Word(nums)
+        print(number.searchString("123 3.1416 789")) #  Better -> [['123'], ['3.1416'], ['789']]
+    """
+    def __init__( self, exprs, savelist = False ):
+        super(MatchFirst,self).__init__(exprs, savelist)
+        if self.exprs:
+            self.mayReturnEmpty = any(e.mayReturnEmpty for e in self.exprs)
+        else:
+            self.mayReturnEmpty = True
+
+    def parseImpl( self, instring, loc, doActions=True ):
+        maxExcLoc = -1
+        maxException = None
+        for e in self.exprs:
+            try:
+                ret = e._parse( instring, loc, doActions )
+                return ret
+            except ParseException as err:
+                if err.loc > maxExcLoc:
+                    maxException = err
+                    maxExcLoc = err.loc
+            except IndexError:
+                if len(instring) > maxExcLoc:
+                    maxException = ParseException(instring,len(instring),e.errmsg,self)
+                    maxExcLoc = len(instring)
+
+        # only got here if no expression matched, raise exception for match that made it the furthest
+        else:
+            if maxException is not None:
+                maxException.msg = self.errmsg
+                raise maxException
+            else:
+                raise ParseException(instring, loc, "no defined alternatives to match", self)
+
+    def __ior__(self, other ):
+        if isinstance( other, basestring ):
+            other = ParserElement._literalStringClass( other )
+        return self.append( other ) #MatchFirst( [ self, other ] )
+
+    def __str__( self ):
+        if hasattr(self,"name"):
+            return self.name
+
+        if self.strRepr is None:
+            self.strRepr = "{" + " | ".join(_ustr(e) for e in self.exprs) + "}"
+
+        return self.strRepr
+
+    def checkRecursion( self, parseElementList ):
+        subRecCheckList = parseElementList[:] + [ self ]
+        for e in self.exprs:
+            e.checkRecursion( subRecCheckList )
+
+
+class Each(ParseExpression):
+    """
+    Requires all given C{ParseExpression}s to be found, but in any order.
+    Expressions may be separated by whitespace.
+    May be constructed using the C{'&'} operator.
+
+    Example::
+        color = oneOf("RED ORANGE YELLOW GREEN BLUE PURPLE BLACK WHITE BROWN")
+        shape_type = oneOf("SQUARE CIRCLE TRIANGLE STAR HEXAGON OCTAGON")
+        integer = Word(nums)
+        shape_attr = "shape:" + shape_type("shape")
+        posn_attr = "posn:" + Group(integer("x") + ',' + integer("y"))("posn")
+        color_attr = "color:" + color("color")
+        size_attr = "size:" + integer("size")
+
+        # use Each (using operator '&') to accept attributes in any order 
+        # (shape and posn are required, color and size are optional)
+        shape_spec = shape_attr & posn_attr & Optional(color_attr) & Optional(size_attr)
+
+        shape_spec.runTests('''
+            shape: SQUARE color: BLACK posn: 100, 120
+            shape: CIRCLE size: 50 color: BLUE posn: 50,80
+            color:GREEN size:20 shape:TRIANGLE posn:20,40
+            '''
+            )
+    prints::
+        shape: SQUARE color: BLACK posn: 100, 120
+        ['shape:', 'SQUARE', 'color:', 'BLACK', 'posn:', ['100', ',', '120']]
+        - color: BLACK
+        - posn: ['100', ',', '120']
+          - x: 100
+          - y: 120
+        - shape: SQUARE
+
+
+        shape: CIRCLE size: 50 color: BLUE posn: 50,80
+        ['shape:', 'CIRCLE', 'size:', '50', 'color:', 'BLUE', 'posn:', ['50', ',', '80']]
+        - color: BLUE
+        - posn: ['50', ',', '80']
+          - x: 50
+          - y: 80
+        - shape: CIRCLE
+        - size: 50
+
+
+        color: GREEN size: 20 shape: TRIANGLE posn: 20,40
+        ['color:', 'GREEN', 'size:', '20', 'shape:', 'TRIANGLE', 'posn:', ['20', ',', '40']]
+        - color: GREEN
+        - posn: ['20', ',', '40']
+          - x: 20
+          - y: 40
+        - shape: TRIANGLE
+        - size: 20
+    """
+    def __init__( self, exprs, savelist = True ):
+        super(Each,self).__init__(exprs, savelist)
+        self.mayReturnEmpty = all(e.mayReturnEmpty for e in self.exprs)
+        self.skipWhitespace = True
+        self.initExprGroups = True
+
+    def parseImpl( self, instring, loc, doActions=True ):
+        if self.initExprGroups:
+            self.opt1map = dict((id(e.expr),e) for e in self.exprs if isinstance(e,Optional))
+            opt1 = [ e.expr for e in self.exprs if isinstance(e,Optional) ]
+            opt2 = [ e for e in self.exprs if e.mayReturnEmpty and not isinstance(e,Optional)]
+            self.optionals = opt1 + opt2
+            self.multioptionals = [ e.expr for e in self.exprs if isinstance(e,ZeroOrMore) ]
+            self.multirequired = [ e.expr for e in self.exprs if isinstance(e,OneOrMore) ]
+            self.required = [ e for e in self.exprs if not isinstance(e,(Optional,ZeroOrMore,OneOrMore)) ]
+            self.required += self.multirequired
+            self.initExprGroups = False
+        tmpLoc = loc
+        tmpReqd = self.required[:]
+        tmpOpt  = self.optionals[:]
+        matchOrder = []
+
+        keepMatching = True
+        while keepMatching:
+            tmpExprs = tmpReqd + tmpOpt + self.multioptionals + self.multirequired
+            failed = []
+            for e in tmpExprs:
+                try:
+                    tmpLoc = e.tryParse( instring, tmpLoc )
+                except ParseException:
+                    failed.append(e)
+                else:
+                    matchOrder.append(self.opt1map.get(id(e),e))
+                    if e in tmpReqd:
+                        tmpReqd.remove(e)
+                    elif e in tmpOpt:
+                        tmpOpt.remove(e)
+            if len(failed) == len(tmpExprs):
+                keepMatching = False
+
+        if tmpReqd:
+            missing = ", ".join(_ustr(e) for e in tmpReqd)
+            raise ParseException(instring,loc,"Missing one or more required elements (%s)" % missing )
+
+        # add any unmatched Optionals, in case they have default values defined
+        matchOrder += [e for e in self.exprs if isinstance(e,Optional) and e.expr in tmpOpt]
+
+        resultlist = []
+        for e in matchOrder:
+            loc,results = e._parse(instring,loc,doActions)
+            resultlist.append(results)
+
+        finalResults = sum(resultlist, ParseResults([]))
+        return loc, finalResults
+
+    def __str__( self ):
+        if hasattr(self,"name"):
+            return self.name
+
+        if self.strRepr is None:
+            self.strRepr = "{" + " & ".join(_ustr(e) for e in self.exprs) + "}"
+
+        return self.strRepr
+
+    def checkRecursion( self, parseElementList ):
+        subRecCheckList = parseElementList[:] + [ self ]
+        for e in self.exprs:
+            e.checkRecursion( subRecCheckList )
+
+
+class ParseElementEnhance(ParserElement):
+    """
+    Abstract subclass of C{ParserElement}, for combining and post-processing parsed tokens.
+    """
+    def __init__( self, expr, savelist=False ):
+        super(ParseElementEnhance,self).__init__(savelist)
+        if isinstance( expr, basestring ):
+            if issubclass(ParserElement._literalStringClass, Token):
+                expr = ParserElement._literalStringClass(expr)
+            else:
+                expr = ParserElement._literalStringClass(Literal(expr))
+        self.expr = expr
+        self.strRepr = None
+        if expr is not None:
+            self.mayIndexError = expr.mayIndexError
+            self.mayReturnEmpty = expr.mayReturnEmpty
+            self.setWhitespaceChars( expr.whiteChars )
+            self.skipWhitespace = expr.skipWhitespace
+            self.saveAsList = expr.saveAsList
+            self.callPreparse = expr.callPreparse
+            self.ignoreExprs.extend(expr.ignoreExprs)
+
+    def parseImpl( self, instring, loc, doActions=True ):
+        if self.expr is not None:
+            return self.expr._parse( instring, loc, doActions, callPreParse=False )
+        else:
+            raise ParseException("",loc,self.errmsg,self)
+
+    def leaveWhitespace( self ):
+        self.skipWhitespace = False
+        self.expr = self.expr.copy()
+        if self.expr is not None:
+            self.expr.leaveWhitespace()
+        return self
+
+    def ignore( self, other ):
+        if isinstance( other, Suppress ):
+            if other not in self.ignoreExprs:
+                super( ParseElementEnhance, self).ignore( other )
+                if self.expr is not None:
+                    self.expr.ignore( self.ignoreExprs[-1] )
+        else:
+            super( ParseElementEnhance, self).ignore( other )
+            if self.expr is not None:
+                self.expr.ignore( self.ignoreExprs[-1] )
+        return self
+
+    def streamline( self ):
+        super(ParseElementEnhance,self).streamline()
+        if self.expr is not None:
+            self.expr.streamline()
+        return self
+
+    def checkRecursion( self, parseElementList ):
+        if self in parseElementList:
+            raise RecursiveGrammarException( parseElementList+[self] )
+        subRecCheckList = parseElementList[:] + [ self ]
+        if self.expr is not None:
+            self.expr.checkRecursion( subRecCheckList )
+
+    def validate( self, validateTrace=[] ):
+        tmp = validateTrace[:]+[self]
+        if self.expr is not None:
+            self.expr.validate(tmp)
+        self.checkRecursion( [] )
+
+    def __str__( self ):
+        try:
+            return super(ParseElementEnhance,self).__str__()
+        except Exception:
+            pass
+
+        if self.strRepr is None and self.expr is not None:
+            self.strRepr = "%s:(%s)" % ( self.__class__.__name__, _ustr(self.expr) )
+        return self.strRepr
+
+
+class FollowedBy(ParseElementEnhance):
+    """
+    Lookahead matching of the given parse expression.  C{FollowedBy}
+    does I{not} advance the parsing position within the input string, it only
+    verifies that the specified parse expression matches at the current
+    position.  C{FollowedBy} always returns a null token list.
+
+    Example::
+        # use FollowedBy to match a label only if it is followed by a ':'
+        data_word = Word(alphas)
+        label = data_word + FollowedBy(':')
+        attr_expr = Group(label + Suppress(':') + OneOrMore(data_word, stopOn=label).setParseAction(' '.join))
+        
+        OneOrMore(attr_expr).parseString("shape: SQUARE color: BLACK posn: upper left").pprint()
+    prints::
+        [['shape', 'SQUARE'], ['color', 'BLACK'], ['posn', 'upper left']]
+    """
+    def __init__( self, expr ):
+        super(FollowedBy,self).__init__(expr)
+        self.mayReturnEmpty = True
+
+    def parseImpl( self, instring, loc, doActions=True ):
+        self.expr.tryParse( instring, loc )
+        return loc, []
+
+
+class NotAny(ParseElementEnhance):
+    """
+    Lookahead to disallow matching with the given parse expression.  C{NotAny}
+    does I{not} advance the parsing position within the input string, it only
+    verifies that the specified parse expression does I{not} match at the current
+    position.  Also, C{NotAny} does I{not} skip over leading whitespace. C{NotAny}
+    always returns a null token list.  May be constructed using the '~' operator.
+
+    Example::
+        
+    """
+    def __init__( self, expr ):
+        super(NotAny,self).__init__(expr)
+        #~ self.leaveWhitespace()
+        self.skipWhitespace = False  # do NOT use self.leaveWhitespace(), don't want to propagate to exprs
+        self.mayReturnEmpty = True
+        self.errmsg = "Found unwanted token, "+_ustr(self.expr)
+
+    def parseImpl( self, instring, loc, doActions=True ):
+        if self.expr.canParseNext(instring, loc):
+            raise ParseException(instring, loc, self.errmsg, self)
+        return loc, []
+
+    def __str__( self ):
+        if hasattr(self,"name"):
+            return self.name
+
+        if self.strRepr is None:
+            self.strRepr = "~{" + _ustr(self.expr) + "}"
+
+        return self.strRepr
+
+class _MultipleMatch(ParseElementEnhance):
+    def __init__( self, expr, stopOn=None):
+        super(_MultipleMatch, self).__init__(expr)
+        self.saveAsList = True
+        ender = stopOn
+        if isinstance(ender, basestring):
+            ender = ParserElement._literalStringClass(ender)
+        self.not_ender = ~ender if ender is not None else None
+
+    def parseImpl( self, instring, loc, doActions=True ):
+        self_expr_parse = self.expr._parse
+        self_skip_ignorables = self._skipIgnorables
+        check_ender = self.not_ender is not None
+        if check_ender:
+            try_not_ender = self.not_ender.tryParse
+        
+        # must be at least one (but first see if we are the stopOn sentinel;
+        # if so, fail)
+        if check_ender:
+            try_not_ender(instring, loc)
+        loc, tokens = self_expr_parse( instring, loc, doActions, callPreParse=False )
+        try:
+            hasIgnoreExprs = (not not self.ignoreExprs)
+            while 1:
+                if check_ender:
+                    try_not_ender(instring, loc)
+                if hasIgnoreExprs:
+                    preloc = self_skip_ignorables( instring, loc )
+                else:
+                    preloc = loc
+                loc, tmptokens = self_expr_parse( instring, preloc, doActions )
+                if tmptokens or tmptokens.haskeys():
+                    tokens += tmptokens
+        except (ParseException,IndexError):
+            pass
+
+        return loc, tokens
+        
+class OneOrMore(_MultipleMatch):
+    """
+    Repetition of one or more of the given expression.
+    
+    Parameters:
+     - expr - expression that must match one or more times
+     - stopOn - (default=C{None}) - expression for a terminating sentinel
+          (only required if the sentinel would ordinarily match the repetition 
+          expression)          
+
+    Example::
+        data_word = Word(alphas)
+        label = data_word + FollowedBy(':')
+        attr_expr = Group(label + Suppress(':') + OneOrMore(data_word).setParseAction(' '.join))
+
+        text = "shape: SQUARE posn: upper left color: BLACK"
+        OneOrMore(attr_expr).parseString(text).pprint()  # Fail! read 'color' as data instead of next label -> [['shape', 'SQUARE color']]
+
+        # use stopOn attribute for OneOrMore to avoid reading label string as part of the data
+        attr_expr = Group(label + Suppress(':') + OneOrMore(data_word, stopOn=label).setParseAction(' '.join))
+        OneOrMore(attr_expr).parseString(text).pprint() # Better -> [['shape', 'SQUARE'], ['posn', 'upper left'], ['color', 'BLACK']]
+        
+        # could also be written as
+        (attr_expr * (1,)).parseString(text).pprint()
+    """
+
+    def __str__( self ):
+        if hasattr(self,"name"):
+            return self.name
+
+        if self.strRepr is None:
+            self.strRepr = "{" + _ustr(self.expr) + "}..."
+
+        return self.strRepr
+
+class ZeroOrMore(_MultipleMatch):
+    """
+    Optional repetition of zero or more of the given expression.
+    
+    Parameters:
+     - expr - expression that must match zero or more times
+     - stopOn - (default=C{None}) - expression for a terminating sentinel
+          (only required if the sentinel would ordinarily match the repetition 
+          expression)          
+
+    Example: similar to L{OneOrMore}
+    """
+    def __init__( self, expr, stopOn=None):
+        super(ZeroOrMore,self).__init__(expr, stopOn=stopOn)
+        self.mayReturnEmpty = True
+        
+    def parseImpl( self, instring, loc, doActions=True ):
+        try:
+            return super(ZeroOrMore, self).parseImpl(instring, loc, doActions)
+        except (ParseException,IndexError):
+            return loc, []
+
+    def __str__( self ):
+        if hasattr(self,"name"):
+            return self.name
+
+        if self.strRepr is None:
+            self.strRepr = "[" + _ustr(self.expr) + "]..."
+
+        return self.strRepr
+
+class _NullToken(object):
+    def __bool__(self):
+        return False
+    __nonzero__ = __bool__
+    def __str__(self):
+        return ""
+
+_optionalNotMatched = _NullToken()
+class Optional(ParseElementEnhance):
+    """
+    Optional matching of the given expression.
+
+    Parameters:
+     - expr - expression that must match zero or more times
+     - default (optional) - value to be returned if the optional expression is not found.
+
+    Example::
+        # US postal code can be a 5-digit zip, plus optional 4-digit qualifier
+        zip = Combine(Word(nums, exact=5) + Optional('-' + Word(nums, exact=4)))
+        zip.runTests('''
+            # traditional ZIP code
+            12345
+            
+            # ZIP+4 form
+            12101-0001
+            
+            # invalid ZIP
+            98765-
+            ''')
+    prints::
+        # traditional ZIP code
+        12345
+        ['12345']
+
+        # ZIP+4 form
+        12101-0001
+        ['12101-0001']
+
+        # invalid ZIP
+        98765-
+             ^
+        FAIL: Expected end of text (at char 5), (line:1, col:6)
+    """
+    def __init__( self, expr, default=_optionalNotMatched ):
+        super(Optional,self).__init__( expr, savelist=False )
+        self.saveAsList = self.expr.saveAsList
+        self.defaultValue = default
+        self.mayReturnEmpty = True
+
+    def parseImpl( self, instring, loc, doActions=True ):
+        try:
+            loc, tokens = self.expr._parse( instring, loc, doActions, callPreParse=False )
+        except (ParseException,IndexError):
+            if self.defaultValue is not _optionalNotMatched:
+                if self.expr.resultsName:
+                    tokens = ParseResults([ self.defaultValue ])
+                    tokens[self.expr.resultsName] = self.defaultValue
+                else:
+                    tokens = [ self.defaultValue ]
+            else:
+                tokens = []
+        return loc, tokens
+
+    def __str__( self ):
+        if hasattr(self,"name"):
+            return self.name
+
+        if self.strRepr is None:
+            self.strRepr = "[" + _ustr(self.expr) + "]"
+
+        return self.strRepr
+
+class SkipTo(ParseElementEnhance):
+    """
+    Token for skipping over all undefined text until the matched expression is found.
+
+    Parameters:
+     - expr - target expression marking the end of the data to be skipped
+     - include - (default=C{False}) if True, the target expression is also parsed 
+          (the skipped text and target expression are returned as a 2-element list).
+     - ignore - (default=C{None}) used to define grammars (typically quoted strings and 
+          comments) that might contain false matches to the target expression
+     - failOn - (default=C{None}) define expressions that are not allowed to be 
+          included in the skipped test; if found before the target expression is found, 
+          the SkipTo is not a match
+
+    Example::
+        report = '''
+            Outstanding Issues Report - 1 Jan 2000
+
+               # | Severity | Description                               |  Days Open
+            -----+----------+-------------------------------------------+-----------
+             101 | Critical | Intermittent system crash                 |          6
+              94 | Cosmetic | Spelling error on Login ('log|n')         |         14
+              79 | Minor    | System slow when running too many reports |         47
+            '''
+        integer = Word(nums)
+        SEP = Suppress('|')
+        # use SkipTo to simply match everything up until the next SEP
+        # - ignore quoted strings, so that a '|' character inside a quoted string does not match
+        # - parse action will call token.strip() for each matched token, i.e., the description body
+        string_data = SkipTo(SEP, ignore=quotedString)
+        string_data.setParseAction(tokenMap(str.strip))
+        ticket_expr = (integer("issue_num") + SEP 
+                      + string_data("sev") + SEP 
+                      + string_data("desc") + SEP 
+                      + integer("days_open"))
+        
+        for tkt in ticket_expr.searchString(report):
+            print tkt.dump()
+    prints::
+        ['101', 'Critical', 'Intermittent system crash', '6']
+        - days_open: 6
+        - desc: Intermittent system crash
+        - issue_num: 101
+        - sev: Critical
+        ['94', 'Cosmetic', "Spelling error on Login ('log|n')", '14']
+        - days_open: 14
+        - desc: Spelling error on Login ('log|n')
+        - issue_num: 94
+        - sev: Cosmetic
+        ['79', 'Minor', 'System slow when running too many reports', '47']
+        - days_open: 47
+        - desc: System slow when running too many reports
+        - issue_num: 79
+        - sev: Minor
+    """
+    def __init__( self, other, include=False, ignore=None, failOn=None ):
+        super( SkipTo, self ).__init__( other )
+        self.ignoreExpr = ignore
+        self.mayReturnEmpty = True
+        self.mayIndexError = False
+        self.includeMatch = include
+        self.asList = False
+        if isinstance(failOn, basestring):
+            self.failOn = ParserElement._literalStringClass(failOn)
+        else:
+            self.failOn = failOn
+        self.errmsg = "No match found for "+_ustr(self.expr)
+
+    def parseImpl( self, instring, loc, doActions=True ):
+        startloc = loc
+        instrlen = len(instring)
+        expr = self.expr
+        expr_parse = self.expr._parse
+        self_failOn_canParseNext = self.failOn.canParseNext if self.failOn is not None else None
+        self_ignoreExpr_tryParse = self.ignoreExpr.tryParse if self.ignoreExpr is not None else None
+        
+        tmploc = loc
+        while tmploc <= instrlen:
+            if self_failOn_canParseNext is not None:
+                # break if failOn expression matches
+                if self_failOn_canParseNext(instring, tmploc):
+                    break
+                    
+            if self_ignoreExpr_tryParse is not None:
+                # advance past ignore expressions
+                while 1:
+                    try:
+                        tmploc = self_ignoreExpr_tryParse(instring, tmploc)
+                    except ParseBaseException:
+                        break
+            
+            try:
+                expr_parse(instring, tmploc, doActions=False, callPreParse=False)
+            except (ParseException, IndexError):
+                # no match, advance loc in string
+                tmploc += 1
+            else:
+                # matched skipto expr, done
+                break
+
+        else:
+            # ran off the end of the input string without matching skipto expr, fail
+            raise ParseException(instring, loc, self.errmsg, self)
+
+        # build up return values
+        loc = tmploc
+        skiptext = instring[startloc:loc]
+        skipresult = ParseResults(skiptext)
+        
+        if self.includeMatch:
+            loc, mat = expr_parse(instring,loc,doActions,callPreParse=False)
+            skipresult += mat
+
+        return loc, skipresult
+
+class Forward(ParseElementEnhance):
+    """
+    Forward declaration of an expression to be defined later -
+    used for recursive grammars, such as algebraic infix notation.
+    When the expression is known, it is assigned to the C{Forward} variable using the '<<' operator.
+
+    Note: take care when assigning to C{Forward} not to overlook precedence of operators.
+    Specifically, '|' has a lower precedence than '<<', so that::
+        fwdExpr << a | b | c
+    will actually be evaluated as::
+        (fwdExpr << a) | b | c
+    thereby leaving b and c out as parseable alternatives.  It is recommended that you
+    explicitly group the values inserted into the C{Forward}::
+        fwdExpr << (a | b | c)
+    Converting to use the '<<=' operator instead will avoid this problem.
+
+    See L{ParseResults.pprint} for an example of a recursive parser created using
+    C{Forward}.
+    """
+    def __init__( self, other=None ):
+        super(Forward,self).__init__( other, savelist=False )
+
+    def __lshift__( self, other ):
+        if isinstance( other, basestring ):
+            other = ParserElement._literalStringClass(other)
+        self.expr = other
+        self.strRepr = None
+        self.mayIndexError = self.expr.mayIndexError
+        self.mayReturnEmpty = self.expr.mayReturnEmpty
+        self.setWhitespaceChars( self.expr.whiteChars )
+        self.skipWhitespace = self.expr.skipWhitespace
+        self.saveAsList = self.expr.saveAsList
+        self.ignoreExprs.extend(self.expr.ignoreExprs)
+        return self
+        
+    def __ilshift__(self, other):
+        return self << other
+    
+    def leaveWhitespace( self ):
+        self.skipWhitespace = False
+        return self
+
+    def streamline( self ):
+        if not self.streamlined:
+            self.streamlined = True
+            if self.expr is not None:
+                self.expr.streamline()
+        return self
+
+    def validate( self, validateTrace=[] ):
+        if self not in validateTrace:
+            tmp = validateTrace[:]+[self]
+            if self.expr is not None:
+                self.expr.validate(tmp)
+        self.checkRecursion([])
+
+    def __str__( self ):
+        if hasattr(self,"name"):
+            return self.name
+        return self.__class__.__name__ + ": ..."
+
+        # stubbed out for now - creates awful memory and perf issues
+        self._revertClass = self.__class__
+        self.__class__ = _ForwardNoRecurse
+        try:
+            if self.expr is not None:
+                retString = _ustr(self.expr)
+            else:
+                retString = "None"
+        finally:
+            self.__class__ = self._revertClass
+        return self.__class__.__name__ + ": " + retString
+
+    def copy(self):
+        if self.expr is not None:
+            return super(Forward,self).copy()
+        else:
+            ret = Forward()
+            ret <<= self
+            return ret
+
+class _ForwardNoRecurse(Forward):
+    def __str__( self ):
+        return "..."
+
+class TokenConverter(ParseElementEnhance):
+    """
+    Abstract subclass of C{ParseExpression}, for converting parsed results.
+    """
+    def __init__( self, expr, savelist=False ):
+        super(TokenConverter,self).__init__( expr )#, savelist )
+        self.saveAsList = False
+
+class Combine(TokenConverter):
+    """
+    Converter to concatenate all matching tokens to a single string.
+    By default, the matching patterns must also be contiguous in the input string;
+    this can be disabled by specifying C{'adjacent=False'} in the constructor.
+
+    Example::
+        real = Word(nums) + '.' + Word(nums)
+        print(real.parseString('3.1416')) # -> ['3', '.', '1416']
+        # will also erroneously match the following
+        print(real.parseString('3. 1416')) # -> ['3', '.', '1416']
+
+        real = Combine(Word(nums) + '.' + Word(nums))
+        print(real.parseString('3.1416')) # -> ['3.1416']
+        # no match when there are internal spaces
+        print(real.parseString('3. 1416')) # -> Exception: Expected W:(0123...)
+    """
+    def __init__( self, expr, joinString="", adjacent=True ):
+        super(Combine,self).__init__( expr )
+        # suppress whitespace-stripping in contained parse expressions, but re-enable it on the Combine itself
+        if adjacent:
+            self.leaveWhitespace()
+        self.adjacent = adjacent
+        self.skipWhitespace = True
+        self.joinString = joinString
+        self.callPreparse = True
+
+    def ignore( self, other ):
+        if self.adjacent:
+            ParserElement.ignore(self, other)
+        else:
+            super( Combine, self).ignore( other )
+        return self
+
+    def postParse( self, instring, loc, tokenlist ):
+        retToks = tokenlist.copy()
+        del retToks[:]
+        retToks += ParseResults([ "".join(tokenlist._asStringList(self.joinString)) ], modal=self.modalResults)
+
+        if self.resultsName and retToks.haskeys():
+            return [ retToks ]
+        else:
+            return retToks
+
+class Group(TokenConverter):
+    """
+    Converter to return the matched tokens as a list - useful for returning tokens of C{L{ZeroOrMore}} and C{L{OneOrMore}} expressions.
+
+    Example::
+        ident = Word(alphas)
+        num = Word(nums)
+        term = ident | num
+        func = ident + Optional(delimitedList(term))
+        print(func.parseString("fn a,b,100"))  # -> ['fn', 'a', 'b', '100']
+
+        func = ident + Group(Optional(delimitedList(term)))
+        print(func.parseString("fn a,b,100"))  # -> ['fn', ['a', 'b', '100']]
+    """
+    def __init__( self, expr ):
+        super(Group,self).__init__( expr )
+        self.saveAsList = True
+
+    def postParse( self, instring, loc, tokenlist ):
+        return [ tokenlist ]
+
+class Dict(TokenConverter):
+    """
+    Converter to return a repetitive expression as a list, but also as a dictionary.
+    Each element can also be referenced using the first token in the expression as its key.
+    Useful for tabular report scraping when the first column can be used as a item key.
+
+    Example::
+        data_word = Word(alphas)
+        label = data_word + FollowedBy(':')
+        attr_expr = Group(label + Suppress(':') + OneOrMore(data_word).setParseAction(' '.join))
+
+        text = "shape: SQUARE posn: upper left color: light blue texture: burlap"
+        attr_expr = (label + Suppress(':') + OneOrMore(data_word, stopOn=label).setParseAction(' '.join))
+        
+        # print attributes as plain groups
+        print(OneOrMore(attr_expr).parseString(text).dump())
+        
+        # instead of OneOrMore(expr), parse using Dict(OneOrMore(Group(expr))) - Dict will auto-assign names
+        result = Dict(OneOrMore(Group(attr_expr))).parseString(text)
+        print(result.dump())
+        
+        # access named fields as dict entries, or output as dict
+        print(result['shape'])        
+        print(result.asDict())
+    prints::
+        ['shape', 'SQUARE', 'posn', 'upper left', 'color', 'light blue', 'texture', 'burlap']
+
+        [['shape', 'SQUARE'], ['posn', 'upper left'], ['color', 'light blue'], ['texture', 'burlap']]
+        - color: light blue
+        - posn: upper left
+        - shape: SQUARE
+        - texture: burlap
+        SQUARE
+        {'color': 'light blue', 'posn': 'upper left', 'texture': 'burlap', 'shape': 'SQUARE'}
+    See more examples at L{ParseResults} of accessing fields by results name.
+    """
+    def __init__( self, expr ):
+        super(Dict,self).__init__( expr )
+        self.saveAsList = True
+
+    def postParse( self, instring, loc, tokenlist ):
+        for i,tok in enumerate(tokenlist):
+            if len(tok) == 0:
+                continue
+            ikey = tok[0]
+            if isinstance(ikey,int):
+                ikey = _ustr(tok[0]).strip()
+            if len(tok)==1:
+                tokenlist[ikey] = _ParseResultsWithOffset("",i)
+            elif len(tok)==2 and not isinstance(tok[1],ParseResults):
+                tokenlist[ikey] = _ParseResultsWithOffset(tok[1],i)
+            else:
+                dictvalue = tok.copy() #ParseResults(i)
+                del dictvalue[0]
+                if len(dictvalue)!= 1 or (isinstance(dictvalue,ParseResults) and dictvalue.haskeys()):
+                    tokenlist[ikey] = _ParseResultsWithOffset(dictvalue,i)
+                else:
+                    tokenlist[ikey] = _ParseResultsWithOffset(dictvalue[0],i)
+
+        if self.resultsName:
+            return [ tokenlist ]
+        else:
+            return tokenlist
+
+
+class Suppress(TokenConverter):
+    """
+    Converter for ignoring the results of a parsed expression.
+
+    Example::
+        source = "a, b, c,d"
+        wd = Word(alphas)
+        wd_list1 = wd + ZeroOrMore(',' + wd)
+        print(wd_list1.parseString(source))
+
+        # often, delimiters that are useful during parsing are just in the
+        # way afterward - use Suppress to keep them out of the parsed output
+        wd_list2 = wd + ZeroOrMore(Suppress(',') + wd)
+        print(wd_list2.parseString(source))
+    prints::
+        ['a', ',', 'b', ',', 'c', ',', 'd']
+        ['a', 'b', 'c', 'd']
+    (See also L{delimitedList}.)
+    """
+    def postParse( self, instring, loc, tokenlist ):
+        return []
+
+    def suppress( self ):
+        return self
+
+
+class OnlyOnce(object):
+    """
+    Wrapper for parse actions, to ensure they are only called once.
+    """
+    def __init__(self, methodCall):
+        self.callable = _trim_arity(methodCall)
+        self.called = False
+    def __call__(self,s,l,t):
+        if not self.called:
+            results = self.callable(s,l,t)
+            self.called = True
+            return results
+        raise ParseException(s,l,"")
+    def reset(self):
+        self.called = False
+
+def traceParseAction(f):
+    """
+    Decorator for debugging parse actions. 
+    
+    When the parse action is called, this decorator will print C{">> entering I{method-name}(line:I{current_source_line}, I{parse_location}, I{matched_tokens})".}
+    When the parse action completes, the decorator will print C{"<<"} followed by the returned value, or any exception that the parse action raised.
+
+    Example::
+        wd = Word(alphas)
+
+        @traceParseAction
+        def remove_duplicate_chars(tokens):
+            return ''.join(sorted(set(''.join(tokens))))
+
+        wds = OneOrMore(wd).setParseAction(remove_duplicate_chars)
+        print(wds.parseString("slkdjs sld sldd sdlf sdljf"))
+    prints::
+        >>entering remove_duplicate_chars(line: 'slkdjs sld sldd sdlf sdljf', 0, (['slkdjs', 'sld', 'sldd', 'sdlf', 'sdljf'], {}))
+        <<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 C{combine=True} in the constructor.
+    If C{combine} is set to C{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 C{intExpr} is specified, it should be a pyparsing expression that produces an integer value.
+
+    Example::
+        countedArray(Word(alphas)).parseString('2 ab cd ef')  # -> ['ab', 'cd']
+
+        # in this parser, the leading integer value is given in binary,
+        # '10' indicating that 2 values are in the array
+        binaryConstant = Word('01').setParseAction(lambda t: int(t[0], 2))
+        countedArray(Word(alphas), intExpr=binaryConstant).parseString('10 ab cd ef')  # -> ['ab', 'cd']
+    """
+    arrayExpr = Forward()
+    def countFieldParseAction(s,l,t):
+        n = t[0]
+        arrayExpr << (n and Group(And([expr]*n)) or Group(empty))
+        return []
+    if intExpr is None:
+        intExpr = Word(nums).setParseAction(lambda t:int(t[0]))
+    else:
+        intExpr = intExpr.copy()
+    intExpr.setName("arrayLen")
+    intExpr.addParseAction(countFieldParseAction, callDuringTry=True)
+    return ( intExpr + arrayExpr ).setName('(len) ' + _ustr(expr) + '...')
+
+def _flatten(L):
+    ret = []
+    for i in L:
+        if isinstance(i,list):
+            ret.extend(_flatten(i))
+        else:
+            ret.append(i)
+    return ret
+
+def matchPreviousLiteral(expr):
+    """
+    Helper to define an expression that is indirectly defined from
+    the tokens matched in a previous expression, that is, it looks
+    for a 'repeat' of a previous expression.  For example::
+        first = Word(nums)
+        second = matchPreviousLiteral(first)
+        matchExpr = first + ":" + second
+    will match C{"1:1"}, but not C{"1:2"}.  Because this matches a
+    previous literal, will also match the leading C{"1:1"} in C{"1:10"}.
+    If this is not desired, use C{matchPreviousExpr}.
+    Do I{not} use with packrat parsing enabled.
+    """
+    rep = Forward()
+    def copyTokenToRepeater(s,l,t):
+        if t:
+            if len(t) == 1:
+                rep << t[0]
+            else:
+                # flatten t tokens
+                tflat = _flatten(t.asList())
+                rep << And(Literal(tt) for tt in tflat)
+        else:
+            rep << Empty()
+    expr.addParseAction(copyTokenToRepeater, callDuringTry=True)
+    rep.setName('(prev) ' + _ustr(expr))
+    return rep
+
+def matchPreviousExpr(expr):
+    """
+    Helper to define an expression that is indirectly defined from
+    the tokens matched in a previous expression, that is, it looks
+    for a 'repeat' of a previous expression.  For example::
+        first = Word(nums)
+        second = matchPreviousExpr(first)
+        matchExpr = first + ":" + second
+    will match C{"1:1"}, but not C{"1:2"}.  Because this matches by
+    expressions, will I{not} match the leading C{"1:1"} in C{"1:10"};
+    the expressions are evaluated first, and then compared, so
+    C{"1"} is compared with C{"10"}.
+    Do I{not} use with packrat parsing enabled.
+    """
+    rep = Forward()
+    e2 = expr.copy()
+    rep <<= e2
+    def copyTokenToRepeater(s,l,t):
+        matchTokens = _flatten(t.asList())
+        def mustMatchTheseTokens(s,l,t):
+            theseTokens = _flatten(t.asList())
+            if  theseTokens != matchTokens:
+                raise ParseException("",0,"")
+        rep.setParseAction( mustMatchTheseTokens, callDuringTry=True )
+    expr.addParseAction(copyTokenToRepeater, callDuringTry=True)
+    rep.setName('(prev) ' + _ustr(expr))
+    return rep
+
+def _escapeRegexRangeChars(s):
+    #~  escape these chars: ^-]
+    for c in r"\^-]":
+        s = s.replace(c,_bslash+c)
+    s = s.replace("\n",r"\n")
+    s = s.replace("\t",r"\t")
+    return _ustr(s)
+
+def oneOf( strs, caseless=False, useRegex=True ):
+    """
+    Helper to quickly define a set of alternative Literals, and makes sure to do
+    longest-first testing when there is a conflict, regardless of the input order,
+    but returns a C{L{MatchFirst}} for best performance.
+
+    Parameters:
+     - strs - a string of space-delimited literals, or a collection of string literals
+     - caseless - (default=C{False}) - treat all literals as caseless
+     - useRegex - (default=C{True}) - as an optimization, will generate a Regex
+          object; otherwise, will generate a C{MatchFirst} object (if C{caseless=True}, or
+          if creating a C{Regex} raises an exception)
+
+    Example::
+        comp_oper = oneOf("< = > <= >= !=")
+        var = Word(alphas)
+        number = Word(nums)
+        term = var | number
+        comparison_expr = term + comp_oper + term
+        print(comparison_expr.searchString("B = 12  AA=23 B<=AA AA>12"))
+    prints::
+        [['B', '=', '12'], ['AA', '=', '23'], ['B', '<=', 'AA'], ['AA', '>', '12']]
+    """
+    if caseless:
+        isequal = ( lambda a,b: a.upper() == b.upper() )
+        masks = ( lambda a,b: b.upper().startswith(a.upper()) )
+        parseElementClass = CaselessLiteral
+    else:
+        isequal = ( lambda a,b: a == b )
+        masks = ( lambda a,b: b.startswith(a) )
+        parseElementClass = Literal
+
+    symbols = []
+    if isinstance(strs,basestring):
+        symbols = strs.split()
+    elif isinstance(strs, Iterable):
+        symbols = list(strs)
+    else:
+        warnings.warn("Invalid argument to oneOf, expected string or iterable",
+                SyntaxWarning, stacklevel=2)
+    if not symbols:
+        return NoMatch()
+
+    i = 0
+    while i < len(symbols)-1:
+        cur = symbols[i]
+        for j,other in enumerate(symbols[i+1:]):
+            if ( isequal(other, cur) ):
+                del symbols[i+j+1]
+                break
+            elif ( masks(cur, other) ):
+                del symbols[i+j+1]
+                symbols.insert(i,other)
+                cur = other
+                break
+        else:
+            i += 1
+
+    if not caseless and useRegex:
+        #~ print (strs,"->", "|".join( [ _escapeRegexChars(sym) for sym in symbols] ))
+        try:
+            if len(symbols)==len("".join(symbols)):
+                return Regex( "[%s]" % "".join(_escapeRegexRangeChars(sym) for sym in symbols) ).setName(' | '.join(symbols))
+            else:
+                return Regex( "|".join(re.escape(sym) for sym in symbols) ).setName(' | '.join(symbols))
+        except Exception:
+            warnings.warn("Exception creating Regex for oneOf, building MatchFirst",
+                    SyntaxWarning, stacklevel=2)
+
+
+    # last resort, just use MatchFirst
+    return MatchFirst(parseElementClass(sym) for sym in symbols).setName(' | '.join(symbols))
+
+def dictOf( key, value ):
+    """
+    Helper to easily and clearly define a dictionary by specifying the respective patterns
+    for the key and value.  Takes care of defining the C{L{Dict}}, C{L{ZeroOrMore}}, and C{L{Group}} tokens
+    in the proper order.  The key pattern can include delimiting markers or punctuation,
+    as long as they are suppressed, thereby leaving the significant key text.  The value
+    pattern can include named results, so that the C{Dict} results can include named token
+    fields.
+
+    Example::
+        text = "shape: SQUARE posn: upper left color: light blue texture: burlap"
+        attr_expr = (label + Suppress(':') + OneOrMore(data_word, stopOn=label).setParseAction(' '.join))
+        print(OneOrMore(attr_expr).parseString(text).dump())
+        
+        attr_label = label
+        attr_value = Suppress(':') + OneOrMore(data_word, stopOn=label).setParseAction(' '.join)
+
+        # similar to Dict, but simpler call format
+        result = dictOf(attr_label, attr_value).parseString(text)
+        print(result.dump())
+        print(result['shape'])
+        print(result.shape)  # object attribute access works too
+        print(result.asDict())
+    prints::
+        [['shape', 'SQUARE'], ['posn', 'upper left'], ['color', 'light blue'], ['texture', 'burlap']]
+        - color: light blue
+        - posn: upper left
+        - shape: SQUARE
+        - texture: burlap
+        SQUARE
+        SQUARE
+        {'color': 'light blue', 'shape': 'SQUARE', 'posn': 'upper left', 'texture': 'burlap'}
+    """
+    return Dict( ZeroOrMore( Group ( key + value ) ) )
+
+def originalTextFor(expr, asString=True):
+    """
+    Helper to return the original, untokenized text for a given expression.  Useful to
+    restore the parsed fields of an HTML start tag into the raw tag text itself, or to
+    revert separate tokens with intervening whitespace back to the original matching
+    input text. By default, returns astring containing the original parsed text.  
+       
+    If the optional C{asString} argument is passed as C{False}, then the return value is a 
+    C{L{ParseResults}} containing any results names that were originally matched, and a 
+    single token containing the original matched text from the input string.  So if 
+    the expression passed to C{L{originalTextFor}} contains expressions with defined
+    results names, you must set C{asString} to C{False} if you want to preserve those
+    results name values.
+
+    Example::
+        src = "this is test <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).setParseAction(lambda t:t[0])
+
+def locatedExpr(expr):
+    """
+    Helper to decorate a returned token with its starting and ending locations in the input string.
+    This helper adds the following results names:
+     - locn_start = location where matched expression begins
+     - locn_end = location where matched expression ends
+     - value = the actual parsed results
+
+    Be careful if the input text contains C{<TAB>} characters, you may want to call
+    C{L{ParserElement.parseWithTabs}}
+
+    Example::
+        wd = Word(alphas)
+        for match in locatedExpr(wd).searchString("ljsdf123lksdjjf123lkkjj1222"):
+            print(match)
+    prints::
+        [[0, 'ljsdf', 5]]
+        [[8, 'lksdjjf', 15]]
+        [[18, 'lkkjj', 23]]
+    """
+    locator = Empty().setParseAction(lambda s,l,t: l)
+    return Group(locator("locn_start") + expr("value") + locator.copy().leaveWhitespace()("locn_end"))
+
+
+# convenience constants for positional expressions
+empty       = Empty().setName("empty")
+lineStart   = LineStart().setName("lineStart")
+lineEnd     = LineEnd().setName("lineEnd")
+stringStart = StringStart().setName("stringStart")
+stringEnd   = StringEnd().setName("stringEnd")
+
+_escapedPunc = Word( _bslash, r"\[]-*.$+^?()~ ", exact=2 ).setParseAction(lambda s,l,t:t[0][1])
+_escapedHexChar = Regex(r"\\0?[xX][0-9a-fA-F]+").setParseAction(lambda s,l,t:unichr(int(t[0].lstrip(r'\0x'),16)))
+_escapedOctChar = Regex(r"\\0[0-7]+").setParseAction(lambda s,l,t:unichr(int(t[0][1:],8)))
+_singleChar = _escapedPunc | _escapedHexChar | _escapedOctChar | CharsNotIn(r'\]', exact=1)
+_charRange = Group(_singleChar + Suppress("-") + _singleChar)
+_reBracketExpr = Literal("[") + Optional("^").setResultsName("negate") + Group( OneOrMore( _charRange | _singleChar ) ).setResultsName("body") + "]"
+
+def srange(s):
+    r"""
+    Helper to easily define string ranges for use in Word construction.  Borrows
+    syntax from regexp '[]' string range definitions::
+        srange("[0-9]")   -> "0123456789"
+        srange("[a-z]")   -> "abcdefghijklmnopqrstuvwxyz"
+        srange("[a-z$_]") -> "abcdefghijklmnopqrstuvwxyz$_"
+    The input string must be enclosed in []'s, and the returned string is the expanded
+    character set joined into a single string.
+    The values enclosed in the []'s may be:
+     - a single character
+     - an escaped character with a leading backslash (such as C{\-} or C{\]})
+     - an escaped hex character with a leading C{'\x'} (C{\x21}, which is a C{'!'} character) 
+         (C{\0x##} is also supported for backwards compatibility) 
+     - an escaped octal character with a leading C{'\0'} (C{\041}, which is a C{'!'} character)
+     - a range of any of the above, separated by a dash (C{'a-z'}, etc.)
+     - any combination of the above (C{'aeiouy'}, C{'a-zA-Z0-9_$'}, etc.)
+    """
+    _expanded = lambda p: p if not isinstance(p,ParseResults) else ''.join(unichr(c) for c in range(ord(p[0]),ord(p[1])+1))
+    try:
+        return "".join(_expanded(part) for part in _reBracketExpr.parseString(s).body)
+    except Exception:
+        return ""
+
+def matchOnlyAtCol(n):
+    """
+    Helper method for defining parse actions that require matching at a specific
+    column in the input text.
+    """
+    def verifyCol(strg,locn,toks):
+        if col(locn,strg) != n:
+            raise ParseException(strg,locn,"matched token not at column %d" % n)
+    return verifyCol
+
+def replaceWith(replStr):
+    """
+    Helper method for common parse actions that simply return a literal value.  Especially
+    useful when used with C{L{transformString<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 C{hex_integer = Word(hexnums).setParseAction(tokenMap(int, 16))}, which will convert the
+    parsed data to an integer using base 16.
+
+    Example (compare the last to example in L{ParserElement.transformString}::
+        hex_ints = OneOrMore(Word(hexnums)).setParseAction(tokenMap(int, 16))
+        hex_ints.runTests('''
+            00 11 22 aa FF 0a 0d 1a
+            ''')
+        
+        upperword = Word(alphas).setParseAction(tokenMap(str.upper))
+        OneOrMore(upperword).runTests('''
+            my kingdom for a horse
+            ''')
+
+        wd = Word(alphas).setParseAction(tokenMap(str.title))
+        OneOrMore(wd).setParseAction(' '.join).runTests('''
+            now is the winter of our discontent made glorious summer by this sun of york
+            ''')
+    prints::
+        00 11 22 aa FF 0a 0d 1a
+        [0, 17, 34, 170, 255, 10, 13, 26]
+
+        my kingdom for a horse
+        ['MY', 'KINGDOM', 'FOR', 'A', 'HORSE']
+
+        now is the winter of our discontent made glorious summer by this sun of york
+        ['Now Is The Winter Of Our Discontent Made Glorious Summer By This Sun Of York']
+    """
+    def pa(s,l,t):
+        return [func(tokn, *args) for tokn in t]
+
+    try:
+        func_name = getattr(func, '__name__', 
+                            getattr(func, '__class__').__name__)
+    except Exception:
+        func_name = str(func)
+    pa.__name__ = func_name
+
+    return pa
+
+upcaseTokens = tokenMap(lambda t: _ustr(t).upper())
+"""(Deprecated) Helper parse action to convert tokens to upper case. Deprecated in favor of L{pyparsing_common.upcaseTokens}"""
+
+downcaseTokens = tokenMap(lambda t: _ustr(t).lower())
+"""(Deprecated) Helper parse action to convert tokens to lower case. Deprecated in favor of L{pyparsing_common.downcaseTokens}"""
+    
+def _makeTags(tagStr, xml):
+    """Internal helper to construct opening and closing tag expressions, given a tag name"""
+    if isinstance(tagStr,basestring):
+        resname = tagStr
+        tagStr = Keyword(tagStr, caseless=not xml)
+    else:
+        resname = tagStr.name
+
+    tagAttrName = Word(alphas,alphanums+"_-:")
+    if (xml):
+        tagAttrValue = dblQuotedString.copy().setParseAction( removeQuotes )
+        openTag = Suppress("<") + tagStr("tag") + \
+                Dict(ZeroOrMore(Group( tagAttrName + Suppress("=") + tagAttrValue ))) + \
+                Optional("/",default=[False]).setResultsName("empty").setParseAction(lambda s,l,t:t[0]=='/') + Suppress(">")
+    else:
+        printablesLessRAbrack = "".join(c for c in printables if c not in ">")
+        tagAttrValue = quotedString.copy().setParseAction( removeQuotes ) | Word(printablesLessRAbrack)
+        openTag = Suppress("<") + tagStr("tag") + \
+                Dict(ZeroOrMore(Group( tagAttrName.setParseAction(downcaseTokens) + \
+                Optional( Suppress("=") + tagAttrValue ) ))) + \
+                Optional("/",default=[False]).setResultsName("empty").setParseAction(lambda s,l,t:t[0]=='/') + Suppress(">")
+    closeTag = Combine(_L("</") + tagStr + ">")
+
+    openTag = openTag.setResultsName("start"+"".join(resname.replace(":"," ").title().split())).setName("<%s>" % resname)
+    closeTag = closeTag.setResultsName("end"+"".join(resname.replace(":"," ").title().split())).setName("</%s>" % resname)
+    openTag.tag = resname
+    closeTag.tag = resname
+    return openTag, closeTag
+
+def makeHTMLTags(tagStr):
+    """
+    Helper to construct opening and closing tag expressions for HTML, given a tag name. Matches
+    tags in either upper or lower case, attributes with namespaces and with quoted or unquoted values.
+
+    Example::
+        text = '<td>More info at the <a href="http://pyparsing.wikispaces.com">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 -> http://pyparsing.wikispaces.com
+    """
+    return _makeTags( tagStr, False )
+
+def makeXMLTags(tagStr):
+    """
+    Helper to construct opening and closing tag expressions for XML, given a tag name. Matches
+    tags only in the given upper/lower case.
+
+    Example: similar to L{makeHTMLTags}
+    """
+    return _makeTags( tagStr, True )
+
+def withAttribute(*args,**attrDict):
+    """
+    Helper to create a validating parse action to be used with start tags created
+    with C{L{makeXMLTags}} or C{L{makeHTMLTags}}. Use C{withAttribute} to qualify a starting tag
+    with a required attribute value, to avoid false matches on common tags such as
+    C{<TD>} or C{<DIV>}.
+
+    Call C{withAttribute} with a series of attribute names and values. Specify the list
+    of filter attributes names and values as:
+     - keyword arguments, as in C{(align="right")}, or
+     - as an explicit dict with C{**} operator, when an attribute name is also a Python
+          reserved word, as in C{**{"class":"Customer", "align":"right"}}
+     - a list of name-value tuples, as in ( ("ns1:class", "Customer"), ("ns2:align","right") )
+    For attribute names with a namespace prefix, you must use the second form.  Attribute
+    names are matched insensitive to upper/lower case.
+       
+    If just testing for C{class} (with or without a namespace), use C{L{withClass}}.
+
+    To verify that the attribute exists, but without specifying a value, pass
+    C{withAttribute.ANY_VALUE} as the value.
+
+    Example::
+        html = '''
+            <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 C{L{withAttribute}} when matching on a div class - made
+    difficult because C{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 = _Constants()
+opAssoc.LEFT = object()
+opAssoc.RIGHT = object()
+
+def infixNotation( baseExpr, opList, lpar=Suppress('('), rpar=Suppress(')') ):
+    """
+    Helper method for constructing grammars of expressions made up of
+    operators working in a precedence hierarchy.  Operators may be unary or
+    binary, left- or right-associative.  Parse actions can also be attached
+    to operator expressions. The generated parser will also recognize the use 
+    of parentheses to override operator precedences (see example below).
+    
+    Note: if you define a deep operator list, you may see performance issues
+    when using infixNotation. See L{ParserElement.enablePackrat} for a
+    mechanism to potentially improve your parser performance.
+
+    Parameters:
+     - baseExpr - expression representing the most basic element for the nested
+     - opList - list of tuples, one for each operator precedence level in the
+      expression grammar; each tuple is of the form
+      (opExpr, numTerms, rightLeftAssoc, parseAction), where:
+       - opExpr is the pyparsing expression for the operator;
+          may also be a string, which will be converted to a Literal;
+          if numTerms is 3, opExpr is a tuple of two expressions, for the
+          two operators separating the 3 terms
+       - numTerms is the number of terms for this operator (must
+          be 1, 2, or 3)
+       - rightLeftAssoc is the indicator whether the operator is
+          right or left associative, using the pyparsing-defined
+          constants C{opAssoc.RIGHT} and C{opAssoc.LEFT}.
+       - parseAction is the parse action to be associated with
+          expressions matching this operator expression (the
+          parse action tuple member may be omitted); if the parse action
+          is passed a tuple or list of functions, this is equivalent to
+          calling C{setParseAction(*fn)} (L{ParserElement.setParseAction})
+     - lpar - expression for matching left-parentheses (default=C{Suppress('(')})
+     - rpar - expression for matching right-parentheses (default=C{Suppress(')')})
+
+    Example::
+        # simple example of four-function arithmetic with ints and variable names
+        integer = pyparsing_common.signed_integer
+        varname = pyparsing_common.identifier 
+        
+        arith_expr = infixNotation(integer | varname,
+            [
+            ('-', 1, opAssoc.RIGHT),
+            (oneOf('* /'), 2, opAssoc.LEFT),
+            (oneOf('+ -'), 2, opAssoc.LEFT),
+            ])
+        
+        arith_expr.runTests('''
+            5+3*6
+            (5+3)*6
+            -2--11
+            ''', fullDump=False)
+    prints::
+        5+3*6
+        [[5, '+', [3, '*', 6]]]
+
+        (5+3)*6
+        [[[5, '+', 3], '*', 6]]
+
+        -2--11
+        [[['-', 2], '-', ['-', 11]]]
+    """
+    ret = Forward()
+    lastExpr = baseExpr | ( lpar + ret + rpar )
+    for i,operDef in enumerate(opList):
+        opExpr,arity,rightLeftAssoc,pa = (operDef + (None,))[:4]
+        termName = "%s term" % opExpr if arity < 3 else "%s%s term" % opExpr
+        if arity == 3:
+            if opExpr is None or len(opExpr) != 2:
+                raise ValueError("if numterms=3, opExpr must be a tuple or list of two expressions")
+            opExpr1, opExpr2 = opExpr
+        thisExpr = Forward().setName(termName)
+        if rightLeftAssoc == opAssoc.LEFT:
+            if arity == 1:
+                matchExpr = FollowedBy(lastExpr + opExpr) + Group( lastExpr + OneOrMore( opExpr ) )
+            elif arity == 2:
+                if opExpr is not None:
+                    matchExpr = FollowedBy(lastExpr + opExpr + lastExpr) + Group( lastExpr + OneOrMore( opExpr + lastExpr ) )
+                else:
+                    matchExpr = FollowedBy(lastExpr+lastExpr) + Group( lastExpr + OneOrMore(lastExpr) )
+            elif arity == 3:
+                matchExpr = FollowedBy(lastExpr + opExpr1 + lastExpr + opExpr2 + lastExpr) + \
+                            Group( lastExpr + opExpr1 + lastExpr + opExpr2 + lastExpr )
+            else:
+                raise ValueError("operator must be unary (1), binary (2), or ternary (3)")
+        elif rightLeftAssoc == opAssoc.RIGHT:
+            if arity == 1:
+                # try to avoid LR with this extra test
+                if not isinstance(opExpr, Optional):
+                    opExpr = Optional(opExpr)
+                matchExpr = FollowedBy(opExpr.expr + thisExpr) + Group( opExpr + thisExpr )
+            elif arity == 2:
+                if opExpr is not None:
+                    matchExpr = FollowedBy(lastExpr + opExpr + thisExpr) + Group( lastExpr + OneOrMore( opExpr + thisExpr ) )
+                else:
+                    matchExpr = FollowedBy(lastExpr + thisExpr) + Group( lastExpr + OneOrMore( thisExpr ) )
+            elif arity == 3:
+                matchExpr = FollowedBy(lastExpr + opExpr1 + thisExpr + opExpr2 + thisExpr) + \
+                            Group( lastExpr + opExpr1 + thisExpr + opExpr2 + thisExpr )
+            else:
+                raise ValueError("operator must be unary (1), binary (2), or ternary (3)")
+        else:
+            raise ValueError("operator must indicate right or left associativity")
+        if pa:
+            if isinstance(pa, (tuple, list)):
+                matchExpr.setParseAction(*pa)
+            else:
+                matchExpr.setParseAction(pa)
+        thisExpr <<= ( matchExpr.setName(termName) | lastExpr )
+        lastExpr = thisExpr
+    ret <<= lastExpr
+    return ret
+
+operatorPrecedence = infixNotation
+"""(Deprecated) Former name of C{L{infixNotation}}, will be dropped in a future release."""
+
+dblQuotedString = Combine(Regex(r'"(?:[^"\n\r\\]|(?:"")|(?:\\(?:[^x]|x[0-9a-fA-F]+)))*')+'"').setName("string enclosed in double quotes")
+sglQuotedString = Combine(Regex(r"'(?:[^'\n\r\\]|(?:'')|(?:\\(?:[^x]|x[0-9a-fA-F]+)))*")+"'").setName("string enclosed in single quotes")
+quotedString = Combine(Regex(r'"(?:[^"\n\r\\]|(?:"")|(?:\\(?:[^x]|x[0-9a-fA-F]+)))*')+'"'|
+                       Regex(r"'(?:[^'\n\r\\]|(?:'')|(?:\\(?:[^x]|x[0-9a-fA-F]+)))*")+"'").setName("quotedString using single or double quotes")
+unicodeString = Combine(_L('u') + quotedString.copy()).setName("unicode string literal")
+
+def nestedExpr(opener="(", closer=")", content=None, ignoreExpr=quotedString.copy()):
+    """
+    Helper method for defining nested lists enclosed in opening and closing
+    delimiters ("(" and ")" are the default).
+
+    Parameters:
+     - opener - opening character for a nested list (default=C{"("}); can also be a pyparsing expression
+     - closer - closing character for a nested list (default=C{")"}); can also be a pyparsing expression
+     - content - expression for items within the nested lists (default=C{None})
+     - ignoreExpr - expression for ignoring opening and closing delimiters (default=C{quotedString})
+
+    If an expression is not provided for the content argument, the nested
+    expression will capture all whitespace-delimited content between delimiters
+    as a list of separate values.
+
+    Use the C{ignoreExpr} argument to define expressions that may contain
+    opening or closing characters that should not be treated as opening
+    or closing characters for nesting, such as quotedString or a comment
+    expression.  Specify multiple expressions using an C{L{Or}} or C{L{MatchFirst}}.
+    The default is L{quotedString}, but if no expressions are to be ignored,
+    then pass C{None} for this argument.
+
+    Example::
+        data_type = oneOf("void int short long char float double")
+        decl_data_type = Combine(data_type + Optional(Word('*')))
+        ident = Word(alphas+'_', alphanums+'_')
+        number = pyparsing_common.number
+        arg = Group(decl_data_type + ident)
+        LPAR,RPAR = map(Suppress, "()")
+
+        code_body = nestedExpr('{', '}', ignoreExpr=(quotedString | cStyleComment))
+
+        c_function = (decl_data_type("type") 
+                      + ident("name")
+                      + LPAR + Optional(delimitedList(arg), [])("args") + RPAR 
+                      + code_body("body"))
+        c_function.ignore(cStyleComment)
+        
+        source_code = '''
+            int is_odd(int x) { 
+                return (x%2); 
+            }
+                
+            int dec_to_hex(char hchar) { 
+                if (hchar >= '0' && hchar <= '9') { 
+                    return (ord(hchar)-ord('0')); 
+                } else { 
+                    return (10+ord(hchar)-ord('A'));
+                } 
+            }
+        '''
+        for func in c_function.searchString(source_code):
+            print("%(name)s (%(type)s) args: %(args)s" % func)
+
+    prints::
+        is_odd (int) args: [['int', 'x']]
+        dec_to_hex (int) args: [['char', 'hchar']]
+    """
+    if opener == closer:
+        raise ValueError("opening and closing strings cannot be the same")
+    if content is None:
+        if isinstance(opener,basestring) and isinstance(closer,basestring):
+            if len(opener) == 1 and len(closer)==1:
+                if ignoreExpr is not None:
+                    content = (Combine(OneOrMore(~ignoreExpr +
+                                    CharsNotIn(opener+closer+ParserElement.DEFAULT_WHITE_CHARS,exact=1))
+                                ).setParseAction(lambda t:t[0].strip()))
+                else:
+                    content = (empty.copy()+CharsNotIn(opener+closer+ParserElement.DEFAULT_WHITE_CHARS
+                                ).setParseAction(lambda t:t[0].strip()))
+            else:
+                if ignoreExpr is not None:
+                    content = (Combine(OneOrMore(~ignoreExpr + 
+                                    ~Literal(opener) + ~Literal(closer) +
+                                    CharsNotIn(ParserElement.DEFAULT_WHITE_CHARS,exact=1))
+                                ).setParseAction(lambda t:t[0].strip()))
+                else:
+                    content = (Combine(OneOrMore(~Literal(opener) + ~Literal(closer) +
+                                    CharsNotIn(ParserElement.DEFAULT_WHITE_CHARS,exact=1))
+                                ).setParseAction(lambda t:t[0].strip()))
+        else:
+            raise ValueError("opening and closing arguments must be strings if no content expression is given")
+    ret = Forward()
+    if ignoreExpr is not None:
+        ret <<= Group( Suppress(opener) + ZeroOrMore( ignoreExpr | ret | content ) + Suppress(closer) )
+    else:
+        ret <<= Group( Suppress(opener) + ZeroOrMore( ret | content )  + Suppress(closer) )
+    ret.setName('nested %s%s expression' % (opener,closer))
+    return ret
+
+def indentedBlock(blockStatementExpr, indentStack, indent=True):
+    """
+    Helper method for defining space-delimited indentation blocks, such as
+    those used to define block statements in Python source code.
+
+    Parameters:
+     - blockStatementExpr - expression defining syntax of statement that
+            is repeated within the indented block
+     - indentStack - list created by caller to manage indentation stack
+            (multiple statementWithIndentedBlock expressions within a single grammar
+            should share a common indentStack)
+     - indent - boolean indicating whether block must be indented beyond the
+            the current level; set to False for block of left-most statements
+            (default=C{True})
+
+    A valid block must contain at least one C{blockStatement}.
+
+    Example::
+        data = '''
+        def A(z):
+          A1
+          B = 100
+          G = A2
+          A2
+          A3
+        B
+        def BB(a,b,c):
+          BB1
+          def BBA():
+            bba1
+            bba2
+            bba3
+        C
+        D
+        def spam(x,y):
+             def eggs(z):
+                 pass
+        '''
+
+
+        indentStack = [1]
+        stmt = Forward()
+
+        identifier = Word(alphas, alphanums)
+        funcDecl = ("def" + identifier + Group( "(" + Optional( delimitedList(identifier) ) + ")" ) + ":")
+        func_body = indentedBlock(stmt, indentStack)
+        funcDef = Group( funcDecl + func_body )
+
+        rvalue = Forward()
+        funcCall = Group(identifier + "(" + Optional(delimitedList(rvalue)) + ")")
+        rvalue << (funcCall | identifier | Word(nums))
+        assignment = Group(identifier + "=" + rvalue)
+        stmt << ( funcDef | assignment | identifier )
+
+        module_body = OneOrMore(stmt)
+
+        parseTree = module_body.parseString(data)
+        parseTree.pprint()
+    prints::
+        [['def',
+          'A',
+          ['(', 'z', ')'],
+          ':',
+          [['A1'], [['B', '=', '100']], [['G', '=', 'A2']], ['A2'], ['A3']]],
+         'B',
+         ['def',
+          'BB',
+          ['(', 'a', 'b', 'c', ')'],
+          ':',
+          [['BB1'], [['def', 'BBA', ['(', ')'], ':', [['bba1'], ['bba2'], ['bba3']]]]]],
+         'C',
+         'D',
+         ['def',
+          'spam',
+          ['(', 'x', 'y', ')'],
+          ':',
+          [[['def', 'eggs', ['(', 'z', ')'], ':', [['pass']]]]]]] 
+    """
+    def checkPeerIndent(s,l,t):
+        if l >= len(s): return
+        curCol = col(l,s)
+        if curCol != indentStack[-1]:
+            if curCol > indentStack[-1]:
+                raise ParseFatalException(s,l,"illegal nesting")
+            raise ParseException(s,l,"not a peer entry")
+
+    def checkSubIndent(s,l,t):
+        curCol = col(l,s)
+        if curCol > indentStack[-1]:
+            indentStack.append( curCol )
+        else:
+            raise ParseException(s,l,"not a subentry")
+
+    def checkUnindent(s,l,t):
+        if l >= len(s): return
+        curCol = col(l,s)
+        if not(indentStack and curCol < indentStack[-1] and curCol <= indentStack[-2]):
+            raise ParseException(s,l,"not an unindent")
+        indentStack.pop()
+
+    NL = OneOrMore(LineEnd().setWhitespaceChars("\t ").suppress())
+    INDENT = (Empty() + Empty().setParseAction(checkSubIndent)).setName('INDENT')
+    PEER   = Empty().setParseAction(checkPeerIndent).setName('')
+    UNDENT = Empty().setParseAction(checkUnindent).setName('UNINDENT')
+    if indent:
+        smExpr = Group( Optional(NL) +
+            #~ FollowedBy(blockStatementExpr) +
+            INDENT + (OneOrMore( PEER + Group(blockStatementExpr) + Optional(NL) )) + UNDENT)
+    else:
+        smExpr = Group( Optional(NL) +
+            (OneOrMore( PEER + Group(blockStatementExpr) + Optional(NL) )) )
+    blockStatementExpr.ignore(_bslash + LineEnd())
+    return smExpr.setName('indented block')
+
+alphas8bit = srange(r"[\0xc0-\0xd6\0xd8-\0xf6\0xf8-\0xff]")
+punc8bit = srange(r"[\0xa1-\0xbf\0xd7\0xf7]")
+
+anyOpenTag,anyCloseTag = makeHTMLTags(Word(alphas,alphanums+"_:").setName('any tag'))
+_htmlEntityMap = dict(zip("gt lt amp nbsp quot apos".split(),'><& "\''))
+commonHTMLEntity = Regex('&(?P<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 C{/* ... */}"
+
+htmlComment = Regex(r"<!--[\s\S]*?-->").setName("HTML comment")
+"Comment of the form C{<!-- ... -->}"
+
+restOfLine = Regex(r".*").leaveWhitespace().setName("rest of line")
+dblSlashComment = Regex(r"//(?:\\\n|[^\n])*").setName("// comment")
+"Comment of the form C{// ... (to end of line)}"
+
+cppStyleComment = Combine(Regex(r"/\*(?:[^*]|\*(?!/))*") + '*/'| dblSlashComment).setName("C++ style comment")
+"Comment of either form C{L{cStyleComment}} or C{L{dblSlashComment}}"
+
+javaStyleComment = cppStyleComment
+"Same as C{L{cppStyleComment}}"
+
+pythonStyleComment = Regex(r"#.*").setName("Python style comment")
+"Comment of the form C{# ... (to end of line)}"
+
+_commasepitem = Combine(OneOrMore(Word(printables, excludeChars=',') +
+                                  Optional( Word(" \t") +
+                                            ~Literal(",") + ~LineEnd() ) ) ).streamline().setName("commaItem")
+commaSeparatedList = delimitedList( Optional( quotedString.copy() | _commasepitem, default="") ).setName("commaSeparatedList")
+"""(Deprecated) Predefined expression of 1 or more printable words or quoted strings, separated by commas.
+   This expression is deprecated in favor of L{pyparsing_common.comma_separated_list}."""
+
+# some other useful expressions - using lower-case class name since we are really using this as a namespace
+class pyparsing_common:
+    """
+    Here are some common low-level expressions that may be useful in jump-starting parser development:
+     - numeric forms (L{integers<integer>}, L{reals<real>}, L{scientific notation<sci_real>})
+     - common L{programming identifiers<identifier>}
+     - network addresses (L{MAC<mac_address>}, L{IPv4<ipv4_address>}, L{IPv6<ipv6_address>})
+     - ISO8601 L{dates<iso8601_date>} and L{datetime<iso8601_datetime>}
+     - L{UUID<uuid>}
+     - L{comma-separated list<comma_separated_list>}
+    Parse actions:
+     - C{L{convertToInteger}}
+     - C{L{convertToFloat}}
+     - C{L{convertToDate}}
+     - C{L{convertToDatetime}}
+     - C{L{stripHTMLTags}}
+     - C{L{upcaseTokens}}
+     - C{L{downcaseTokens}}
+
+    Example::
+        pyparsing_common.number.runTests('''
+            # any int or real number, returned as the appropriate type
+            100
+            -100
+            +100
+            3.14159
+            6.02e23
+            1e-12
+            ''')
+
+        pyparsing_common.fnumber.runTests('''
+            # any int or real number, returned as float
+            100
+            -100
+            +100
+            3.14159
+            6.02e23
+            1e-12
+            ''')
+
+        pyparsing_common.hex_integer.runTests('''
+            # hex numbers
+            100
+            FF
+            ''')
+
+        pyparsing_common.fraction.runTests('''
+            # fractions
+            1/2
+            -3/4
+            ''')
+
+        pyparsing_common.mixed_integer.runTests('''
+            # mixed fractions
+            1
+            1/2
+            -3/4
+            1-3/4
+            ''')
+
+        import uuid
+        pyparsing_common.uuid.setParseAction(tokenMap(uuid.UUID))
+        pyparsing_common.uuid.runTests('''
+            # uuid
+            12345678-1234-5678-1234-567812345678
+            ''')
+    prints::
+        # any int or real number, returned as the appropriate type
+        100
+        [100]
+
+        -100
+        [-100]
+
+        +100
+        [100]
+
+        3.14159
+        [3.14159]
+
+        6.02e23
+        [6.02e+23]
+
+        1e-12
+        [1e-12]
+
+        # any int or real number, returned as float
+        100
+        [100.0]
+
+        -100
+        [-100.0]
+
+        +100
+        [100.0]
+
+        3.14159
+        [3.14159]
+
+        6.02e23
+        [6.02e+23]
+
+        1e-12
+        [1e-12]
+
+        # hex numbers
+        100
+        [256]
+
+        FF
+        [255]
+
+        # fractions
+        1/2
+        [0.5]
+
+        -3/4
+        [-0.75]
+
+        # mixed fractions
+        1
+        [1]
+
+        1/2
+        [0.5]
+
+        -3/4
+        [-0.75]
+
+        1-3/4
+        [1.75]
+
+        # uuid
+        12345678-1234-5678-1234-567812345678
+        [UUID('12345678-1234-5678-1234-567812345678')]
+    """
+
+    convertToInteger = tokenMap(int)
+    """
+    Parse action for converting parsed integers to Python int
+    """
+
+    convertToFloat = tokenMap(float)
+    """
+    Parse action for converting parsed numbers to Python float
+    """
+
+    integer = Word(nums).setName("integer").setParseAction(convertToInteger)
+    """expression that parses an unsigned integer, returns an int"""
+
+    hex_integer = Word(hexnums).setName("hex integer").setParseAction(tokenMap(int,16))
+    """expression that parses a hexadecimal integer, returns an int"""
+
+    signed_integer = Regex(r'[+-]?\d+').setName("signed integer").setParseAction(convertToInteger)
+    """expression that parses an integer with optional leading sign, returns an int"""
+
+    fraction = (signed_integer().setParseAction(convertToFloat) + '/' + signed_integer().setParseAction(convertToFloat)).setName("fraction")
+    """fractional expression of an integer divided by an integer, returns a float"""
+    fraction.addParseAction(lambda t: t[0]/t[-1])
+
+    mixed_integer = (fraction | signed_integer + Optional(Optional('-').suppress() + fraction)).setName("fraction or mixed integer-fraction")
+    """mixed integer of the form 'integer - fraction', with optional leading integer, returns float"""
+    mixed_integer.addParseAction(sum)
+
+    real = Regex(r'[+-]?\d+\.\d*').setName("real number").setParseAction(convertToFloat)
+    """expression that parses a floating point number and returns a float"""
+
+    sci_real = Regex(r'[+-]?\d+([eE][+-]?\d+|\.\d*([eE][+-]?\d+)?)').setName("real number with scientific notation").setParseAction(convertToFloat)
+    """expression that parses a floating point number with optional scientific notation and returns a float"""
+
+    # streamlining this expression makes the docs nicer-looking
+    number = (sci_real | real | signed_integer).streamline()
+    """any numeric expression, returns the corresponding Python type"""
+
+    fnumber = Regex(r'[+-]?\d+\.?\d*([eE][+-]?\d+)?').setName("fnumber").setParseAction(convertToFloat)
+    """any int or real number, returned as float"""
+    
+    identifier = Word(alphas+'_', alphanums+'_').setName("identifier")
+    """typical code identifier (leading alpha or '_', followed by 0 or more alphas, nums, or '_')"""
+    
+    ipv4_address = Regex(r'(25[0-5]|2[0-4][0-9]|1?[0-9]{1,2})(\.(25[0-5]|2[0-4][0-9]|1?[0-9]{1,2})){3}').setName("IPv4 address")
+    "IPv4 address (C{0.0.0.0 - 255.255.255.255})"
+
+    _ipv6_part = Regex(r'[0-9a-fA-F]{1,4}').setName("hex_integer")
+    _full_ipv6_address = (_ipv6_part + (':' + _ipv6_part)*7).setName("full IPv6 address")
+    _short_ipv6_address = (Optional(_ipv6_part + (':' + _ipv6_part)*(0,6)) + "::" + Optional(_ipv6_part + (':' + _ipv6_part)*(0,6))).setName("short IPv6 address")
+    _short_ipv6_address.addCondition(lambda t: sum(1 for tt in t if pyparsing_common._ipv6_part.matches(tt)) < 8)
+    _mixed_ipv6_address = ("::ffff:" + ipv4_address).setName("mixed IPv6 address")
+    ipv6_address = Combine((_full_ipv6_address | _mixed_ipv6_address | _short_ipv6_address).setName("IPv6 address")).setName("IPv6 address")
+    "IPv6 address (long, short, or mixed form)"
+    
+    mac_address = Regex(r'[0-9a-fA-F]{2}([:.-])[0-9a-fA-F]{2}(?:\1[0-9a-fA-F]{2}){4}').setName("MAC address")
+    "MAC address xx:xx:xx:xx:xx (may also have '-' or '.' delimiters)"
+
+    @staticmethod
+    def convertToDate(fmt="%Y-%m-%d"):
+        """
+        Helper to create a parse action for converting parsed date string to Python datetime.date
+
+        Params -
+         - fmt - format to be passed to datetime.strptime (default=C{"%Y-%m-%d"})
+
+        Example::
+            date_expr = pyparsing_common.iso8601_date.copy()
+            date_expr.setParseAction(pyparsing_common.convertToDate())
+            print(date_expr.parseString("1999-12-31"))
+        prints::
+            [datetime.date(1999, 12, 31)]
+        """
+        def cvt_fn(s,l,t):
+            try:
+                return datetime.strptime(t[0], fmt).date()
+            except ValueError as ve:
+                raise ParseException(s, l, str(ve))
+        return cvt_fn
+
+    @staticmethod
+    def convertToDatetime(fmt="%Y-%m-%dT%H:%M:%S.%f"):
+        """
+        Helper to create a parse action for converting parsed datetime string to Python datetime.datetime
+
+        Params -
+         - fmt - format to be passed to datetime.strptime (default=C{"%Y-%m-%dT%H:%M:%S.%f"})
+
+        Example::
+            dt_expr = pyparsing_common.iso8601_datetime.copy()
+            dt_expr.setParseAction(pyparsing_common.convertToDatetime())
+            print(dt_expr.parseString("1999-12-31T23:59:59.999"))
+        prints::
+            [datetime.datetime(1999, 12, 31, 23, 59, 59, 999000)]
+        """
+        def cvt_fn(s,l,t):
+            try:
+                return datetime.strptime(t[0], fmt)
+            except ValueError as ve:
+                raise ParseException(s, l, str(ve))
+        return cvt_fn
+
+    iso8601_date = Regex(r'(?P<year>\d{4})(?:-(?P<month>\d\d)(?:-(?P<day>\d\d))?)?').setName("ISO8601 date")
+    "ISO8601 date (C{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 (C{yyyy-mm-ddThh:mm:ss.s(Z|+-00:00)}) - trailing seconds, milliseconds, and timezone optional; accepts separating C{'T'} or C{' '}"
+
+    uuid = Regex(r'[0-9a-fA-F]{8}(-[0-9a-fA-F]{4}){3}-[0-9a-fA-F]{12}').setName("UUID")
+    "UUID (C{xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx})"
+
+    _html_stripper = anyOpenTag.suppress() | anyCloseTag.suppress()
+    @staticmethod
+    def stripHTMLTags(s, l, tokens):
+        """
+        Parse action to remove HTML tags from web page HTML source
+
+        Example::
+            # strip HTML links from normal text 
+            text = '<td>More info at the <a href="http://pyparsing.wikispaces.com">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) # -> 'More info at the pyparsing wiki page'
+        """
+        return pyparsing_common._html_stripper.transformString(tokens[0])
+
+    _commasepitem = Combine(OneOrMore(~Literal(",") + ~LineEnd() + Word(printables, excludeChars=',') 
+                                        + Optional( White(" \t") ) ) ).streamline().setName("commaItem")
+    comma_separated_list = delimitedList( Optional( quotedString.copy() | _commasepitem, default="") ).setName("comma separated list")
+    """Predefined expression of 1 or more printable words or quoted strings, separated by commas."""
+
+    upcaseTokens = staticmethod(tokenMap(lambda t: _ustr(t).upper()))
+    """Parse action to convert tokens to upper case."""
+
+    downcaseTokens = staticmethod(tokenMap(lambda t: _ustr(t).lower()))
+    """Parse action to convert tokens to lower case."""
+
+
+if __name__ == "__main__":
+
+    selectToken    = CaselessLiteral("select")
+    fromToken      = CaselessLiteral("from")
+
+    ident          = Word(alphas, alphanums + "_$")
+
+    columnName     = delimitedList(ident, ".", combine=True).setParseAction(upcaseTokens)
+    columnNameList = Group(delimitedList(columnName)).setName("columns")
+    columnSpec     = ('*' | columnNameList)
+
+    tableName      = delimitedList(ident, ".", combine=True).setParseAction(upcaseTokens)
+    tableNameList  = Group(delimitedList(tableName)).setName("tables")
+    
+    simpleSQL      = selectToken("command") + columnSpec("columns") + fromToken + tableNameList("tables")
+
+    # demo runTests method, including embedded comments in test string
+    simpleSQL.runTests("""
+        # '*' as column list and dotted table name
+        select * from SYS.XYZZY
+
+        # caseless match on "SELECT", and casts back to "select"
+        SELECT * from XYZZY, ABC
+
+        # list of column names, and mixed case SELECT keyword
+        Select AA,BB,CC from Sys.dual
+
+        # multiple tables
+        Select A, B, C from Sys.dual, Table2
+
+        # invalid SELECT keyword - should fail
+        Xelect A, B, C from Sys.dual
+
+        # incomplete command - should fail
+        Select
+
+        # invalid column name - should fail
+        Select ^^^ frox Sys.dual
+
+        """)
+
+    pyparsing_common.number.runTests("""
+        100
+        -100
+        +100
+        3.14159
+        6.02e23
+        1e-12
+        """)
+
+    # any int or real number, returned as float
+    pyparsing_common.fnumber.runTests("""
+        100
+        -100
+        +100
+        3.14159
+        6.02e23
+        1e-12
+        """)
+
+    pyparsing_common.hex_integer.runTests("""
+        100
+        FF
+        """)
+
+    import uuid
+    pyparsing_common.uuid.setParseAction(tokenMap(uuid.UUID))
+    pyparsing_common.uuid.runTests("""
+        12345678-1234-5678-1234-567812345678
+        """)
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pkg_resources/_vendor/pyparsing.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pkg_resources/_vendor/pyparsing.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..1ab45b21240f9d77709bd1172a42d22a4c1b2853
GIT binary patch
literal 260233
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

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pkg_resources/_vendor/six.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pkg_resources/_vendor/six.py
new file mode 100644
index 0000000..190c023
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pkg_resources/_vendor/six.py
@@ -0,0 +1,868 @@
+"""Utilities for writing code that runs on Python 2 and 3"""
+
+# Copyright (c) 2010-2015 Benjamin Peterson
+#
+# Permission is hereby granted, free of charge, to any person obtaining a copy
+# of this software and associated documentation files (the "Software"), to deal
+# in the Software without restriction, including without limitation the rights
+# to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
+# copies of the Software, and to permit persons to whom the Software is
+# furnished to do so, subject to the following conditions:
+#
+# The above copyright notice and this permission notice shall be included in all
+# copies or substantial portions of the Software.
+#
+# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
+# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
+# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
+# AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
+# LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
+# OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
+# SOFTWARE.
+
+from __future__ import absolute_import
+
+import functools
+import itertools
+import operator
+import sys
+import types
+
+__author__ = "Benjamin Peterson <benjamin@python.org>"
+__version__ = "1.10.0"
+
+
+# Useful for very coarse version differentiation.
+PY2 = sys.version_info[0] == 2
+PY3 = sys.version_info[0] == 3
+PY34 = sys.version_info[0:2] >= (3, 4)
+
+if PY3:
+    string_types = str,
+    integer_types = int,
+    class_types = type,
+    text_type = str
+    binary_type = bytes
+
+    MAXSIZE = sys.maxsize
+else:
+    string_types = basestring,
+    integer_types = (int, long)
+    class_types = (type, types.ClassType)
+    text_type = unicode
+    binary_type = str
+
+    if sys.platform.startswith("java"):
+        # Jython always uses 32 bits.
+        MAXSIZE = int((1 << 31) - 1)
+    else:
+        # It's possible to have sizeof(long) != sizeof(Py_ssize_t).
+        class X(object):
+
+            def __len__(self):
+                return 1 << 31
+        try:
+            len(X())
+        except OverflowError:
+            # 32-bit
+            MAXSIZE = int((1 << 31) - 1)
+        else:
+            # 64-bit
+            MAXSIZE = int((1 << 63) - 1)
+        del X
+
+
+def _add_doc(func, doc):
+    """Add documentation to a function."""
+    func.__doc__ = doc
+
+
+def _import_module(name):
+    """Import module, returning the module after the last dot."""
+    __import__(name)
+    return sys.modules[name]
+
+
+class _LazyDescr(object):
+
+    def __init__(self, name):
+        self.name = name
+
+    def __get__(self, obj, tp):
+        result = self._resolve()
+        setattr(obj, self.name, result)  # Invokes __set__.
+        try:
+            # This is a bit ugly, but it avoids running this again by
+            # removing this descriptor.
+            delattr(obj.__class__, self.name)
+        except AttributeError:
+            pass
+        return result
+
+
+class MovedModule(_LazyDescr):
+
+    def __init__(self, name, old, new=None):
+        super(MovedModule, self).__init__(name)
+        if PY3:
+            if new is None:
+                new = name
+            self.mod = new
+        else:
+            self.mod = old
+
+    def _resolve(self):
+        return _import_module(self.mod)
+
+    def __getattr__(self, attr):
+        _module = self._resolve()
+        value = getattr(_module, attr)
+        setattr(self, attr, value)
+        return value
+
+
+class _LazyModule(types.ModuleType):
+
+    def __init__(self, name):
+        super(_LazyModule, self).__init__(name)
+        self.__doc__ = self.__class__.__doc__
+
+    def __dir__(self):
+        attrs = ["__doc__", "__name__"]
+        attrs += [attr.name for attr in self._moved_attributes]
+        return attrs
+
+    # Subclasses should override this
+    _moved_attributes = []
+
+
+class MovedAttribute(_LazyDescr):
+
+    def __init__(self, name, old_mod, new_mod, old_attr=None, new_attr=None):
+        super(MovedAttribute, self).__init__(name)
+        if PY3:
+            if new_mod is None:
+                new_mod = name
+            self.mod = new_mod
+            if new_attr is None:
+                if old_attr is None:
+                    new_attr = name
+                else:
+                    new_attr = old_attr
+            self.attr = new_attr
+        else:
+            self.mod = old_mod
+            if old_attr is None:
+                old_attr = name
+            self.attr = old_attr
+
+    def _resolve(self):
+        module = _import_module(self.mod)
+        return getattr(module, self.attr)
+
+
+class _SixMetaPathImporter(object):
+
+    """
+    A meta path importer to import six.moves and its submodules.
+
+    This class implements a PEP302 finder and loader. It should be compatible
+    with Python 2.5 and all existing versions of Python3
+    """
+
+    def __init__(self, six_module_name):
+        self.name = six_module_name
+        self.known_modules = {}
+
+    def _add_module(self, mod, *fullnames):
+        for fullname in fullnames:
+            self.known_modules[self.name + "." + fullname] = mod
+
+    def _get_module(self, fullname):
+        return self.known_modules[self.name + "." + fullname]
+
+    def find_module(self, fullname, path=None):
+        if fullname in self.known_modules:
+            return self
+        return None
+
+    def __get_module(self, fullname):
+        try:
+            return self.known_modules[fullname]
+        except KeyError:
+            raise ImportError("This loader does not know module " + fullname)
+
+    def load_module(self, fullname):
+        try:
+            # in case of a reload
+            return sys.modules[fullname]
+        except KeyError:
+            pass
+        mod = self.__get_module(fullname)
+        if isinstance(mod, MovedModule):
+            mod = mod._resolve()
+        else:
+            mod.__loader__ = self
+        sys.modules[fullname] = mod
+        return mod
+
+    def is_package(self, fullname):
+        """
+        Return true, if the named module is a package.
+
+        We need this method to get correct spec objects with
+        Python 3.4 (see PEP451)
+        """
+        return hasattr(self.__get_module(fullname), "__path__")
+
+    def get_code(self, fullname):
+        """Return None
+
+        Required, if is_package is implemented"""
+        self.__get_module(fullname)  # eventually raises ImportError
+        return None
+    get_source = get_code  # same as get_code
+
+_importer = _SixMetaPathImporter(__name__)
+
+
+class _MovedItems(_LazyModule):
+
+    """Lazy loading of moved objects"""
+    __path__ = []  # mark as package
+
+
+_moved_attributes = [
+    MovedAttribute("cStringIO", "cStringIO", "io", "StringIO"),
+    MovedAttribute("filter", "itertools", "builtins", "ifilter", "filter"),
+    MovedAttribute("filterfalse", "itertools", "itertools", "ifilterfalse", "filterfalse"),
+    MovedAttribute("input", "__builtin__", "builtins", "raw_input", "input"),
+    MovedAttribute("intern", "__builtin__", "sys"),
+    MovedAttribute("map", "itertools", "builtins", "imap", "map"),
+    MovedAttribute("getcwd", "os", "os", "getcwdu", "getcwd"),
+    MovedAttribute("getcwdb", "os", "os", "getcwd", "getcwdb"),
+    MovedAttribute("range", "__builtin__", "builtins", "xrange", "range"),
+    MovedAttribute("reload_module", "__builtin__", "importlib" if PY34 else "imp", "reload"),
+    MovedAttribute("reduce", "__builtin__", "functools"),
+    MovedAttribute("shlex_quote", "pipes", "shlex", "quote"),
+    MovedAttribute("StringIO", "StringIO", "io"),
+    MovedAttribute("UserDict", "UserDict", "collections"),
+    MovedAttribute("UserList", "UserList", "collections"),
+    MovedAttribute("UserString", "UserString", "collections"),
+    MovedAttribute("xrange", "__builtin__", "builtins", "xrange", "range"),
+    MovedAttribute("zip", "itertools", "builtins", "izip", "zip"),
+    MovedAttribute("zip_longest", "itertools", "itertools", "izip_longest", "zip_longest"),
+    MovedModule("builtins", "__builtin__"),
+    MovedModule("configparser", "ConfigParser"),
+    MovedModule("copyreg", "copy_reg"),
+    MovedModule("dbm_gnu", "gdbm", "dbm.gnu"),
+    MovedModule("_dummy_thread", "dummy_thread", "_dummy_thread"),
+    MovedModule("http_cookiejar", "cookielib", "http.cookiejar"),
+    MovedModule("http_cookies", "Cookie", "http.cookies"),
+    MovedModule("html_entities", "htmlentitydefs", "html.entities"),
+    MovedModule("html_parser", "HTMLParser", "html.parser"),
+    MovedModule("http_client", "httplib", "http.client"),
+    MovedModule("email_mime_multipart", "email.MIMEMultipart", "email.mime.multipart"),
+    MovedModule("email_mime_nonmultipart", "email.MIMENonMultipart", "email.mime.nonmultipart"),
+    MovedModule("email_mime_text", "email.MIMEText", "email.mime.text"),
+    MovedModule("email_mime_base", "email.MIMEBase", "email.mime.base"),
+    MovedModule("BaseHTTPServer", "BaseHTTPServer", "http.server"),
+    MovedModule("CGIHTTPServer", "CGIHTTPServer", "http.server"),
+    MovedModule("SimpleHTTPServer", "SimpleHTTPServer", "http.server"),
+    MovedModule("cPickle", "cPickle", "pickle"),
+    MovedModule("queue", "Queue"),
+    MovedModule("reprlib", "repr"),
+    MovedModule("socketserver", "SocketServer"),
+    MovedModule("_thread", "thread", "_thread"),
+    MovedModule("tkinter", "Tkinter"),
+    MovedModule("tkinter_dialog", "Dialog", "tkinter.dialog"),
+    MovedModule("tkinter_filedialog", "FileDialog", "tkinter.filedialog"),
+    MovedModule("tkinter_scrolledtext", "ScrolledText", "tkinter.scrolledtext"),
+    MovedModule("tkinter_simpledialog", "SimpleDialog", "tkinter.simpledialog"),
+    MovedModule("tkinter_tix", "Tix", "tkinter.tix"),
+    MovedModule("tkinter_ttk", "ttk", "tkinter.ttk"),
+    MovedModule("tkinter_constants", "Tkconstants", "tkinter.constants"),
+    MovedModule("tkinter_dnd", "Tkdnd", "tkinter.dnd"),
+    MovedModule("tkinter_colorchooser", "tkColorChooser",
+                "tkinter.colorchooser"),
+    MovedModule("tkinter_commondialog", "tkCommonDialog",
+                "tkinter.commondialog"),
+    MovedModule("tkinter_tkfiledialog", "tkFileDialog", "tkinter.filedialog"),
+    MovedModule("tkinter_font", "tkFont", "tkinter.font"),
+    MovedModule("tkinter_messagebox", "tkMessageBox", "tkinter.messagebox"),
+    MovedModule("tkinter_tksimpledialog", "tkSimpleDialog",
+                "tkinter.simpledialog"),
+    MovedModule("urllib_parse", __name__ + ".moves.urllib_parse", "urllib.parse"),
+    MovedModule("urllib_error", __name__ + ".moves.urllib_error", "urllib.error"),
+    MovedModule("urllib", __name__ + ".moves.urllib", __name__ + ".moves.urllib"),
+    MovedModule("urllib_robotparser", "robotparser", "urllib.robotparser"),
+    MovedModule("xmlrpc_client", "xmlrpclib", "xmlrpc.client"),
+    MovedModule("xmlrpc_server", "SimpleXMLRPCServer", "xmlrpc.server"),
+]
+# Add windows specific modules.
+if sys.platform == "win32":
+    _moved_attributes += [
+        MovedModule("winreg", "_winreg"),
+    ]
+
+for attr in _moved_attributes:
+    setattr(_MovedItems, attr.name, attr)
+    if isinstance(attr, MovedModule):
+        _importer._add_module(attr, "moves." + attr.name)
+del attr
+
+_MovedItems._moved_attributes = _moved_attributes
+
+moves = _MovedItems(__name__ + ".moves")
+_importer._add_module(moves, "moves")
+
+
+class Module_six_moves_urllib_parse(_LazyModule):
+
+    """Lazy loading of moved objects in six.moves.urllib_parse"""
+
+
+_urllib_parse_moved_attributes = [
+    MovedAttribute("ParseResult", "urlparse", "urllib.parse"),
+    MovedAttribute("SplitResult", "urlparse", "urllib.parse"),
+    MovedAttribute("parse_qs", "urlparse", "urllib.parse"),
+    MovedAttribute("parse_qsl", "urlparse", "urllib.parse"),
+    MovedAttribute("urldefrag", "urlparse", "urllib.parse"),
+    MovedAttribute("urljoin", "urlparse", "urllib.parse"),
+    MovedAttribute("urlparse", "urlparse", "urllib.parse"),
+    MovedAttribute("urlsplit", "urlparse", "urllib.parse"),
+    MovedAttribute("urlunparse", "urlparse", "urllib.parse"),
+    MovedAttribute("urlunsplit", "urlparse", "urllib.parse"),
+    MovedAttribute("quote", "urllib", "urllib.parse"),
+    MovedAttribute("quote_plus", "urllib", "urllib.parse"),
+    MovedAttribute("unquote", "urllib", "urllib.parse"),
+    MovedAttribute("unquote_plus", "urllib", "urllib.parse"),
+    MovedAttribute("urlencode", "urllib", "urllib.parse"),
+    MovedAttribute("splitquery", "urllib", "urllib.parse"),
+    MovedAttribute("splittag", "urllib", "urllib.parse"),
+    MovedAttribute("splituser", "urllib", "urllib.parse"),
+    MovedAttribute("uses_fragment", "urlparse", "urllib.parse"),
+    MovedAttribute("uses_netloc", "urlparse", "urllib.parse"),
+    MovedAttribute("uses_params", "urlparse", "urllib.parse"),
+    MovedAttribute("uses_query", "urlparse", "urllib.parse"),
+    MovedAttribute("uses_relative", "urlparse", "urllib.parse"),
+]
+for attr in _urllib_parse_moved_attributes:
+    setattr(Module_six_moves_urllib_parse, attr.name, attr)
+del attr
+
+Module_six_moves_urllib_parse._moved_attributes = _urllib_parse_moved_attributes
+
+_importer._add_module(Module_six_moves_urllib_parse(__name__ + ".moves.urllib_parse"),
+                      "moves.urllib_parse", "moves.urllib.parse")
+
+
+class Module_six_moves_urllib_error(_LazyModule):
+
+    """Lazy loading of moved objects in six.moves.urllib_error"""
+
+
+_urllib_error_moved_attributes = [
+    MovedAttribute("URLError", "urllib2", "urllib.error"),
+    MovedAttribute("HTTPError", "urllib2", "urllib.error"),
+    MovedAttribute("ContentTooShortError", "urllib", "urllib.error"),
+]
+for attr in _urllib_error_moved_attributes:
+    setattr(Module_six_moves_urllib_error, attr.name, attr)
+del attr
+
+Module_six_moves_urllib_error._moved_attributes = _urllib_error_moved_attributes
+
+_importer._add_module(Module_six_moves_urllib_error(__name__ + ".moves.urllib.error"),
+                      "moves.urllib_error", "moves.urllib.error")
+
+
+class Module_six_moves_urllib_request(_LazyModule):
+
+    """Lazy loading of moved objects in six.moves.urllib_request"""
+
+
+_urllib_request_moved_attributes = [
+    MovedAttribute("urlopen", "urllib2", "urllib.request"),
+    MovedAttribute("install_opener", "urllib2", "urllib.request"),
+    MovedAttribute("build_opener", "urllib2", "urllib.request"),
+    MovedAttribute("pathname2url", "urllib", "urllib.request"),
+    MovedAttribute("url2pathname", "urllib", "urllib.request"),
+    MovedAttribute("getproxies", "urllib", "urllib.request"),
+    MovedAttribute("Request", "urllib2", "urllib.request"),
+    MovedAttribute("OpenerDirector", "urllib2", "urllib.request"),
+    MovedAttribute("HTTPDefaultErrorHandler", "urllib2", "urllib.request"),
+    MovedAttribute("HTTPRedirectHandler", "urllib2", "urllib.request"),
+    MovedAttribute("HTTPCookieProcessor", "urllib2", "urllib.request"),
+    MovedAttribute("ProxyHandler", "urllib2", "urllib.request"),
+    MovedAttribute("BaseHandler", "urllib2", "urllib.request"),
+    MovedAttribute("HTTPPasswordMgr", "urllib2", "urllib.request"),
+    MovedAttribute("HTTPPasswordMgrWithDefaultRealm", "urllib2", "urllib.request"),
+    MovedAttribute("AbstractBasicAuthHandler", "urllib2", "urllib.request"),
+    MovedAttribute("HTTPBasicAuthHandler", "urllib2", "urllib.request"),
+    MovedAttribute("ProxyBasicAuthHandler", "urllib2", "urllib.request"),
+    MovedAttribute("AbstractDigestAuthHandler", "urllib2", "urllib.request"),
+    MovedAttribute("HTTPDigestAuthHandler", "urllib2", "urllib.request"),
+    MovedAttribute("ProxyDigestAuthHandler", "urllib2", "urllib.request"),
+    MovedAttribute("HTTPHandler", "urllib2", "urllib.request"),
+    MovedAttribute("HTTPSHandler", "urllib2", "urllib.request"),
+    MovedAttribute("FileHandler", "urllib2", "urllib.request"),
+    MovedAttribute("FTPHandler", "urllib2", "urllib.request"),
+    MovedAttribute("CacheFTPHandler", "urllib2", "urllib.request"),
+    MovedAttribute("UnknownHandler", "urllib2", "urllib.request"),
+    MovedAttribute("HTTPErrorProcessor", "urllib2", "urllib.request"),
+    MovedAttribute("urlretrieve", "urllib", "urllib.request"),
+    MovedAttribute("urlcleanup", "urllib", "urllib.request"),
+    MovedAttribute("URLopener", "urllib", "urllib.request"),
+    MovedAttribute("FancyURLopener", "urllib", "urllib.request"),
+    MovedAttribute("proxy_bypass", "urllib", "urllib.request"),
+]
+for attr in _urllib_request_moved_attributes:
+    setattr(Module_six_moves_urllib_request, attr.name, attr)
+del attr
+
+Module_six_moves_urllib_request._moved_attributes = _urllib_request_moved_attributes
+
+_importer._add_module(Module_six_moves_urllib_request(__name__ + ".moves.urllib.request"),
+                      "moves.urllib_request", "moves.urllib.request")
+
+
+class Module_six_moves_urllib_response(_LazyModule):
+
+    """Lazy loading of moved objects in six.moves.urllib_response"""
+
+
+_urllib_response_moved_attributes = [
+    MovedAttribute("addbase", "urllib", "urllib.response"),
+    MovedAttribute("addclosehook", "urllib", "urllib.response"),
+    MovedAttribute("addinfo", "urllib", "urllib.response"),
+    MovedAttribute("addinfourl", "urllib", "urllib.response"),
+]
+for attr in _urllib_response_moved_attributes:
+    setattr(Module_six_moves_urllib_response, attr.name, attr)
+del attr
+
+Module_six_moves_urllib_response._moved_attributes = _urllib_response_moved_attributes
+
+_importer._add_module(Module_six_moves_urllib_response(__name__ + ".moves.urllib.response"),
+                      "moves.urllib_response", "moves.urllib.response")
+
+
+class Module_six_moves_urllib_robotparser(_LazyModule):
+
+    """Lazy loading of moved objects in six.moves.urllib_robotparser"""
+
+
+_urllib_robotparser_moved_attributes = [
+    MovedAttribute("RobotFileParser", "robotparser", "urllib.robotparser"),
+]
+for attr in _urllib_robotparser_moved_attributes:
+    setattr(Module_six_moves_urllib_robotparser, attr.name, attr)
+del attr
+
+Module_six_moves_urllib_robotparser._moved_attributes = _urllib_robotparser_moved_attributes
+
+_importer._add_module(Module_six_moves_urllib_robotparser(__name__ + ".moves.urllib.robotparser"),
+                      "moves.urllib_robotparser", "moves.urllib.robotparser")
+
+
+class Module_six_moves_urllib(types.ModuleType):
+
+    """Create a six.moves.urllib namespace that resembles the Python 3 namespace"""
+    __path__ = []  # mark as package
+    parse = _importer._get_module("moves.urllib_parse")
+    error = _importer._get_module("moves.urllib_error")
+    request = _importer._get_module("moves.urllib_request")
+    response = _importer._get_module("moves.urllib_response")
+    robotparser = _importer._get_module("moves.urllib_robotparser")
+
+    def __dir__(self):
+        return ['parse', 'error', 'request', 'response', 'robotparser']
+
+_importer._add_module(Module_six_moves_urllib(__name__ + ".moves.urllib"),
+                      "moves.urllib")
+
+
+def add_move(move):
+    """Add an item to six.moves."""
+    setattr(_MovedItems, move.name, move)
+
+
+def remove_move(name):
+    """Remove item from six.moves."""
+    try:
+        delattr(_MovedItems, name)
+    except AttributeError:
+        try:
+            del moves.__dict__[name]
+        except KeyError:
+            raise AttributeError("no such move, %r" % (name,))
+
+
+if PY3:
+    _meth_func = "__func__"
+    _meth_self = "__self__"
+
+    _func_closure = "__closure__"
+    _func_code = "__code__"
+    _func_defaults = "__defaults__"
+    _func_globals = "__globals__"
+else:
+    _meth_func = "im_func"
+    _meth_self = "im_self"
+
+    _func_closure = "func_closure"
+    _func_code = "func_code"
+    _func_defaults = "func_defaults"
+    _func_globals = "func_globals"
+
+
+try:
+    advance_iterator = next
+except NameError:
+    def advance_iterator(it):
+        return it.next()
+next = advance_iterator
+
+
+try:
+    callable = callable
+except NameError:
+    def callable(obj):
+        return any("__call__" in klass.__dict__ for klass in type(obj).__mro__)
+
+
+if PY3:
+    def get_unbound_function(unbound):
+        return unbound
+
+    create_bound_method = types.MethodType
+
+    def create_unbound_method(func, cls):
+        return func
+
+    Iterator = object
+else:
+    def get_unbound_function(unbound):
+        return unbound.im_func
+
+    def create_bound_method(func, obj):
+        return types.MethodType(func, obj, obj.__class__)
+
+    def create_unbound_method(func, cls):
+        return types.MethodType(func, None, cls)
+
+    class Iterator(object):
+
+        def next(self):
+            return type(self).__next__(self)
+
+    callable = callable
+_add_doc(get_unbound_function,
+         """Get the function out of a possibly unbound function""")
+
+
+get_method_function = operator.attrgetter(_meth_func)
+get_method_self = operator.attrgetter(_meth_self)
+get_function_closure = operator.attrgetter(_func_closure)
+get_function_code = operator.attrgetter(_func_code)
+get_function_defaults = operator.attrgetter(_func_defaults)
+get_function_globals = operator.attrgetter(_func_globals)
+
+
+if PY3:
+    def iterkeys(d, **kw):
+        return iter(d.keys(**kw))
+
+    def itervalues(d, **kw):
+        return iter(d.values(**kw))
+
+    def iteritems(d, **kw):
+        return iter(d.items(**kw))
+
+    def iterlists(d, **kw):
+        return iter(d.lists(**kw))
+
+    viewkeys = operator.methodcaller("keys")
+
+    viewvalues = operator.methodcaller("values")
+
+    viewitems = operator.methodcaller("items")
+else:
+    def iterkeys(d, **kw):
+        return d.iterkeys(**kw)
+
+    def itervalues(d, **kw):
+        return d.itervalues(**kw)
+
+    def iteritems(d, **kw):
+        return d.iteritems(**kw)
+
+    def iterlists(d, **kw):
+        return d.iterlists(**kw)
+
+    viewkeys = operator.methodcaller("viewkeys")
+
+    viewvalues = operator.methodcaller("viewvalues")
+
+    viewitems = operator.methodcaller("viewitems")
+
+_add_doc(iterkeys, "Return an iterator over the keys of a dictionary.")
+_add_doc(itervalues, "Return an iterator over the values of a dictionary.")
+_add_doc(iteritems,
+         "Return an iterator over the (key, value) pairs of a dictionary.")
+_add_doc(iterlists,
+         "Return an iterator over the (key, [values]) pairs of a dictionary.")
+
+
+if PY3:
+    def b(s):
+        return s.encode("latin-1")
+
+    def u(s):
+        return s
+    unichr = chr
+    import struct
+    int2byte = struct.Struct(">B").pack
+    del struct
+    byte2int = operator.itemgetter(0)
+    indexbytes = operator.getitem
+    iterbytes = iter
+    import io
+    StringIO = io.StringIO
+    BytesIO = io.BytesIO
+    _assertCountEqual = "assertCountEqual"
+    if sys.version_info[1] <= 1:
+        _assertRaisesRegex = "assertRaisesRegexp"
+        _assertRegex = "assertRegexpMatches"
+    else:
+        _assertRaisesRegex = "assertRaisesRegex"
+        _assertRegex = "assertRegex"
+else:
+    def b(s):
+        return s
+    # Workaround for standalone backslash
+
+    def u(s):
+        return unicode(s.replace(r'\\', r'\\\\'), "unicode_escape")
+    unichr = unichr
+    int2byte = chr
+
+    def byte2int(bs):
+        return ord(bs[0])
+
+    def indexbytes(buf, i):
+        return ord(buf[i])
+    iterbytes = functools.partial(itertools.imap, ord)
+    import StringIO
+    StringIO = BytesIO = StringIO.StringIO
+    _assertCountEqual = "assertItemsEqual"
+    _assertRaisesRegex = "assertRaisesRegexp"
+    _assertRegex = "assertRegexpMatches"
+_add_doc(b, """Byte literal""")
+_add_doc(u, """Text literal""")
+
+
+def assertCountEqual(self, *args, **kwargs):
+    return getattr(self, _assertCountEqual)(*args, **kwargs)
+
+
+def assertRaisesRegex(self, *args, **kwargs):
+    return getattr(self, _assertRaisesRegex)(*args, **kwargs)
+
+
+def assertRegex(self, *args, **kwargs):
+    return getattr(self, _assertRegex)(*args, **kwargs)
+
+
+if PY3:
+    exec_ = getattr(moves.builtins, "exec")
+
+    def reraise(tp, value, tb=None):
+        if value is None:
+            value = tp()
+        if value.__traceback__ is not tb:
+            raise value.with_traceback(tb)
+        raise value
+
+else:
+    def exec_(_code_, _globs_=None, _locs_=None):
+        """Execute code in a namespace."""
+        if _globs_ is None:
+            frame = sys._getframe(1)
+            _globs_ = frame.f_globals
+            if _locs_ is None:
+                _locs_ = frame.f_locals
+            del frame
+        elif _locs_ is None:
+            _locs_ = _globs_
+        exec("""exec _code_ in _globs_, _locs_""")
+
+    exec_("""def reraise(tp, value, tb=None):
+    raise tp, value, tb
+""")
+
+
+if sys.version_info[:2] == (3, 2):
+    exec_("""def raise_from(value, from_value):
+    if from_value is None:
+        raise value
+    raise value from from_value
+""")
+elif sys.version_info[:2] > (3, 2):
+    exec_("""def raise_from(value, from_value):
+    raise value from from_value
+""")
+else:
+    def raise_from(value, from_value):
+        raise value
+
+
+print_ = getattr(moves.builtins, "print", None)
+if print_ is None:
+    def print_(*args, **kwargs):
+        """The new-style print function for Python 2.4 and 2.5."""
+        fp = kwargs.pop("file", sys.stdout)
+        if fp is None:
+            return
+
+        def write(data):
+            if not isinstance(data, basestring):
+                data = str(data)
+            # If the file has an encoding, encode unicode with it.
+            if (isinstance(fp, file) and
+                    isinstance(data, unicode) and
+                    fp.encoding is not None):
+                errors = getattr(fp, "errors", None)
+                if errors is None:
+                    errors = "strict"
+                data = data.encode(fp.encoding, errors)
+            fp.write(data)
+        want_unicode = False
+        sep = kwargs.pop("sep", None)
+        if sep is not None:
+            if isinstance(sep, unicode):
+                want_unicode = True
+            elif not isinstance(sep, str):
+                raise TypeError("sep must be None or a string")
+        end = kwargs.pop("end", None)
+        if end is not None:
+            if isinstance(end, unicode):
+                want_unicode = True
+            elif not isinstance(end, str):
+                raise TypeError("end must be None or a string")
+        if kwargs:
+            raise TypeError("invalid keyword arguments to print()")
+        if not want_unicode:
+            for arg in args:
+                if isinstance(arg, unicode):
+                    want_unicode = True
+                    break
+        if want_unicode:
+            newline = unicode("\n")
+            space = unicode(" ")
+        else:
+            newline = "\n"
+            space = " "
+        if sep is None:
+            sep = space
+        if end is None:
+            end = newline
+        for i, arg in enumerate(args):
+            if i:
+                write(sep)
+            write(arg)
+        write(end)
+if sys.version_info[:2] < (3, 3):
+    _print = print_
+
+    def print_(*args, **kwargs):
+        fp = kwargs.get("file", sys.stdout)
+        flush = kwargs.pop("flush", False)
+        _print(*args, **kwargs)
+        if flush and fp is not None:
+            fp.flush()
+
+_add_doc(reraise, """Reraise an exception.""")
+
+if sys.version_info[0:2] < (3, 4):
+    def wraps(wrapped, assigned=functools.WRAPPER_ASSIGNMENTS,
+              updated=functools.WRAPPER_UPDATES):
+        def wrapper(f):
+            f = functools.wraps(wrapped, assigned, updated)(f)
+            f.__wrapped__ = wrapped
+            return f
+        return wrapper
+else:
+    wraps = functools.wraps
+
+
+def with_metaclass(meta, *bases):
+    """Create a base class with a metaclass."""
+    # This requires a bit of explanation: the basic idea is to make a dummy
+    # metaclass for one level of class instantiation that replaces itself with
+    # the actual metaclass.
+    class metaclass(meta):
+
+        def __new__(cls, name, this_bases, d):
+            return meta(name, bases, d)
+    return type.__new__(metaclass, 'temporary_class', (), {})
+
+
+def add_metaclass(metaclass):
+    """Class decorator for creating a class with a metaclass."""
+    def wrapper(cls):
+        orig_vars = cls.__dict__.copy()
+        slots = orig_vars.get('__slots__')
+        if slots is not None:
+            if isinstance(slots, str):
+                slots = [slots]
+            for slots_var in slots:
+                orig_vars.pop(slots_var)
+        orig_vars.pop('__dict__', None)
+        orig_vars.pop('__weakref__', None)
+        return metaclass(cls.__name__, cls.__bases__, orig_vars)
+    return wrapper
+
+
+def python_2_unicode_compatible(klass):
+    """
+    A decorator that defines __unicode__ and __str__ methods under Python 2.
+    Under Python 3 it does nothing.
+
+    To support Python 2 and 3 with a single code base, define a __str__ method
+    returning text and apply this decorator to the class.
+    """
+    if PY2:
+        if '__str__' not in klass.__dict__:
+            raise ValueError("@python_2_unicode_compatible cannot be applied "
+                             "to %s because it doesn't define __str__()." %
+                             klass.__name__)
+        klass.__unicode__ = klass.__str__
+        klass.__str__ = lambda self: self.__unicode__().encode('utf-8')
+    return klass
+
+
+# Complete the moves implementation.
+# This code is at the end of this module to speed up module loading.
+# Turn this module into a package.
+__path__ = []  # required for PEP 302 and PEP 451
+__package__ = __name__  # see PEP 366 @ReservedAssignment
+if globals().get("__spec__") is not None:
+    __spec__.submodule_search_locations = []  # PEP 451 @UndefinedVariable
+# Remove other six meta path importers, since they cause problems. This can
+# happen if six is removed from sys.modules and then reloaded. (Setuptools does
+# this for some reason.)
+if sys.meta_path:
+    for i, importer in enumerate(sys.meta_path):
+        # Here's some real nastiness: Another "instance" of the six module might
+        # be floating around. Therefore, we can't use isinstance() to check for
+        # the six meta path importer, since the other six instance will have
+        # inserted an importer with different class.
+        if (type(importer).__name__ == "_SixMetaPathImporter" and
+                importer.name == __name__):
+            del sys.meta_path[i]
+            break
+    del i, importer
+# Finally, add the importer to the meta path import hook.
+sys.meta_path.append(_importer)
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pkg_resources/_vendor/six.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pkg_resources/_vendor/six.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..9f0649bc46df4bcf6efcf7eed84fce194bb72d7f
GIT binary patch
literal 36102
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
F0stA>$qxVk

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pkg_resources/extern/__init__.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pkg_resources/extern/__init__.py
new file mode 100644
index 0000000..c1eb9e9
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pkg_resources/extern/__init__.py
@@ -0,0 +1,73 @@
+import sys
+
+
+class VendorImporter:
+    """
+    A PEP 302 meta path importer for finding optionally-vendored
+    or otherwise naturally-installed packages from root_name.
+    """
+
+    def __init__(self, root_name, vendored_names=(), vendor_pkg=None):
+        self.root_name = root_name
+        self.vendored_names = set(vendored_names)
+        self.vendor_pkg = vendor_pkg or root_name.replace('extern', '_vendor')
+
+    @property
+    def search_path(self):
+        """
+        Search first the vendor package then as a natural package.
+        """
+        yield self.vendor_pkg + '.'
+        yield ''
+
+    def find_module(self, fullname, path=None):
+        """
+        Return self when fullname starts with root_name and the
+        target module is one vendored through this importer.
+        """
+        root, base, target = fullname.partition(self.root_name + '.')
+        if root:
+            return
+        if not any(map(target.startswith, self.vendored_names)):
+            return
+        return self
+
+    def load_module(self, fullname):
+        """
+        Iterate over the search path to locate and load fullname.
+        """
+        root, base, target = fullname.partition(self.root_name + '.')
+        for prefix in self.search_path:
+            try:
+                extant = prefix + target
+                __import__(extant)
+                mod = sys.modules[extant]
+                sys.modules[fullname] = mod
+                # mysterious hack:
+                # Remove the reference to the extant package/module
+                # on later Python versions to cause relative imports
+                # in the vendor package to resolve the same modules
+                # as those going through this importer.
+                if prefix and sys.version_info > (3, 3):
+                    del sys.modules[extant]
+                return mod
+            except ImportError:
+                pass
+        else:
+            raise ImportError(
+                "The '{target}' package is required; "
+                "normally this is bundled with this package so if you get "
+                "this warning, consult the packager of your "
+                "distribution.".format(**locals())
+            )
+
+    def install(self):
+        """
+        Install this importer into sys.meta_path if not already present.
+        """
+        if self not in sys.meta_path:
+            sys.meta_path.append(self)
+
+
+names = 'packaging', 'pyparsing', 'six', 'appdirs'
+VendorImporter(__name__, names).install()
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pkg_resources/extern/__init__.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pkg_resources/extern/__init__.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..f6122076047c8a95d7e5176bf299a98e11c6a764
GIT binary patch
literal 3353
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
JW?>gLMgSv;LRJ6(

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/pkg_resources/py31compat.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pkg_resources/py31compat.py
new file mode 100644
index 0000000..a381c42
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pkg_resources/py31compat.py
@@ -0,0 +1,23 @@
+import os
+import errno
+import sys
+
+from .extern 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/tests/python/assert_test01/venv/lib/python2.7/site-packages/pkg_resources/py31compat.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/pkg_resources/py31compat.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..e5d43bf827afb0f446b4976dd9374d9966ada371
GIT binary patch
literal 866
zcmZSn%**AGdLky70SZ_c7#JKF7#NBh85kH+7#LC*8FCmHqTp;shA2juI1@t@6GI9U
zLkcrP4l_e83quqO17j*HLkbH+3nN1m8$&7!Ll!$jK`KKEJ3}fHLly@E3v)IjLw+(t
z3I{_r14AAY0~2EuCqpVHLs1DsDjP!{8$&7sLlzf96c@<mU=2<N28PW4|NsB@%VcC=
zV9)>&CCniAWmY6JF)%QI*sKf;49*}iF9rsNN<oGa28Jv~h8hNjW=00a@H`_1mJ%k0
zY%Yc(R|dvfCI-eDMh2c@8-^MthAd`=5@v=h7KUtQh9WnHCI*H=H-<b$hKLjfhG4K|
zei|UtOF&lT7ng7_FfimMW~ZiP78RGUGcYjt2fG#(<rkHJ6r~mw<>i;KF)%Q=x<+^g
zhiHJ@Rssspg2a*xu-?>)%;J*x{A{onQY(@*K%ovMii;Q+81xH@GRqQ6QuWIci}cg-
zb5c@^iuIFH^vjcy@^Vdci;WDE%+ssVEle%SbF!+;3_u_~Pd`MzAhSR>Gq1QLF(*gY
zt<1yII6%KRwWPG5BtJi=Sic}UJ-#TlIKQ+gIki~7pwiedIX|}`u|%(+vV@0$fgv8|
zrFdgQkPnNwK+a-hW)x)PXOv{j1o<Nq<PQx{Fd%Wk5?}%(3yC3a1_p*8P&5UB#K0ac
zt}F%zOKL?)YEfPg$Z&9gxh3Wlrv`B{Fn}U~fgvE$2<)7))S}|d{Ji+gytMohJ_ZJc
zywuc`Vz?uNK#l;18G;z7&;x~*O>TZlX-=vg$j`+f=khS}F!C@7F!S(mGRiXn0GA`W
AhyVZp

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools-41.0.1.dist-info/INSTALLER b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools-41.0.1.dist-info/INSTALLER
new file mode 100644
index 0000000..a1b589e
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools-41.0.1.dist-info/INSTALLER
@@ -0,0 +1 @@
+pip
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools-41.0.1.dist-info/LICENSE b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools-41.0.1.dist-info/LICENSE
new file mode 100644
index 0000000..6e0693b
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools-41.0.1.dist-info/LICENSE
@@ -0,0 +1,19 @@
+Copyright (C) 2016 Jason R Coombs <jaraco@jaraco.com>
+
+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/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools-41.0.1.dist-info/METADATA b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools-41.0.1.dist-info/METADATA
new file mode 100644
index 0000000..571a5cb
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools-41.0.1.dist-info/METADATA
@@ -0,0 +1,77 @@
+Metadata-Version: 2.1
+Name: setuptools
+Version: 41.0.1
+Summary: Easily download, build, install, upgrade, and uninstall Python packages
+Home-page: https://github.com/pypa/setuptools
+Author: Python Packaging Authority
+Author-email: distutils-sig@python.org
+License: UNKNOWN
+Project-URL: Documentation, https://setuptools.readthedocs.io/
+Keywords: CPAN PyPI distutils eggs package management
+Platform: UNKNOWN
+Classifier: Development Status :: 5 - Production/Stable
+Classifier: Intended Audience :: Developers
+Classifier: License :: OSI Approved :: MIT License
+Classifier: Operating System :: OS Independent
+Classifier: Programming Language :: Python :: 2
+Classifier: Programming Language :: Python :: 2.7
+Classifier: Programming Language :: Python :: 3
+Classifier: Programming Language :: Python :: 3.4
+Classifier: Programming Language :: Python :: 3.5
+Classifier: Programming Language :: Python :: 3.6
+Classifier: Programming Language :: Python :: 3.7
+Classifier: Topic :: Software Development :: Libraries :: Python Modules
+Classifier: Topic :: System :: Archiving :: Packaging
+Classifier: Topic :: System :: Systems Administration
+Classifier: Topic :: Utilities
+Requires-Python: >=2.7,!=3.0.*,!=3.1.*,!=3.2.*,!=3.3.*
+Description-Content-Type: text/x-rst; charset=UTF-8
+Provides-Extra: certs
+Requires-Dist: certifi (==2016.9.26) ; extra == 'certs'
+Provides-Extra: ssl
+Requires-Dist: wincertstore (==0.2) ; (sys_platform=='win32') and extra == 'ssl'
+
+.. image:: https://img.shields.io/pypi/v/setuptools.svg
+   :target: https://pypi.org/project/setuptools
+
+.. image:: https://img.shields.io/readthedocs/setuptools/latest.svg
+    :target: https://setuptools.readthedocs.io
+
+.. image:: https://img.shields.io/travis/pypa/setuptools/master.svg?label=Linux%20CI&logo=travis&logoColor=white
+   :target: https://travis-ci.org/pypa/setuptools
+
+.. image:: https://img.shields.io/appveyor/ci/pypa/setuptools/master.svg?label=Windows%20CI&logo=appveyor&logoColor=white
+   :target: https://ci.appveyor.com/project/pypa/setuptools/branch/master
+
+.. image:: https://img.shields.io/codecov/c/github/pypa/setuptools/master.svg?logo=codecov&logoColor=white
+   :target: https://codecov.io/gh/pypa/setuptools
+
+.. image:: https://tidelift.com/badges/github/pypa/setuptools?style=flat
+   :target: https://tidelift.com/subscription/pkg/pypi-setuptools?utm_source=pypi-setuptools&utm_medium=readme
+
+.. image:: https://img.shields.io/pypi/pyversions/setuptools.svg
+
+See the `Installation Instructions
+<https://packaging.python.org/installing/>`_ in the Python Packaging
+User's Guide for instructions on installing, upgrading, and uninstalling
+Setuptools.
+
+Questions and comments should be directed to the `distutils-sig
+mailing list <http://mail.python.org/pipermail/distutils-sig/>`_.
+Bug reports and especially tested patches may be
+submitted directly to the `bug tracker
+<https://github.com/pypa/setuptools/issues>`_.
+
+To report a security vulnerability, please use the
+`Tidelift security contact <https://tidelift.com/security>`_.
+Tidelift will coordinate the fix and disclosure.
+
+
+Code of Conduct
+---------------
+
+Everyone interacting in the setuptools project's codebases, issue trackers,
+chat rooms, and mailing lists is expected to follow the
+`PyPA Code of Conduct <https://www.pypa.io/en/latest/code-of-conduct/>`_.
+
+
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools-41.0.1.dist-info/RECORD b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools-41.0.1.dist-info/RECORD
new file mode 100644
index 0000000..bac892e
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools-41.0.1.dist-info/RECORD
@@ -0,0 +1,186 @@
+../../../bin/easy_install,sha256=ofM4cU12NwNZpkVbjy_Xu2ktlId-ZzIP2xVgGWq8_6c,291
+../../../bin/easy_install-2.7,sha256=ofM4cU12NwNZpkVbjy_Xu2ktlId-ZzIP2xVgGWq8_6c,291
+easy_install.py,sha256=MDC9vt5AxDsXX5qcKlBz2TnW6Tpuv_AobnfhCJ9X3PM,126
+easy_install.pyc,,
+pkg_resources/__init__.py,sha256=pp8b7Asoaheso-q8lIMS1tpQp88xjAkYgCIRX-JsPlE,107982
+pkg_resources/__init__.pyc,,
+pkg_resources/_vendor/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
+pkg_resources/_vendor/__init__.pyc,,
+pkg_resources/_vendor/appdirs.py,sha256=MievUEuv3l_mQISH5SF0shDk_BNhHHzYiAPrT3ITN4I,24701
+pkg_resources/_vendor/appdirs.pyc,,
+pkg_resources/_vendor/packaging/__about__.py,sha256=zkcCPTN_6TcLW0Nrlg0176-R1QQ_WVPTm8sz1R4-HjM,720
+pkg_resources/_vendor/packaging/__about__.pyc,,
+pkg_resources/_vendor/packaging/__init__.py,sha256=_vNac5TrzwsrzbOFIbF-5cHqc_Y2aPT2D7zrIR06BOo,513
+pkg_resources/_vendor/packaging/__init__.pyc,,
+pkg_resources/_vendor/packaging/_compat.py,sha256=Vi_A0rAQeHbU-a9X0tt1yQm9RqkgQbDSxzRw8WlU9kA,860
+pkg_resources/_vendor/packaging/_compat.pyc,,
+pkg_resources/_vendor/packaging/_structures.py,sha256=RImECJ4c_wTlaTYYwZYLHEiebDMaAJmK1oPARhw1T5o,1416
+pkg_resources/_vendor/packaging/_structures.pyc,,
+pkg_resources/_vendor/packaging/markers.py,sha256=uEcBBtGvzqltgnArqb9c4RrcInXezDLos14zbBHhWJo,8248
+pkg_resources/_vendor/packaging/markers.pyc,,
+pkg_resources/_vendor/packaging/requirements.py,sha256=SikL2UynbsT0qtY9ltqngndha_sfo0w6XGFhAhoSoaQ,4355
+pkg_resources/_vendor/packaging/requirements.pyc,,
+pkg_resources/_vendor/packaging/specifiers.py,sha256=SAMRerzO3fK2IkFZCaZkuwZaL_EGqHNOz4pni4vhnN0,28025
+pkg_resources/_vendor/packaging/specifiers.pyc,,
+pkg_resources/_vendor/packaging/utils.py,sha256=3m6WvPm6NNxE8rkTGmn0r75B_GZSGg7ikafxHsBN1WA,421
+pkg_resources/_vendor/packaging/utils.pyc,,
+pkg_resources/_vendor/packaging/version.py,sha256=OwGnxYfr2ghNzYx59qWIBkrK3SnB6n-Zfd1XaLpnnM0,11556
+pkg_resources/_vendor/packaging/version.pyc,,
+pkg_resources/_vendor/pyparsing.py,sha256=tmrp-lu-qO1i75ZzIN5A12nKRRD1Cm4Vpk-5LR9rims,232055
+pkg_resources/_vendor/pyparsing.pyc,,
+pkg_resources/_vendor/six.py,sha256=A6hdJZVjI3t_geebZ9BzUvwRrIXo0lfwzQlM2LcKyas,30098
+pkg_resources/_vendor/six.pyc,,
+pkg_resources/extern/__init__.py,sha256=cHiEfHuLmm6rs5Ve_ztBfMI7Lr31vss-D4wkqF5xzlI,2498
+pkg_resources/extern/__init__.pyc,,
+pkg_resources/py31compat.py,sha256=-WQ0e4c3RG_acdhwC3gLiXhP_lg4G5q7XYkZkQg0gxU,558
+pkg_resources/py31compat.pyc,,
+setuptools-41.0.1.dist-info/INSTALLER,sha256=zuuue4knoyJ-UwPPXg8fezS7VCrXJQrAP7zeNuwvFQg,4
+setuptools-41.0.1.dist-info/LICENSE,sha256=wyo6w5WvYyHv0ovnPQagDw22q4h9HCHU_sRhKNIFbVo,1078
+setuptools-41.0.1.dist-info/METADATA,sha256=_i0otxacylu95CLISnMjTjG7DZ2vYZOvwedcoJ06JNE,3303
+setuptools-41.0.1.dist-info/RECORD,,
+setuptools-41.0.1.dist-info/WHEEL,sha256=HX-v9-noUkyUoxyZ1PMSuS7auUxDAR4VBdoYLqD0xws,110
+setuptools-41.0.1.dist-info/dependency_links.txt,sha256=HlkCFkoK5TbZ5EMLbLKYhLcY_E31kBWD8TqW2EgmatQ,239
+setuptools-41.0.1.dist-info/entry_points.txt,sha256=jBqCYDlVjl__sjYFGXo1JQGIMAYFJE-prYWUtnMZEew,2990
+setuptools-41.0.1.dist-info/top_level.txt,sha256=2HUXVVwA4Pff1xgTFr3GsTXXKaPaO6vlG6oNJ_4u4Tg,38
+setuptools-41.0.1.dist-info/zip-safe,sha256=AbpHGcgLb-kRsJGnwFEktk7uzpZOCcBY74-YBdrKVGs,1
+setuptools/__init__.py,sha256=WBpCcn2lvdckotabeae1TTYonPOcgCIF3raD2zRWzBc,7283
+setuptools/__init__.pyc,,
+setuptools/_deprecation_warning.py,sha256=jU9-dtfv6cKmtQJOXN8nP1mm7gONw5kKEtiPtbwnZyI,218
+setuptools/_deprecation_warning.pyc,,
+setuptools/_vendor/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
+setuptools/_vendor/__init__.pyc,,
+setuptools/_vendor/packaging/__about__.py,sha256=zkcCPTN_6TcLW0Nrlg0176-R1QQ_WVPTm8sz1R4-HjM,720
+setuptools/_vendor/packaging/__about__.pyc,,
+setuptools/_vendor/packaging/__init__.py,sha256=_vNac5TrzwsrzbOFIbF-5cHqc_Y2aPT2D7zrIR06BOo,513
+setuptools/_vendor/packaging/__init__.pyc,,
+setuptools/_vendor/packaging/_compat.py,sha256=Vi_A0rAQeHbU-a9X0tt1yQm9RqkgQbDSxzRw8WlU9kA,860
+setuptools/_vendor/packaging/_compat.pyc,,
+setuptools/_vendor/packaging/_structures.py,sha256=RImECJ4c_wTlaTYYwZYLHEiebDMaAJmK1oPARhw1T5o,1416
+setuptools/_vendor/packaging/_structures.pyc,,
+setuptools/_vendor/packaging/markers.py,sha256=Gvpk9EY20yKaMTiKgQZ8yFEEpodqVgVYtfekoic1Yts,8239
+setuptools/_vendor/packaging/markers.pyc,,
+setuptools/_vendor/packaging/requirements.py,sha256=t44M2HVWtr8phIz2OhnILzuGT3rTATaovctV1dpnVIg,4343
+setuptools/_vendor/packaging/requirements.pyc,,
+setuptools/_vendor/packaging/specifiers.py,sha256=SAMRerzO3fK2IkFZCaZkuwZaL_EGqHNOz4pni4vhnN0,28025
+setuptools/_vendor/packaging/specifiers.pyc,,
+setuptools/_vendor/packaging/utils.py,sha256=3m6WvPm6NNxE8rkTGmn0r75B_GZSGg7ikafxHsBN1WA,421
+setuptools/_vendor/packaging/utils.pyc,,
+setuptools/_vendor/packaging/version.py,sha256=OwGnxYfr2ghNzYx59qWIBkrK3SnB6n-Zfd1XaLpnnM0,11556
+setuptools/_vendor/packaging/version.pyc,,
+setuptools/_vendor/pyparsing.py,sha256=tmrp-lu-qO1i75ZzIN5A12nKRRD1Cm4Vpk-5LR9rims,232055
+setuptools/_vendor/pyparsing.pyc,,
+setuptools/_vendor/six.py,sha256=A6hdJZVjI3t_geebZ9BzUvwRrIXo0lfwzQlM2LcKyas,30098
+setuptools/_vendor/six.pyc,,
+setuptools/archive_util.py,sha256=kw8Ib_lKjCcnPKNbS7h8HztRVK0d5RacU3r_KRdVnmM,6592
+setuptools/archive_util.pyc,,
+setuptools/build_meta.py,sha256=ioZE7tGSWY6vy7KLune0Iq334ugXuO39imcKC8prjBY,9387
+setuptools/build_meta.pyc,,
+setuptools/cli-32.exe,sha256=dfEuovMNnA2HLa3jRfMPVi5tk4R7alCbpTvuxtCyw0Y,65536
+setuptools/cli-64.exe,sha256=KLABu5pyrnokJCv6skjXZ6GsXeyYHGcqOUT3oHI3Xpo,74752
+setuptools/cli.exe,sha256=dfEuovMNnA2HLa3jRfMPVi5tk4R7alCbpTvuxtCyw0Y,65536
+setuptools/command/__init__.py,sha256=NWzJ0A1BEengZpVeqUyWLNm2bk4P3F4iL5QUErHy7kA,594
+setuptools/command/__init__.pyc,,
+setuptools/command/alias.py,sha256=KjpE0sz_SDIHv3fpZcIQK-sCkJz-SrC6Gmug6b9Nkc8,2426
+setuptools/command/alias.pyc,,
+setuptools/command/bdist_egg.py,sha256=be-IBpr1zhS9i6GjKANJgzkbH3ChImdWY7S-j0r2BK8,18167
+setuptools/command/bdist_egg.pyc,,
+setuptools/command/bdist_rpm.py,sha256=B7l0TnzCGb-0nLlm6rS00jWLkojASwVmdhW2w5Qz_Ak,1508
+setuptools/command/bdist_rpm.pyc,,
+setuptools/command/bdist_wininst.py,sha256=_6dz3lpB1tY200LxKPLM7qgwTCceOMgaWFF-jW2-pm0,637
+setuptools/command/bdist_wininst.pyc,,
+setuptools/command/build_clib.py,sha256=bQ9aBr-5ZSO-9fGsGsDLz0mnnFteHUZnftVLkhvHDq0,4484
+setuptools/command/build_clib.pyc,,
+setuptools/command/build_ext.py,sha256=81CTgsqjBjNl_HOgCJ1lQ5vv1NIM3RBpcoVGpqT4N1M,12897
+setuptools/command/build_ext.pyc,,
+setuptools/command/build_py.py,sha256=yWyYaaS9F3o9JbIczn064A5g1C5_UiKRDxGaTqYbtLE,9596
+setuptools/command/build_py.pyc,,
+setuptools/command/develop.py,sha256=MQlnGS6uP19erK2JCNOyQYoYyquk3PADrqrrinqqLtA,8184
+setuptools/command/develop.pyc,,
+setuptools/command/dist_info.py,sha256=5t6kOfrdgALT-P3ogss6PF9k-Leyesueycuk3dUyZnI,960
+setuptools/command/dist_info.pyc,,
+setuptools/command/easy_install.py,sha256=telww7CuPsoTtvlpY-ktnZGT85cZ6xGCGZa0vHvFJ-Q,87273
+setuptools/command/easy_install.pyc,,
+setuptools/command/egg_info.py,sha256=w73EdxYSOk2gsaAiHGL2dZrCldoPiuRr2eTfqcFvCds,25570
+setuptools/command/egg_info.pyc,,
+setuptools/command/install.py,sha256=a0EZpL_A866KEdhicTGbuyD_TYl1sykfzdrri-zazT4,4683
+setuptools/command/install.pyc,,
+setuptools/command/install_egg_info.py,sha256=bMgeIeRiXzQ4DAGPV1328kcjwQjHjOWU4FngAWLV78Q,2203
+setuptools/command/install_egg_info.pyc,,
+setuptools/command/install_lib.py,sha256=11mxf0Ch12NsuYwS8PHwXBRvyh671QAM4cTRh7epzG0,3840
+setuptools/command/install_lib.pyc,,
+setuptools/command/install_scripts.py,sha256=UD0rEZ6861mTYhIdzcsqKnUl8PozocXWl9VBQ1VTWnc,2439
+setuptools/command/install_scripts.pyc,,
+setuptools/command/launcher manifest.xml,sha256=xlLbjWrB01tKC0-hlVkOKkiSPbzMml2eOPtJ_ucCnbE,628
+setuptools/command/py36compat.py,sha256=SzjZcOxF7zdFUT47Zv2n7AM3H8koDys_0OpS-n9gIfc,4986
+setuptools/command/py36compat.pyc,,
+setuptools/command/register.py,sha256=LO3MvYKPE8dN1m-KkrBRHC68ZFoPvA_vI8Xgp7vv6zI,534
+setuptools/command/register.pyc,,
+setuptools/command/rotate.py,sha256=co5C1EkI7P0GGT6Tqz-T2SIj2LBJTZXYELpmao6d4KQ,2164
+setuptools/command/rotate.pyc,,
+setuptools/command/saveopts.py,sha256=za7QCBcQimKKriWcoCcbhxPjUz30gSB74zuTL47xpP4,658
+setuptools/command/saveopts.pyc,,
+setuptools/command/sdist.py,sha256=gr5hFrDzUtGfp_0tu0sllzIyr3jMQegIkFmlDauQJxw,7388
+setuptools/command/sdist.pyc,,
+setuptools/command/setopt.py,sha256=NTWDyx-gjDF-txf4dO577s7LOzHVoKR0Mq33rFxaRr8,5085
+setuptools/command/setopt.pyc,,
+setuptools/command/test.py,sha256=oePJ49u17ENKtrM-rOrrLlRhtNnrzcSr0IW-gE9XVq0,9285
+setuptools/command/test.pyc,,
+setuptools/command/upload.py,sha256=GxtNkIl7SA0r8mACkbDcSCN1m2_WPppK9gZXJmQSiow,6811
+setuptools/command/upload.pyc,,
+setuptools/command/upload_docs.py,sha256=oXiGplM_cUKLwE4CWWw98RzCufAu8tBhMC97GegFcms,7311
+setuptools/command/upload_docs.pyc,,
+setuptools/config.py,sha256=lz19l1AtoHctpp1_tbYZv176nrEj4Gpf7ykNIYTIkAQ,20425
+setuptools/config.pyc,,
+setuptools/dep_util.py,sha256=fgixvC1R7sH3r13ktyf7N0FALoqEXL1cBarmNpSEoWg,935
+setuptools/dep_util.pyc,,
+setuptools/depends.py,sha256=hC8QIDcM3VDpRXvRVA6OfL9AaQfxvhxHcN_w6sAyNq8,5837
+setuptools/depends.pyc,,
+setuptools/dist.py,sha256=qYPmmVlLPWCLHrILR0J74bqoYgTSZh5ocLeyRKqnVyU,49913
+setuptools/dist.pyc,,
+setuptools/extension.py,sha256=uc6nHI-MxwmNCNPbUiBnybSyqhpJqjbhvOQ-emdvt_E,1729
+setuptools/extension.pyc,,
+setuptools/extern/__init__.py,sha256=TxeNKFMSfBMzBpBDiHx8Dh3RzsdVmvWaXhtZ03DZMs0,2499
+setuptools/extern/__init__.pyc,,
+setuptools/glibc.py,sha256=X64VvGPL2AbURKwYRsWJOXXGAYOiF_v2qixeTkAULuU,3146
+setuptools/glibc.pyc,,
+setuptools/glob.py,sha256=o75cHrOxYsvn854thSxE0x9k8JrKDuhP_rRXlVB00Q4,5084
+setuptools/glob.pyc,,
+setuptools/gui-32.exe,sha256=XBr0bHMA6Hpz2s9s9Bzjl-PwXfa9nH4ie0rFn4V2kWA,65536
+setuptools/gui-64.exe,sha256=aYKMhX1IJLn4ULHgWX0sE0yREUt6B3TEHf_jOw6yNyE,75264
+setuptools/gui.exe,sha256=XBr0bHMA6Hpz2s9s9Bzjl-PwXfa9nH4ie0rFn4V2kWA,65536
+setuptools/launch.py,sha256=sd7ejwhBocCDx_wG9rIs0OaZ8HtmmFU8ZC6IR_S0Lvg,787
+setuptools/launch.pyc,,
+setuptools/lib2to3_ex.py,sha256=t5e12hbR2pi9V4ezWDTB4JM-AISUnGOkmcnYHek3xjg,2013
+setuptools/lib2to3_ex.pyc,,
+setuptools/monkey.py,sha256=FGc9fffh7gAxMLFmJs2DW_OYWpBjkdbNS2n14UAK4NA,5264
+setuptools/monkey.pyc,,
+setuptools/msvc.py,sha256=uuRFaZzjJt5Fv3ZmyKUUuLtjx12_8G9RILigGec4irI,40838
+setuptools/msvc.pyc,,
+setuptools/namespaces.py,sha256=F0Nrbv8KCT2OrO7rwa03om4N4GZKAlnce-rr-cgDQa8,3199
+setuptools/namespaces.pyc,,
+setuptools/package_index.py,sha256=F9LBC-hQ5fkjeEVflxif0mo_DzRMrepahdFTPenOtGM,40587
+setuptools/package_index.pyc,,
+setuptools/pep425tags.py,sha256=o_D_WVeWcXZiI2xjPSg7pouGOvaWRgGRxEDK9DzAXIA,10861
+setuptools/pep425tags.pyc,,
+setuptools/py27compat.py,sha256=3mwxRMDk5Q5O1rSXOERbQDXhFqwDJhhUitfMW_qpUCo,536
+setuptools/py27compat.pyc,,
+setuptools/py31compat.py,sha256=h2rtZghOfwoGYd8sQ0-auaKiF3TcL3qX0bX3VessqcE,838
+setuptools/py31compat.pyc,,
+setuptools/py33compat.py,sha256=OubjldHJH1KGE1CKt1kRU-Q55keftHT3ea1YoL0ZSco,1195
+setuptools/py33compat.pyc,,
+setuptools/sandbox.py,sha256=9UbwfEL5QY436oMI1LtFWohhoZ-UzwHvGyZjUH_qhkw,14276
+setuptools/sandbox.pyc,,
+setuptools/script (dev).tmpl,sha256=RUzQzCQUaXtwdLtYHWYbIQmOaES5Brqq1FvUA_tu-5I,218
+setuptools/script.tmpl,sha256=WGTt5piezO27c-Dbx6l5Q4T3Ff20A5z7872hv3aAhYY,138
+setuptools/site-patch.py,sha256=OumkIHMuoSenRSW1382kKWI1VAwxNE86E5W8iDd34FY,2302
+setuptools/site-patch.pyc,,
+setuptools/ssl_support.py,sha256=nLjPUBBw7RTTx6O4RJZ5eAMGgjJG8beiDbkFXDZpLuM,8493
+setuptools/ssl_support.pyc,,
+setuptools/unicode_utils.py,sha256=NOiZ_5hD72A6w-4wVj8awHFM3n51Kmw1Ic_vx15XFqw,996
+setuptools/unicode_utils.pyc,,
+setuptools/version.py,sha256=og_cuZQb0QI6ukKZFfZWPlr1HgJBPPn2vO2m_bI9ZTE,144
+setuptools/version.pyc,,
+setuptools/wheel.py,sha256=94uqXsOaKt91d9hW5z6ZppZmNSs_nO66R4uiwhcr4V0,8094
+setuptools/wheel.pyc,,
+setuptools/windows_support.py,sha256=5GrfqSP2-dLGJoZTq2g6dCKkyQxxa2n5IQiXlJCoYEE,714
+setuptools/windows_support.pyc,,
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools-41.0.1.dist-info/WHEEL b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools-41.0.1.dist-info/WHEEL
new file mode 100644
index 0000000..c8240f0
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools-41.0.1.dist-info/WHEEL
@@ -0,0 +1,6 @@
+Wheel-Version: 1.0
+Generator: bdist_wheel (0.33.1)
+Root-Is-Purelib: true
+Tag: py2-none-any
+Tag: py3-none-any
+
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools-41.0.1.dist-info/dependency_links.txt b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools-41.0.1.dist-info/dependency_links.txt
new file mode 100644
index 0000000..e87d021
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools-41.0.1.dist-info/dependency_links.txt
@@ -0,0 +1,2 @@
+https://files.pythonhosted.org/packages/source/c/certifi/certifi-2016.9.26.tar.gz#md5=baa81e951a29958563689d868ef1064d
+https://files.pythonhosted.org/packages/source/w/wincertstore/wincertstore-0.2.zip#md5=ae728f2f007185648d0c7a8679b361e2
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools-41.0.1.dist-info/entry_points.txt b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools-41.0.1.dist-info/entry_points.txt
new file mode 100644
index 0000000..4159fd0
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools-41.0.1.dist-info/entry_points.txt
@@ -0,0 +1,65 @@
+[console_scripts]
+easy_install = setuptools.command.easy_install:main
+easy_install-3.6 = setuptools.command.easy_install:main
+
+[distutils.commands]
+alias = setuptools.command.alias:alias
+bdist_egg = setuptools.command.bdist_egg:bdist_egg
+bdist_rpm = setuptools.command.bdist_rpm:bdist_rpm
+bdist_wininst = setuptools.command.bdist_wininst:bdist_wininst
+build_clib = setuptools.command.build_clib:build_clib
+build_ext = setuptools.command.build_ext:build_ext
+build_py = setuptools.command.build_py:build_py
+develop = setuptools.command.develop:develop
+dist_info = setuptools.command.dist_info:dist_info
+easy_install = setuptools.command.easy_install:easy_install
+egg_info = setuptools.command.egg_info:egg_info
+install = setuptools.command.install:install
+install_egg_info = setuptools.command.install_egg_info:install_egg_info
+install_lib = setuptools.command.install_lib:install_lib
+install_scripts = setuptools.command.install_scripts:install_scripts
+register = setuptools.command.register:register
+rotate = setuptools.command.rotate:rotate
+saveopts = setuptools.command.saveopts:saveopts
+sdist = setuptools.command.sdist:sdist
+setopt = setuptools.command.setopt:setopt
+test = setuptools.command.test:test
+upload = setuptools.command.upload:upload
+upload_docs = setuptools.command.upload_docs:upload_docs
+
+[distutils.setup_keywords]
+convert_2to3_doctests = setuptools.dist:assert_string_list
+dependency_links = setuptools.dist:assert_string_list
+eager_resources = setuptools.dist:assert_string_list
+entry_points = setuptools.dist:check_entry_points
+exclude_package_data = setuptools.dist:check_package_data
+extras_require = setuptools.dist:check_extras
+include_package_data = setuptools.dist:assert_bool
+install_requires = setuptools.dist:check_requirements
+namespace_packages = setuptools.dist:check_nsp
+package_data = setuptools.dist:check_package_data
+packages = setuptools.dist:check_packages
+python_requires = setuptools.dist:check_specifier
+setup_requires = setuptools.dist:check_requirements
+test_loader = setuptools.dist:check_importable
+test_runner = setuptools.dist:check_importable
+test_suite = setuptools.dist:check_test_suite
+tests_require = setuptools.dist:check_requirements
+use_2to3 = setuptools.dist:assert_bool
+use_2to3_exclude_fixers = setuptools.dist:assert_string_list
+use_2to3_fixers = setuptools.dist:assert_string_list
+zip_safe = setuptools.dist:assert_bool
+
+[egg_info.writers]
+PKG-INFO = setuptools.command.egg_info:write_pkg_info
+dependency_links.txt = setuptools.command.egg_info:overwrite_arg
+depends.txt = setuptools.command.egg_info:warn_depends_obsolete
+eager_resources.txt = setuptools.command.egg_info:overwrite_arg
+entry_points.txt = setuptools.command.egg_info:write_entries
+namespace_packages.txt = setuptools.command.egg_info:overwrite_arg
+requires.txt = setuptools.command.egg_info:write_requirements
+top_level.txt = setuptools.command.egg_info:write_toplevel_names
+
+[setuptools.installation]
+eggsecutable = setuptools.command.easy_install:bootstrap
+
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools-41.0.1.dist-info/top_level.txt b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools-41.0.1.dist-info/top_level.txt
new file mode 100644
index 0000000..4577c6a
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools-41.0.1.dist-info/top_level.txt
@@ -0,0 +1,3 @@
+easy_install
+pkg_resources
+setuptools
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools-41.0.1.dist-info/zip-safe b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools-41.0.1.dist-info/zip-safe
new file mode 100644
index 0000000..8b13789
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools-41.0.1.dist-info/zip-safe
@@ -0,0 +1 @@
+
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/__init__.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/__init__.py
new file mode 100644
index 0000000..a71b2bb
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/__init__.py
@@ -0,0 +1,228 @@
+"""Extensions to the 'distutils' for large or complex distributions"""
+
+import os
+import sys
+import functools
+import distutils.core
+import distutils.filelist
+import re
+from distutils.errors import DistutilsOptionError
+from distutils.util import convert_path
+from fnmatch import fnmatchcase
+
+from ._deprecation_warning import SetuptoolsDeprecationWarning
+
+from setuptools.extern.six import PY3, string_types
+from setuptools.extern.six.moves import filter, map
+
+import setuptools.version
+from setuptools.extension import Extension
+from setuptools.dist import Distribution, Feature
+from setuptools.depends import Require
+from . import monkey
+
+__metaclass__ = type
+
+
+__all__ = [
+    'setup', 'Distribution', 'Feature', 'Command', 'Extension', 'Require',
+    'SetuptoolsDeprecationWarning',
+    'find_packages'
+]
+
+if PY3:
+  __all__.append('find_namespace_packages')
+
+__version__ = setuptools.version.__version__
+
+bootstrap_install_from = None
+
+# If we run 2to3 on .py files, should we also convert docstrings?
+# Default: yes; assume that we can detect doctests reliably
+run_2to3_on_doctests = True
+# Standard package names for fixer packages
+lib2to3_fixer_packages = ['lib2to3.fixes']
+
+
+class PackageFinder:
+    """
+    Generate a list of all Python packages found within a directory
+    """
+
+    @classmethod
+    def find(cls, where='.', exclude=(), include=('*',)):
+        """Return a list all Python packages found within directory 'where'
+
+        'where' is the root directory which will be searched for packages.  It
+        should be supplied as a "cross-platform" (i.e. URL-style) path; it will
+        be converted to the appropriate local path syntax.
+
+        'exclude' is a sequence of package names to exclude; '*' can be used
+        as a wildcard in the names, such that 'foo.*' will exclude all
+        subpackages of 'foo' (but not 'foo' itself).
+
+        'include' is a sequence of package names to include.  If it's
+        specified, only the named packages will be included.  If it's not
+        specified, all found packages will be included.  'include' can contain
+        shell style wildcard patterns just like 'exclude'.
+        """
+
+        return list(cls._find_packages_iter(
+            convert_path(where),
+            cls._build_filter('ez_setup', '*__pycache__', *exclude),
+            cls._build_filter(*include)))
+
+    @classmethod
+    def _find_packages_iter(cls, where, exclude, include):
+        """
+        All the packages found in 'where' that pass the 'include' filter, but
+        not the 'exclude' filter.
+        """
+        for root, dirs, files in os.walk(where, followlinks=True):
+            # Copy dirs to iterate over it, then empty dirs.
+            all_dirs = dirs[:]
+            dirs[:] = []
+
+            for dir in all_dirs:
+                full_path = os.path.join(root, dir)
+                rel_path = os.path.relpath(full_path, where)
+                package = rel_path.replace(os.path.sep, '.')
+
+                # Skip directory trees that are not valid packages
+                if ('.' in dir or not cls._looks_like_package(full_path)):
+                    continue
+
+                # Should this package be included?
+                if include(package) and not exclude(package):
+                    yield package
+
+                # Keep searching subdirectories, as there may be more packages
+                # down there, even if the parent was excluded.
+                dirs.append(dir)
+
+    @staticmethod
+    def _looks_like_package(path):
+        """Does a directory look like a package?"""
+        return os.path.isfile(os.path.join(path, '__init__.py'))
+
+    @staticmethod
+    def _build_filter(*patterns):
+        """
+        Given a list of patterns, return a callable that will be true only if
+        the input matches at least one of the patterns.
+        """
+        return lambda name: any(fnmatchcase(name, pat=pat) for pat in patterns)
+
+
+class PEP420PackageFinder(PackageFinder):
+    @staticmethod
+    def _looks_like_package(path):
+        return True
+
+
+find_packages = PackageFinder.find
+
+if PY3:
+  find_namespace_packages = PEP420PackageFinder.find
+
+
+def _install_setup_requires(attrs):
+    # Note: do not use `setuptools.Distribution` directly, as
+    # our PEP 517 backend patch `distutils.core.Distribution`.
+    dist = distutils.core.Distribution(dict(
+        (k, v) for k, v in attrs.items()
+        if k in ('dependency_links', 'setup_requires')
+    ))
+    # Honor setup.cfg's options.
+    dist.parse_config_files(ignore_option_errors=True)
+    if dist.setup_requires:
+        dist.fetch_build_eggs(dist.setup_requires)
+
+
+def setup(**attrs):
+    # Make sure we have any requirements needed to interpret 'attrs'.
+    _install_setup_requires(attrs)
+    return distutils.core.setup(**attrs)
+
+setup.__doc__ = distutils.core.setup.__doc__
+
+
+_Command = monkey.get_unpatched(distutils.core.Command)
+
+
+class Command(_Command):
+    __doc__ = _Command.__doc__
+
+    command_consumes_arguments = False
+
+    def __init__(self, dist, **kw):
+        """
+        Construct the command for dist, updating
+        vars(self) with any keyword parameters.
+        """
+        _Command.__init__(self, dist)
+        vars(self).update(kw)
+
+    def _ensure_stringlike(self, option, what, default=None):
+        val = getattr(self, option)
+        if val is None:
+            setattr(self, option, default)
+            return default
+        elif not isinstance(val, string_types):
+            raise DistutilsOptionError("'%s' must be a %s (got `%s`)"
+                                       % (option, what, val))
+        return val
+
+    def ensure_string_list(self, option):
+        r"""Ensure that 'option' is a list of strings.  If 'option' is
+        currently a string, we split it either on /,\s*/ or /\s+/, so
+        "foo bar baz", "foo,bar,baz", and "foo,   bar baz" all become
+        ["foo", "bar", "baz"].
+        """
+        val = getattr(self, option)
+        if val is None:
+            return
+        elif isinstance(val, string_types):
+            setattr(self, option, re.split(r',\s*|\s+', val))
+        else:
+            if isinstance(val, list):
+                ok = all(isinstance(v, string_types) for v in val)
+            else:
+                ok = False
+            if not ok:
+                raise DistutilsOptionError(
+                      "'%s' must be a list of strings (got %r)"
+                      % (option, val))
+
+    def reinitialize_command(self, command, reinit_subcommands=0, **kw):
+        cmd = _Command.reinitialize_command(self, command, reinit_subcommands)
+        vars(cmd).update(kw)
+        return cmd
+
+
+def _find_all_simple(path):
+    """
+    Find all files under 'path'
+    """
+    results = (
+        os.path.join(base, file)
+        for base, dirs, files in os.walk(path, followlinks=True)
+        for file in files
+    )
+    return filter(os.path.isfile, results)
+
+
+def findall(dir=os.curdir):
+    """
+    Find all files under 'dir' and return the list of full filenames.
+    Unless dir is '.', return full filenames with dir prepended.
+    """
+    files = _find_all_simple(dir)
+    if dir == os.curdir:
+        make_rel = functools.partial(os.path.relpath, start=dir)
+        files = map(make_rel, files)
+    return list(files)
+
+
+# Apply monkey patches
+monkey.patch_all()
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/__init__.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/__init__.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..e586cedf415e68e1da741f989d0ad8597b1d6cc1
GIT binary patch
literal 10555
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

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/_deprecation_warning.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/_deprecation_warning.py
new file mode 100644
index 0000000..086b64d
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/_deprecation_warning.py
@@ -0,0 +1,7 @@
+class SetuptoolsDeprecationWarning(Warning):
+    """
+    Base class for warning deprecations in ``setuptools``
+
+    This class is not derived from ``DeprecationWarning``, and as such is
+    visible by default.
+    """
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/_deprecation_warning.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/_deprecation_warning.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..13fe45cd02894c0b1668ac2ad233d1b3c54e14de
GIT binary patch
literal 690
zcmZSn%**AGdLky70ScHI7#JKF7#NDB7#J8*7#LC+7}6LSQWzOp7#Nxv7$Tz>8B&-S
zf;B+uN@N%q7=lwvN()Nz^K*(_QVWVwlM_oa^Yg+Ji}Et_(&45uGB7YWflTFN02>K1
zg@GZ8i6JOh10+|xh=GBDOF=<F!6~sgRUtVivA9?vEx$;i9Ac0{3c~DSh0HvKgoI+a
zy$K0iV67n;nZ;18nZ*iu`6UV|sYRJ(sVNF+Mftf32?>}EOi0jCNX$!7NGw(;E=|r*
z$Sek%RF+wsnUs^NkW{IVlA4xSnp2_&7KiwngMon|K0YroH#I)KgbU2c%}*)K0dd*E
z+?4#}_;?Lah$4vMN(Kf7{eq&*vc!^9{j$U&{j~g?l+>bP{iGEA@}#7^T+`fQBf})~
z^s00VQ;YJPtSU1D5J=C{5795kEYQu&D=taQ$<cKy^YAnd&_@ISGBX}2q~f8Wr&mxJ
u1ab^Gq?s5P7}(hSG(dC-$hpwC0;@nc7t9)1H<y3{+6EG|c3`)IJOKbb(!b0A

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/_vendor/__init__.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/_vendor/__init__.py
new file mode 100644
index 0000000..e69de29
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/_vendor/__init__.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/_vendor/__init__.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..9e1894ecb014c0cdc87dd2ced400b9bef3b442d7
GIT binary patch
literal 204
zcmZSn%**AGdLky70SXuy7#JKF7#NCK7#J8*7#M;zKq7t`AZawBxRil`LBF6Vvn;VB
zRlh8;NIxw<CndG0SU)L6zdR`^FV{4;*vK%+JiRL2!qlQXC#%ZL00h$W^h5LuG7EGw
z^NLFnb8>Xu$~-)c1N4hiOG*n$^7C_wk(u#jsd*{+Mf&manR%Hd@$q^El_eYu3=B58
Q`6;D2sdgau6@#1y05tM7DgXcg

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/_vendor/packaging/__about__.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/_vendor/packaging/__about__.py
new file mode 100644
index 0000000..95d330e
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/_vendor/packaging/__about__.py
@@ -0,0 +1,21 @@
+# This file is dual licensed under the terms of the Apache License, Version
+# 2.0, and the BSD License. See the LICENSE file in the root of this repository
+# for complete details.
+from __future__ import absolute_import, division, print_function
+
+__all__ = [
+    "__title__", "__summary__", "__uri__", "__version__", "__author__",
+    "__email__", "__license__", "__copyright__",
+]
+
+__title__ = "packaging"
+__summary__ = "Core utilities for Python packages"
+__uri__ = "https://github.com/pypa/packaging"
+
+__version__ = "16.8"
+
+__author__ = "Donald Stufft and individual contributors"
+__email__ = "donald@stufft.io"
+
+__license__ = "BSD or Apache License, Version 2.0"
+__copyright__ = "Copyright 2014-2016 %s" % __author__
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/_vendor/packaging/__about__.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/_vendor/packaging/__about__.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..927fe094904acc75421f9865bc2b28a40aafb02c
GIT binary patch
literal 843
zcmZSn%**AGdLky70SY)67#JK97#WI-7#J8*7#LC*8FCmHav2$-7#VVz7^0XMa+w*T
zm>C#Tm>5!+8B$mnQdk*M*cejS8B#bHQaBmXIT)f?7*e<xqF5PHxEZ3@7*co`qSzTy
zcp0KN7*hBcqBt2+_!*+O7*YfnqPQ7S1Q}8}8N{M^7*d27f;EI07#K1^ZqZ<7U|=ZW
zXJBAROe)ULDJ@Bj&&(~zFDfYkIWZ-(EVDQ>Kd*$3fq|i*C^N4lKCLt_xdbG{$-ux6
zA77GLl9L)AU&0OM6_@7bCKgr3$Ct2!`K3jfaJjP7B9Kw>@g-bfxx~_vjQpbb_!5Xg
zskw=nIdH`}naQbn#UO)u!HSdf3o45;(=$q->I)K+vlG)Z^U{lz7#J9w^NUgyN=q_x
zGD|X3ixtxHixdJXOEU8F6d>wSi;EQ*7#K22N(zdt^!3v-OEOB6^pf*)^$RKs67?a9
zK!&j}FfbUJ=~)zOGB7Z><mV;kq$mWJl%}PXC?w{kC}ie=0wkq0F-IXeKd+=HGpV#B
zzo@ua02GN})egmA)q0uvV23#cyC~!rDL57+CTFB7_&_|RqYwrO3I!uQgJLnT`=P#5
zFfuSS(KRwKG*eJ5_R|3Q9U59`r6r|Bsqyhaphyd1WME(jVgkh+B%Bj-a^mBIKv5Y4
z@<I?RNS+NufaHTfQ5ggZ<{(heYk-VE5XB7)3=H}OMVV!ZC8_#liADNp`8g@6MaB9_
zDf;C}NqM=Zxy43?N#^NQ=@zCI<vCeZW(FXTo~Iw8Uyxa#o0(T!l9-dD>sIFBX&j(m
zoLW*^P?DdYQ;f`vFH6l!$uB|#wtjqkVp4u-NqoFsK_xh~+2rP@l;)(`fxJ*G!oa{F
U!_3df&&<Zi#>mFR#snrA0acyVcmMzZ

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/_vendor/packaging/__init__.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/_vendor/packaging/__init__.py
new file mode 100644
index 0000000..5ee6220
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/_vendor/packaging/__init__.py
@@ -0,0 +1,14 @@
+# This file is dual licensed under the terms of the Apache License, Version
+# 2.0, and the BSD License. See the LICENSE file in the root of this repository
+# for complete details.
+from __future__ import absolute_import, division, print_function
+
+from .__about__ import (
+    __author__, __copyright__, __email__, __license__, __summary__, __title__,
+    __uri__, __version__
+)
+
+__all__ = [
+    "__title__", "__summary__", "__uri__", "__version__", "__author__",
+    "__email__", "__license__", "__copyright__",
+]
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/_vendor/packaging/__init__.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/_vendor/packaging/__init__.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..152f69ee3688c4527dce4b83264689ad7d2a86d0
GIT binary patch
literal 665
zcmZSn%**AGdLky70SY)67#JK97#WHy7#J8*7#LC*8FCmHav2$-7#VVz7^0XMa+w*T
zm>C#Tm>5!+8FE+{a#<OoSQ&EJ7^2u1a@iT8*coy;7@{~Bayc2II2m%e7^1isa=96z
zxEXSJ7@~L>7*kjnQdk*M*cejS8B#bHQaBk>xENBn8PYizqIelnco>2;co`TNGC?lV
zU}j)oDB)*dU`R|V&d(_=NsZ6UEyyn_DFHb&C9^EEI5R)5gpYxNp`a);uOvRLG%vX%
zGe0krk%56h1Ei>gi-Cb5K0dLuBqP5lKE4EGc6@wtenDkXW_m_Re0&KfSV3xTVrEW!
zd<i$0my?;Cnpd0(=NFge<|Y<Z!c~`KmgInB*}<wyi!$LV%TkL#Zi<f&0@)q}QV;~P
zAqeD-Adr88SQ!`?g4jR=3j+g#p9aYJP-mu<mXsEy#>WSNd>;hzL=Y1w2tX#p$0sJ`
zmzKoGLrekbMKTI(5!gzQTCi;;AhG!P#GIV?cny$&2%@;2fq_B4peVB}u_RT$EU`#G
zEk7qEwWwG>DMi0LDJd`4G`HBuFv&c<D&4}=qC6+7%FF-+()08~^b0ZzbTjjcOA>Q(
zblu84JdFeNi&INV3rh0ybBd9f@nxxbDfvbE1&PVoiRqbn>H6{UnR%Hd@$q^EmEbtE
X$<0qG%}KQb`KA~YCNfM`Z2XJ>JmQnD

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/_vendor/packaging/_compat.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/_vendor/packaging/_compat.py
new file mode 100644
index 0000000..210bb80
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/_vendor/packaging/_compat.py
@@ -0,0 +1,30 @@
+# This file is dual licensed under the terms of the Apache License, Version
+# 2.0, and the BSD License. See the LICENSE file in the root of this repository
+# for complete details.
+from __future__ import absolute_import, division, print_function
+
+import sys
+
+
+PY2 = sys.version_info[0] == 2
+PY3 = sys.version_info[0] == 3
+
+# flake8: noqa
+
+if PY3:
+    string_types = str,
+else:
+    string_types = basestring,
+
+
+def with_metaclass(meta, *bases):
+    """
+    Create a base class with a metaclass.
+    """
+    # This requires a bit of explanation: the basic idea is to make a dummy
+    # metaclass for one level of class instantiation that replaces itself with
+    # the actual metaclass.
+    class metaclass(meta):
+        def __new__(cls, name, this_bases, d):
+            return meta(name, bases, d)
+    return type.__new__(metaclass, 'temporary_class', (), {})
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/_vendor/packaging/_compat.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/_vendor/packaging/_compat.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..98e25128ee9c6fc11d66fa1e170ee9c9942c844e
GIT binary patch
literal 1460
zcmZSn%**AGdLky70ScHH7#JK97#WJo7#J8*7#LC*8FCmHav2$-7#VVz7^0XMa+w*T
zm>C#Ba!d?4EDTXB45=&(S*#${k}1p#*-Q*kY{)_^U?FyfRCb1<1cp=&hBQWoC{Bhv
zPKH!2C_9Cfp@o4Vikl&Yi6K~nje&t76XYHZW(Ed^5`G2-hQy@e{G8H~)cDNYg8ZVA
z5)P2-GRrcHGxPIG_!t-%3W_rGO5)Q>^O8$4^Yi>NLH@`DX-{TkU|;|-SQ!`?*g-xs
z1?gpE=wJj{-p;_#&d89)1hTn}fuWg!A+nZ<p@e}Ui;<y*i6MoVA%z9xm}VA+U=5HF
z#rg~k3|tBd3JT6esfi`23W*9yiN&c3$vKI|#R}z_B^e5d3c0BziC_Ueu*won1_lPW
z7)n?(fm|fTz`&5o019G+a~K%f7(l@t6s!UAK{5*i0|N{TgER>+Fo66}!^qIVz)-`?
z(9FyLQR=4w4m*(I5|GD}bBaqqoV>)`)DkXGh-PFK$AcVQTmmvWMFSLAB_Pj11VM^H
zt_7P@T*tt`pkGjwS(aFms$Z5^q@R|blag9gte=#kU!Ihdmus3^Y-E^Zo?ex1VQNvH
zlT~GA00QZG`XTxSnFYF;dBr7(IXSv+Wgec!0s6(MC8Y%=`T04;$jtb%)V!4ZBK?BI
z<m|-s%)E5{_~iWDg2WQNg31zh1_p-s_`KBe_;?ux28Lpgdl?uZsRNV};^RSni;oBU
zE<QdtKczG$H9kHF<XNyMz&;EDDGdTe1z2nlcq|AMJ<>2Au`z;^dPyoMi6<6S#)DH3
z*sWmqgCnt|vLF@WFOXiaZy^2xaS>`EVj#Z`0&jvdC@5#dgHjdPS0W%!gVGrTyF9Z7
z4=7QBA}c;Vt+b@H2o!gqG#ms<o<X441}Eg=%Hk4`(z4VdP`;1P%uCA$O9Vt3L1|+!
zU0hNGR#;q8l$n<v4+^tlaN2;RZ;)URs8oT37sw_sYcK>AD2>`c60jX8e2PJZn+y{V
PvoNDD3mYR36DKnOB*I;t

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/_vendor/packaging/_structures.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/_vendor/packaging/_structures.py
new file mode 100644
index 0000000..ccc2786
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/_vendor/packaging/_structures.py
@@ -0,0 +1,68 @@
+# This file is dual licensed under the terms of the Apache License, Version
+# 2.0, and the BSD License. See the LICENSE file in the root of this repository
+# for complete details.
+from __future__ import absolute_import, division, print_function
+
+
+class Infinity(object):
+
+    def __repr__(self):
+        return "Infinity"
+
+    def __hash__(self):
+        return hash(repr(self))
+
+    def __lt__(self, other):
+        return False
+
+    def __le__(self, other):
+        return False
+
+    def __eq__(self, other):
+        return isinstance(other, self.__class__)
+
+    def __ne__(self, other):
+        return not isinstance(other, self.__class__)
+
+    def __gt__(self, other):
+        return True
+
+    def __ge__(self, other):
+        return True
+
+    def __neg__(self):
+        return NegativeInfinity
+
+Infinity = Infinity()
+
+
+class NegativeInfinity(object):
+
+    def __repr__(self):
+        return "-Infinity"
+
+    def __hash__(self):
+        return hash(repr(self))
+
+    def __lt__(self, other):
+        return True
+
+    def __le__(self, other):
+        return True
+
+    def __eq__(self, other):
+        return isinstance(other, self.__class__)
+
+    def __ne__(self, other):
+        return not isinstance(other, self.__class__)
+
+    def __gt__(self, other):
+        return False
+
+    def __ge__(self, other):
+        return False
+
+    def __neg__(self):
+        return Infinity
+
+NegativeInfinity = NegativeInfinity()
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/_vendor/packaging/_structures.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/_vendor/packaging/_structures.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..ced3d174f412c01b4d5efc2f94f88e53bc766664
GIT binary patch
literal 5307
zcmZSn%**AGdLky70ScHI7#JK97#WJ=7#J8*7#LC*8FCmHav2$-7#VVz7^0XMa+w*T
zm>C#Tm>5!77}6LSQkWT97#Nxv7$T!s8B$q6tSDB76c(5?D_ok5A(ag*&Bl<z#t^K*
z&cMKs39?rMWNQgO0|P^1QgMDxX-R5)W^O@#QAr60$Q7AonZ=p;c_n-d3=9QDnRzAg
zX{C9|B_JV?yk}loW?p7VCEO2;3=9lTAU{MhFfgPtfSjJf0CGhX6UaX;3?L7rFo8u_
zpzen_86?HVkOFpc6g$Y3AQ29R6n3y;PKFc?FoTOBC|HA&fq@|zWETuOgY0AhxtNh5
zSc8dyfx#~b<TDMhA3>^0K(fWDIcX3fka%$u0|SG8K~ZK|Vo9ogSz?iXT7FJSYEiL%
zQi^_gQc_;7X>PHRVUl@zRl0?#MR`tEm6-tur03~}=oe%b=w{{>mn7!o=(?48cp3-j
z7pIn#7L?@Y=M*C|<I7U>Qu2%R3lfvF6Vo&E()HtuONvU9OG=AUi}eaB!66+VUzA!<
z6dw=rSux1{42*COf;<BDpa25{LkR;z2_r)d14A<-2nB0^Jm&}YGT4h5iNzUU2FN_H
zWDv;bgVom{=f=nLFfcH{d=2tE2!s3u_BF`)B@7HOpMu0oSQ!`?+!Aw&Q^6hw`w%Ra
zUy_kpH2D0=#=yW3AD>ea9}miDr1&(5lYxN&;mIH_5Eqnq!JZr}DH!U%)cANIEHR0m
zerp&(={Jj!p_vIDtDqP!0eLR77@Vo{l2c1K!J(F%lUQ6FA3sFGAhj?)UKC##2tx8O
zav1Qyk~Sz1f_NDi7=l3M?GW*CUTS>21Qs8I@+r>z3(C_WMWsmDcTlJ7^pf~^X%hVy
z1d8b)5{K!j@$qs<{sYAw4C9PLP;KOwnx0saS(XZG2n^;52h`??kIzd@kB?VG_*H`&
zlp#TlnfUm;#N5>QcyKWkAD^3_Qks(*A0Gs&Yl1)uf<Q`xKy_6Rs2C3d1was}zzY%v
z<yla+2banSVvv;2;HD7B`^6yFvN3ToqrxB&P<skgtAH>l;s;3^t{7AW=)w~h$aRA_
zg@IFwCL(E(+<*%L)uTb6h#Jhk1Z4#sBwvDREf5B!8(f9OkSGkn`CETj`V3TP8Da4m
zu}!m~(<%WM&8GOg3aXb&7#M~@3k+NXSzz%i-mC~JQwMvy1YE6J4@;kc+6s0^J_E%S
z4C5?5LHTqr*9oAuk0ZiU;6_!D7^qbw4kCs@6AIKsQV01EdlSkJJfsF~I;NF^#&+W4
zgFp?IAW-B6fhx!nQ1zall$DxX0&bCkn_Y;;BA7KuT8!W^DH})=*bdZLD+bm2GR$JK
IoXldf00MjuZvX%Q

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/_vendor/packaging/markers.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/_vendor/packaging/markers.py
new file mode 100644
index 0000000..031332a
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/_vendor/packaging/markers.py
@@ -0,0 +1,301 @@
+# This file is dual licensed under the terms of the Apache License, Version
+# 2.0, and the BSD License. See the LICENSE file in the root of this repository
+# for complete details.
+from __future__ import absolute_import, division, print_function
+
+import operator
+import os
+import platform
+import sys
+
+from setuptools.extern.pyparsing import ParseException, ParseResults, stringStart, stringEnd
+from setuptools.extern.pyparsing import ZeroOrMore, Group, Forward, QuotedString
+from setuptools.extern.pyparsing import Literal as L  # noqa
+
+from ._compat import string_types
+from .specifiers import Specifier, InvalidSpecifier
+
+
+__all__ = [
+    "InvalidMarker", "UndefinedComparison", "UndefinedEnvironmentName",
+    "Marker", "default_environment",
+]
+
+
+class InvalidMarker(ValueError):
+    """
+    An invalid marker was found, users should refer to PEP 508.
+    """
+
+
+class UndefinedComparison(ValueError):
+    """
+    An invalid operation was attempted on a value that doesn't support it.
+    """
+
+
+class UndefinedEnvironmentName(ValueError):
+    """
+    A name was attempted to be used that does not exist inside of the
+    environment.
+    """
+
+
+class Node(object):
+
+    def __init__(self, value):
+        self.value = value
+
+    def __str__(self):
+        return str(self.value)
+
+    def __repr__(self):
+        return "<{0}({1!r})>".format(self.__class__.__name__, str(self))
+
+    def serialize(self):
+        raise NotImplementedError
+
+
+class Variable(Node):
+
+    def serialize(self):
+        return str(self)
+
+
+class Value(Node):
+
+    def serialize(self):
+        return '"{0}"'.format(self)
+
+
+class Op(Node):
+
+    def serialize(self):
+        return str(self)
+
+
+VARIABLE = (
+    L("implementation_version") |
+    L("platform_python_implementation") |
+    L("implementation_name") |
+    L("python_full_version") |
+    L("platform_release") |
+    L("platform_version") |
+    L("platform_machine") |
+    L("platform_system") |
+    L("python_version") |
+    L("sys_platform") |
+    L("os_name") |
+    L("os.name") |  # PEP-345
+    L("sys.platform") |  # PEP-345
+    L("platform.version") |  # PEP-345
+    L("platform.machine") |  # PEP-345
+    L("platform.python_implementation") |  # PEP-345
+    L("python_implementation") |  # undocumented setuptools legacy
+    L("extra")
+)
+ALIASES = {
+    'os.name': 'os_name',
+    'sys.platform': 'sys_platform',
+    'platform.version': 'platform_version',
+    'platform.machine': 'platform_machine',
+    'platform.python_implementation': 'platform_python_implementation',
+    'python_implementation': 'platform_python_implementation'
+}
+VARIABLE.setParseAction(lambda s, l, t: Variable(ALIASES.get(t[0], t[0])))
+
+VERSION_CMP = (
+    L("===") |
+    L("==") |
+    L(">=") |
+    L("<=") |
+    L("!=") |
+    L("~=") |
+    L(">") |
+    L("<")
+)
+
+MARKER_OP = VERSION_CMP | L("not in") | L("in")
+MARKER_OP.setParseAction(lambda s, l, t: Op(t[0]))
+
+MARKER_VALUE = QuotedString("'") | QuotedString('"')
+MARKER_VALUE.setParseAction(lambda s, l, t: Value(t[0]))
+
+BOOLOP = L("and") | L("or")
+
+MARKER_VAR = VARIABLE | MARKER_VALUE
+
+MARKER_ITEM = Group(MARKER_VAR + MARKER_OP + MARKER_VAR)
+MARKER_ITEM.setParseAction(lambda s, l, t: tuple(t[0]))
+
+LPAREN = L("(").suppress()
+RPAREN = L(")").suppress()
+
+MARKER_EXPR = Forward()
+MARKER_ATOM = MARKER_ITEM | Group(LPAREN + MARKER_EXPR + RPAREN)
+MARKER_EXPR << MARKER_ATOM + ZeroOrMore(BOOLOP + MARKER_EXPR)
+
+MARKER = stringStart + MARKER_EXPR + stringEnd
+
+
+def _coerce_parse_result(results):
+    if isinstance(results, ParseResults):
+        return [_coerce_parse_result(i) for i in results]
+    else:
+        return results
+
+
+def _format_marker(marker, first=True):
+    assert isinstance(marker, (list, tuple, string_types))
+
+    # Sometimes we have a structure like [[...]] which is a single item list
+    # where the single item is itself it's own list. In that case we want skip
+    # the rest of this function so that we don't get extraneous () on the
+    # outside.
+    if (isinstance(marker, list) and len(marker) == 1 and
+            isinstance(marker[0], (list, tuple))):
+        return _format_marker(marker[0])
+
+    if isinstance(marker, list):
+        inner = (_format_marker(m, first=False) for m in marker)
+        if first:
+            return " ".join(inner)
+        else:
+            return "(" + " ".join(inner) + ")"
+    elif isinstance(marker, tuple):
+        return " ".join([m.serialize() for m in marker])
+    else:
+        return marker
+
+
+_operators = {
+    "in": lambda lhs, rhs: lhs in rhs,
+    "not in": lambda lhs, rhs: lhs not in rhs,
+    "<": operator.lt,
+    "<=": operator.le,
+    "==": operator.eq,
+    "!=": operator.ne,
+    ">=": operator.ge,
+    ">": operator.gt,
+}
+
+
+def _eval_op(lhs, op, rhs):
+    try:
+        spec = Specifier("".join([op.serialize(), rhs]))
+    except InvalidSpecifier:
+        pass
+    else:
+        return spec.contains(lhs)
+
+    oper = _operators.get(op.serialize())
+    if oper is None:
+        raise UndefinedComparison(
+            "Undefined {0!r} on {1!r} and {2!r}.".format(op, lhs, rhs)
+        )
+
+    return oper(lhs, rhs)
+
+
+_undefined = object()
+
+
+def _get_env(environment, name):
+    value = environment.get(name, _undefined)
+
+    if value is _undefined:
+        raise UndefinedEnvironmentName(
+            "{0!r} does not exist in evaluation environment.".format(name)
+        )
+
+    return value
+
+
+def _evaluate_markers(markers, environment):
+    groups = [[]]
+
+    for marker in markers:
+        assert isinstance(marker, (list, tuple, string_types))
+
+        if isinstance(marker, list):
+            groups[-1].append(_evaluate_markers(marker, environment))
+        elif isinstance(marker, tuple):
+            lhs, op, rhs = marker
+
+            if isinstance(lhs, Variable):
+                lhs_value = _get_env(environment, lhs.value)
+                rhs_value = rhs.value
+            else:
+                lhs_value = lhs.value
+                rhs_value = _get_env(environment, rhs.value)
+
+            groups[-1].append(_eval_op(lhs_value, op, rhs_value))
+        else:
+            assert marker in ["and", "or"]
+            if marker == "or":
+                groups.append([])
+
+    return any(all(item) for item in groups)
+
+
+def format_full_version(info):
+    version = '{0.major}.{0.minor}.{0.micro}'.format(info)
+    kind = info.releaselevel
+    if kind != 'final':
+        version += kind[0] + str(info.serial)
+    return version
+
+
+def default_environment():
+    if hasattr(sys, 'implementation'):
+        iver = format_full_version(sys.implementation.version)
+        implementation_name = sys.implementation.name
+    else:
+        iver = '0'
+        implementation_name = ''
+
+    return {
+        "implementation_name": implementation_name,
+        "implementation_version": iver,
+        "os_name": os.name,
+        "platform_machine": platform.machine(),
+        "platform_release": platform.release(),
+        "platform_system": platform.system(),
+        "platform_version": platform.version(),
+        "python_full_version": platform.python_version(),
+        "platform_python_implementation": platform.python_implementation(),
+        "python_version": platform.python_version()[:3],
+        "sys_platform": sys.platform,
+    }
+
+
+class Marker(object):
+
+    def __init__(self, marker):
+        try:
+            self._markers = _coerce_parse_result(MARKER.parseString(marker))
+        except ParseException as e:
+            err_str = "Invalid marker: {0!r}, parse error at {1!r}".format(
+                marker, marker[e.loc:e.loc + 8])
+            raise InvalidMarker(err_str)
+
+    def __str__(self):
+        return _format_marker(self._markers)
+
+    def __repr__(self):
+        return "<Marker({0!r})>".format(str(self))
+
+    def evaluate(self, environment=None):
+        """Evaluate a marker.
+
+        Return the boolean from evaluating the given marker against the
+        environment. environment is an optional argument to override all or
+        part of the determined environment.
+
+        The environment is determined from the current Python process.
+        """
+        current_environment = default_environment()
+        if environment is not None:
+            current_environment.update(environment)
+
+        return _evaluate_markers(self._markers, current_environment)
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/_vendor/packaging/markers.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/_vendor/packaging/markers.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..4edb10312e0e08d8484d0217644a27cd2c050423
GIT binary patch
literal 13854
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
TfxIl7f}G5p+?>*!9Gv0+Xym%I

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/_vendor/packaging/requirements.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/_vendor/packaging/requirements.py
new file mode 100644
index 0000000..5b49341
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/_vendor/packaging/requirements.py
@@ -0,0 +1,127 @@
+# This file is dual licensed under the terms of the Apache License, Version
+# 2.0, and the BSD License. See the LICENSE file in the root of this repository
+# for complete details.
+from __future__ import absolute_import, division, print_function
+
+import string
+import re
+
+from setuptools.extern.pyparsing import stringStart, stringEnd, originalTextFor, ParseException
+from setuptools.extern.pyparsing import ZeroOrMore, Word, Optional, Regex, Combine
+from setuptools.extern.pyparsing import Literal as L  # noqa
+from setuptools.extern.six.moves.urllib import parse as urlparse
+
+from .markers import MARKER_EXPR, Marker
+from .specifiers import LegacySpecifier, Specifier, SpecifierSet
+
+
+class InvalidRequirement(ValueError):
+    """
+    An invalid requirement was found, users should refer to PEP 508.
+    """
+
+
+ALPHANUM = Word(string.ascii_letters + string.digits)
+
+LBRACKET = L("[").suppress()
+RBRACKET = L("]").suppress()
+LPAREN = L("(").suppress()
+RPAREN = L(")").suppress()
+COMMA = L(",").suppress()
+SEMICOLON = L(";").suppress()
+AT = L("@").suppress()
+
+PUNCTUATION = Word("-_.")
+IDENTIFIER_END = ALPHANUM | (ZeroOrMore(PUNCTUATION) + ALPHANUM)
+IDENTIFIER = Combine(ALPHANUM + ZeroOrMore(IDENTIFIER_END))
+
+NAME = IDENTIFIER("name")
+EXTRA = IDENTIFIER
+
+URI = Regex(r'[^ ]+')("url")
+URL = (AT + URI)
+
+EXTRAS_LIST = EXTRA + ZeroOrMore(COMMA + EXTRA)
+EXTRAS = (LBRACKET + Optional(EXTRAS_LIST) + RBRACKET)("extras")
+
+VERSION_PEP440 = Regex(Specifier._regex_str, re.VERBOSE | re.IGNORECASE)
+VERSION_LEGACY = Regex(LegacySpecifier._regex_str, re.VERBOSE | re.IGNORECASE)
+
+VERSION_ONE = VERSION_PEP440 ^ VERSION_LEGACY
+VERSION_MANY = Combine(VERSION_ONE + ZeroOrMore(COMMA + VERSION_ONE),
+                       joinString=",", adjacent=False)("_raw_spec")
+_VERSION_SPEC = Optional(((LPAREN + VERSION_MANY + RPAREN) | VERSION_MANY))
+_VERSION_SPEC.setParseAction(lambda s, l, t: t._raw_spec or '')
+
+VERSION_SPEC = originalTextFor(_VERSION_SPEC)("specifier")
+VERSION_SPEC.setParseAction(lambda s, l, t: t[1])
+
+MARKER_EXPR = originalTextFor(MARKER_EXPR())("marker")
+MARKER_EXPR.setParseAction(
+    lambda s, l, t: Marker(s[t._original_start:t._original_end])
+)
+MARKER_SEPERATOR = SEMICOLON
+MARKER = MARKER_SEPERATOR + MARKER_EXPR
+
+VERSION_AND_MARKER = VERSION_SPEC + Optional(MARKER)
+URL_AND_MARKER = URL + Optional(MARKER)
+
+NAMED_REQUIREMENT = \
+    NAME + Optional(EXTRAS) + (URL_AND_MARKER | VERSION_AND_MARKER)
+
+REQUIREMENT = stringStart + NAMED_REQUIREMENT + stringEnd
+
+
+class Requirement(object):
+    """Parse a requirement.
+
+    Parse a given requirement string into its parts, such as name, specifier,
+    URL, and extras. Raises InvalidRequirement on a badly-formed requirement
+    string.
+    """
+
+    # TODO: Can we test whether something is contained within a requirement?
+    #       If so how do we do that? Do we need to test against the _name_ of
+    #       the thing as well as the version? What about the markers?
+    # TODO: Can we normalize the name and extra name?
+
+    def __init__(self, requirement_string):
+        try:
+            req = REQUIREMENT.parseString(requirement_string)
+        except ParseException as e:
+            raise InvalidRequirement(
+                "Invalid requirement, parse error at \"{0!r}\"".format(
+                    requirement_string[e.loc:e.loc + 8]))
+
+        self.name = req.name
+        if req.url:
+            parsed_url = urlparse.urlparse(req.url)
+            if not (parsed_url.scheme and parsed_url.netloc) or (
+                    not parsed_url.scheme and not parsed_url.netloc):
+                raise InvalidRequirement("Invalid URL given")
+            self.url = req.url
+        else:
+            self.url = None
+        self.extras = set(req.extras.asList() if req.extras else [])
+        self.specifier = SpecifierSet(req.specifier)
+        self.marker = req.marker if req.marker else None
+
+    def __str__(self):
+        parts = [self.name]
+
+        if self.extras:
+            parts.append("[{0}]".format(",".join(sorted(self.extras))))
+
+        if self.specifier:
+            parts.append(str(self.specifier))
+
+        if self.url:
+            parts.append("@ {0}".format(self.url))
+
+        if self.marker:
+            parts.append("; {0}".format(self.marker))
+
+        return "".join(parts)
+
+    def __repr__(self):
+        return "<Requirement({0!r})>".format(str(self))
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/_vendor/packaging/requirements.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/_vendor/packaging/requirements.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..0e046d3cc03434ae7bf1294011b5d56f62043fb2
GIT binary patch
literal 5650
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
SHbyQc5Eft*V3uIwV+H`NE(+WL

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/_vendor/packaging/specifiers.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/_vendor/packaging/specifiers.py
new file mode 100644
index 0000000..7f5a76c
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/_vendor/packaging/specifiers.py
@@ -0,0 +1,774 @@
+# This file is dual licensed under the terms of the Apache License, Version
+# 2.0, and the BSD License. See the LICENSE file in the root of this repository
+# for complete details.
+from __future__ import absolute_import, division, print_function
+
+import abc
+import functools
+import itertools
+import re
+
+from ._compat import string_types, with_metaclass
+from .version import Version, LegacyVersion, parse
+
+
+class InvalidSpecifier(ValueError):
+    """
+    An invalid specifier was found, users should refer to PEP 440.
+    """
+
+
+class BaseSpecifier(with_metaclass(abc.ABCMeta, object)):
+
+    @abc.abstractmethod
+    def __str__(self):
+        """
+        Returns the str representation of this Specifier like object. This
+        should be representative of the Specifier itself.
+        """
+
+    @abc.abstractmethod
+    def __hash__(self):
+        """
+        Returns a hash value for this Specifier like object.
+        """
+
+    @abc.abstractmethod
+    def __eq__(self, other):
+        """
+        Returns a boolean representing whether or not the two Specifier like
+        objects are equal.
+        """
+
+    @abc.abstractmethod
+    def __ne__(self, other):
+        """
+        Returns a boolean representing whether or not the two Specifier like
+        objects are not equal.
+        """
+
+    @abc.abstractproperty
+    def prereleases(self):
+        """
+        Returns whether or not pre-releases as a whole are allowed by this
+        specifier.
+        """
+
+    @prereleases.setter
+    def prereleases(self, value):
+        """
+        Sets whether or not pre-releases as a whole are allowed by this
+        specifier.
+        """
+
+    @abc.abstractmethod
+    def contains(self, item, prereleases=None):
+        """
+        Determines if the given item is contained within this specifier.
+        """
+
+    @abc.abstractmethod
+    def filter(self, iterable, prereleases=None):
+        """
+        Takes an iterable of items and filters them so that only items which
+        are contained within this specifier are allowed in it.
+        """
+
+
+class _IndividualSpecifier(BaseSpecifier):
+
+    _operators = {}
+
+    def __init__(self, spec="", prereleases=None):
+        match = self._regex.search(spec)
+        if not match:
+            raise InvalidSpecifier("Invalid specifier: '{0}'".format(spec))
+
+        self._spec = (
+            match.group("operator").strip(),
+            match.group("version").strip(),
+        )
+
+        # Store whether or not this Specifier should accept prereleases
+        self._prereleases = prereleases
+
+    def __repr__(self):
+        pre = (
+            ", prereleases={0!r}".format(self.prereleases)
+            if self._prereleases is not None
+            else ""
+        )
+
+        return "<{0}({1!r}{2})>".format(
+            self.__class__.__name__,
+            str(self),
+            pre,
+        )
+
+    def __str__(self):
+        return "{0}{1}".format(*self._spec)
+
+    def __hash__(self):
+        return hash(self._spec)
+
+    def __eq__(self, other):
+        if isinstance(other, string_types):
+            try:
+                other = self.__class__(other)
+            except InvalidSpecifier:
+                return NotImplemented
+        elif not isinstance(other, self.__class__):
+            return NotImplemented
+
+        return self._spec == other._spec
+
+    def __ne__(self, other):
+        if isinstance(other, string_types):
+            try:
+                other = self.__class__(other)
+            except InvalidSpecifier:
+                return NotImplemented
+        elif not isinstance(other, self.__class__):
+            return NotImplemented
+
+        return self._spec != other._spec
+
+    def _get_operator(self, op):
+        return getattr(self, "_compare_{0}".format(self._operators[op]))
+
+    def _coerce_version(self, version):
+        if not isinstance(version, (LegacyVersion, Version)):
+            version = parse(version)
+        return version
+
+    @property
+    def operator(self):
+        return self._spec[0]
+
+    @property
+    def version(self):
+        return self._spec[1]
+
+    @property
+    def prereleases(self):
+        return self._prereleases
+
+    @prereleases.setter
+    def prereleases(self, value):
+        self._prereleases = value
+
+    def __contains__(self, item):
+        return self.contains(item)
+
+    def contains(self, item, prereleases=None):
+        # Determine if prereleases are to be allowed or not.
+        if prereleases is None:
+            prereleases = self.prereleases
+
+        # Normalize item to a Version or LegacyVersion, this allows us to have
+        # a shortcut for ``"2.0" in Specifier(">=2")
+        item = self._coerce_version(item)
+
+        # Determine if we should be supporting prereleases in this specifier
+        # or not, if we do not support prereleases than we can short circuit
+        # logic if this version is a prereleases.
+        if item.is_prerelease and not prereleases:
+            return False
+
+        # Actually do the comparison to determine if this item is contained
+        # within this Specifier or not.
+        return self._get_operator(self.operator)(item, self.version)
+
+    def filter(self, iterable, prereleases=None):
+        yielded = False
+        found_prereleases = []
+
+        kw = {"prereleases": prereleases if prereleases is not None else True}
+
+        # Attempt to iterate over all the values in the iterable and if any of
+        # them match, yield them.
+        for version in iterable:
+            parsed_version = self._coerce_version(version)
+
+            if self.contains(parsed_version, **kw):
+                # If our version is a prerelease, and we were not set to allow
+                # prereleases, then we'll store it for later incase nothing
+                # else matches this specifier.
+                if (parsed_version.is_prerelease and not
+                        (prereleases or self.prereleases)):
+                    found_prereleases.append(version)
+                # Either this is not a prerelease, or we should have been
+                # accepting prereleases from the begining.
+                else:
+                    yielded = True
+                    yield version
+
+        # Now that we've iterated over everything, determine if we've yielded
+        # any values, and if we have not and we have any prereleases stored up
+        # then we will go ahead and yield the prereleases.
+        if not yielded and found_prereleases:
+            for version in found_prereleases:
+                yield version
+
+
+class LegacySpecifier(_IndividualSpecifier):
+
+    _regex_str = (
+        r"""
+        (?P<operator>(==|!=|<=|>=|<|>))
+        \s*
+        (?P<version>
+            [^,;\s)]* # Since this is a "legacy" specifier, and the version
+                      # string can be just about anything, we match everything
+                      # except for whitespace, a semi-colon for marker support,
+                      # a closing paren since versions can be enclosed in
+                      # them, and a comma since it's a version separator.
+        )
+        """
+    )
+
+    _regex = re.compile(
+        r"^\s*" + _regex_str + r"\s*$", re.VERBOSE | re.IGNORECASE)
+
+    _operators = {
+        "==": "equal",
+        "!=": "not_equal",
+        "<=": "less_than_equal",
+        ">=": "greater_than_equal",
+        "<": "less_than",
+        ">": "greater_than",
+    }
+
+    def _coerce_version(self, version):
+        if not isinstance(version, LegacyVersion):
+            version = LegacyVersion(str(version))
+        return version
+
+    def _compare_equal(self, prospective, spec):
+        return prospective == self._coerce_version(spec)
+
+    def _compare_not_equal(self, prospective, spec):
+        return prospective != self._coerce_version(spec)
+
+    def _compare_less_than_equal(self, prospective, spec):
+        return prospective <= self._coerce_version(spec)
+
+    def _compare_greater_than_equal(self, prospective, spec):
+        return prospective >= self._coerce_version(spec)
+
+    def _compare_less_than(self, prospective, spec):
+        return prospective < self._coerce_version(spec)
+
+    def _compare_greater_than(self, prospective, spec):
+        return prospective > self._coerce_version(spec)
+
+
+def _require_version_compare(fn):
+    @functools.wraps(fn)
+    def wrapped(self, prospective, spec):
+        if not isinstance(prospective, Version):
+            return False
+        return fn(self, prospective, spec)
+    return wrapped
+
+
+class Specifier(_IndividualSpecifier):
+
+    _regex_str = (
+        r"""
+        (?P<operator>(~=|==|!=|<=|>=|<|>|===))
+        (?P<version>
+            (?:
+                # The identity operators allow for an escape hatch that will
+                # do an exact string match of the version you wish to install.
+                # This will not be parsed by PEP 440 and we cannot determine
+                # any semantic meaning from it. This operator is discouraged
+                # but included entirely as an escape hatch.
+                (?<====)  # Only match for the identity operator
+                \s*
+                [^\s]*    # We just match everything, except for whitespace
+                          # since we are only testing for strict identity.
+            )
+            |
+            (?:
+                # The (non)equality operators allow for wild card and local
+                # versions to be specified so we have to define these two
+                # operators separately to enable that.
+                (?<===|!=)            # Only match for equals and not equals
+
+                \s*
+                v?
+                (?:[0-9]+!)?          # epoch
+                [0-9]+(?:\.[0-9]+)*   # release
+                (?:                   # pre release
+                    [-_\.]?
+                    (a|b|c|rc|alpha|beta|pre|preview)
+                    [-_\.]?
+                    [0-9]*
+                )?
+                (?:                   # post release
+                    (?:-[0-9]+)|(?:[-_\.]?(post|rev|r)[-_\.]?[0-9]*)
+                )?
+
+                # You cannot use a wild card and a dev or local version
+                # together so group them with a | and make them optional.
+                (?:
+                    (?:[-_\.]?dev[-_\.]?[0-9]*)?         # dev release
+                    (?:\+[a-z0-9]+(?:[-_\.][a-z0-9]+)*)? # local
+                    |
+                    \.\*  # Wild card syntax of .*
+                )?
+            )
+            |
+            (?:
+                # The compatible operator requires at least two digits in the
+                # release segment.
+                (?<=~=)               # Only match for the compatible operator
+
+                \s*
+                v?
+                (?:[0-9]+!)?          # epoch
+                [0-9]+(?:\.[0-9]+)+   # release  (We have a + instead of a *)
+                (?:                   # pre release
+                    [-_\.]?
+                    (a|b|c|rc|alpha|beta|pre|preview)
+                    [-_\.]?
+                    [0-9]*
+                )?
+                (?:                                   # post release
+                    (?:-[0-9]+)|(?:[-_\.]?(post|rev|r)[-_\.]?[0-9]*)
+                )?
+                (?:[-_\.]?dev[-_\.]?[0-9]*)?          # dev release
+            )
+            |
+            (?:
+                # All other operators only allow a sub set of what the
+                # (non)equality operators do. Specifically they do not allow
+                # local versions to be specified nor do they allow the prefix
+                # matching wild cards.
+                (?<!==|!=|~=)         # We have special cases for these
+                                      # operators so we want to make sure they
+                                      # don't match here.
+
+                \s*
+                v?
+                (?:[0-9]+!)?          # epoch
+                [0-9]+(?:\.[0-9]+)*   # release
+                (?:                   # pre release
+                    [-_\.]?
+                    (a|b|c|rc|alpha|beta|pre|preview)
+                    [-_\.]?
+                    [0-9]*
+                )?
+                (?:                                   # post release
+                    (?:-[0-9]+)|(?:[-_\.]?(post|rev|r)[-_\.]?[0-9]*)
+                )?
+                (?:[-_\.]?dev[-_\.]?[0-9]*)?          # dev release
+            )
+        )
+        """
+    )
+
+    _regex = re.compile(
+        r"^\s*" + _regex_str + r"\s*$", re.VERBOSE | re.IGNORECASE)
+
+    _operators = {
+        "~=": "compatible",
+        "==": "equal",
+        "!=": "not_equal",
+        "<=": "less_than_equal",
+        ">=": "greater_than_equal",
+        "<": "less_than",
+        ">": "greater_than",
+        "===": "arbitrary",
+    }
+
+    @_require_version_compare
+    def _compare_compatible(self, prospective, spec):
+        # Compatible releases have an equivalent combination of >= and ==. That
+        # is that ~=2.2 is equivalent to >=2.2,==2.*. This allows us to
+        # implement this in terms of the other specifiers instead of
+        # implementing it ourselves. The only thing we need to do is construct
+        # the other specifiers.
+
+        # We want everything but the last item in the version, but we want to
+        # ignore post and dev releases and we want to treat the pre-release as
+        # it's own separate segment.
+        prefix = ".".join(
+            list(
+                itertools.takewhile(
+                    lambda x: (not x.startswith("post") and not
+                               x.startswith("dev")),
+                    _version_split(spec),
+                )
+            )[:-1]
+        )
+
+        # Add the prefix notation to the end of our string
+        prefix += ".*"
+
+        return (self._get_operator(">=")(prospective, spec) and
+                self._get_operator("==")(prospective, prefix))
+
+    @_require_version_compare
+    def _compare_equal(self, prospective, spec):
+        # We need special logic to handle prefix matching
+        if spec.endswith(".*"):
+            # In the case of prefix matching we want to ignore local segment.
+            prospective = Version(prospective.public)
+            # Split the spec out by dots, and pretend that there is an implicit
+            # dot in between a release segment and a pre-release segment.
+            spec = _version_split(spec[:-2])  # Remove the trailing .*
+
+            # Split the prospective version out by dots, and pretend that there
+            # is an implicit dot in between a release segment and a pre-release
+            # segment.
+            prospective = _version_split(str(prospective))
+
+            # Shorten the prospective version to be the same length as the spec
+            # so that we can determine if the specifier is a prefix of the
+            # prospective version or not.
+            prospective = prospective[:len(spec)]
+
+            # Pad out our two sides with zeros so that they both equal the same
+            # length.
+            spec, prospective = _pad_version(spec, prospective)
+        else:
+            # Convert our spec string into a Version
+            spec = Version(spec)
+
+            # If the specifier does not have a local segment, then we want to
+            # act as if the prospective version also does not have a local
+            # segment.
+            if not spec.local:
+                prospective = Version(prospective.public)
+
+        return prospective == spec
+
+    @_require_version_compare
+    def _compare_not_equal(self, prospective, spec):
+        return not self._compare_equal(prospective, spec)
+
+    @_require_version_compare
+    def _compare_less_than_equal(self, prospective, spec):
+        return prospective <= Version(spec)
+
+    @_require_version_compare
+    def _compare_greater_than_equal(self, prospective, spec):
+        return prospective >= Version(spec)
+
+    @_require_version_compare
+    def _compare_less_than(self, prospective, spec):
+        # Convert our spec to a Version instance, since we'll want to work with
+        # it as a version.
+        spec = Version(spec)
+
+        # Check to see if the prospective version is less than the spec
+        # version. If it's not we can short circuit and just return False now
+        # instead of doing extra unneeded work.
+        if not prospective < spec:
+            return False
+
+        # This special case is here so that, unless the specifier itself
+        # includes is a pre-release version, that we do not accept pre-release
+        # versions for the version mentioned in the specifier (e.g. <3.1 should
+        # not match 3.1.dev0, but should match 3.0.dev0).
+        if not spec.is_prerelease and prospective.is_prerelease:
+            if Version(prospective.base_version) == Version(spec.base_version):
+                return False
+
+        # If we've gotten to here, it means that prospective version is both
+        # less than the spec version *and* it's not a pre-release of the same
+        # version in the spec.
+        return True
+
+    @_require_version_compare
+    def _compare_greater_than(self, prospective, spec):
+        # Convert our spec to a Version instance, since we'll want to work with
+        # it as a version.
+        spec = Version(spec)
+
+        # Check to see if the prospective version is greater than the spec
+        # version. If it's not we can short circuit and just return False now
+        # instead of doing extra unneeded work.
+        if not prospective > spec:
+            return False
+
+        # This special case is here so that, unless the specifier itself
+        # includes is a post-release version, that we do not accept
+        # post-release versions for the version mentioned in the specifier
+        # (e.g. >3.1 should not match 3.0.post0, but should match 3.2.post0).
+        if not spec.is_postrelease and prospective.is_postrelease:
+            if Version(prospective.base_version) == Version(spec.base_version):
+                return False
+
+        # Ensure that we do not allow a local version of the version mentioned
+        # in the specifier, which is techincally greater than, to match.
+        if prospective.local is not None:
+            if Version(prospective.base_version) == Version(spec.base_version):
+                return False
+
+        # If we've gotten to here, it means that prospective version is both
+        # greater than the spec version *and* it's not a pre-release of the
+        # same version in the spec.
+        return True
+
+    def _compare_arbitrary(self, prospective, spec):
+        return str(prospective).lower() == str(spec).lower()
+
+    @property
+    def prereleases(self):
+        # If there is an explicit prereleases set for this, then we'll just
+        # blindly use that.
+        if self._prereleases is not None:
+            return self._prereleases
+
+        # Look at all of our specifiers and determine if they are inclusive
+        # operators, and if they are if they are including an explicit
+        # prerelease.
+        operator, version = self._spec
+        if operator in ["==", ">=", "<=", "~=", "==="]:
+            # The == specifier can include a trailing .*, if it does we
+            # want to remove before parsing.
+            if operator == "==" and version.endswith(".*"):
+                version = version[:-2]
+
+            # Parse the version, and if it is a pre-release than this
+            # specifier allows pre-releases.
+            if parse(version).is_prerelease:
+                return True
+
+        return False
+
+    @prereleases.setter
+    def prereleases(self, value):
+        self._prereleases = value
+
+
+_prefix_regex = re.compile(r"^([0-9]+)((?:a|b|c|rc)[0-9]+)$")
+
+
+def _version_split(version):
+    result = []
+    for item in version.split("."):
+        match = _prefix_regex.search(item)
+        if match:
+            result.extend(match.groups())
+        else:
+            result.append(item)
+    return result
+
+
+def _pad_version(left, right):
+    left_split, right_split = [], []
+
+    # Get the release segment of our versions
+    left_split.append(list(itertools.takewhile(lambda x: x.isdigit(), left)))
+    right_split.append(list(itertools.takewhile(lambda x: x.isdigit(), right)))
+
+    # Get the rest of our versions
+    left_split.append(left[len(left_split[0]):])
+    right_split.append(right[len(right_split[0]):])
+
+    # Insert our padding
+    left_split.insert(
+        1,
+        ["0"] * max(0, len(right_split[0]) - len(left_split[0])),
+    )
+    right_split.insert(
+        1,
+        ["0"] * max(0, len(left_split[0]) - len(right_split[0])),
+    )
+
+    return (
+        list(itertools.chain(*left_split)),
+        list(itertools.chain(*right_split)),
+    )
+
+
+class SpecifierSet(BaseSpecifier):
+
+    def __init__(self, specifiers="", prereleases=None):
+        # Split on , to break each indidivual specifier into it's own item, and
+        # strip each item to remove leading/trailing whitespace.
+        specifiers = [s.strip() for s in specifiers.split(",") if s.strip()]
+
+        # Parsed each individual specifier, attempting first to make it a
+        # Specifier and falling back to a LegacySpecifier.
+        parsed = set()
+        for specifier in specifiers:
+            try:
+                parsed.add(Specifier(specifier))
+            except InvalidSpecifier:
+                parsed.add(LegacySpecifier(specifier))
+
+        # Turn our parsed specifiers into a frozen set and save them for later.
+        self._specs = frozenset(parsed)
+
+        # Store our prereleases value so we can use it later to determine if
+        # we accept prereleases or not.
+        self._prereleases = prereleases
+
+    def __repr__(self):
+        pre = (
+            ", prereleases={0!r}".format(self.prereleases)
+            if self._prereleases is not None
+            else ""
+        )
+
+        return "<SpecifierSet({0!r}{1})>".format(str(self), pre)
+
+    def __str__(self):
+        return ",".join(sorted(str(s) for s in self._specs))
+
+    def __hash__(self):
+        return hash(self._specs)
+
+    def __and__(self, other):
+        if isinstance(other, string_types):
+            other = SpecifierSet(other)
+        elif not isinstance(other, SpecifierSet):
+            return NotImplemented
+
+        specifier = SpecifierSet()
+        specifier._specs = frozenset(self._specs | other._specs)
+
+        if self._prereleases is None and other._prereleases is not None:
+            specifier._prereleases = other._prereleases
+        elif self._prereleases is not None and other._prereleases is None:
+            specifier._prereleases = self._prereleases
+        elif self._prereleases == other._prereleases:
+            specifier._prereleases = self._prereleases
+        else:
+            raise ValueError(
+                "Cannot combine SpecifierSets with True and False prerelease "
+                "overrides."
+            )
+
+        return specifier
+
+    def __eq__(self, other):
+        if isinstance(other, string_types):
+            other = SpecifierSet(other)
+        elif isinstance(other, _IndividualSpecifier):
+            other = SpecifierSet(str(other))
+        elif not isinstance(other, SpecifierSet):
+            return NotImplemented
+
+        return self._specs == other._specs
+
+    def __ne__(self, other):
+        if isinstance(other, string_types):
+            other = SpecifierSet(other)
+        elif isinstance(other, _IndividualSpecifier):
+            other = SpecifierSet(str(other))
+        elif not isinstance(other, SpecifierSet):
+            return NotImplemented
+
+        return self._specs != other._specs
+
+    def __len__(self):
+        return len(self._specs)
+
+    def __iter__(self):
+        return iter(self._specs)
+
+    @property
+    def prereleases(self):
+        # If we have been given an explicit prerelease modifier, then we'll
+        # pass that through here.
+        if self._prereleases is not None:
+            return self._prereleases
+
+        # If we don't have any specifiers, and we don't have a forced value,
+        # then we'll just return None since we don't know if this should have
+        # pre-releases or not.
+        if not self._specs:
+            return None
+
+        # Otherwise we'll see if any of the given specifiers accept
+        # prereleases, if any of them do we'll return True, otherwise False.
+        return any(s.prereleases for s in self._specs)
+
+    @prereleases.setter
+    def prereleases(self, value):
+        self._prereleases = value
+
+    def __contains__(self, item):
+        return self.contains(item)
+
+    def contains(self, item, prereleases=None):
+        # Ensure that our item is a Version or LegacyVersion instance.
+        if not isinstance(item, (LegacyVersion, Version)):
+            item = parse(item)
+
+        # Determine if we're forcing a prerelease or not, if we're not forcing
+        # one for this particular filter call, then we'll use whatever the
+        # SpecifierSet thinks for whether or not we should support prereleases.
+        if prereleases is None:
+            prereleases = self.prereleases
+
+        # We can determine if we're going to allow pre-releases by looking to
+        # see if any of the underlying items supports them. If none of them do
+        # and this item is a pre-release then we do not allow it and we can
+        # short circuit that here.
+        # Note: This means that 1.0.dev1 would not be contained in something
+        #       like >=1.0.devabc however it would be in >=1.0.debabc,>0.0.dev0
+        if not prereleases and item.is_prerelease:
+            return False
+
+        # We simply dispatch to the underlying specs here to make sure that the
+        # given version is contained within all of them.
+        # Note: This use of all() here means that an empty set of specifiers
+        #       will always return True, this is an explicit design decision.
+        return all(
+            s.contains(item, prereleases=prereleases)
+            for s in self._specs
+        )
+
+    def filter(self, iterable, prereleases=None):
+        # Determine if we're forcing a prerelease or not, if we're not forcing
+        # one for this particular filter call, then we'll use whatever the
+        # SpecifierSet thinks for whether or not we should support prereleases.
+        if prereleases is None:
+            prereleases = self.prereleases
+
+        # If we have any specifiers, then we want to wrap our iterable in the
+        # filter method for each one, this will act as a logical AND amongst
+        # each specifier.
+        if self._specs:
+            for spec in self._specs:
+                iterable = spec.filter(iterable, prereleases=bool(prereleases))
+            return iterable
+        # If we do not have any specifiers, then we need to have a rough filter
+        # which will filter out any pre-releases, unless there are no final
+        # releases, and which will filter out LegacyVersion in general.
+        else:
+            filtered = []
+            found_prereleases = []
+
+            for item in iterable:
+                # Ensure that we some kind of Version class for this item.
+                if not isinstance(item, (LegacyVersion, Version)):
+                    parsed_version = parse(item)
+                else:
+                    parsed_version = item
+
+                # Filter out any item which is parsed as a LegacyVersion
+                if isinstance(parsed_version, LegacyVersion):
+                    continue
+
+                # Store any item which is a pre-release for later unless we've
+                # already found a final version or we are accepting prereleases
+                if parsed_version.is_prerelease and not prereleases:
+                    if not filtered:
+                        found_prereleases.append(item)
+                else:
+                    filtered.append(item)
+
+            # If we've found no items except for pre-releases, then we'll go
+            # ahead and use the pre-releases
+            if not filtered and found_prereleases and prereleases is None:
+                return found_prereleases
+
+            return filtered
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/_vendor/packaging/specifiers.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/_vendor/packaging/specifiers.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..42ba243a02b9930fd6b41da30d44114df38ac778
GIT binary patch
literal 29161
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
E0KvGF^#A|>

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/_vendor/packaging/utils.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/_vendor/packaging/utils.py
new file mode 100644
index 0000000..942387c
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/_vendor/packaging/utils.py
@@ -0,0 +1,14 @@
+# This file is dual licensed under the terms of the Apache License, Version
+# 2.0, and the BSD License. See the LICENSE file in the root of this repository
+# for complete details.
+from __future__ import absolute_import, division, print_function
+
+import re
+
+
+_canonicalize_regex = re.compile(r"[-_.]+")
+
+
+def canonicalize_name(name):
+    # This is taken from PEP 503.
+    return _canonicalize_regex.sub("-", name).lower()
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/_vendor/packaging/utils.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/_vendor/packaging/utils.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..21a92c276ac900b80963de590e2b43ccfcd2d797
GIT binary patch
literal 702
zcmZSn%**AGdLky70ScHH7#JK97#WIP7#J8*7#LC*8FCmHav2$-7#VVz7^0XMa+w*T
zm>C#Ba!d?4EDTXB45=&(S*#2x%nZ$p3{h+hDJ%>v3=C213@J<u!5XX#3=Ekd(>0hG
z7#K?U85kH6lZx|mN=s7XGjj{_i%Lp3Kz3!8Wfo`V=auj=FfbGpW#*N{r<LX<mt^MW
z`4zJ<Ffc^x#_PpuCo?iIFn}<~FlUfM#XzPqFk~@;+*-rH(9Fb;#l+Cez!0nf@{C^z
zNVP7+a$yDrhWO;fy!^b(<iwoJs?_+R)b!Mf5|ClVrAZ|qx8~%Rrxs~|G?lP0FfimL
z=B8?Zoev_4YZw?9^b3kI%Mwdc^~(~A^waWlQc{bG^^;Qc%afAwa!qrKjSQ2_)2q@g
zOfAZDvZ~AsKp;I&KSaMEvp_d9uec;JCr8(<%)`?-K)*P(q_m(UKR>4!nHgV}nwOGa
zq+gJjoSm4SnU}6#T9TPltXEK3BFMnNfZ_v?19=!27>Yr@Wnj_(1!f5s$fNOTr6r|B
zsqyhaAg2d`yc7gdR01N3QcKuDM&;)gWagv>fxH?7(u(jam^JVo206+mH$SB`C)Ez*
ON^oM3Vd7!tX9fU>x2#hD

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/_vendor/packaging/version.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/_vendor/packaging/version.py
new file mode 100644
index 0000000..83b5ee8
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/_vendor/packaging/version.py
@@ -0,0 +1,393 @@
+# This file is dual licensed under the terms of the Apache License, Version
+# 2.0, and the BSD License. See the LICENSE file in the root of this repository
+# for complete details.
+from __future__ import absolute_import, division, print_function
+
+import collections
+import itertools
+import re
+
+from ._structures import Infinity
+
+
+__all__ = [
+    "parse", "Version", "LegacyVersion", "InvalidVersion", "VERSION_PATTERN"
+]
+
+
+_Version = collections.namedtuple(
+    "_Version",
+    ["epoch", "release", "dev", "pre", "post", "local"],
+)
+
+
+def parse(version):
+    """
+    Parse the given version string and return either a :class:`Version` object
+    or a :class:`LegacyVersion` object depending on if the given version is
+    a valid PEP 440 version or a legacy version.
+    """
+    try:
+        return Version(version)
+    except InvalidVersion:
+        return LegacyVersion(version)
+
+
+class InvalidVersion(ValueError):
+    """
+    An invalid version was found, users should refer to PEP 440.
+    """
+
+
+class _BaseVersion(object):
+
+    def __hash__(self):
+        return hash(self._key)
+
+    def __lt__(self, other):
+        return self._compare(other, lambda s, o: s < o)
+
+    def __le__(self, other):
+        return self._compare(other, lambda s, o: s <= o)
+
+    def __eq__(self, other):
+        return self._compare(other, lambda s, o: s == o)
+
+    def __ge__(self, other):
+        return self._compare(other, lambda s, o: s >= o)
+
+    def __gt__(self, other):
+        return self._compare(other, lambda s, o: s > o)
+
+    def __ne__(self, other):
+        return self._compare(other, lambda s, o: s != o)
+
+    def _compare(self, other, method):
+        if not isinstance(other, _BaseVersion):
+            return NotImplemented
+
+        return method(self._key, other._key)
+
+
+class LegacyVersion(_BaseVersion):
+
+    def __init__(self, version):
+        self._version = str(version)
+        self._key = _legacy_cmpkey(self._version)
+
+    def __str__(self):
+        return self._version
+
+    def __repr__(self):
+        return "<LegacyVersion({0})>".format(repr(str(self)))
+
+    @property
+    def public(self):
+        return self._version
+
+    @property
+    def base_version(self):
+        return self._version
+
+    @property
+    def local(self):
+        return None
+
+    @property
+    def is_prerelease(self):
+        return False
+
+    @property
+    def is_postrelease(self):
+        return False
+
+
+_legacy_version_component_re = re.compile(
+    r"(\d+ | [a-z]+ | \.| -)", re.VERBOSE,
+)
+
+_legacy_version_replacement_map = {
+    "pre": "c", "preview": "c", "-": "final-", "rc": "c", "dev": "@",
+}
+
+
+def _parse_version_parts(s):
+    for part in _legacy_version_component_re.split(s):
+        part = _legacy_version_replacement_map.get(part, part)
+
+        if not part or part == ".":
+            continue
+
+        if part[:1] in "0123456789":
+            # pad for numeric comparison
+            yield part.zfill(8)
+        else:
+            yield "*" + part
+
+    # ensure that alpha/beta/candidate are before final
+    yield "*final"
+
+
+def _legacy_cmpkey(version):
+    # We hardcode an epoch of -1 here. A PEP 440 version can only have a epoch
+    # greater than or equal to 0. This will effectively put the LegacyVersion,
+    # which uses the defacto standard originally implemented by setuptools,
+    # as before all PEP 440 versions.
+    epoch = -1
+
+    # This scheme is taken from pkg_resources.parse_version setuptools prior to
+    # it's adoption of the packaging library.
+    parts = []
+    for part in _parse_version_parts(version.lower()):
+        if part.startswith("*"):
+            # remove "-" before a prerelease tag
+            if part < "*final":
+                while parts and parts[-1] == "*final-":
+                    parts.pop()
+
+            # remove trailing zeros from each series of numeric parts
+            while parts and parts[-1] == "00000000":
+                parts.pop()
+
+        parts.append(part)
+    parts = tuple(parts)
+
+    return epoch, parts
+
+# Deliberately not anchored to the start and end of the string, to make it
+# easier for 3rd party code to reuse
+VERSION_PATTERN = r"""
+    v?
+    (?:
+        (?:(?P<epoch>[0-9]+)!)?                           # epoch
+        (?P<release>[0-9]+(?:\.[0-9]+)*)                  # release segment
+        (?P<pre>                                          # pre-release
+            [-_\.]?
+            (?P<pre_l>(a|b|c|rc|alpha|beta|pre|preview))
+            [-_\.]?
+            (?P<pre_n>[0-9]+)?
+        )?
+        (?P<post>                                         # post release
+            (?:-(?P<post_n1>[0-9]+))
+            |
+            (?:
+                [-_\.]?
+                (?P<post_l>post|rev|r)
+                [-_\.]?
+                (?P<post_n2>[0-9]+)?
+            )
+        )?
+        (?P<dev>                                          # dev release
+            [-_\.]?
+            (?P<dev_l>dev)
+            [-_\.]?
+            (?P<dev_n>[0-9]+)?
+        )?
+    )
+    (?:\+(?P<local>[a-z0-9]+(?:[-_\.][a-z0-9]+)*))?       # local version
+"""
+
+
+class Version(_BaseVersion):
+
+    _regex = re.compile(
+        r"^\s*" + VERSION_PATTERN + r"\s*$",
+        re.VERBOSE | re.IGNORECASE,
+    )
+
+    def __init__(self, version):
+        # Validate the version and parse it into pieces
+        match = self._regex.search(version)
+        if not match:
+            raise InvalidVersion("Invalid version: '{0}'".format(version))
+
+        # Store the parsed out pieces of the version
+        self._version = _Version(
+            epoch=int(match.group("epoch")) if match.group("epoch") else 0,
+            release=tuple(int(i) for i in match.group("release").split(".")),
+            pre=_parse_letter_version(
+                match.group("pre_l"),
+                match.group("pre_n"),
+            ),
+            post=_parse_letter_version(
+                match.group("post_l"),
+                match.group("post_n1") or match.group("post_n2"),
+            ),
+            dev=_parse_letter_version(
+                match.group("dev_l"),
+                match.group("dev_n"),
+            ),
+            local=_parse_local_version(match.group("local")),
+        )
+
+        # Generate a key which will be used for sorting
+        self._key = _cmpkey(
+            self._version.epoch,
+            self._version.release,
+            self._version.pre,
+            self._version.post,
+            self._version.dev,
+            self._version.local,
+        )
+
+    def __repr__(self):
+        return "<Version({0})>".format(repr(str(self)))
+
+    def __str__(self):
+        parts = []
+
+        # Epoch
+        if self._version.epoch != 0:
+            parts.append("{0}!".format(self._version.epoch))
+
+        # Release segment
+        parts.append(".".join(str(x) for x in self._version.release))
+
+        # Pre-release
+        if self._version.pre is not None:
+            parts.append("".join(str(x) for x in self._version.pre))
+
+        # Post-release
+        if self._version.post is not None:
+            parts.append(".post{0}".format(self._version.post[1]))
+
+        # Development release
+        if self._version.dev is not None:
+            parts.append(".dev{0}".format(self._version.dev[1]))
+
+        # Local version segment
+        if self._version.local is not None:
+            parts.append(
+                "+{0}".format(".".join(str(x) for x in self._version.local))
+            )
+
+        return "".join(parts)
+
+    @property
+    def public(self):
+        return str(self).split("+", 1)[0]
+
+    @property
+    def base_version(self):
+        parts = []
+
+        # Epoch
+        if self._version.epoch != 0:
+            parts.append("{0}!".format(self._version.epoch))
+
+        # Release segment
+        parts.append(".".join(str(x) for x in self._version.release))
+
+        return "".join(parts)
+
+    @property
+    def local(self):
+        version_string = str(self)
+        if "+" in version_string:
+            return version_string.split("+", 1)[1]
+
+    @property
+    def is_prerelease(self):
+        return bool(self._version.dev or self._version.pre)
+
+    @property
+    def is_postrelease(self):
+        return bool(self._version.post)
+
+
+def _parse_letter_version(letter, number):
+    if letter:
+        # We consider there to be an implicit 0 in a pre-release if there is
+        # not a numeral associated with it.
+        if number is None:
+            number = 0
+
+        # We normalize any letters to their lower case form
+        letter = letter.lower()
+
+        # We consider some words to be alternate spellings of other words and
+        # in those cases we want to normalize the spellings to our preferred
+        # spelling.
+        if letter == "alpha":
+            letter = "a"
+        elif letter == "beta":
+            letter = "b"
+        elif letter in ["c", "pre", "preview"]:
+            letter = "rc"
+        elif letter in ["rev", "r"]:
+            letter = "post"
+
+        return letter, int(number)
+    if not letter and number:
+        # We assume if we are given a number, but we are not given a letter
+        # then this is using the implicit post release syntax (e.g. 1.0-1)
+        letter = "post"
+
+        return letter, int(number)
+
+
+_local_version_seperators = re.compile(r"[\._-]")
+
+
+def _parse_local_version(local):
+    """
+    Takes a string like abc.1.twelve and turns it into ("abc", 1, "twelve").
+    """
+    if local is not None:
+        return tuple(
+            part.lower() if not part.isdigit() else int(part)
+            for part in _local_version_seperators.split(local)
+        )
+
+
+def _cmpkey(epoch, release, pre, post, dev, local):
+    # When we compare a release version, we want to compare it with all of the
+    # trailing zeros removed. So we'll use a reverse the list, drop all the now
+    # leading zeros until we come to something non zero, then take the rest
+    # re-reverse it back into the correct order and make it a tuple and use
+    # that for our sorting key.
+    release = tuple(
+        reversed(list(
+            itertools.dropwhile(
+                lambda x: x == 0,
+                reversed(release),
+            )
+        ))
+    )
+
+    # We need to "trick" the sorting algorithm to put 1.0.dev0 before 1.0a0.
+    # We'll do this by abusing the pre segment, but we _only_ want to do this
+    # if there is not a pre or a post segment. If we have one of those then
+    # the normal sorting rules will handle this case correctly.
+    if pre is None and post is None and dev is not None:
+        pre = -Infinity
+    # Versions without a pre-release (except as noted above) should sort after
+    # those with one.
+    elif pre is None:
+        pre = Infinity
+
+    # Versions without a post segment should sort before those with one.
+    if post is None:
+        post = -Infinity
+
+    # Versions without a development segment should sort after those with one.
+    if dev is None:
+        dev = Infinity
+
+    if local is None:
+        # Versions without a local segment should sort before those with one.
+        local = -Infinity
+    else:
+        # Versions with a local segment need that segment parsed to implement
+        # the sorting rules in PEP440.
+        # - Alpha numeric segments sort before numeric segments
+        # - Alpha numeric segments sort lexicographically
+        # - Numeric segments sort numerically
+        # - Shorter versions sort before longer versions when the prefixes
+        #   match exactly
+        local = tuple(
+            (i, "") if isinstance(i, int) else (-Infinity, i)
+            for i in local
+        )
+
+    return epoch, release, pre, post, dev, local
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/_vendor/packaging/version.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/_vendor/packaging/version.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..4054a0ef235ea64bd57f5763671711367b7caa6e
GIT binary patch
literal 17101
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
F0{|)_Wk~=4

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/_vendor/pyparsing.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/_vendor/pyparsing.py
new file mode 100644
index 0000000..cf75e1e
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/_vendor/pyparsing.py
@@ -0,0 +1,5742 @@
+# module pyparsing.py
+#
+# Copyright (c) 2003-2018  Paul T. McGuire
+#
+# Permission is hereby granted, free of charge, to any person obtaining
+# a copy of this software and associated documentation files (the
+# "Software"), to deal in the Software without restriction, including
+# without limitation the rights to use, copy, modify, merge, publish,
+# distribute, sublicense, and/or sell copies of the Software, and to
+# permit persons to whom the Software is furnished to do so, subject to
+# the following conditions:
+#
+# The above copyright notice and this permission notice shall be
+# included in all copies or substantial portions of the Software.
+#
+# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
+# EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
+# MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
+# IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY
+# CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,
+# TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
+# SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
+#
+
+__doc__ = \
+"""
+pyparsing module - Classes and methods to define and execute parsing grammars
+=============================================================================
+
+The pyparsing module is an alternative approach to creating and executing simple grammars,
+vs. the traditional lex/yacc approach, or the use of regular expressions.  With pyparsing, you
+don't need to learn a new syntax for defining grammars or matching expressions - the parsing module
+provides a library of classes that you use to construct the grammar directly in Python.
+
+Here is a program to parse "Hello, World!" (or any greeting of the form 
+C{"<salutation>, <addressee>!"}), built up using L{Word}, L{Literal}, and L{And} elements 
+(L{'+'<ParserElement.__add__>} operator gives L{And} expressions, strings are auto-converted to
+L{Literal} expressions)::
+
+    from pyparsing import Word, alphas
+
+    # define grammar of a greeting
+    greet = Word(alphas) + "," + Word(alphas) + "!"
+
+    hello = "Hello, World!"
+    print (hello, "->", greet.parseString(hello))
+
+The program outputs the following::
+
+    Hello, World! -> ['Hello', ',', 'World', '!']
+
+The Python representation of the grammar is quite readable, owing to the self-explanatory
+class names, and the use of '+', '|' and '^' operators.
+
+The L{ParseResults} object returned from L{ParserElement.parseString<ParserElement.parseString>} can be accessed as a nested list, a dictionary, or an
+object with named attributes.
+
+The pyparsing module handles some of the problems that are typically vexing when writing text parsers:
+ - extra or missing whitespace (the above program will also handle "Hello,World!", "Hello  ,  World  !", etc.)
+ - quoted strings
+ - embedded comments
+
+
+Getting Started -
+-----------------
+Visit the classes L{ParserElement} and L{ParseResults} to see the base classes that most other pyparsing
+classes inherit from. Use the docstrings for examples of how to:
+ - construct literal match expressions from L{Literal} and L{CaselessLiteral} classes
+ - construct character word-group expressions using the L{Word} class
+ - see how to create repetitive expressions using L{ZeroOrMore} and L{OneOrMore} classes
+ - use L{'+'<And>}, L{'|'<MatchFirst>}, L{'^'<Or>}, and L{'&'<Each>} operators to combine simple expressions into more complex ones
+ - associate names with your parsed results using L{ParserElement.setResultsName}
+ - find some helpful expression short-cuts like L{delimitedList} and L{oneOf}
+ - find more useful common expressions in the L{pyparsing_common} namespace class
+"""
+
+__version__ = "2.2.1"
+__versionTime__ = "18 Sep 2018 00:49 UTC"
+__author__ = "Paul McGuire <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
+
+try:
+    from _thread import RLock
+except ImportError:
+    from threading import RLock
+
+try:
+    # Python 3
+    from collections.abc import Iterable
+    from collections.abc import MutableMapping
+except ImportError:
+    # Python 2.7
+    from collections import Iterable
+    from collections import MutableMapping
+
+try:
+    from collections import OrderedDict as _OrderedDict
+except ImportError:
+    try:
+        from ordereddict import OrderedDict as _OrderedDict
+    except ImportError:
+        _OrderedDict = None
+
+#~ sys.stderr.write( "testing pyparsing module, version %s, %s\n" % (__version__,__versionTime__ ) )
+
+__all__ = [
+'And', 'CaselessKeyword', 'CaselessLiteral', 'CharsNotIn', 'Combine', 'Dict', 'Each', 'Empty',
+'FollowedBy', 'Forward', 'GoToColumn', 'Group', 'Keyword', 'LineEnd', 'LineStart', 'Literal',
+'MatchFirst', 'NoMatch', 'NotAny', 'OneOrMore', 'OnlyOnce', 'Optional', 'Or',
+'ParseBaseException', 'ParseElementEnhance', 'ParseException', 'ParseExpression', 'ParseFatalException',
+'ParseResults', 'ParseSyntaxException', 'ParserElement', 'QuotedString', 'RecursiveGrammarException',
+'Regex', 'SkipTo', 'StringEnd', 'StringStart', 'Suppress', 'Token', 'TokenConverter', 
+'White', 'Word', 'WordEnd', 'WordStart', 'ZeroOrMore',
+'alphanums', 'alphas', 'alphas8bit', 'anyCloseTag', 'anyOpenTag', 'cStyleComment', 'col',
+'commaSeparatedList', 'commonHTMLEntity', 'countedArray', 'cppStyleComment', 'dblQuotedString',
+'dblSlashComment', 'delimitedList', 'dictOf', 'downcaseTokens', 'empty', 'hexnums',
+'htmlComment', 'javaStyleComment', 'line', 'lineEnd', 'lineStart', 'lineno',
+'makeHTMLTags', 'makeXMLTags', 'matchOnlyAtCol', 'matchPreviousExpr', 'matchPreviousLiteral',
+'nestedExpr', 'nullDebugAction', 'nums', 'oneOf', 'opAssoc', 'operatorPrecedence', 'printables',
+'punc8bit', 'pythonStyleComment', 'quotedString', 'removeQuotes', 'replaceHTMLEntity', 
+'replaceWith', 'restOfLine', 'sglQuotedString', 'srange', 'stringEnd',
+'stringStart', 'traceParseAction', 'unicodeString', 'upcaseTokens', 'withAttribute',
+'indentedBlock', 'originalTextFor', 'ungroup', 'infixNotation','locatedExpr', 'withClass',
+'CloseMatch', 'tokenMap', 'pyparsing_common',
+]
+
+system_version = tuple(sys.version_info)[:3]
+PY_3 = system_version[0] == 3
+if PY_3:
+    _MAX_INT = sys.maxsize
+    basestring = str
+    unichr = chr
+    _ustr = str
+
+    # build list of single arg builtins, that can be used as parse actions
+    singleArgBuiltins = [sum, len, sorted, reversed, list, tuple, set, any, all, min, max]
+
+else:
+    _MAX_INT = sys.maxint
+    range = xrange
+
+    def _ustr(obj):
+        """Drop-in replacement for str(obj) that tries to be Unicode friendly. It first tries
+           str(obj). If that fails with a UnicodeEncodeError, then it tries unicode(obj). It
+           then < returns the unicode object | encodes it with the default encoding | ... >.
+        """
+        if isinstance(obj,unicode):
+            return obj
+
+        try:
+            # If this works, then _ustr(obj) has the same behaviour as str(obj), so
+            # it won't break any existing code.
+            return str(obj)
+
+        except UnicodeEncodeError:
+            # Else encode it
+            ret = unicode(obj).encode(sys.getdefaultencoding(), 'xmlcharrefreplace')
+            xmlcharref = Regex(r'&#\d+;')
+            xmlcharref.setParseAction(lambda t: '\\u' + hex(int(t[0][2:-1]))[2:])
+            return xmlcharref.transformString(ret)
+
+    # build list of single arg builtins, tolerant of Python version, that can be used as parse actions
+    singleArgBuiltins = []
+    import __builtin__
+    for fname in "sum len sorted reversed list tuple set any all min max".split():
+        try:
+            singleArgBuiltins.append(getattr(__builtin__,fname))
+        except AttributeError:
+            continue
+            
+_generatorType = type((y for y in range(1)))
+ 
+def _xml_escape(data):
+    """Escape &, <, >, ", ', etc. in a string of data."""
+
+    # ampersand must be replaced first
+    from_symbols = '&><"\''
+    to_symbols = ('&'+s+';' for s in "amp gt lt quot apos".split())
+    for from_,to_ in zip(from_symbols, to_symbols):
+        data = data.replace(from_, to_)
+    return data
+
+class _Constants(object):
+    pass
+
+alphas     = string.ascii_uppercase + string.ascii_lowercase
+nums       = "0123456789"
+hexnums    = nums + "ABCDEFabcdef"
+alphanums  = alphas + nums
+_bslash    = chr(92)
+printables = "".join(c for c in string.printable if c not in string.whitespace)
+
+class ParseBaseException(Exception):
+    """base exception class for all parsing runtime exceptions"""
+    # Performance tuning: we construct a *lot* of these, so keep this
+    # constructor as small and fast as possible
+    def __init__( self, pstr, loc=0, msg=None, elem=None ):
+        self.loc = loc
+        if msg is None:
+            self.msg = pstr
+            self.pstr = ""
+        else:
+            self.msg = msg
+            self.pstr = pstr
+        self.parserElement = elem
+        self.args = (pstr, loc, msg)
+
+    @classmethod
+    def _from_exception(cls, pe):
+        """
+        internal factory method to simplify creating one type of ParseException 
+        from another - avoids having __init__ signature conflicts among subclasses
+        """
+        return cls(pe.pstr, pe.loc, pe.msg, pe.parserElement)
+
+    def __getattr__( self, aname ):
+        """supported attributes by name are:
+            - lineno - returns the line number of the exception text
+            - col - returns the column number of the exception text
+            - line - returns the line containing the exception text
+        """
+        if( aname == "lineno" ):
+            return lineno( self.loc, self.pstr )
+        elif( aname in ("col", "column") ):
+            return col( self.loc, self.pstr )
+        elif( aname == "line" ):
+            return line( self.loc, self.pstr )
+        else:
+            raise AttributeError(aname)
+
+    def __str__( self ):
+        return "%s (at char %d), (line:%d, col:%d)" % \
+                ( self.msg, self.loc, self.lineno, self.column )
+    def __repr__( self ):
+        return _ustr(self)
+    def markInputline( self, markerString = ">!<" ):
+        """Extracts the exception line from the input string, and marks
+           the location of the exception with a special symbol.
+        """
+        line_str = self.line
+        line_column = self.column - 1
+        if markerString:
+            line_str = "".join((line_str[:line_column],
+                                markerString, line_str[line_column:]))
+        return line_str.strip()
+    def __dir__(self):
+        return "lineno col line".split() + dir(type(self))
+
+class ParseException(ParseBaseException):
+    """
+    Exception thrown when parse expressions don't match class;
+    supported attributes by name are:
+     - lineno - returns the line number of the exception text
+     - col - returns the column number of the exception text
+     - line - returns the line containing the exception text
+        
+    Example::
+        try:
+            Word(nums).setName("integer").parseString("ABC")
+        except ParseException as pe:
+            print(pe)
+            print("column: {}".format(pe.col))
+            
+    prints::
+       Expected integer (at char 0), (line:1, col:1)
+        column: 1
+    """
+    pass
+
+class ParseFatalException(ParseBaseException):
+    """user-throwable exception thrown when inconsistent parse content
+       is found; stops all parsing immediately"""
+    pass
+
+class ParseSyntaxException(ParseFatalException):
+    """just like L{ParseFatalException}, but thrown internally when an
+       L{ErrorStop<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 L{ParserElement.validate} if the grammar could be improperly recursive"""
+    def __init__( self, parseElementList ):
+        self.parseElementTrace = parseElementList
+
+    def __str__( self ):
+        return "RecursiveGrammarException: %s" % self.parseElementTrace
+
+class _ParseResultsWithOffset(object):
+    def __init__(self,p1,p2):
+        self.tup = (p1,p2)
+    def __getitem__(self,i):
+        return self.tup[i]
+    def __repr__(self):
+        return repr(self.tup[0])
+    def setOffset(self,i):
+        self.tup = (self.tup[0],i)
+
+class ParseResults(object):
+    """
+    Structured parse results, to provide multiple means of access to the parsed data:
+       - as a list (C{len(results)})
+       - by list index (C{results[0], results[1]}, etc.)
+       - by attribute (C{results.<resultsName>} - see L{ParserElement.setResultsName})
+
+    Example::
+        integer = Word(nums)
+        date_str = (integer.setResultsName("year") + '/' 
+                        + integer.setResultsName("month") + '/' 
+                        + integer.setResultsName("day"))
+        # equivalent form:
+        # date_str = integer("year") + '/' + integer("month") + '/' + integer("day")
+
+        # parseString returns a ParseResults object
+        result = date_str.parseString("1999/12/31")
+
+        def test(s, fn=repr):
+            print("%s -> %s" % (s, fn(eval(s))))
+        test("list(result)")
+        test("result[0]")
+        test("result['month']")
+        test("result.day")
+        test("'month' in result")
+        test("'minutes' in result")
+        test("result.dump()", str)
+    prints::
+        list(result) -> ['1999', '/', '12', '/', '31']
+        result[0] -> '1999'
+        result['month'] -> '12'
+        result.day -> '31'
+        'month' in result -> True
+        'minutes' in result -> False
+        result.dump() -> ['1999', '/', '12', '/', '31']
+        - day: 31
+        - month: 12
+        - year: 1999
+    """
+    def __new__(cls, toklist=None, name=None, asList=True, modal=True ):
+        if isinstance(toklist, cls):
+            return toklist
+        retobj = object.__new__(cls)
+        retobj.__doinit = True
+        return retobj
+
+    # Performance tuning: we construct a *lot* of these, so keep this
+    # constructor as small and fast as possible
+    def __init__( self, toklist=None, name=None, asList=True, modal=True, isinstance=isinstance ):
+        if self.__doinit:
+            self.__doinit = False
+            self.__name = None
+            self.__parent = None
+            self.__accumNames = {}
+            self.__asList = asList
+            self.__modal = modal
+            if toklist is None:
+                toklist = []
+            if isinstance(toklist, list):
+                self.__toklist = toklist[:]
+            elif isinstance(toklist, _generatorType):
+                self.__toklist = list(toklist)
+            else:
+                self.__toklist = [toklist]
+            self.__tokdict = dict()
+
+        if name is not None and name:
+            if not modal:
+                self.__accumNames[name] = 0
+            if isinstance(name,int):
+                name = _ustr(name) # will always return a str, but use _ustr for consistency
+            self.__name = name
+            if not (isinstance(toklist, (type(None), basestring, list)) and toklist in (None,'',[])):
+                if isinstance(toklist,basestring):
+                    toklist = [ toklist ]
+                if asList:
+                    if isinstance(toklist,ParseResults):
+                        self[name] = _ParseResultsWithOffset(toklist.copy(),0)
+                    else:
+                        self[name] = _ParseResultsWithOffset(ParseResults(toklist[0]),0)
+                    self[name].__name = name
+                else:
+                    try:
+                        self[name] = toklist[0]
+                    except (KeyError,TypeError,IndexError):
+                        self[name] = toklist
+
+    def __getitem__( self, i ):
+        if isinstance( i, (int,slice) ):
+            return self.__toklist[i]
+        else:
+            if i not in self.__accumNames:
+                return self.__tokdict[i][-1][0]
+            else:
+                return ParseResults([ v[0] for v in self.__tokdict[i] ])
+
+    def __setitem__( self, k, v, isinstance=isinstance ):
+        if isinstance(v,_ParseResultsWithOffset):
+            self.__tokdict[k] = self.__tokdict.get(k,list()) + [v]
+            sub = v[0]
+        elif isinstance(k,(int,slice)):
+            self.__toklist[k] = v
+            sub = v
+        else:
+            self.__tokdict[k] = self.__tokdict.get(k,list()) + [_ParseResultsWithOffset(v,0)]
+            sub = v
+        if isinstance(sub,ParseResults):
+            sub.__parent = wkref(self)
+
+    def __delitem__( self, i ):
+        if isinstance(i,(int,slice)):
+            mylen = len( self.__toklist )
+            del self.__toklist[i]
+
+            # convert int to slice
+            if isinstance(i, int):
+                if i < 0:
+                    i += mylen
+                i = slice(i, i+1)
+            # get removed indices
+            removed = list(range(*i.indices(mylen)))
+            removed.reverse()
+            # fixup indices in token dictionary
+            for name,occurrences in self.__tokdict.items():
+                for j in removed:
+                    for k, (value, position) in enumerate(occurrences):
+                        occurrences[k] = _ParseResultsWithOffset(value, position - (position > j))
+        else:
+            del self.__tokdict[i]
+
+    def __contains__( self, k ):
+        return k in self.__tokdict
+
+    def __len__( self ): return len( self.__toklist )
+    def __bool__(self): return ( not not self.__toklist )
+    __nonzero__ = __bool__
+    def __iter__( self ): return iter( self.__toklist )
+    def __reversed__( self ): return iter( self.__toklist[::-1] )
+    def _iterkeys( self ):
+        if hasattr(self.__tokdict, "iterkeys"):
+            return self.__tokdict.iterkeys()
+        else:
+            return iter(self.__tokdict)
+
+    def _itervalues( self ):
+        return (self[k] for k in self._iterkeys())
+            
+    def _iteritems( self ):
+        return ((k, self[k]) for k in self._iterkeys())
+
+    if PY_3:
+        keys = _iterkeys       
+        """Returns an iterator of all named result keys (Python 3.x only)."""
+
+        values = _itervalues
+        """Returns an iterator of all named result values (Python 3.x only)."""
+
+        items = _iteritems
+        """Returns an iterator of all named result key-value tuples (Python 3.x only)."""
+
+    else:
+        iterkeys = _iterkeys
+        """Returns an iterator of all named result keys (Python 2.x only)."""
+
+        itervalues = _itervalues
+        """Returns an iterator of all named result values (Python 2.x only)."""
+
+        iteritems = _iteritems
+        """Returns an iterator of all named result key-value tuples (Python 2.x only)."""
+
+        def keys( self ):
+            """Returns all named result keys (as a list in Python 2.x, as an iterator in Python 3.x)."""
+            return list(self.iterkeys())
+
+        def values( self ):
+            """Returns all named result values (as a list in Python 2.x, as an iterator in Python 3.x)."""
+            return list(self.itervalues())
+                
+        def items( self ):
+            """Returns all named result key-values (as a list of tuples in Python 2.x, as an iterator in Python 3.x)."""
+            return list(self.iteritems())
+
+    def haskeys( self ):
+        """Since keys() returns an iterator, this method is helpful in bypassing
+           code that looks for the existence of any defined results names."""
+        return bool(self.__tokdict)
+        
+    def pop( self, *args, **kwargs):
+        """
+        Removes and returns item at specified index (default=C{last}).
+        Supports both C{list} and C{dict} semantics for C{pop()}. If passed no
+        argument or an integer argument, it will use C{list} semantics
+        and pop tokens from the list of parsed tokens. If passed a 
+        non-integer argument (most likely a string), it will use C{dict}
+        semantics and pop the corresponding value from any defined 
+        results names. A second default return value argument is 
+        supported, just as in C{dict.pop()}.
+
+        Example::
+            def remove_first(tokens):
+                tokens.pop(0)
+            print(OneOrMore(Word(nums)).parseString("0 123 321")) # -> ['0', '123', '321']
+            print(OneOrMore(Word(nums)).addParseAction(remove_first).parseString("0 123 321")) # -> ['123', '321']
+
+            label = Word(alphas)
+            patt = label("LABEL") + OneOrMore(Word(nums))
+            print(patt.parseString("AAB 123 321").dump())
+
+            # Use pop() in a parse action to remove named result (note that corresponding value is not
+            # removed from list form of results)
+            def remove_LABEL(tokens):
+                tokens.pop("LABEL")
+                return tokens
+            patt.addParseAction(remove_LABEL)
+            print(patt.parseString("AAB 123 321").dump())
+        prints::
+            ['AAB', '123', '321']
+            - LABEL: AAB
+
+            ['AAB', '123', '321']
+        """
+        if not args:
+            args = [-1]
+        for k,v in kwargs.items():
+            if k == 'default':
+                args = (args[0], v)
+            else:
+                raise TypeError("pop() got an unexpected keyword argument '%s'" % k)
+        if (isinstance(args[0], int) or 
+                        len(args) == 1 or 
+                        args[0] in self):
+            index = args[0]
+            ret = self[index]
+            del self[index]
+            return ret
+        else:
+            defaultvalue = args[1]
+            return defaultvalue
+
+    def get(self, key, defaultValue=None):
+        """
+        Returns named result matching the given key, or if there is no
+        such name, then returns the given C{defaultValue} or C{None} if no
+        C{defaultValue} is specified.
+
+        Similar to C{dict.get()}.
+        
+        Example::
+            integer = Word(nums)
+            date_str = integer("year") + '/' + integer("month") + '/' + integer("day")           
+
+            result = date_str.parseString("1999/12/31")
+            print(result.get("year")) # -> '1999'
+            print(result.get("hour", "not specified")) # -> 'not specified'
+            print(result.get("hour")) # -> None
+        """
+        if key in self:
+            return self[key]
+        else:
+            return defaultValue
+
+    def insert( self, index, insStr ):
+        """
+        Inserts new element at location index in the list of parsed tokens.
+        
+        Similar to C{list.insert()}.
+
+        Example::
+            print(OneOrMore(Word(nums)).parseString("0 123 321")) # -> ['0', '123', '321']
+
+            # use a parse action to insert the parse location in the front of the parsed results
+            def insert_locn(locn, tokens):
+                tokens.insert(0, locn)
+            print(OneOrMore(Word(nums)).addParseAction(insert_locn).parseString("0 123 321")) # -> [0, '0', '123', '321']
+        """
+        self.__toklist.insert(index, insStr)
+        # fixup indices in token dictionary
+        for name,occurrences in self.__tokdict.items():
+            for k, (value, position) in enumerate(occurrences):
+                occurrences[k] = _ParseResultsWithOffset(value, position + (position > index))
+
+    def append( self, item ):
+        """
+        Add single element to end of ParseResults list of elements.
+
+        Example::
+            print(OneOrMore(Word(nums)).parseString("0 123 321")) # -> ['0', '123', '321']
+            
+            # use a parse action to compute the sum of the parsed integers, and add it to the end
+            def append_sum(tokens):
+                tokens.append(sum(map(int, tokens)))
+            print(OneOrMore(Word(nums)).addParseAction(append_sum).parseString("0 123 321")) # -> ['0', '123', '321', 444]
+        """
+        self.__toklist.append(item)
+
+    def extend( self, itemseq ):
+        """
+        Add sequence of elements to end of ParseResults list of elements.
+
+        Example::
+            patt = OneOrMore(Word(alphas))
+            
+            # use a parse action to append the reverse of the matched strings, to make a palindrome
+            def make_palindrome(tokens):
+                tokens.extend(reversed([t[::-1] for t in tokens]))
+                return ''.join(tokens)
+            print(patt.addParseAction(make_palindrome).parseString("lskdj sdlkjf lksd")) # -> 'lskdjsdlkjflksddsklfjkldsjdksl'
+        """
+        if isinstance(itemseq, ParseResults):
+            self += itemseq
+        else:
+            self.__toklist.extend(itemseq)
+
+    def clear( self ):
+        """
+        Clear all elements and results names.
+        """
+        del self.__toklist[:]
+        self.__tokdict.clear()
+
+    def __getattr__( self, name ):
+        try:
+            return self[name]
+        except KeyError:
+            return ""
+            
+        if name in self.__tokdict:
+            if name not in self.__accumNames:
+                return self.__tokdict[name][-1][0]
+            else:
+                return ParseResults([ v[0] for v in self.__tokdict[name] ])
+        else:
+            return ""
+
+    def __add__( self, other ):
+        ret = self.copy()
+        ret += other
+        return ret
+
+    def __iadd__( self, other ):
+        if other.__tokdict:
+            offset = len(self.__toklist)
+            addoffset = lambda a: offset if a<0 else a+offset
+            otheritems = other.__tokdict.items()
+            otherdictitems = [(k, _ParseResultsWithOffset(v[0],addoffset(v[1])) )
+                                for (k,vlist) in otheritems for v in vlist]
+            for k,v in otherdictitems:
+                self[k] = v
+                if isinstance(v[0],ParseResults):
+                    v[0].__parent = wkref(self)
+            
+        self.__toklist += other.__toklist
+        self.__accumNames.update( other.__accumNames )
+        return self
+
+    def __radd__(self, other):
+        if isinstance(other,int) and other == 0:
+            # useful for merging many ParseResults using sum() builtin
+            return self.copy()
+        else:
+            # this may raise a TypeError - so be it
+            return other + self
+        
+    def __repr__( self ):
+        return "(%s, %s)" % ( repr( self.__toklist ), repr( self.__tokdict ) )
+
+    def __str__( self ):
+        return '[' + ', '.join(_ustr(i) if isinstance(i, ParseResults) else repr(i) for i in self.__toklist) + ']'
+
+    def _asStringList( self, sep='' ):
+        out = []
+        for item in self.__toklist:
+            if out and sep:
+                out.append(sep)
+            if isinstance( item, ParseResults ):
+                out += item._asStringList()
+            else:
+                out.append( _ustr(item) )
+        return out
+
+    def asList( self ):
+        """
+        Returns the parse results as a nested list of matching tokens, all converted to strings.
+
+        Example::
+            patt = OneOrMore(Word(alphas))
+            result = patt.parseString("sldkj lsdkj sldkj")
+            # even though the result prints in string-like form, it is actually a pyparsing ParseResults
+            print(type(result), result) # -> <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 C{ParseResults} object.
+        """
+        ret = ParseResults( self.__toklist )
+        ret.__tokdict = self.__tokdict.copy()
+        ret.__parent = self.__parent
+        ret.__accumNames.update( self.__accumNames )
+        ret.__name = self.__name
+        return ret
+
+    def asXML( self, doctag=None, namedItemsOnly=False, indent="", formatted=True ):
+        """
+        (Deprecated) Returns the parse results as XML. Tags are created for tokens and lists that have defined results names.
+        """
+        nl = "\n"
+        out = []
+        namedItems = dict((v[1],k) for (k,vlist) in self.__tokdict.items()
+                                                            for v in vlist)
+        nextLevelIndent = indent + "  "
+
+        # collapse out indents if formatting is not desired
+        if not formatted:
+            indent = ""
+            nextLevelIndent = ""
+            nl = ""
+
+        selfTag = None
+        if doctag is not None:
+            selfTag = doctag
+        else:
+            if self.__name:
+                selfTag = self.__name
+
+        if not selfTag:
+            if namedItemsOnly:
+                return ""
+            else:
+                selfTag = "ITEM"
+
+        out += [ nl, indent, "<", selfTag, ">" ]
+
+        for i,res in enumerate(self.__toklist):
+            if isinstance(res,ParseResults):
+                if i in namedItems:
+                    out += [ res.asXML(namedItems[i],
+                                        namedItemsOnly and doctag is None,
+                                        nextLevelIndent,
+                                        formatted)]
+                else:
+                    out += [ res.asXML(None,
+                                        namedItemsOnly and doctag is None,
+                                        nextLevelIndent,
+                                        formatted)]
+            else:
+                # individual token, see if there is a name for it
+                resTag = None
+                if i in namedItems:
+                    resTag = namedItems[i]
+                if not resTag:
+                    if namedItemsOnly:
+                        continue
+                    else:
+                        resTag = "ITEM"
+                xmlBodyText = _xml_escape(_ustr(res))
+                out += [ nl, nextLevelIndent, "<", resTag, ">",
+                                                xmlBodyText,
+                                                "</", 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='', depth=0, full=True):
+        """
+        Diagnostic method for listing out the contents of a C{ParseResults}.
+        Accepts an optional C{indent} argument so that this string can be embedded
+        in a nested display of other data.
+
+        Example::
+            integer = Word(nums)
+            date_str = integer("year") + '/' + integer("month") + '/' + integer("day")
+            
+            result = date_str.parseString('12/31/1999')
+            print(result.dump())
+        prints::
+            ['12', '/', '31', '/', '1999']
+            - day: 1999
+            - month: 31
+            - year: 12
+        """
+        out = []
+        NL = '\n'
+        out.append( indent+_ustr(self.asList()) )
+        if full:
+            if self.haskeys():
+                items = sorted((str(k), v) for k,v in self.items())
+                for k,v in items:
+                    if out:
+                        out.append(NL)
+                    out.append( "%s%s- %s: " % (indent,('  '*depth), k) )
+                    if isinstance(v,ParseResults):
+                        if v:
+                            out.append( v.dump(indent,depth+1) )
+                        else:
+                            out.append(_ustr(v))
+                    else:
+                        out.append(repr(v))
+            elif any(isinstance(vv,ParseResults) for vv in self):
+                v = self
+                for i,vv in enumerate(v):
+                    if isinstance(vv,ParseResults):
+                        out.append("\n%s%s[%d]:\n%s%s%s" % (indent,('  '*(depth)),i,indent,('  '*(depth+1)),vv.dump(indent,depth+1) ))
+                    else:
+                        out.append("\n%s%s[%d]:\n%s%s%s" % (indent,('  '*(depth)),i,indent,('  '*(depth+1)),_ustr(vv)))
+            
+        return "".join(out)
+
+    def pprint(self, *args, **kwargs):
+        """
+        Pretty-printer for parsed results as a list, using the C{pprint} module.
+        Accepts additional positional or keyword args as defined for the 
+        C{pprint.pprint} method. (U{http://docs.python.org/3/library/pprint.html#pprint.pprint})
+
+        Example::
+            ident = Word(alphas, alphanums)
+            num = Word(nums)
+            func = Forward()
+            term = ident | num | Group('(' + func + ')')
+            func <<= ident + Group(Optional(delimitedList(term)))
+            result = func.parseString("fna a,b,(fnb c,d,200),100")
+            result.pprint(width=40)
+        prints::
+            ['fna',
+             ['a',
+              'b',
+              ['(', 'fnb', ['c', 'd', '200'], ')'],
+              '100']]
+        """
+        pprint.pprint(self.asList(), *args, **kwargs)
+
+    # add support for pickle protocol
+    def __getstate__(self):
+        return ( self.__toklist,
+                 ( self.__tokdict.copy(),
+                   self.__parent is not None and self.__parent() or None,
+                   self.__accumNames,
+                   self.__name ) )
+
+    def __setstate__(self,state):
+        self.__toklist = state[0]
+        (self.__tokdict,
+         par,
+         inAccumNames,
+         self.__name) = state[1]
+        self.__accumNames = {}
+        self.__accumNames.update(inAccumNames)
+        if par is not None:
+            self.__parent = wkref(par)
+        else:
+            self.__parent = None
+
+    def __getnewargs__(self):
+        return self.__toklist, self.__name, self.__asList, self.__modal
+
+    def __dir__(self):
+        return (dir(type(self)) + list(self.keys()))
+
+MutableMapping.register(ParseResults)
+
+def col (loc,strg):
+    """Returns current column within a string, counting newlines as line separators.
+   The first column is number 1.
+
+   Note: the default parsing behavior is to expand tabs in the input string
+   before starting the parsing process.  See L{I{ParserElement.parseString}<ParserElement.parseString>} for more information
+   on parsing strings containing C{<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 L{I{ParserElement.parseString}<ParserElement.parseString>} for more information
+   on parsing strings containing C{<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:
+                        del tb
+
+                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
+
+    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 = ParserElement.DEFAULT_WHITE_CHARS
+        self.copyDefaultWhiteChars = True
+        self.mayReturnEmpty = False # used when checking for left-recursion
+        self.keepTabs = False
+        self.ignoreExprs = list()
+        self.debug = False
+        self.streamlined = False
+        self.mayIndexError = True # used to optimize exception handling for subclasses that don't advance parse index
+        self.errmsg = ""
+        self.modalResults = True # used to mark results names as modal (report only last) or cumulative (list all)
+        self.debugActions = ( None, None, None ) #custom debug actions
+        self.re = None
+        self.callPreparse = True # used to avoid redundant calls to preParse
+        self.callDuringTry = False
+
+    def copy( self ):
+        """
+        Make a copy of this C{ParserElement}.  Useful for defining different parse actions
+        for the same parsing pattern, using copies of the original parse element.
+        
+        Example::
+            integer = Word(nums).setParseAction(lambda toks: int(toks[0]))
+            integerK = integer.copy().addParseAction(lambda toks: toks[0]*1024) + Suppress("K")
+            integerM = integer.copy().addParseAction(lambda toks: toks[0]*1024*1024) + Suppress("M")
+            
+            print(OneOrMore(integerK | integerM | integer).parseString("5K 100 640K 256M"))
+        prints::
+            [5120, 100, 655360, 268435456]
+        Equivalent form of C{expr.copy()} is just C{expr()}::
+            integerM = integer().addParseAction(lambda toks: toks[0]*1024*1024) + Suppress("M")
+        """
+        cpy = copy.copy( self )
+        cpy.parseAction = self.parseAction[:]
+        cpy.ignoreExprs = self.ignoreExprs[:]
+        if self.copyDefaultWhiteChars:
+            cpy.whiteChars = ParserElement.DEFAULT_WHITE_CHARS
+        return cpy
+
+    def setName( self, name ):
+        """
+        Define name for this expression, makes debugging and exception messages clearer.
+        
+        Example::
+            Word(nums).parseString("ABC")  # -> Exception: Expected W:(0123...) (at char 0), (line:1, col:1)
+            Word(nums).setName("integer").parseString("ABC")  # -> Exception: Expected integer (at char 0), (line:1, col:1)
+        """
+        self.name = name
+        self.errmsg = "Expected " + self.name
+        if hasattr(self,"exception"):
+            self.exception.msg = self.errmsg
+        return self
+
+    def setResultsName( self, name, listAllMatches=False ):
+        """
+        Define name for referencing matching tokens as a nested attribute
+        of the returned parse results.
+        NOTE: this returns a *copy* of the original C{ParserElement} object;
+        this is so that the client can define a basic element, such as an
+        integer, and reference it in multiple places with different names.
+
+        You can also set results names using the abbreviated syntax,
+        C{expr("name")} in place of C{expr.setResultsName("name")} - 
+        see L{I{__call__}<__call__>}.
+
+        Example::
+            date_str = (integer.setResultsName("year") + '/' 
+                        + integer.setResultsName("month") + '/' 
+                        + integer.setResultsName("day"))
+
+            # equivalent form:
+            date_str = integer("year") + '/' + integer("month") + '/' + integer("day")
+        """
+        newself = self.copy()
+        if name.endswith("*"):
+            name = name[:-1]
+            listAllMatches=True
+        newself.resultsName = name
+        newself.modalResults = not listAllMatches
+        return newself
+
+    def setBreak(self,breakFlag = True):
+        """Method to invoke the Python pdb debugger when this element is
+           about to be parsed. Set C{breakFlag} to True to enable, False to
+           disable.
+        """
+        if breakFlag:
+            _parseMethod = self._parse
+            def breaker(instring, loc, doActions=True, callPreParse=True):
+                import pdb
+                pdb.set_trace()
+                return _parseMethod( instring, loc, doActions, callPreParse )
+            breaker._originalParseMethod = _parseMethod
+            self._parse = breaker
+        else:
+            if hasattr(self._parse,"_originalParseMethod"):
+                self._parse = self._parse._originalParseMethod
+        return self
+
+    def setParseAction( self, *fns, **kwargs ):
+        """
+        Define one or more actions to perform when successfully matching parse element definition.
+        Parse action fn is a callable method with 0-3 arguments, called as C{fn(s,loc,toks)},
+        C{fn(loc,toks)}, C{fn(toks)}, or just C{fn()}, where:
+         - s   = the original string being parsed (see note below)
+         - loc = the location of the matching substring
+         - toks = a list of the matched tokens, packaged as a C{L{ParseResults}} object
+        If the functions in fns modify the tokens, they can return them as the return
+        value from fn, and the modified list of tokens will replace the original.
+        Otherwise, fn does not need to return any value.
+
+        Optional keyword arguments:
+         - callDuringTry = (default=C{False}) indicate if parse action should be run during lookaheads and alternate testing
+
+        Note: the default parsing behavior is to expand tabs in the input string
+        before starting the parsing process.  See L{I{parseString}<parseString>} for more information
+        on parsing strings containing C{<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]
+        """
+        self.parseAction = list(map(_trim_arity, list(fns)))
+        self.callDuringTry = kwargs.get("callDuringTry", False)
+        return self
+
+    def addParseAction( self, *fns, **kwargs ):
+        """
+        Add one or more parse actions to expression's list of parse actions. See L{I{setParseAction}<setParseAction>}.
+        
+        See examples in L{I{copy}<copy>}.
+        """
+        self.parseAction += list(map(_trim_arity, list(fns)))
+        self.callDuringTry = self.callDuringTry or kwargs.get("callDuringTry", False)
+        return self
+
+    def addCondition(self, *fns, **kwargs):
+        """Add a boolean predicate function to expression's list of parse actions. See 
+        L{I{setParseAction}<setParseAction>} for function call signatures. Unlike C{setParseAction}, 
+        functions passed to C{addCondition} need to return boolean success/fail of the condition.
+
+        Optional keyword arguments:
+         - message = define a custom message to be used in the raised exception
+         - fatal   = if True, will raise ParseFatalException to stop parsing immediately; otherwise will raise ParseException
+         
+        Example::
+            integer = Word(nums).setParseAction(lambda toks: int(toks[0]))
+            year_int = integer.copy()
+            year_int.addCondition(lambda toks: toks[0] >= 2000, message="Only support years 2000 and later")
+            date_str = year_int + '/' + integer + '/' + integer
+
+            result = date_str.parseString("1999/12/31")  # -> Exception: Only support years 2000 and later (at char 0), (line:1, col:1)
+        """
+        msg = kwargs.get("message", "failed user-defined condition")
+        exc_type = ParseFatalException if kwargs.get("fatal", False) else ParseException
+        for fn in fns:
+            def pa(s,l,t):
+                if not bool(_trim_arity(fn)(s,l,t)):
+                    raise exc_type(s,l,msg)
+            self.parseAction.append(pa)
+        self.callDuringTry = self.callDuringTry or kwargs.get("callDuringTry", False)
+        return self
+
+    def setFailAction( self, fn ):
+        """Define action to perform if parsing fails at this expression.
+           Fail acton fn is a callable function that takes the arguments
+           C{fn(s,loc,expr,err)} where:
+            - s = string being parsed
+            - loc = location where expression match was attempted and failed
+            - expr = the parse expression that failed
+            - err = the exception thrown
+           The function returns no value.  It may throw C{L{ParseFatalException}}
+           if it is desired to stop parsing immediately."""
+        self.failAction = fn
+        return self
+
+    def _skipIgnorables( self, instring, loc ):
+        exprsFound = True
+        while exprsFound:
+            exprsFound = False
+            for e in self.ignoreExprs:
+                try:
+                    while 1:
+                        loc,dummy = e._parse( instring, loc )
+                        exprsFound = True
+                except ParseException:
+                    pass
+        return loc
+
+    def preParse( self, instring, loc ):
+        if self.ignoreExprs:
+            loc = self._skipIgnorables( instring, loc )
+
+        if self.skipWhitespace:
+            wt = self.whiteChars
+            instrlen = len(instring)
+            while loc < instrlen and instring[loc] in wt:
+                loc += 1
+
+        return loc
+
+    def parseImpl( self, instring, loc, doActions=True ):
+        return loc, []
+
+    def postParse( self, instring, loc, tokenlist ):
+        return tokenlist
+
+    #~ @profile
+    def _parseNoCache( self, instring, loc, doActions=True, callPreParse=True ):
+        debugging = ( self.debug ) #and doActions )
+
+        if debugging or self.failAction:
+            #~ print ("Match",self,"at loc",loc,"(%d,%d)" % ( lineno(loc,instring), col(loc,instring) ))
+            if (self.debugActions[0] ):
+                self.debugActions[0]( instring, loc, self )
+            if callPreParse and self.callPreparse:
+                preloc = self.preParse( instring, loc )
+            else:
+                preloc = loc
+            tokensStart = preloc
+            try:
+                try:
+                    loc,tokens = self.parseImpl( instring, preloc, doActions )
+                except IndexError:
+                    raise ParseException( instring, len(instring), self.errmsg, self )
+            except ParseBaseException as err:
+                #~ print ("Exception raised:", err)
+                if self.debugActions[2]:
+                    self.debugActions[2]( instring, tokensStart, self, err )
+                if self.failAction:
+                    self.failAction( instring, tokensStart, self, err )
+                raise
+        else:
+            if callPreParse and self.callPreparse:
+                preloc = self.preParse( instring, loc )
+            else:
+                preloc = loc
+            tokensStart = preloc
+            if self.mayIndexError or preloc >= len(instring):
+                try:
+                    loc,tokens = self.parseImpl( instring, preloc, doActions )
+                except IndexError:
+                    raise ParseException( instring, len(instring), self.errmsg, self )
+            else:
+                loc,tokens = self.parseImpl( instring, preloc, doActions )
+
+        tokens = self.postParse( instring, loc, tokens )
+
+        retTokens = ParseResults( tokens, self.resultsName, asList=self.saveAsList, modal=self.modalResults )
+        if self.parseAction and (doActions or self.callDuringTry):
+            if debugging:
+                try:
+                    for fn in self.parseAction:
+                        tokens = fn( instring, tokensStart, retTokens )
+                        if tokens is not None:
+                            retTokens = ParseResults( tokens,
+                                                      self.resultsName,
+                                                      asList=self.saveAsList and isinstance(tokens,(ParseResults,list)),
+                                                      modal=self.modalResults )
+                except ParseBaseException as err:
+                    #~ print "Exception raised in user parse action:", err
+                    if (self.debugActions[2] ):
+                        self.debugActions[2]( instring, tokensStart, self, err )
+                    raise
+            else:
+                for fn in self.parseAction:
+                    tokens = fn( instring, tokensStart, retTokens )
+                    if tokens is not None:
+                        retTokens = ParseResults( tokens,
+                                                  self.resultsName,
+                                                  asList=self.saveAsList and isinstance(tokens,(ParseResults,list)),
+                                                  modal=self.modalResults )
+        if debugging:
+            #~ print ("Matched",self,"->",retTokens.asList())
+            if (self.debugActions[1] ):
+                self.debugActions[1]( instring, tokensStart, loc, self, retTokens )
+
+        return loc, retTokens
+
+    def tryParse( self, instring, loc ):
+        try:
+            return self._parse( instring, loc, doActions=False )[0]
+        except ParseFatalException:
+            raise ParseException( instring, loc, self.errmsg, self)
+    
+    def canParseNext(self, instring, loc):
+        try:
+            self.tryParse(instring, loc)
+        except (ParseException, IndexError):
+            return False
+        else:
+            return True
+
+    class _UnboundedCache(object):
+        def __init__(self):
+            cache = {}
+            self.not_in_cache = not_in_cache = object()
+
+            def get(self, key):
+                return cache.get(key, not_in_cache)
+
+            def set(self, key, value):
+                cache[key] = value
+
+            def clear(self):
+                cache.clear()
+                
+            def cache_len(self):
+                return len(cache)
+
+            self.get = types.MethodType(get, self)
+            self.set = types.MethodType(set, self)
+            self.clear = types.MethodType(clear, self)
+            self.__len__ = types.MethodType(cache_len, self)
+
+    if _OrderedDict is not None:
+        class _FifoCache(object):
+            def __init__(self, size):
+                self.not_in_cache = not_in_cache = object()
+
+                cache = _OrderedDict()
+
+                def get(self, key):
+                    return cache.get(key, not_in_cache)
+
+                def set(self, key, value):
+                    cache[key] = value
+                    while len(cache) > size:
+                        try:
+                            cache.popitem(False)
+                        except KeyError:
+                            pass
+
+                def clear(self):
+                    cache.clear()
+
+                def cache_len(self):
+                    return len(cache)
+
+                self.get = types.MethodType(get, self)
+                self.set = types.MethodType(set, self)
+                self.clear = types.MethodType(clear, self)
+                self.__len__ = types.MethodType(cache_len, self)
+
+    else:
+        class _FifoCache(object):
+            def __init__(self, size):
+                self.not_in_cache = not_in_cache = object()
+
+                cache = {}
+                key_fifo = collections.deque([], size)
+
+                def get(self, key):
+                    return cache.get(key, not_in_cache)
+
+                def set(self, key, value):
+                    cache[key] = value
+                    while len(key_fifo) > size:
+                        cache.pop(key_fifo.popleft(), None)
+                    key_fifo.append(key)
+
+                def clear(self):
+                    cache.clear()
+                    key_fifo.clear()
+
+                def cache_len(self):
+                    return len(cache)
+
+                self.get = types.MethodType(get, self)
+                self.set = types.MethodType(set, self)
+                self.clear = types.MethodType(clear, self)
+                self.__len__ = types.MethodType(cache_len, self)
+
+    # argument cache for optimizing repeated calls when backtracking through recursive expressions
+    packrat_cache = {} # this is set later by enabledPackrat(); this is here so that resetCache() doesn't fail
+    packrat_cache_lock = RLock()
+    packrat_cache_stats = [0, 0]
+
+    # this method gets repeatedly called during backtracking with the same arguments -
+    # we can cache these arguments and save ourselves the trouble of re-parsing the contained expression
+    def _parseCache( self, instring, loc, doActions=True, callPreParse=True ):
+        HIT, MISS = 0, 1
+        lookup = (self, instring, loc, callPreParse, doActions)
+        with ParserElement.packrat_cache_lock:
+            cache = ParserElement.packrat_cache
+            value = cache.get(lookup)
+            if value is cache.not_in_cache:
+                ParserElement.packrat_cache_stats[MISS] += 1
+                try:
+                    value = self._parseNoCache(instring, loc, doActions, callPreParse)
+                except ParseBaseException as pe:
+                    # cache a copy of the exception, without the traceback
+                    cache.set(lookup, pe.__class__(*pe.args))
+                    raise
+                else:
+                    cache.set(lookup, (value[0], value[1].copy()))
+                    return value
+            else:
+                ParserElement.packrat_cache_stats[HIT] += 1
+                if isinstance(value, Exception):
+                    raise value
+                return (value[0], value[1].copy())
+
+    _parse = _parseNoCache
+
+    @staticmethod
+    def resetCache():
+        ParserElement.packrat_cache.clear()
+        ParserElement.packrat_cache_stats[:] = [0] * len(ParserElement.packrat_cache_stats)
+
+    _packratEnabled = False
+    @staticmethod
+    def enablePackrat(cache_size_limit=128):
+        """Enables "packrat" parsing, which adds memoizing to the parsing logic.
+           Repeated parse attempts at the same string location (which happens
+           often in many complex grammars) can immediately return a cached value,
+           instead of re-executing parsing/validating code.  Memoizing is done of
+           both valid results and parsing exceptions.
+           
+           Parameters:
+            - cache_size_limit - (default=C{128}) - if an integer value is provided
+              will limit the size of the packrat cache; if None is passed, then
+              the cache size will be unbounded; if 0 is passed, the cache will
+              be effectively disabled.
+            
+           This speedup may break existing programs that use parse actions that
+           have side-effects.  For this reason, packrat parsing is disabled when
+           you first import pyparsing.  To activate the packrat feature, your
+           program must call the class method C{ParserElement.enablePackrat()}.  If
+           your program uses C{psyco} to "compile as you go", you must call
+           C{enablePackrat} before calling C{psyco.full()}.  If you do not do this,
+           Python will crash.  For best results, call C{enablePackrat()} immediately
+           after importing pyparsing.
+           
+           Example::
+               import pyparsing
+               pyparsing.ParserElement.enablePackrat()
+        """
+        if not ParserElement._packratEnabled:
+            ParserElement._packratEnabled = True
+            if cache_size_limit is None:
+                ParserElement.packrat_cache = ParserElement._UnboundedCache()
+            else:
+                ParserElement.packrat_cache = ParserElement._FifoCache(cache_size_limit)
+            ParserElement._parse = ParserElement._parseCache
+
+    def parseString( self, instring, parseAll=False ):
+        """
+        Execute the parse expression with the given string.
+        This is the main interface to the client code, once the complete
+        expression has been built.
+
+        If you want the grammar to require that the entire input string be
+        successfully parsed, then set C{parseAll} to True (equivalent to ending
+        the grammar with C{L{StringEnd()}}).
+
+        Note: C{parseString} implicitly calls C{expandtabs()} on the input string,
+        in order to report proper column numbers in parse actions.
+        If the input string contains tabs and
+        the grammar uses parse actions that use the C{loc} argument to index into the
+        string being parsed, you can ensure you have a consistent view of the input
+        string by:
+         - calling C{parseWithTabs} on your grammar before calling C{parseString}
+           (see L{I{parseWithTabs}<parseWithTabs>})
+         - define your parse action using the full C{(s,loc,toks)} signature, and
+           reference the input string using the parse action's C{s} argument
+         - explictly expand the tabs in your input string before calling
+           C{parseString}
+        
+        Example::
+            Word('a').parseString('aaaaabaaa')  # -> ['aaaaa']
+            Word('a').parseString('aaaaabaaa', parseAll=True)  # -> Exception: Expected end of text
+        """
+        ParserElement.resetCache()
+        if not self.streamlined:
+            self.streamline()
+            #~ self.saveAsList = True
+        for e in self.ignoreExprs:
+            e.streamline()
+        if not self.keepTabs:
+            instring = instring.expandtabs()
+        try:
+            loc, tokens = self._parse( instring, 0 )
+            if parseAll:
+                loc = self.preParse( instring, loc )
+                se = Empty() + StringEnd()
+                se._parse( instring, loc )
+        except ParseBaseException as exc:
+            if ParserElement.verbose_stacktrace:
+                raise
+            else:
+                # catch and re-raise exception from here, clears out pyparsing internal stack trace
+                raise exc
+        else:
+            return tokens
+
+    def scanString( self, instring, maxMatches=_MAX_INT, overlap=False ):
+        """
+        Scan the input string for expression matches.  Each match will return the
+        matching tokens, start location, and end location.  May be called with optional
+        C{maxMatches} argument, to clip scanning after 'n' matches are found.  If
+        C{overlap} is specified, then overlapping matches will be reported.
+
+        Note that the start and end locations are reported relative to the string
+        being parsed.  See L{I{parseString}<parseString>} for more information on parsing
+        strings with embedded tabs.
+
+        Example::
+            source = "sldjf123lsdjjkf345sldkjf879lkjsfd987"
+            print(source)
+            for tokens,start,end in Word(alphas).scanString(source):
+                print(' '*start + '^'*(end-start))
+                print(' '*start + tokens[0])
+        
+        prints::
+        
+            sldjf123lsdjjkf345sldkjf879lkjsfd987
+            ^^^^^
+            sldjf
+                    ^^^^^^^
+                    lsdjjkf
+                              ^^^^^^
+                              sldkjf
+                                       ^^^^^^
+                                       lkjsfd
+        """
+        if not self.streamlined:
+            self.streamline()
+        for e in self.ignoreExprs:
+            e.streamline()
+
+        if not self.keepTabs:
+            instring = _ustr(instring).expandtabs()
+        instrlen = len(instring)
+        loc = 0
+        preparseFn = self.preParse
+        parseFn = self._parse
+        ParserElement.resetCache()
+        matches = 0
+        try:
+            while loc <= instrlen and matches < maxMatches:
+                try:
+                    preloc = preparseFn( instring, loc )
+                    nextLoc,tokens = parseFn( instring, preloc, callPreParse=False )
+                except ParseException:
+                    loc = preloc+1
+                else:
+                    if nextLoc > loc:
+                        matches += 1
+                        yield tokens, preloc, nextLoc
+                        if overlap:
+                            nextloc = preparseFn( instring, loc )
+                            if nextloc > loc:
+                                loc = nextLoc
+                            else:
+                                loc += 1
+                        else:
+                            loc = nextLoc
+                    else:
+                        loc = preloc+1
+        except ParseBaseException as exc:
+            if ParserElement.verbose_stacktrace:
+                raise
+            else:
+                # catch and re-raise exception from here, clears out pyparsing internal stack trace
+                raise exc
+
+    def transformString( self, instring ):
+        """
+        Extension to C{L{scanString}}, to modify matching text with modified tokens that may
+        be returned from a parse action.  To use C{transformString}, define a grammar and
+        attach a parse action to it that modifies the returned token list.
+        Invoking C{transformString()} on a target string will then scan for matches,
+        and replace the matched text patterns according to the logic in the parse
+        action.  C{transformString()} returns the resulting transformed string.
+        
+        Example::
+            wd = Word(alphas)
+            wd.setParseAction(lambda toks: toks[0].title())
+            
+            print(wd.transformString("now is the winter of our discontent made glorious summer by this sun of york."))
+        Prints::
+            Now Is The Winter Of Our Discontent Made Glorious Summer By This Sun Of York.
+        """
+        out = []
+        lastE = 0
+        # force preservation of <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, clears out pyparsing internal stack trace
+                raise exc
+
+    def searchString( self, instring, maxMatches=_MAX_INT ):
+        """
+        Another extension to C{L{scanString}}, simplifying the access to the tokens found
+        to match the given parse expression.  May be called with optional
+        C{maxMatches} argument, to clip searching after 'n' matches are found.
+        
+        Example::
+            # a capitalized word starts with an uppercase letter, followed by zero or more lowercase letters
+            cap_word = Word(alphas.upper(), alphas.lower())
+            
+            print(cap_word.searchString("More than Iron, more than Lead, more than Gold I need Electricity"))
+
+            # the sum() builtin can be used to merge results into a single ParseResults object
+            print(sum(cap_word.searchString("More than Iron, more than Lead, more than Gold I need Electricity")))
+        prints::
+            [['More'], ['Iron'], ['Lead'], ['Gold'], ['I'], ['Electricity']]
+            ['More', 'Iron', 'Lead', 'Gold', 'I', 'Electricity']
+        """
+        try:
+            return ParseResults([ t for t,s,e in self.scanString( instring, maxMatches ) ])
+        except ParseBaseException as exc:
+            if ParserElement.verbose_stacktrace:
+                raise
+            else:
+                # catch and re-raise exception from here, clears out pyparsing internal stack trace
+                raise exc
+
+    def split(self, instring, maxsplit=_MAX_INT, includeSeparators=False):
+        """
+        Generator method to split a string using the given expression as a separator.
+        May be called with optional C{maxsplit} argument, to limit the number of splits;
+        and the optional C{includeSeparators} argument (default=C{False}), if the separating
+        matching text should be included in the split results.
+        
+        Example::        
+            punc = oneOf(list(".,;:/-!?"))
+            print(list(punc.split("This, this?, this sentence, is badly punctuated!")))
+        prints::
+            ['This', ' this', '', ' this sentence', ' is badly punctuated', '']
+        """
+        splits = 0
+        last = 0
+        for t,s,e in self.scanString(instring, maxMatches=maxsplit):
+            yield instring[last:s]
+            if includeSeparators:
+                yield t[0]
+            last = e
+        yield instring[last:]
+
+    def __add__(self, other ):
+        """
+        Implementation of + operator - returns C{L{And}}. Adding strings to a ParserElement
+        converts them to L{Literal}s by default.
+        
+        Example::
+            greet = Word(alphas) + "," + Word(alphas) + "!"
+            hello = "Hello, World!"
+            print (hello, "->", greet.parseString(hello))
+        Prints::
+            Hello, World! -> ['Hello', ',', 'World', '!']
+        """
+        if isinstance( other, basestring ):
+            other = ParserElement._literalStringClass( other )
+        if not isinstance( other, ParserElement ):
+            warnings.warn("Cannot combine element of type %s with ParserElement" % type(other),
+                    SyntaxWarning, stacklevel=2)
+            return None
+        return And( [ self, other ] )
+
+    def __radd__(self, other ):
+        """
+        Implementation of + operator when left operand is not a C{L{ParserElement}}
+        """
+        if isinstance( other, basestring ):
+            other = ParserElement._literalStringClass( other )
+        if not isinstance( other, ParserElement ):
+            warnings.warn("Cannot combine element of type %s with ParserElement" % type(other),
+                    SyntaxWarning, stacklevel=2)
+            return None
+        return other + self
+
+    def __sub__(self, other):
+        """
+        Implementation of - operator, returns C{L{And}} with error stop
+        """
+        if isinstance( other, basestring ):
+            other = ParserElement._literalStringClass( other )
+        if not isinstance( other, ParserElement ):
+            warnings.warn("Cannot combine element of type %s with ParserElement" % type(other),
+                    SyntaxWarning, stacklevel=2)
+            return None
+        return self + And._ErrorStop() + other
+
+    def __rsub__(self, other ):
+        """
+        Implementation of - operator when left operand is not a C{L{ParserElement}}
+        """
+        if isinstance( other, basestring ):
+            other = ParserElement._literalStringClass( other )
+        if not isinstance( other, ParserElement ):
+            warnings.warn("Cannot combine element of type %s with ParserElement" % type(other),
+                    SyntaxWarning, stacklevel=2)
+            return None
+        return other - self
+
+    def __mul__(self,other):
+        """
+        Implementation of * operator, allows use of C{expr * 3} in place of
+        C{expr + expr + expr}.  Expressions may also me multiplied by a 2-integer
+        tuple, similar to C{{min,max}} multipliers in regular expressions.  Tuples
+        may also include C{None} as in:
+         - C{expr*(n,None)} or C{expr*(n,)} is equivalent
+              to C{expr*n + L{ZeroOrMore}(expr)}
+              (read as "at least n instances of C{expr}")
+         - C{expr*(None,n)} is equivalent to C{expr*(0,n)}
+              (read as "0 to n instances of C{expr}")
+         - C{expr*(None,None)} is equivalent to C{L{ZeroOrMore}(expr)}
+         - C{expr*(1,None)} is equivalent to C{L{OneOrMore}(expr)}
+
+        Note that C{expr*(None,n)} does not raise an exception if
+        more than n exprs exist in the input stream; that is,
+        C{expr*(None,n)} does not enforce a maximum number of expr
+        occurrences.  If this behavior is desired, then write
+        C{expr*(None,n) + ~expr}
+        """
+        if isinstance(other,int):
+            minElements, optElements = other,0
+        elif isinstance(other,tuple):
+            other = (other + (None, None))[:2]
+            if other[0] is None:
+                other = (0, other[1])
+            if isinstance(other[0],int) and other[1] is None:
+                if other[0] == 0:
+                    return ZeroOrMore(self)
+                if other[0] == 1:
+                    return OneOrMore(self)
+                else:
+                    return self*other[0] + ZeroOrMore(self)
+            elif isinstance(other[0],int) and isinstance(other[1],int):
+                minElements, optElements = other
+                optElements -= minElements
+            else:
+                raise TypeError("cannot multiply 'ParserElement' and ('%s','%s') objects", type(other[0]),type(other[1]))
+        else:
+            raise TypeError("cannot multiply 'ParserElement' and '%s' objects", type(other))
+
+        if minElements < 0:
+            raise ValueError("cannot multiply ParserElement by negative value")
+        if optElements < 0:
+            raise ValueError("second tuple value must be greater or equal to first tuple value")
+        if minElements == optElements == 0:
+            raise ValueError("cannot multiply ParserElement by 0 or (0,0)")
+
+        if (optElements):
+            def makeOptionalList(n):
+                if n>1:
+                    return Optional(self + makeOptionalList(n-1))
+                else:
+                    return Optional(self)
+            if minElements:
+                if minElements == 1:
+                    ret = self + makeOptionalList(optElements)
+                else:
+                    ret = And([self]*minElements) + makeOptionalList(optElements)
+            else:
+                ret = makeOptionalList(optElements)
+        else:
+            if minElements == 1:
+                ret = self
+            else:
+                ret = And([self]*minElements)
+        return ret
+
+    def __rmul__(self, other):
+        return self.__mul__(other)
+
+    def __or__(self, other ):
+        """
+        Implementation of | operator - returns C{L{MatchFirst}}
+        """
+        if isinstance( other, basestring ):
+            other = ParserElement._literalStringClass( other )
+        if not isinstance( other, ParserElement ):
+            warnings.warn("Cannot combine element of type %s with ParserElement" % type(other),
+                    SyntaxWarning, stacklevel=2)
+            return None
+        return MatchFirst( [ self, other ] )
+
+    def __ror__(self, other ):
+        """
+        Implementation of | operator when left operand is not a C{L{ParserElement}}
+        """
+        if isinstance( other, basestring ):
+            other = ParserElement._literalStringClass( other )
+        if not isinstance( other, ParserElement ):
+            warnings.warn("Cannot combine element of type %s with ParserElement" % type(other),
+                    SyntaxWarning, stacklevel=2)
+            return None
+        return other | self
+
+    def __xor__(self, other ):
+        """
+        Implementation of ^ operator - returns C{L{Or}}
+        """
+        if isinstance( other, basestring ):
+            other = ParserElement._literalStringClass( other )
+        if not isinstance( other, ParserElement ):
+            warnings.warn("Cannot combine element of type %s with ParserElement" % type(other),
+                    SyntaxWarning, stacklevel=2)
+            return None
+        return Or( [ self, other ] )
+
+    def __rxor__(self, other ):
+        """
+        Implementation of ^ operator when left operand is not a C{L{ParserElement}}
+        """
+        if isinstance( other, basestring ):
+            other = ParserElement._literalStringClass( other )
+        if not isinstance( other, ParserElement ):
+            warnings.warn("Cannot combine element of type %s with ParserElement" % type(other),
+                    SyntaxWarning, stacklevel=2)
+            return None
+        return other ^ self
+
+    def __and__(self, other ):
+        """
+        Implementation of & operator - returns C{L{Each}}
+        """
+        if isinstance( other, basestring ):
+            other = ParserElement._literalStringClass( other )
+        if not isinstance( other, ParserElement ):
+            warnings.warn("Cannot combine element of type %s with ParserElement" % type(other),
+                    SyntaxWarning, stacklevel=2)
+            return None
+        return Each( [ self, other ] )
+
+    def __rand__(self, other ):
+        """
+        Implementation of & operator when left operand is not a C{L{ParserElement}}
+        """
+        if isinstance( other, basestring ):
+            other = ParserElement._literalStringClass( other )
+        if not isinstance( other, ParserElement ):
+            warnings.warn("Cannot combine element of type %s with ParserElement" % type(other),
+                    SyntaxWarning, stacklevel=2)
+            return None
+        return other & self
+
+    def __invert__( self ):
+        """
+        Implementation of ~ operator - returns C{L{NotAny}}
+        """
+        return NotAny( self )
+
+    def __call__(self, name=None):
+        """
+        Shortcut for C{L{setResultsName}}, with C{listAllMatches=False}.
+        
+        If C{name} is given with a trailing C{'*'} character, then C{listAllMatches} will be
+        passed as C{True}.
+           
+        If C{name} is omitted, same as calling C{L{copy}}.
+
+        Example::
+            # these are equivalent
+            userdata = Word(alphas).setResultsName("name") + Word(nums+"-").setResultsName("socsecno")
+            userdata = Word(alphas)("name") + Word(nums+"-")("socsecno")             
+        """
+        if name is not None:
+            return self.setResultsName(name)
+        else:
+            return self.copy()
+
+    def suppress( self ):
+        """
+        Suppresses the output of this C{ParserElement}; useful to keep punctuation from
+        cluttering up returned output.
+        """
+        return Suppress( self )
+
+    def leaveWhitespace( self ):
+        """
+        Disables the skipping of whitespace before matching the characters in the
+        C{ParserElement}'s defined pattern.  This is normally only used internally by
+        the pyparsing module, but may be needed in some whitespace-sensitive grammars.
+        """
+        self.skipWhitespace = False
+        return self
+
+    def setWhitespaceChars( self, chars ):
+        """
+        Overrides the default whitespace chars
+        """
+        self.skipWhitespace = True
+        self.whiteChars = chars
+        self.copyDefaultWhiteChars = False
+        return self
+
+    def parseWithTabs( self ):
+        """
+        Overrides default behavior to expand C{<TAB>}s to spaces before parsing the input string.
+        Must be called before C{parseString} when the input grammar contains elements that
+        match C{<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 C{flag} to True to enable, False to disable.
+
+        Example::
+            wd = Word(alphas).setName("alphaword")
+            integer = Word(nums).setName("numword")
+            term = wd | integer
+            
+            # turn on debugging for wd
+            wd.setDebug()
+
+            OneOrMore(term).parseString("abc 123 xyz 890")
+        
+        prints::
+            Match alphaword at loc 0(1,1)
+            Matched alphaword -> ['abc']
+            Match alphaword at loc 3(1,4)
+            Exception raised:Expected alphaword (at char 4), (line:1, col:5)
+            Match alphaword at loc 7(1,8)
+            Matched alphaword -> ['xyz']
+            Match alphaword at loc 11(1,12)
+            Exception raised:Expected alphaword (at char 12), (line:1, col:13)
+            Match alphaword at loc 15(1,16)
+            Exception raised:Expected alphaword (at char 15), (line:1, col:16)
+
+        The output shown is that produced by the default debug actions - custom debug actions can be
+        specified using L{setDebugActions}. Prior to attempting
+        to match the C{wd} expression, the debugging message C{"Match <exprname> at loc <n>(<line>,<col>)"}
+        is shown. Then if the parse succeeds, a C{"Matched"} message is shown, or an C{"Exception raised"}
+        message is shown. Also note the use of L{setName} to assign a human-readable name to the expression,
+        which makes debugging and exception messages easier to understand - for instance, the default
+        name created for the C{Word} expression without calling C{setName} is C{"W:(ABCD...)"}.
+        """
+        if flag:
+            self.setDebugActions( _defaultStartDebugAction, _defaultSuccessDebugAction, _defaultExceptionDebugAction )
+        else:
+            self.debug = False
+        return self
+
+    def __str__( self ):
+        return self.name
+
+    def __repr__( self ):
+        return _ustr(self)
+
+    def streamline( self ):
+        self.streamlined = True
+        self.strRepr = None
+        return self
+
+    def checkRecursion( self, parseElementList ):
+        pass
+
+    def validate( self, validateTrace=[] ):
+        """
+        Check defined expressions for valid structure, check for infinite recursive definitions.
+        """
+        self.checkRecursion( [] )
+
+    def parseFile( self, file_or_filename, parseAll=False ):
+        """
+        Execute the parse expression on the given file or filename.
+        If a filename is specified (instead of a file object),
+        the entire file is opened, read, and closed before parsing.
+        """
+        try:
+            file_contents = file_or_filename.read()
+        except AttributeError:
+            with open(file_or_filename, "r") as f:
+                file_contents = f.read()
+        try:
+            return self.parseString(file_contents, parseAll)
+        except ParseBaseException as exc:
+            if ParserElement.verbose_stacktrace:
+                raise
+            else:
+                # catch and re-raise exception from here, clears out pyparsing internal stack trace
+                raise exc
+
+    def __eq__(self,other):
+        if isinstance(other, ParserElement):
+            return self is other or vars(self) == vars(other)
+        elif isinstance(other, basestring):
+            return self.matches(other)
+        else:
+            return super(ParserElement,self)==other
+
+    def __ne__(self,other):
+        return not (self == other)
+
+    def __hash__(self):
+        return hash(id(self))
+
+    def __req__(self,other):
+        return self == other
+
+    def __rne__(self,other):
+        return not (self == other)
+
+    def matches(self, testString, parseAll=True):
+        """
+        Method for quick testing of a parser against a test string. Good for simple 
+        inline microtests of sub expressions while building up larger parser.
+           
+        Parameters:
+         - testString - to test against this expression for a match
+         - parseAll - (default=C{True}) - flag to pass to C{L{parseString}} when running tests
+            
+        Example::
+            expr = Word(nums)
+            assert expr.matches("100")
+        """
+        try:
+            self.parseString(_ustr(testString), parseAll=parseAll)
+            return True
+        except ParseBaseException:
+            return False
+                
+    def runTests(self, tests, parseAll=True, comment='#', fullDump=True, printResults=True, failureTests=False):
+        """
+        Execute the parse expression on a series of test strings, showing each
+        test, the parsed results or where the parse failed. Quick and easy way to
+        run a parse expression against a list of sample strings.
+           
+        Parameters:
+         - tests - a list of separate test strings, or a multiline string of test strings
+         - parseAll - (default=C{True}) - flag to pass to C{L{parseString}} when running tests           
+         - comment - (default=C{'#'}) - expression for indicating embedded comments in the test 
+              string; pass None to disable comment filtering
+         - fullDump - (default=C{True}) - dump results as list followed by results names in nested outline;
+              if False, only dump nested list
+         - printResults - (default=C{True}) prints test output to stdout
+         - failureTests - (default=C{False}) indicates if these tests are expected to fail parsing
+
+        Returns: a (success, results) tuple, where success indicates that all tests succeeded
+        (or failed if C{failureTests} is True), and the results contain a list of lines of each 
+        test's output
+        
+        Example::
+            number_expr = pyparsing_common.number.copy()
+
+            result = number_expr.runTests('''
+                # unsigned integer
+                100
+                # negative integer
+                -100
+                # float with scientific notation
+                6.02e23
+                # integer with scientific notation
+                1e-12
+                ''')
+            print("Success" if result[0] else "Failed!")
+
+            result = number_expr.runTests('''
+                # stray character
+                100Z
+                # missing leading digit before '.'
+                -.100
+                # too many '.'
+                3.14.159
+                ''', failureTests=True)
+            print("Success" if result[0] else "Failed!")
+        prints::
+            # unsigned integer
+            100
+            [100]
+
+            # negative integer
+            -100
+            [-100]
+
+            # float with scientific notation
+            6.02e23
+            [6.02e+23]
+
+            # integer with scientific notation
+            1e-12
+            [1e-12]
+
+            Success
+            
+            # stray character
+            100Z
+               ^
+            FAIL: Expected end of text (at char 3), (line:1, col:4)
+
+            # missing leading digit before '.'
+            -.100
+            ^
+            FAIL: Expected {real number with scientific notation | real number | signed integer} (at char 0), (line:1, col:1)
+
+            # too many '.'
+            3.14.159
+                ^
+            FAIL: Expected end of text (at char 4), (line:1, col:5)
+
+            Success
+
+        Each test string must be on a single line. If you want to test a string that spans multiple
+        lines, create a test like this::
+
+            expr.runTest(r"this is a test\\n of strings that spans \\n 3 lines")
+        
+        (Note that this is a raw string literal, you must include the leading 'r'.)
+        """
+        if isinstance(tests, basestring):
+            tests = list(map(str.strip, tests.rstrip().splitlines()))
+        if isinstance(comment, basestring):
+            comment = Literal(comment)
+        allResults = []
+        comments = []
+        success = True
+        for t in tests:
+            if comment is not None and comment.matches(t, False) or comments and not t:
+                comments.append(t)
+                continue
+            if not t:
+                continue
+            out = ['\n'.join(comments), t]
+            comments = []
+            try:
+                t = t.replace(r'\n','\n')
+                result = self.parseString(t, parseAll=parseAll)
+                out.append(result.dump(full=fullDump))
+                success = success and not failureTests
+            except ParseBaseException as pe:
+                fatal = "(FATAL)" if isinstance(pe, ParseFatalException) else ""
+                if '\n' in t:
+                    out.append(line(pe.loc, t))
+                    out.append(' '*(col(pe.loc,t)-1) + '^' + fatal)
+                else:
+                    out.append(' '*pe.loc + '^' + fatal)
+                out.append("FAIL: " + str(pe))
+                success = success and failureTests
+                result = pe
+            except Exception as exc:
+                out.append("FAIL-EXCEPTION: " + str(exc))
+                success = success and failureTests
+                result = exc
+
+            if printResults:
+                if fullDump:
+                    out.append('')
+                print('\n'.join(out))
+
+            allResults.append((t, result))
+        
+        return success, allResults
+
+        
+class Token(ParserElement):
+    """
+    Abstract C{ParserElement} subclass, for defining atomic matching patterns.
+    """
+    def __init__( self ):
+        super(Token,self).__init__( savelist=False )
+
+
+class Empty(Token):
+    """
+    An empty token, will always match.
+    """
+    def __init__( self ):
+        super(Empty,self).__init__()
+        self.name = "Empty"
+        self.mayReturnEmpty = True
+        self.mayIndexError = False
+
+
+class NoMatch(Token):
+    """
+    A token that will never match.
+    """
+    def __init__( self ):
+        super(NoMatch,self).__init__()
+        self.name = "NoMatch"
+        self.mayReturnEmpty = True
+        self.mayIndexError = False
+        self.errmsg = "Unmatchable token"
+
+    def parseImpl( self, instring, loc, doActions=True ):
+        raise ParseException(instring, loc, self.errmsg, self)
+
+
+class Literal(Token):
+    """
+    Token to exactly match a specified string.
+    
+    Example::
+        Literal('blah').parseString('blah')  # -> ['blah']
+        Literal('blah').parseString('blahfooblah')  # -> ['blah']
+        Literal('blah').parseString('bla')  # -> Exception: Expected "blah"
+    
+    For case-insensitive matching, use L{CaselessLiteral}.
+    
+    For keyword matching (force word break before and after the matched string),
+    use L{Keyword} or L{CaselessKeyword}.
+    """
+    def __init__( self, matchString ):
+        super(Literal,self).__init__()
+        self.match = matchString
+        self.matchLen = len(matchString)
+        try:
+            self.firstMatchChar = matchString[0]
+        except IndexError:
+            warnings.warn("null string passed to Literal; use Empty() instead",
+                            SyntaxWarning, stacklevel=2)
+            self.__class__ = Empty
+        self.name = '"%s"' % _ustr(self.match)
+        self.errmsg = "Expected " + self.name
+        self.mayReturnEmpty = False
+        self.mayIndexError = False
+
+    # Performance tuning: this routine gets called a *lot*
+    # if this is a single character match string  and the first character matches,
+    # short-circuit as quickly as possible, and avoid calling startswith
+    #~ @profile
+    def parseImpl( self, instring, loc, doActions=True ):
+        if (instring[loc] == self.firstMatchChar and
+            (self.matchLen==1 or instring.startswith(self.match,loc)) ):
+            return loc+self.matchLen, self.match
+        raise ParseException(instring, loc, self.errmsg, self)
+_L = Literal
+ParserElement._literalStringClass = Literal
+
+class Keyword(Token):
+    """
+    Token to exactly match a specified string as a keyword, that is, it must be
+    immediately followed by a non-keyword character.  Compare with C{L{Literal}}:
+     - C{Literal("if")} will match the leading C{'if'} in C{'ifAndOnlyIf'}.
+     - C{Keyword("if")} will not; it will only match the leading C{'if'} in C{'if x=1'}, or C{'if(y==2)'}
+    Accepts two optional constructor arguments in addition to the keyword string:
+     - C{identChars} is a string of characters that would be valid identifier characters,
+          defaulting to all alphanumerics + "_" and "$"
+     - C{caseless} allows case-insensitive matching, default is C{False}.
+       
+    Example::
+        Keyword("start").parseString("start")  # -> ['start']
+        Keyword("start").parseString("starting")  # -> Exception
+
+    For case-insensitive matching, use L{CaselessKeyword}.
+    """
+    DEFAULT_KEYWORD_CHARS = alphanums+"_$"
+
+    def __init__( self, matchString, identChars=None, caseless=False ):
+        super(Keyword,self).__init__()
+        if identChars is None:
+            identChars = Keyword.DEFAULT_KEYWORD_CHARS
+        self.match = matchString
+        self.matchLen = len(matchString)
+        try:
+            self.firstMatchChar = matchString[0]
+        except IndexError:
+            warnings.warn("null string passed to Keyword; use Empty() instead",
+                            SyntaxWarning, stacklevel=2)
+        self.name = '"%s"' % self.match
+        self.errmsg = "Expected " + self.name
+        self.mayReturnEmpty = False
+        self.mayIndexError = False
+        self.caseless = caseless
+        if caseless:
+            self.caselessmatch = matchString.upper()
+            identChars = identChars.upper()
+        self.identChars = set(identChars)
+
+    def parseImpl( self, instring, loc, doActions=True ):
+        if self.caseless:
+            if ( (instring[ loc:loc+self.matchLen ].upper() == self.caselessmatch) and
+                 (loc >= len(instring)-self.matchLen or instring[loc+self.matchLen].upper() not in self.identChars) and
+                 (loc == 0 or instring[loc-1].upper() not in self.identChars) ):
+                return loc+self.matchLen, self.match
+        else:
+            if (instring[loc] == self.firstMatchChar and
+                (self.matchLen==1 or instring.startswith(self.match,loc)) and
+                (loc >= len(instring)-self.matchLen or instring[loc+self.matchLen] not in self.identChars) and
+                (loc == 0 or instring[loc-1] not in self.identChars) ):
+                return loc+self.matchLen, self.match
+        raise ParseException(instring, loc, self.errmsg, self)
+
+    def copy(self):
+        c = super(Keyword,self).copy()
+        c.identChars = Keyword.DEFAULT_KEYWORD_CHARS
+        return c
+
+    @staticmethod
+    def setDefaultKeywordChars( chars ):
+        """Overrides the default Keyword chars
+        """
+        Keyword.DEFAULT_KEYWORD_CHARS = chars
+
+class CaselessLiteral(Literal):
+    """
+    Token to match a specified string, ignoring case of letters.
+    Note: the matched results will always be in the case of the given
+    match string, NOT the case of the input text.
+
+    Example::
+        OneOrMore(CaselessLiteral("CMD")).parseString("cmd CMD Cmd10") # -> ['CMD', 'CMD', 'CMD']
+        
+    (Contrast with example for L{CaselessKeyword}.)
+    """
+    def __init__( self, matchString ):
+        super(CaselessLiteral,self).__init__( matchString.upper() )
+        # Preserve the defining literal.
+        self.returnString = matchString
+        self.name = "'%s'" % self.returnString
+        self.errmsg = "Expected " + self.name
+
+    def parseImpl( self, instring, loc, doActions=True ):
+        if instring[ loc:loc+self.matchLen ].upper() == self.match:
+            return loc+self.matchLen, self.returnString
+        raise ParseException(instring, loc, self.errmsg, self)
+
+class CaselessKeyword(Keyword):
+    """
+    Caseless version of L{Keyword}.
+
+    Example::
+        OneOrMore(CaselessKeyword("CMD")).parseString("cmd CMD Cmd10") # -> ['CMD', 'CMD']
+        
+    (Contrast with example for L{CaselessLiteral}.)
+    """
+    def __init__( self, matchString, identChars=None ):
+        super(CaselessKeyword,self).__init__( matchString, identChars, caseless=True )
+
+    def parseImpl( self, instring, loc, doActions=True ):
+        if ( (instring[ loc:loc+self.matchLen ].upper() == self.caselessmatch) and
+             (loc >= len(instring)-self.matchLen or instring[loc+self.matchLen].upper() not in self.identChars) ):
+            return loc+self.matchLen, self.match
+        raise ParseException(instring, loc, self.errmsg, self)
+
+class CloseMatch(Token):
+    """
+    A variation on L{Literal} which matches "close" matches, that is, 
+    strings with at most 'n' mismatching characters. C{CloseMatch} takes parameters:
+     - C{match_string} - string to be matched
+     - C{maxMismatches} - (C{default=1}) maximum number of mismatches allowed to count as a match
+    
+    The results from a successful parse will contain the matched text from the input string and the following named results:
+     - C{mismatches} - a list of the positions within the match_string where mismatches were found
+     - C{original} - the original match_string used to compare against the input string
+    
+    If C{mismatches} is an empty list, then the match was an exact match.
+    
+    Example::
+        patt = CloseMatch("ATCATCGAATGGA")
+        patt.parseString("ATCATCGAAXGGA") # -> (['ATCATCGAAXGGA'], {'mismatches': [[9]], 'original': ['ATCATCGAATGGA']})
+        patt.parseString("ATCAXCGAAXGGA") # -> Exception: Expected 'ATCATCGAATGGA' (with up to 1 mismatches) (at char 0), (line:1, col:1)
+
+        # exact match
+        patt.parseString("ATCATCGAATGGA") # -> (['ATCATCGAATGGA'], {'mismatches': [[]], 'original': ['ATCATCGAATGGA']})
+
+        # close match allowing up to 2 mismatches
+        patt = CloseMatch("ATCATCGAATGGA", maxMismatches=2)
+        patt.parseString("ATCAXCGAAXGGA") # -> (['ATCAXCGAAXGGA'], {'mismatches': [[4, 9]], 'original': ['ATCATCGAATGGA']})
+    """
+    def __init__(self, match_string, maxMismatches=1):
+        super(CloseMatch,self).__init__()
+        self.name = match_string
+        self.match_string = match_string
+        self.maxMismatches = maxMismatches
+        self.errmsg = "Expected %r (with up to %d mismatches)" % (self.match_string, self.maxMismatches)
+        self.mayIndexError = False
+        self.mayReturnEmpty = False
+
+    def parseImpl( self, instring, loc, doActions=True ):
+        start = loc
+        instrlen = len(instring)
+        maxloc = start + len(self.match_string)
+
+        if maxloc <= instrlen:
+            match_string = self.match_string
+            match_stringloc = 0
+            mismatches = []
+            maxMismatches = self.maxMismatches
+
+            for match_stringloc,s_m in enumerate(zip(instring[loc:maxloc], self.match_string)):
+                src,mat = s_m
+                if src != mat:
+                    mismatches.append(match_stringloc)
+                    if len(mismatches) > maxMismatches:
+                        break
+            else:
+                loc = match_stringloc + 1
+                results = ParseResults([instring[start:loc]])
+                results['original'] = self.match_string
+                results['mismatches'] = mismatches
+                return loc, results
+
+        raise ParseException(instring, loc, self.errmsg, self)
+
+
+class Word(Token):
+    """
+    Token for matching words composed of allowed character sets.
+    Defined with string containing all allowed initial characters,
+    an optional string containing allowed body characters (if omitted,
+    defaults to the initial character set), and an optional minimum,
+    maximum, and/or exact length.  The default value for C{min} is 1 (a
+    minimum value < 1 is not valid); the default values for C{max} and C{exact}
+    are 0, meaning no maximum or exact length restriction. An optional
+    C{excludeChars} parameter can list characters that might be found in 
+    the input C{bodyChars} string; useful to define a word of all printables
+    except for one or two characters, for instance.
+    
+    L{srange} is useful for defining custom character set strings for defining 
+    C{Word} expressions, using range notation from regular expression character sets.
+    
+    A common mistake is to use C{Word} to match a specific literal string, as in 
+    C{Word("Address")}. Remember that C{Word} uses the string argument to define
+    I{sets} of matchable characters. This expression would match "Add", "AAA",
+    "dAred", or any other word made up of the characters 'A', 'd', 'r', 'e', and 's'.
+    To match an exact literal string, use L{Literal} or L{Keyword}.
+
+    pyparsing includes helper strings for building Words:
+     - L{alphas}
+     - L{nums}
+     - L{alphanums}
+     - L{hexnums}
+     - L{alphas8bit} (alphabetic characters in ASCII range 128-255 - accented, tilded, umlauted, etc.)
+     - L{punc8bit} (non-alphabetic characters in ASCII range 128-255 - currency, symbols, superscripts, diacriticals, etc.)
+     - L{printables} (any non-whitespace character)
+
+    Example::
+        # a word composed of digits
+        integer = Word(nums) # equivalent to Word("0123456789") or Word(srange("0-9"))
+        
+        # a word with a leading capital, and zero or more lowercase
+        capital_word = Word(alphas.upper(), alphas.lower())
+
+        # hostnames are alphanumeric, with leading alpha, and '-'
+        hostname = Word(alphas, alphanums+'-')
+        
+        # roman numeral (not a strict parser, accepts invalid mix of characters)
+        roman = Word("IVXLCDM")
+        
+        # any string of non-whitespace characters, except for ','
+        csv_value = Word(printables, excludeChars=",")
+    """
+    def __init__( self, initChars, bodyChars=None, min=1, max=0, exact=0, asKeyword=False, excludeChars=None ):
+        super(Word,self).__init__()
+        if excludeChars:
+            initChars = ''.join(c for c in initChars if c not in excludeChars)
+            if bodyChars:
+                bodyChars = ''.join(c for c in bodyChars if c not in excludeChars)
+        self.initCharsOrig = initChars
+        self.initChars = set(initChars)
+        if bodyChars :
+            self.bodyCharsOrig = bodyChars
+            self.bodyChars = set(bodyChars)
+        else:
+            self.bodyCharsOrig = initChars
+            self.bodyChars = set(initChars)
+
+        self.maxSpecified = max > 0
+
+        if min < 1:
+            raise ValueError("cannot specify a minimum length < 1; use Optional(Word()) if zero-length word is permitted")
+
+        self.minLen = min
+
+        if max > 0:
+            self.maxLen = max
+        else:
+            self.maxLen = _MAX_INT
+
+        if exact > 0:
+            self.maxLen = exact
+            self.minLen = exact
+
+        self.name = _ustr(self)
+        self.errmsg = "Expected " + self.name
+        self.mayIndexError = False
+        self.asKeyword = asKeyword
+
+        if ' ' not in self.initCharsOrig+self.bodyCharsOrig and (min==1 and max==0 and exact==0):
+            if self.bodyCharsOrig == self.initCharsOrig:
+                self.reString = "[%s]+" % _escapeRegexRangeChars(self.initCharsOrig)
+            elif len(self.initCharsOrig) == 1:
+                self.reString = "%s[%s]*" % \
+                                      (re.escape(self.initCharsOrig),
+                                      _escapeRegexRangeChars(self.bodyCharsOrig),)
+            else:
+                self.reString = "[%s][%s]*" % \
+                                      (_escapeRegexRangeChars(self.initCharsOrig),
+                                      _escapeRegexRangeChars(self.bodyCharsOrig),)
+            if self.asKeyword:
+                self.reString = r"\b"+self.reString+r"\b"
+            try:
+                self.re = re.compile( self.reString )
+            except Exception:
+                self.re = None
+
+    def parseImpl( self, instring, loc, doActions=True ):
+        if self.re:
+            result = self.re.match(instring,loc)
+            if not result:
+                raise ParseException(instring, loc, self.errmsg, self)
+
+            loc = result.end()
+            return loc, result.group()
+
+        if not(instring[ loc ] in self.initChars):
+            raise ParseException(instring, loc, self.errmsg, self)
+
+        start = loc
+        loc += 1
+        instrlen = len(instring)
+        bodychars = self.bodyChars
+        maxloc = start + self.maxLen
+        maxloc = min( maxloc, instrlen )
+        while loc < maxloc and instring[loc] in bodychars:
+            loc += 1
+
+        throwException = False
+        if loc - start < self.minLen:
+            throwException = True
+        if self.maxSpecified and loc < instrlen and instring[loc] in bodychars:
+            throwException = True
+        if self.asKeyword:
+            if (start>0 and instring[start-1] in bodychars) or (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 Regex(Token):
+    r"""
+    Token for matching strings that match a given regular expression.
+    Defined with string specifying the regular expression in a form recognized by the inbuilt Python re module.
+    If the given regex contains named groups (defined using C{(?P<name>...)}), these will be preserved as 
+    named parse results.
+
+    Example::
+        realnum = Regex(r"[+-]?\d+\.\d*")
+        date = Regex(r'(?P<year>\d{4})-(?P<month>\d\d?)-(?P<day>\d\d?)')
+        # ref: http://stackoverflow.com/questions/267399/how-do-you-match-only-valid-roman-numerals-with-a-regular-expression
+        roman = Regex(r"M{0,4}(CM|CD|D?C{0,3})(XC|XL|L?X{0,3})(IX|IV|V?I{0,3})")
+    """
+    compiledREtype = type(re.compile("[A-Z]"))
+    def __init__( self, pattern, flags=0):
+        """The parameters C{pattern} and C{flags} are passed to the C{re.compile()} function as-is. See the Python C{re} module for an explanation of the acceptable patterns and flags."""
+        super(Regex,self).__init__()
+
+        if isinstance(pattern, basestring):
+            if not pattern:
+                warnings.warn("null string passed to Regex; use Empty() instead",
+                        SyntaxWarning, stacklevel=2)
+
+            self.pattern = pattern
+            self.flags = flags
+
+            try:
+                self.re = re.compile(self.pattern, self.flags)
+                self.reString = self.pattern
+            except sre_constants.error:
+                warnings.warn("invalid pattern (%s) passed to Regex" % pattern,
+                    SyntaxWarning, stacklevel=2)
+                raise
+
+        elif isinstance(pattern, Regex.compiledREtype):
+            self.re = pattern
+            self.pattern = \
+            self.reString = str(pattern)
+            self.flags = flags
+            
+        else:
+            raise ValueError("Regex may only be constructed with a string or a compiled RE object")
+
+        self.name = _ustr(self)
+        self.errmsg = "Expected " + self.name
+        self.mayIndexError = False
+        self.mayReturnEmpty = True
+
+    def parseImpl( self, instring, loc, doActions=True ):
+        result = self.re.match(instring,loc)
+        if not result:
+            raise ParseException(instring, loc, self.errmsg, self)
+
+        loc = result.end()
+        d = result.groupdict()
+        ret = ParseResults(result.group())
+        if d:
+            for k in d:
+                ret[k] = d[k]
+        return loc,ret
+
+    def __str__( self ):
+        try:
+            return super(Regex,self).__str__()
+        except Exception:
+            pass
+
+        if self.strRepr is None:
+            self.strRepr = "Re:(%s)" % repr(self.pattern)
+
+        return self.strRepr
+
+
+class QuotedString(Token):
+    r"""
+    Token for matching strings that are delimited by quoting characters.
+    
+    Defined with the following parameters:
+        - quoteChar - string of one or more characters defining the quote delimiting string
+        - escChar - character to escape quotes, typically backslash (default=C{None})
+        - escQuote - special quote sequence to escape an embedded quote string (such as SQL's "" to escape an embedded ") (default=C{None})
+        - multiline - boolean indicating whether quotes can span multiple lines (default=C{False})
+        - unquoteResults - boolean indicating whether the matched text should be unquoted (default=C{True})
+        - endQuoteChar - string of one or more characters defining the end of the quote delimited string (default=C{None} => same as quoteChar)
+        - convertWhitespaceEscapes - convert escaped whitespace (C{'\t'}, C{'\n'}, etc.) to actual whitespace (default=C{True})
+
+    Example::
+        qs = QuotedString('"')
+        print(qs.searchString('lsjdf "This is the quote" sldjf'))
+        complex_qs = QuotedString('{{', endQuoteChar='}}')
+        print(complex_qs.searchString('lsjdf {{This is the "quote"}} sldjf'))
+        sql_qs = QuotedString('"', escQuote='""')
+        print(sql_qs.searchString('lsjdf "This is the quote with ""embedded"" quotes" sldjf'))
+    prints::
+        [['This is the quote']]
+        [['This is the "quote"']]
+        [['This is the quote with "embedded" quotes']]
+    """
+    def __init__( self, quoteChar, escChar=None, escQuote=None, multiline=False, unquoteResults=True, endQuoteChar=None, convertWhitespaceEscapes=True):
+        super(QuotedString,self).__init__()
+
+        # remove white space from quote chars - wont work anyway
+        quoteChar = quoteChar.strip()
+        if not quoteChar:
+            warnings.warn("quoteChar cannot be the empty string",SyntaxWarning,stacklevel=2)
+            raise SyntaxError()
+
+        if endQuoteChar is None:
+            endQuoteChar = quoteChar
+        else:
+            endQuoteChar = endQuoteChar.strip()
+            if not endQuoteChar:
+                warnings.warn("endQuoteChar cannot be the empty string",SyntaxWarning,stacklevel=2)
+                raise SyntaxError()
+
+        self.quoteChar = quoteChar
+        self.quoteCharLen = len(quoteChar)
+        self.firstQuoteChar = quoteChar[0]
+        self.endQuoteChar = endQuoteChar
+        self.endQuoteCharLen = len(endQuoteChar)
+        self.escChar = escChar
+        self.escQuote = escQuote
+        self.unquoteResults = unquoteResults
+        self.convertWhitespaceEscapes = convertWhitespaceEscapes
+
+        if multiline:
+            self.flags = re.MULTILINE | re.DOTALL
+            self.pattern = r'%s(?:[^%s%s]' % \
+                ( re.escape(self.quoteChar),
+                  _escapeRegexRangeChars(self.endQuoteChar[0]),
+                  (escChar is not None and _escapeRegexRangeChars(escChar) or '') )
+        else:
+            self.flags = 0
+            self.pattern = r'%s(?:[^%s\n\r%s]' % \
+                ( re.escape(self.quoteChar),
+                  _escapeRegexRangeChars(self.endQuoteChar[0]),
+                  (escChar is not None and _escapeRegexRangeChars(escChar) or '') )
+        if len(self.endQuoteChar) > 1:
+            self.pattern += (
+                '|(?:' + ')|(?:'.join("%s[^%s]" % (re.escape(self.endQuoteChar[:i]),
+                                               _escapeRegexRangeChars(self.endQuoteChar[i]))
+                                    for i in range(len(self.endQuoteChar)-1,0,-1)) + ')'
+                )
+        if escQuote:
+            self.pattern += (r'|(?:%s)' % re.escape(escQuote))
+        if escChar:
+            self.pattern += (r'|(?:%s.)' % re.escape(escChar))
+            self.escCharReplacePattern = re.escape(self.escChar)+"(.)"
+        self.pattern += (r')*%s' % re.escape(self.endQuoteChar))
+
+        try:
+            self.re = re.compile(self.pattern, self.flags)
+            self.reString = self.pattern
+        except sre_constants.error:
+            warnings.warn("invalid pattern (%s) passed to Regex" % self.pattern,
+                SyntaxWarning, stacklevel=2)
+            raise
+
+        self.name = _ustr(self)
+        self.errmsg = "Expected " + self.name
+        self.mayIndexError = False
+        self.mayReturnEmpty = True
+
+    def parseImpl( self, instring, loc, doActions=True ):
+        result = instring[loc] == self.firstQuoteChar and self.re.match(instring,loc) or None
+        if not result:
+            raise ParseException(instring, loc, self.errmsg, self)
+
+        loc = result.end()
+        ret = result.group()
+
+        if self.unquoteResults:
+
+            # strip off quotes
+            ret = ret[self.quoteCharLen:-self.endQuoteCharLen]
+
+            if isinstance(ret,basestring):
+                # replace escaped whitespace
+                if '\\' in ret and self.convertWhitespaceEscapes:
+                    ws_map = {
+                        r'\t' : '\t',
+                        r'\n' : '\n',
+                        r'\f' : '\f',
+                        r'\r' : '\r',
+                    }
+                    for wslit,wschar in ws_map.items():
+                        ret = ret.replace(wslit, wschar)
+
+                # replace escaped characters
+                if self.escChar:
+                    ret = re.sub(self.escCharReplacePattern, r"\g<1>", ret)
+
+                # replace escaped quotes
+                if self.escQuote:
+                    ret = ret.replace(self.escQuote, self.endQuoteChar)
+
+        return loc, ret
+
+    def __str__( self ):
+        try:
+            return super(QuotedString,self).__str__()
+        except Exception:
+            pass
+
+        if self.strRepr is None:
+            self.strRepr = "quoted string, starting with %s ending with %s" % (self.quoteChar, self.endQuoteChar)
+
+        return self.strRepr
+
+
+class CharsNotIn(Token):
+    """
+    Token for matching words composed of characters I{not} in a given set (will
+    include whitespace in matched characters if not listed in the provided exclusion set - see example).
+    Defined with string containing all disallowed characters, and an optional
+    minimum, maximum, and/or exact length.  The default value for C{min} is 1 (a
+    minimum value < 1 is not valid); the default values for C{max} and C{exact}
+    are 0, meaning no maximum or exact length restriction.
+
+    Example::
+        # define a comma-separated-value as anything that is not a ','
+        csv_value = CharsNotIn(',')
+        print(delimitedList(csv_value).parseString("dkls,lsdkjf,s12 34,@!#,213"))
+    prints::
+        ['dkls', 'lsdkjf', 's12 34', '@!#', '213']
+    """
+    def __init__( self, notChars, min=1, max=0, exact=0 ):
+        super(CharsNotIn,self).__init__()
+        self.skipWhitespace = False
+        self.notChars = notChars
+
+        if min < 1:
+            raise ValueError("cannot specify a minimum length < 1; use Optional(CharsNotIn()) if zero-length char group is permitted")
+
+        self.minLen = min
+
+        if max > 0:
+            self.maxLen = max
+        else:
+            self.maxLen = _MAX_INT
+
+        if exact > 0:
+            self.maxLen = exact
+            self.minLen = exact
+
+        self.name = _ustr(self)
+        self.errmsg = "Expected " + self.name
+        self.mayReturnEmpty = ( self.minLen == 0 )
+        self.mayIndexError = False
+
+    def parseImpl( self, instring, loc, doActions=True ):
+        if instring[loc] in self.notChars:
+            raise ParseException(instring, loc, self.errmsg, self)
+
+        start = loc
+        loc += 1
+        notchars = self.notChars
+        maxlen = min( start+self.maxLen, len(instring) )
+        while loc < maxlen and \
+              (instring[loc] not in notchars):
+            loc += 1
+
+        if loc - start < self.minLen:
+            raise ParseException(instring, loc, self.errmsg, self)
+
+        return loc, instring[start:loc]
+
+    def __str__( self ):
+        try:
+            return super(CharsNotIn, self).__str__()
+        except Exception:
+            pass
+
+        if self.strRepr is None:
+            if len(self.notChars) > 4:
+                self.strRepr = "!W:(%s...)" % self.notChars[:4]
+            else:
+                self.strRepr = "!W:(%s)" % self.notChars
+
+        return self.strRepr
+
+class White(Token):
+    """
+    Special matching class for matching whitespace.  Normally, whitespace is ignored
+    by pyparsing grammars.  This class is included when some whitespace structures
+    are significant.  Define with a string containing the whitespace characters to be
+    matched; default is C{" \\t\\r\\n"}.  Also takes optional C{min}, C{max}, and C{exact} arguments,
+    as defined for the C{L{Word}} class.
+    """
+    whiteStrs = {
+        " " : "<SPC>",
+        "\t": "<TAB>",
+        "\n": "<LF>",
+        "\r": "<CR>",
+        "\f": "<FF>",
+        }
+    def __init__(self, ws=" \t\r\n", min=1, max=0, exact=0):
+        super(White,self).__init__()
+        self.matchWhite = ws
+        self.setWhitespaceChars( "".join(c for c in self.whiteChars if c not in self.matchWhite) )
+        #~ self.leaveWhitespace()
+        self.name = ("".join(White.whiteStrs[c] for c in self.matchWhite))
+        self.mayReturnEmpty = True
+        self.errmsg = "Expected " + self.name
+
+        self.minLen = min
+
+        if max > 0:
+            self.maxLen = max
+        else:
+            self.maxLen = _MAX_INT
+
+        if exact > 0:
+            self.maxLen = exact
+            self.minLen = exact
+
+    def parseImpl( self, instring, loc, doActions=True ):
+        if not(instring[ loc ] in self.matchWhite):
+            raise ParseException(instring, loc, self.errmsg, self)
+        start = loc
+        loc += 1
+        maxloc = start + self.maxLen
+        maxloc = min( maxloc, len(instring) )
+        while loc < maxloc and instring[loc] in self.matchWhite:
+            loc += 1
+
+        if loc - start < self.minLen:
+            raise ParseException(instring, loc, self.errmsg, self)
+
+        return loc, instring[start:loc]
+
+
+class _PositionToken(Token):
+    def __init__( self ):
+        super(_PositionToken,self).__init__()
+        self.name=self.__class__.__name__
+        self.mayReturnEmpty = True
+        self.mayIndexError = False
+
+class GoToColumn(_PositionToken):
+    """
+    Token to advance to a specific column of input text; useful for tabular report scraping.
+    """
+    def __init__( self, colno ):
+        super(GoToColumn,self).__init__()
+        self.col = colno
+
+    def preParse( self, instring, loc ):
+        if col(loc,instring) != self.col:
+            instrlen = len(instring)
+            if self.ignoreExprs:
+                loc = self._skipIgnorables( instring, loc )
+            while loc < instrlen and instring[loc].isspace() and col( loc, instring ) != self.col :
+                loc += 1
+        return loc
+
+    def parseImpl( self, instring, loc, doActions=True ):
+        thiscol = col( loc, instring )
+        if thiscol > self.col:
+            raise ParseException( instring, loc, "Text not in expected column", self )
+        newloc = loc + self.col - thiscol
+        ret = instring[ loc: newloc ]
+        return newloc, ret
+
+
+class LineStart(_PositionToken):
+    """
+    Matches if current position is at the beginning of a line within the parse string
+    
+    Example::
+    
+        test = '''\
+        AAA this line
+        AAA and this line
+          AAA but not this one
+        B AAA and definitely not this one
+        '''
+
+        for t in (LineStart() + 'AAA' + restOfLine).searchString(test):
+            print(t)
+    
+    Prints::
+        ['AAA', ' this line']
+        ['AAA', ' and this line']    
+
+    """
+    def __init__( self ):
+        super(LineStart,self).__init__()
+        self.errmsg = "Expected start of line"
+
+    def parseImpl( self, instring, loc, doActions=True ):
+        if col(loc, instring) == 1:
+            return loc, []
+        raise ParseException(instring, loc, self.errmsg, self)
+
+class LineEnd(_PositionToken):
+    """
+    Matches if current position is at the end of a line within the parse string
+    """
+    def __init__( self ):
+        super(LineEnd,self).__init__()
+        self.setWhitespaceChars( ParserElement.DEFAULT_WHITE_CHARS.replace("\n","") )
+        self.errmsg = "Expected end of line"
+
+    def parseImpl( self, instring, loc, doActions=True ):
+        if loc<len(instring):
+            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 C{wordChars}
+    (default=C{printables}). To emulate the C{\b} behavior of regular expressions,
+    use C{WordStart(alphanums)}. C{WordStart} will also match at the beginning of
+    the string being parsed, or at the beginning of a line.
+    """
+    def __init__(self, wordChars = printables):
+        super(WordStart,self).__init__()
+        self.wordChars = set(wordChars)
+        self.errmsg = "Not at the start of a word"
+
+    def parseImpl(self, instring, loc, doActions=True ):
+        if loc != 0:
+            if (instring[loc-1] in self.wordChars or
+                instring[loc] not in self.wordChars):
+                raise ParseException(instring, loc, self.errmsg, self)
+        return loc, []
+
+class WordEnd(_PositionToken):
+    """
+    Matches if the current position is at the end of a Word, and
+    is not followed by any character in a given set of C{wordChars}
+    (default=C{printables}). To emulate the C{\b} behavior of regular expressions,
+    use C{WordEnd(alphanums)}. C{WordEnd} will also match at the end of
+    the string being parsed, or at the end of a line.
+    """
+    def __init__(self, wordChars = printables):
+        super(WordEnd,self).__init__()
+        self.wordChars = set(wordChars)
+        self.skipWhitespace = False
+        self.errmsg = "Not at the end of a word"
+
+    def parseImpl(self, instring, loc, doActions=True ):
+        instrlen = len(instring)
+        if instrlen>0 and loc<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 = [ ParserElement._literalStringClass( exprs ) ]
+        elif isinstance( exprs, Iterable ):
+            exprs = list(exprs)
+            # if sequence of strings provided, wrap with Literal
+            if all(isinstance(expr, basestring) for expr in exprs):
+                exprs = map(ParserElement._literalStringClass, exprs)
+            self.exprs = list(exprs)
+        else:
+            try:
+                self.exprs = list( exprs )
+            except TypeError:
+                self.exprs = [ exprs ]
+        self.callPreparse = False
+
+    def __getitem__( self, i ):
+        return self.exprs[i]
+
+    def append( self, other ):
+        self.exprs.append( other )
+        self.strRepr = None
+        return self
+
+    def leaveWhitespace( self ):
+        """Extends C{leaveWhitespace} defined in base class, and also invokes C{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 setResultsName( self, name, listAllMatches=False ):
+        ret = super(ParseExpression,self).setResultsName(name,listAllMatches)
+        return ret
+
+    def validate( self, validateTrace=[] ):
+        tmp = validateTrace[:]+[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
+
+class And(ParseExpression):
+    """
+    Requires all given C{ParseExpression}s to be found in the given order.
+    Expressions may be separated by whitespace.
+    May be constructed using the C{'+'} operator.
+    May also be constructed using the C{'-'} 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 ):
+        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 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 = ParserElement._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 C{ParseExpression} is found.
+    If two expressions match, the expression that matches the longest string will be used.
+    May be constructed using the C{'^'} 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 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:
+            matches.sort(key=lambda x: -x[0])
+            for _,e in matches:
+                try:
+                    return e._parse( instring, loc, doActions )
+                except ParseException as err:
+                    err.__traceback__ = None
+                    if err.loc > maxExcLoc:
+                        maxException = err
+                        maxExcLoc = err.loc
+
+        if maxException is not None:
+            maxException.msg = self.errmsg
+            raise maxException
+        else:
+            raise ParseException(instring, loc, "no defined alternatives to match", self)
+
+
+    def __ixor__(self, other ):
+        if isinstance( other, basestring ):
+            other = ParserElement._literalStringClass( other )
+        return self.append( other ) #Or( [ self, other ] )
+
+    def __str__( self ):
+        if hasattr(self,"name"):
+            return self.name
+
+        if self.strRepr is None:
+            self.strRepr = "{" + " ^ ".join(_ustr(e) for e in self.exprs) + "}"
+
+        return self.strRepr
+
+    def checkRecursion( self, parseElementList ):
+        subRecCheckList = parseElementList[:] + [ self ]
+        for e in self.exprs:
+            e.checkRecursion( subRecCheckList )
+
+
+class MatchFirst(ParseExpression):
+    """
+    Requires that at least one C{ParseExpression} is found.
+    If two expressions match, the first one listed is the one that will match.
+    May be constructed using the C{'|'} operator.
+
+    Example::
+        # construct MatchFirst using '|' operator
+        
+        # watch the order of expressions to match
+        number = Word(nums) | Combine(Word(nums) + '.' + Word(nums))
+        print(number.searchString("123 3.1416 789")) #  Fail! -> [['123'], ['3'], ['1416'], ['789']]
+
+        # put more selective expression first
+        number = Combine(Word(nums) + '.' + Word(nums)) | Word(nums)
+        print(number.searchString("123 3.1416 789")) #  Better -> [['123'], ['3.1416'], ['789']]
+    """
+    def __init__( self, exprs, savelist = False ):
+        super(MatchFirst,self).__init__(exprs, savelist)
+        if self.exprs:
+            self.mayReturnEmpty = any(e.mayReturnEmpty for e in self.exprs)
+        else:
+            self.mayReturnEmpty = True
+
+    def parseImpl( self, instring, loc, doActions=True ):
+        maxExcLoc = -1
+        maxException = None
+        for e in self.exprs:
+            try:
+                ret = e._parse( instring, loc, doActions )
+                return ret
+            except ParseException as err:
+                if err.loc > maxExcLoc:
+                    maxException = err
+                    maxExcLoc = err.loc
+            except IndexError:
+                if len(instring) > maxExcLoc:
+                    maxException = ParseException(instring,len(instring),e.errmsg,self)
+                    maxExcLoc = len(instring)
+
+        # only got here if no expression matched, raise exception for match that made it the furthest
+        else:
+            if maxException is not None:
+                maxException.msg = self.errmsg
+                raise maxException
+            else:
+                raise ParseException(instring, loc, "no defined alternatives to match", self)
+
+    def __ior__(self, other ):
+        if isinstance( other, basestring ):
+            other = ParserElement._literalStringClass( other )
+        return self.append( other ) #MatchFirst( [ self, other ] )
+
+    def __str__( self ):
+        if hasattr(self,"name"):
+            return self.name
+
+        if self.strRepr is None:
+            self.strRepr = "{" + " | ".join(_ustr(e) for e in self.exprs) + "}"
+
+        return self.strRepr
+
+    def checkRecursion( self, parseElementList ):
+        subRecCheckList = parseElementList[:] + [ self ]
+        for e in self.exprs:
+            e.checkRecursion( subRecCheckList )
+
+
+class Each(ParseExpression):
+    """
+    Requires all given C{ParseExpression}s to be found, but in any order.
+    Expressions may be separated by whitespace.
+    May be constructed using the C{'&'} operator.
+
+    Example::
+        color = oneOf("RED ORANGE YELLOW GREEN BLUE PURPLE BLACK WHITE BROWN")
+        shape_type = oneOf("SQUARE CIRCLE TRIANGLE STAR HEXAGON OCTAGON")
+        integer = Word(nums)
+        shape_attr = "shape:" + shape_type("shape")
+        posn_attr = "posn:" + Group(integer("x") + ',' + integer("y"))("posn")
+        color_attr = "color:" + color("color")
+        size_attr = "size:" + integer("size")
+
+        # use Each (using operator '&') to accept attributes in any order 
+        # (shape and posn are required, color and size are optional)
+        shape_spec = shape_attr & posn_attr & Optional(color_attr) & Optional(size_attr)
+
+        shape_spec.runTests('''
+            shape: SQUARE color: BLACK posn: 100, 120
+            shape: CIRCLE size: 50 color: BLUE posn: 50,80
+            color:GREEN size:20 shape:TRIANGLE posn:20,40
+            '''
+            )
+    prints::
+        shape: SQUARE color: BLACK posn: 100, 120
+        ['shape:', 'SQUARE', 'color:', 'BLACK', 'posn:', ['100', ',', '120']]
+        - color: BLACK
+        - posn: ['100', ',', '120']
+          - x: 100
+          - y: 120
+        - shape: SQUARE
+
+
+        shape: CIRCLE size: 50 color: BLUE posn: 50,80
+        ['shape:', 'CIRCLE', 'size:', '50', 'color:', 'BLUE', 'posn:', ['50', ',', '80']]
+        - color: BLUE
+        - posn: ['50', ',', '80']
+          - x: 50
+          - y: 80
+        - shape: CIRCLE
+        - size: 50
+
+
+        color: GREEN size: 20 shape: TRIANGLE posn: 20,40
+        ['color:', 'GREEN', 'size:', '20', 'shape:', 'TRIANGLE', 'posn:', ['20', ',', '40']]
+        - color: GREEN
+        - posn: ['20', ',', '40']
+          - x: 20
+          - y: 40
+        - shape: TRIANGLE
+        - size: 20
+    """
+    def __init__( self, exprs, savelist = True ):
+        super(Each,self).__init__(exprs, savelist)
+        self.mayReturnEmpty = all(e.mayReturnEmpty for e in self.exprs)
+        self.skipWhitespace = True
+        self.initExprGroups = True
+
+    def parseImpl( self, instring, loc, doActions=True ):
+        if self.initExprGroups:
+            self.opt1map = dict((id(e.expr),e) for e in self.exprs if isinstance(e,Optional))
+            opt1 = [ e.expr for e in self.exprs if isinstance(e,Optional) ]
+            opt2 = [ e for e in self.exprs if e.mayReturnEmpty and not isinstance(e,Optional)]
+            self.optionals = opt1 + opt2
+            self.multioptionals = [ e.expr for e in self.exprs if isinstance(e,ZeroOrMore) ]
+            self.multirequired = [ e.expr for e in self.exprs if isinstance(e,OneOrMore) ]
+            self.required = [ e for e in self.exprs if not isinstance(e,(Optional,ZeroOrMore,OneOrMore)) ]
+            self.required += self.multirequired
+            self.initExprGroups = False
+        tmpLoc = loc
+        tmpReqd = self.required[:]
+        tmpOpt  = self.optionals[:]
+        matchOrder = []
+
+        keepMatching = True
+        while keepMatching:
+            tmpExprs = tmpReqd + tmpOpt + self.multioptionals + self.multirequired
+            failed = []
+            for e in tmpExprs:
+                try:
+                    tmpLoc = e.tryParse( instring, tmpLoc )
+                except ParseException:
+                    failed.append(e)
+                else:
+                    matchOrder.append(self.opt1map.get(id(e),e))
+                    if e in tmpReqd:
+                        tmpReqd.remove(e)
+                    elif e in tmpOpt:
+                        tmpOpt.remove(e)
+            if len(failed) == len(tmpExprs):
+                keepMatching = False
+
+        if tmpReqd:
+            missing = ", ".join(_ustr(e) for e in tmpReqd)
+            raise ParseException(instring,loc,"Missing one or more required elements (%s)" % missing )
+
+        # add any unmatched Optionals, in case they have default values defined
+        matchOrder += [e for e in self.exprs if isinstance(e,Optional) and e.expr in tmpOpt]
+
+        resultlist = []
+        for e in matchOrder:
+            loc,results = e._parse(instring,loc,doActions)
+            resultlist.append(results)
+
+        finalResults = sum(resultlist, ParseResults([]))
+        return loc, finalResults
+
+    def __str__( self ):
+        if hasattr(self,"name"):
+            return self.name
+
+        if self.strRepr is None:
+            self.strRepr = "{" + " & ".join(_ustr(e) for e in self.exprs) + "}"
+
+        return self.strRepr
+
+    def checkRecursion( self, parseElementList ):
+        subRecCheckList = parseElementList[:] + [ self ]
+        for e in self.exprs:
+            e.checkRecursion( subRecCheckList )
+
+
+class ParseElementEnhance(ParserElement):
+    """
+    Abstract subclass of C{ParserElement}, for combining and post-processing parsed tokens.
+    """
+    def __init__( self, expr, savelist=False ):
+        super(ParseElementEnhance,self).__init__(savelist)
+        if isinstance( expr, basestring ):
+            if issubclass(ParserElement._literalStringClass, Token):
+                expr = ParserElement._literalStringClass(expr)
+            else:
+                expr = ParserElement._literalStringClass(Literal(expr))
+        self.expr = expr
+        self.strRepr = None
+        if expr is not None:
+            self.mayIndexError = expr.mayIndexError
+            self.mayReturnEmpty = expr.mayReturnEmpty
+            self.setWhitespaceChars( expr.whiteChars )
+            self.skipWhitespace = expr.skipWhitespace
+            self.saveAsList = expr.saveAsList
+            self.callPreparse = expr.callPreparse
+            self.ignoreExprs.extend(expr.ignoreExprs)
+
+    def parseImpl( self, instring, loc, doActions=True ):
+        if self.expr is not None:
+            return self.expr._parse( instring, loc, doActions, callPreParse=False )
+        else:
+            raise ParseException("",loc,self.errmsg,self)
+
+    def leaveWhitespace( self ):
+        self.skipWhitespace = False
+        self.expr = self.expr.copy()
+        if self.expr is not None:
+            self.expr.leaveWhitespace()
+        return self
+
+    def ignore( self, other ):
+        if isinstance( other, Suppress ):
+            if other not in self.ignoreExprs:
+                super( ParseElementEnhance, self).ignore( other )
+                if self.expr is not None:
+                    self.expr.ignore( self.ignoreExprs[-1] )
+        else:
+            super( ParseElementEnhance, self).ignore( other )
+            if self.expr is not None:
+                self.expr.ignore( self.ignoreExprs[-1] )
+        return self
+
+    def streamline( self ):
+        super(ParseElementEnhance,self).streamline()
+        if self.expr is not None:
+            self.expr.streamline()
+        return self
+
+    def checkRecursion( self, parseElementList ):
+        if self in parseElementList:
+            raise RecursiveGrammarException( parseElementList+[self] )
+        subRecCheckList = parseElementList[:] + [ self ]
+        if self.expr is not None:
+            self.expr.checkRecursion( subRecCheckList )
+
+    def validate( self, validateTrace=[] ):
+        tmp = validateTrace[:]+[self]
+        if self.expr is not None:
+            self.expr.validate(tmp)
+        self.checkRecursion( [] )
+
+    def __str__( self ):
+        try:
+            return super(ParseElementEnhance,self).__str__()
+        except Exception:
+            pass
+
+        if self.strRepr is None and self.expr is not None:
+            self.strRepr = "%s:(%s)" % ( self.__class__.__name__, _ustr(self.expr) )
+        return self.strRepr
+
+
+class FollowedBy(ParseElementEnhance):
+    """
+    Lookahead matching of the given parse expression.  C{FollowedBy}
+    does I{not} advance the parsing position within the input string, it only
+    verifies that the specified parse expression matches at the current
+    position.  C{FollowedBy} always returns a null token list.
+
+    Example::
+        # use FollowedBy to match a label only if it is followed by a ':'
+        data_word = Word(alphas)
+        label = data_word + FollowedBy(':')
+        attr_expr = Group(label + Suppress(':') + OneOrMore(data_word, stopOn=label).setParseAction(' '.join))
+        
+        OneOrMore(attr_expr).parseString("shape: SQUARE color: BLACK posn: upper left").pprint()
+    prints::
+        [['shape', 'SQUARE'], ['color', 'BLACK'], ['posn', 'upper left']]
+    """
+    def __init__( self, expr ):
+        super(FollowedBy,self).__init__(expr)
+        self.mayReturnEmpty = True
+
+    def parseImpl( self, instring, loc, doActions=True ):
+        self.expr.tryParse( instring, loc )
+        return loc, []
+
+
+class NotAny(ParseElementEnhance):
+    """
+    Lookahead to disallow matching with the given parse expression.  C{NotAny}
+    does I{not} advance the parsing position within the input string, it only
+    verifies that the specified parse expression does I{not} match at the current
+    position.  Also, C{NotAny} does I{not} skip over leading whitespace. C{NotAny}
+    always returns a null token list.  May be constructed using the '~' operator.
+
+    Example::
+        
+    """
+    def __init__( self, expr ):
+        super(NotAny,self).__init__(expr)
+        #~ self.leaveWhitespace()
+        self.skipWhitespace = False  # do NOT use self.leaveWhitespace(), don't want to propagate to exprs
+        self.mayReturnEmpty = True
+        self.errmsg = "Found unwanted token, "+_ustr(self.expr)
+
+    def parseImpl( self, instring, loc, doActions=True ):
+        if self.expr.canParseNext(instring, loc):
+            raise ParseException(instring, loc, self.errmsg, self)
+        return loc, []
+
+    def __str__( self ):
+        if hasattr(self,"name"):
+            return self.name
+
+        if self.strRepr is None:
+            self.strRepr = "~{" + _ustr(self.expr) + "}"
+
+        return self.strRepr
+
+class _MultipleMatch(ParseElementEnhance):
+    def __init__( self, expr, stopOn=None):
+        super(_MultipleMatch, self).__init__(expr)
+        self.saveAsList = True
+        ender = stopOn
+        if isinstance(ender, basestring):
+            ender = ParserElement._literalStringClass(ender)
+        self.not_ender = ~ender if ender is not None else None
+
+    def parseImpl( self, instring, loc, doActions=True ):
+        self_expr_parse = self.expr._parse
+        self_skip_ignorables = self._skipIgnorables
+        check_ender = self.not_ender is not None
+        if check_ender:
+            try_not_ender = self.not_ender.tryParse
+        
+        # must be at least one (but first see if we are the stopOn sentinel;
+        # if so, fail)
+        if check_ender:
+            try_not_ender(instring, loc)
+        loc, tokens = self_expr_parse( instring, loc, doActions, callPreParse=False )
+        try:
+            hasIgnoreExprs = (not not self.ignoreExprs)
+            while 1:
+                if check_ender:
+                    try_not_ender(instring, loc)
+                if hasIgnoreExprs:
+                    preloc = self_skip_ignorables( instring, loc )
+                else:
+                    preloc = loc
+                loc, tmptokens = self_expr_parse( instring, preloc, doActions )
+                if tmptokens or tmptokens.haskeys():
+                    tokens += tmptokens
+        except (ParseException,IndexError):
+            pass
+
+        return loc, tokens
+        
+class OneOrMore(_MultipleMatch):
+    """
+    Repetition of one or more of the given expression.
+    
+    Parameters:
+     - expr - expression that must match one or more times
+     - stopOn - (default=C{None}) - expression for a terminating sentinel
+          (only required if the sentinel would ordinarily match the repetition 
+          expression)          
+
+    Example::
+        data_word = Word(alphas)
+        label = data_word + FollowedBy(':')
+        attr_expr = Group(label + Suppress(':') + OneOrMore(data_word).setParseAction(' '.join))
+
+        text = "shape: SQUARE posn: upper left color: BLACK"
+        OneOrMore(attr_expr).parseString(text).pprint()  # Fail! read 'color' as data instead of next label -> [['shape', 'SQUARE color']]
+
+        # use stopOn attribute for OneOrMore to avoid reading label string as part of the data
+        attr_expr = Group(label + Suppress(':') + OneOrMore(data_word, stopOn=label).setParseAction(' '.join))
+        OneOrMore(attr_expr).parseString(text).pprint() # Better -> [['shape', 'SQUARE'], ['posn', 'upper left'], ['color', 'BLACK']]
+        
+        # could also be written as
+        (attr_expr * (1,)).parseString(text).pprint()
+    """
+
+    def __str__( self ):
+        if hasattr(self,"name"):
+            return self.name
+
+        if self.strRepr is None:
+            self.strRepr = "{" + _ustr(self.expr) + "}..."
+
+        return self.strRepr
+
+class ZeroOrMore(_MultipleMatch):
+    """
+    Optional repetition of zero or more of the given expression.
+    
+    Parameters:
+     - expr - expression that must match zero or more times
+     - stopOn - (default=C{None}) - expression for a terminating sentinel
+          (only required if the sentinel would ordinarily match the repetition 
+          expression)          
+
+    Example: similar to L{OneOrMore}
+    """
+    def __init__( self, expr, stopOn=None):
+        super(ZeroOrMore,self).__init__(expr, stopOn=stopOn)
+        self.mayReturnEmpty = True
+        
+    def parseImpl( self, instring, loc, doActions=True ):
+        try:
+            return super(ZeroOrMore, self).parseImpl(instring, loc, doActions)
+        except (ParseException,IndexError):
+            return loc, []
+
+    def __str__( self ):
+        if hasattr(self,"name"):
+            return self.name
+
+        if self.strRepr is None:
+            self.strRepr = "[" + _ustr(self.expr) + "]..."
+
+        return self.strRepr
+
+class _NullToken(object):
+    def __bool__(self):
+        return False
+    __nonzero__ = __bool__
+    def __str__(self):
+        return ""
+
+_optionalNotMatched = _NullToken()
+class Optional(ParseElementEnhance):
+    """
+    Optional matching of the given expression.
+
+    Parameters:
+     - expr - expression that must match zero or more times
+     - default (optional) - value to be returned if the optional expression is not found.
+
+    Example::
+        # US postal code can be a 5-digit zip, plus optional 4-digit qualifier
+        zip = Combine(Word(nums, exact=5) + Optional('-' + Word(nums, exact=4)))
+        zip.runTests('''
+            # traditional ZIP code
+            12345
+            
+            # ZIP+4 form
+            12101-0001
+            
+            # invalid ZIP
+            98765-
+            ''')
+    prints::
+        # traditional ZIP code
+        12345
+        ['12345']
+
+        # ZIP+4 form
+        12101-0001
+        ['12101-0001']
+
+        # invalid ZIP
+        98765-
+             ^
+        FAIL: Expected end of text (at char 5), (line:1, col:6)
+    """
+    def __init__( self, expr, default=_optionalNotMatched ):
+        super(Optional,self).__init__( expr, savelist=False )
+        self.saveAsList = self.expr.saveAsList
+        self.defaultValue = default
+        self.mayReturnEmpty = True
+
+    def parseImpl( self, instring, loc, doActions=True ):
+        try:
+            loc, tokens = self.expr._parse( instring, loc, doActions, callPreParse=False )
+        except (ParseException,IndexError):
+            if self.defaultValue is not _optionalNotMatched:
+                if self.expr.resultsName:
+                    tokens = ParseResults([ self.defaultValue ])
+                    tokens[self.expr.resultsName] = self.defaultValue
+                else:
+                    tokens = [ self.defaultValue ]
+            else:
+                tokens = []
+        return loc, tokens
+
+    def __str__( self ):
+        if hasattr(self,"name"):
+            return self.name
+
+        if self.strRepr is None:
+            self.strRepr = "[" + _ustr(self.expr) + "]"
+
+        return self.strRepr
+
+class SkipTo(ParseElementEnhance):
+    """
+    Token for skipping over all undefined text until the matched expression is found.
+
+    Parameters:
+     - expr - target expression marking the end of the data to be skipped
+     - include - (default=C{False}) if True, the target expression is also parsed 
+          (the skipped text and target expression are returned as a 2-element list).
+     - ignore - (default=C{None}) used to define grammars (typically quoted strings and 
+          comments) that might contain false matches to the target expression
+     - failOn - (default=C{None}) define expressions that are not allowed to be 
+          included in the skipped test; if found before the target expression is found, 
+          the SkipTo is not a match
+
+    Example::
+        report = '''
+            Outstanding Issues Report - 1 Jan 2000
+
+               # | Severity | Description                               |  Days Open
+            -----+----------+-------------------------------------------+-----------
+             101 | Critical | Intermittent system crash                 |          6
+              94 | Cosmetic | Spelling error on Login ('log|n')         |         14
+              79 | Minor    | System slow when running too many reports |         47
+            '''
+        integer = Word(nums)
+        SEP = Suppress('|')
+        # use SkipTo to simply match everything up until the next SEP
+        # - ignore quoted strings, so that a '|' character inside a quoted string does not match
+        # - parse action will call token.strip() for each matched token, i.e., the description body
+        string_data = SkipTo(SEP, ignore=quotedString)
+        string_data.setParseAction(tokenMap(str.strip))
+        ticket_expr = (integer("issue_num") + SEP 
+                      + string_data("sev") + SEP 
+                      + string_data("desc") + SEP 
+                      + integer("days_open"))
+        
+        for tkt in ticket_expr.searchString(report):
+            print tkt.dump()
+    prints::
+        ['101', 'Critical', 'Intermittent system crash', '6']
+        - days_open: 6
+        - desc: Intermittent system crash
+        - issue_num: 101
+        - sev: Critical
+        ['94', 'Cosmetic', "Spelling error on Login ('log|n')", '14']
+        - days_open: 14
+        - desc: Spelling error on Login ('log|n')
+        - issue_num: 94
+        - sev: Cosmetic
+        ['79', 'Minor', 'System slow when running too many reports', '47']
+        - days_open: 47
+        - desc: System slow when running too many reports
+        - issue_num: 79
+        - sev: Minor
+    """
+    def __init__( self, other, include=False, ignore=None, failOn=None ):
+        super( SkipTo, self ).__init__( other )
+        self.ignoreExpr = ignore
+        self.mayReturnEmpty = True
+        self.mayIndexError = False
+        self.includeMatch = include
+        self.asList = False
+        if isinstance(failOn, basestring):
+            self.failOn = ParserElement._literalStringClass(failOn)
+        else:
+            self.failOn = failOn
+        self.errmsg = "No match found for "+_ustr(self.expr)
+
+    def parseImpl( self, instring, loc, doActions=True ):
+        startloc = loc
+        instrlen = len(instring)
+        expr = self.expr
+        expr_parse = self.expr._parse
+        self_failOn_canParseNext = self.failOn.canParseNext if self.failOn is not None else None
+        self_ignoreExpr_tryParse = self.ignoreExpr.tryParse if self.ignoreExpr is not None else None
+        
+        tmploc = loc
+        while tmploc <= instrlen:
+            if self_failOn_canParseNext is not None:
+                # break if failOn expression matches
+                if self_failOn_canParseNext(instring, tmploc):
+                    break
+                    
+            if self_ignoreExpr_tryParse is not None:
+                # advance past ignore expressions
+                while 1:
+                    try:
+                        tmploc = self_ignoreExpr_tryParse(instring, tmploc)
+                    except ParseBaseException:
+                        break
+            
+            try:
+                expr_parse(instring, tmploc, doActions=False, callPreParse=False)
+            except (ParseException, IndexError):
+                # no match, advance loc in string
+                tmploc += 1
+            else:
+                # matched skipto expr, done
+                break
+
+        else:
+            # ran off the end of the input string without matching skipto expr, fail
+            raise ParseException(instring, loc, self.errmsg, self)
+
+        # build up return values
+        loc = tmploc
+        skiptext = instring[startloc:loc]
+        skipresult = ParseResults(skiptext)
+        
+        if self.includeMatch:
+            loc, mat = expr_parse(instring,loc,doActions,callPreParse=False)
+            skipresult += mat
+
+        return loc, skipresult
+
+class Forward(ParseElementEnhance):
+    """
+    Forward declaration of an expression to be defined later -
+    used for recursive grammars, such as algebraic infix notation.
+    When the expression is known, it is assigned to the C{Forward} variable using the '<<' operator.
+
+    Note: take care when assigning to C{Forward} not to overlook precedence of operators.
+    Specifically, '|' has a lower precedence than '<<', so that::
+        fwdExpr << a | b | c
+    will actually be evaluated as::
+        (fwdExpr << a) | b | c
+    thereby leaving b and c out as parseable alternatives.  It is recommended that you
+    explicitly group the values inserted into the C{Forward}::
+        fwdExpr << (a | b | c)
+    Converting to use the '<<=' operator instead will avoid this problem.
+
+    See L{ParseResults.pprint} for an example of a recursive parser created using
+    C{Forward}.
+    """
+    def __init__( self, other=None ):
+        super(Forward,self).__init__( other, savelist=False )
+
+    def __lshift__( self, other ):
+        if isinstance( other, basestring ):
+            other = ParserElement._literalStringClass(other)
+        self.expr = other
+        self.strRepr = None
+        self.mayIndexError = self.expr.mayIndexError
+        self.mayReturnEmpty = self.expr.mayReturnEmpty
+        self.setWhitespaceChars( self.expr.whiteChars )
+        self.skipWhitespace = self.expr.skipWhitespace
+        self.saveAsList = self.expr.saveAsList
+        self.ignoreExprs.extend(self.expr.ignoreExprs)
+        return self
+        
+    def __ilshift__(self, other):
+        return self << other
+    
+    def leaveWhitespace( self ):
+        self.skipWhitespace = False
+        return self
+
+    def streamline( self ):
+        if not self.streamlined:
+            self.streamlined = True
+            if self.expr is not None:
+                self.expr.streamline()
+        return self
+
+    def validate( self, validateTrace=[] ):
+        if self not in validateTrace:
+            tmp = validateTrace[:]+[self]
+            if self.expr is not None:
+                self.expr.validate(tmp)
+        self.checkRecursion([])
+
+    def __str__( self ):
+        if hasattr(self,"name"):
+            return self.name
+        return self.__class__.__name__ + ": ..."
+
+        # stubbed out for now - creates awful memory and perf issues
+        self._revertClass = self.__class__
+        self.__class__ = _ForwardNoRecurse
+        try:
+            if self.expr is not None:
+                retString = _ustr(self.expr)
+            else:
+                retString = "None"
+        finally:
+            self.__class__ = self._revertClass
+        return self.__class__.__name__ + ": " + retString
+
+    def copy(self):
+        if self.expr is not None:
+            return super(Forward,self).copy()
+        else:
+            ret = Forward()
+            ret <<= self
+            return ret
+
+class _ForwardNoRecurse(Forward):
+    def __str__( self ):
+        return "..."
+
+class TokenConverter(ParseElementEnhance):
+    """
+    Abstract subclass of C{ParseExpression}, for converting parsed results.
+    """
+    def __init__( self, expr, savelist=False ):
+        super(TokenConverter,self).__init__( expr )#, savelist )
+        self.saveAsList = False
+
+class Combine(TokenConverter):
+    """
+    Converter to concatenate all matching tokens to a single string.
+    By default, the matching patterns must also be contiguous in the input string;
+    this can be disabled by specifying C{'adjacent=False'} in the constructor.
+
+    Example::
+        real = Word(nums) + '.' + Word(nums)
+        print(real.parseString('3.1416')) # -> ['3', '.', '1416']
+        # will also erroneously match the following
+        print(real.parseString('3. 1416')) # -> ['3', '.', '1416']
+
+        real = Combine(Word(nums) + '.' + Word(nums))
+        print(real.parseString('3.1416')) # -> ['3.1416']
+        # no match when there are internal spaces
+        print(real.parseString('3. 1416')) # -> Exception: Expected W:(0123...)
+    """
+    def __init__( self, expr, joinString="", adjacent=True ):
+        super(Combine,self).__init__( expr )
+        # suppress whitespace-stripping in contained parse expressions, but re-enable it on the Combine itself
+        if adjacent:
+            self.leaveWhitespace()
+        self.adjacent = adjacent
+        self.skipWhitespace = True
+        self.joinString = joinString
+        self.callPreparse = True
+
+    def ignore( self, other ):
+        if self.adjacent:
+            ParserElement.ignore(self, other)
+        else:
+            super( Combine, self).ignore( other )
+        return self
+
+    def postParse( self, instring, loc, tokenlist ):
+        retToks = tokenlist.copy()
+        del retToks[:]
+        retToks += ParseResults([ "".join(tokenlist._asStringList(self.joinString)) ], modal=self.modalResults)
+
+        if self.resultsName and retToks.haskeys():
+            return [ retToks ]
+        else:
+            return retToks
+
+class Group(TokenConverter):
+    """
+    Converter to return the matched tokens as a list - useful for returning tokens of C{L{ZeroOrMore}} and C{L{OneOrMore}} expressions.
+
+    Example::
+        ident = Word(alphas)
+        num = Word(nums)
+        term = ident | num
+        func = ident + Optional(delimitedList(term))
+        print(func.parseString("fn a,b,100"))  # -> ['fn', 'a', 'b', '100']
+
+        func = ident + Group(Optional(delimitedList(term)))
+        print(func.parseString("fn a,b,100"))  # -> ['fn', ['a', 'b', '100']]
+    """
+    def __init__( self, expr ):
+        super(Group,self).__init__( expr )
+        self.saveAsList = True
+
+    def postParse( self, instring, loc, tokenlist ):
+        return [ tokenlist ]
+
+class Dict(TokenConverter):
+    """
+    Converter to return a repetitive expression as a list, but also as a dictionary.
+    Each element can also be referenced using the first token in the expression as its key.
+    Useful for tabular report scraping when the first column can be used as a item key.
+
+    Example::
+        data_word = Word(alphas)
+        label = data_word + FollowedBy(':')
+        attr_expr = Group(label + Suppress(':') + OneOrMore(data_word).setParseAction(' '.join))
+
+        text = "shape: SQUARE posn: upper left color: light blue texture: burlap"
+        attr_expr = (label + Suppress(':') + OneOrMore(data_word, stopOn=label).setParseAction(' '.join))
+        
+        # print attributes as plain groups
+        print(OneOrMore(attr_expr).parseString(text).dump())
+        
+        # instead of OneOrMore(expr), parse using Dict(OneOrMore(Group(expr))) - Dict will auto-assign names
+        result = Dict(OneOrMore(Group(attr_expr))).parseString(text)
+        print(result.dump())
+        
+        # access named fields as dict entries, or output as dict
+        print(result['shape'])        
+        print(result.asDict())
+    prints::
+        ['shape', 'SQUARE', 'posn', 'upper left', 'color', 'light blue', 'texture', 'burlap']
+
+        [['shape', 'SQUARE'], ['posn', 'upper left'], ['color', 'light blue'], ['texture', 'burlap']]
+        - color: light blue
+        - posn: upper left
+        - shape: SQUARE
+        - texture: burlap
+        SQUARE
+        {'color': 'light blue', 'posn': 'upper left', 'texture': 'burlap', 'shape': 'SQUARE'}
+    See more examples at L{ParseResults} of accessing fields by results name.
+    """
+    def __init__( self, expr ):
+        super(Dict,self).__init__( expr )
+        self.saveAsList = True
+
+    def postParse( self, instring, loc, tokenlist ):
+        for i,tok in enumerate(tokenlist):
+            if len(tok) == 0:
+                continue
+            ikey = tok[0]
+            if isinstance(ikey,int):
+                ikey = _ustr(tok[0]).strip()
+            if len(tok)==1:
+                tokenlist[ikey] = _ParseResultsWithOffset("",i)
+            elif len(tok)==2 and not isinstance(tok[1],ParseResults):
+                tokenlist[ikey] = _ParseResultsWithOffset(tok[1],i)
+            else:
+                dictvalue = tok.copy() #ParseResults(i)
+                del dictvalue[0]
+                if len(dictvalue)!= 1 or (isinstance(dictvalue,ParseResults) and dictvalue.haskeys()):
+                    tokenlist[ikey] = _ParseResultsWithOffset(dictvalue,i)
+                else:
+                    tokenlist[ikey] = _ParseResultsWithOffset(dictvalue[0],i)
+
+        if self.resultsName:
+            return [ tokenlist ]
+        else:
+            return tokenlist
+
+
+class Suppress(TokenConverter):
+    """
+    Converter for ignoring the results of a parsed expression.
+
+    Example::
+        source = "a, b, c,d"
+        wd = Word(alphas)
+        wd_list1 = wd + ZeroOrMore(',' + wd)
+        print(wd_list1.parseString(source))
+
+        # often, delimiters that are useful during parsing are just in the
+        # way afterward - use Suppress to keep them out of the parsed output
+        wd_list2 = wd + ZeroOrMore(Suppress(',') + wd)
+        print(wd_list2.parseString(source))
+    prints::
+        ['a', ',', 'b', ',', 'c', ',', 'd']
+        ['a', 'b', 'c', 'd']
+    (See also L{delimitedList}.)
+    """
+    def postParse( self, instring, loc, tokenlist ):
+        return []
+
+    def suppress( self ):
+        return self
+
+
+class OnlyOnce(object):
+    """
+    Wrapper for parse actions, to ensure they are only called once.
+    """
+    def __init__(self, methodCall):
+        self.callable = _trim_arity(methodCall)
+        self.called = False
+    def __call__(self,s,l,t):
+        if not self.called:
+            results = self.callable(s,l,t)
+            self.called = True
+            return results
+        raise ParseException(s,l,"")
+    def reset(self):
+        self.called = False
+
+def traceParseAction(f):
+    """
+    Decorator for debugging parse actions. 
+    
+    When the parse action is called, this decorator will print C{">> entering I{method-name}(line:I{current_source_line}, I{parse_location}, I{matched_tokens})".}
+    When the parse action completes, the decorator will print C{"<<"} followed by the returned value, or any exception that the parse action raised.
+
+    Example::
+        wd = Word(alphas)
+
+        @traceParseAction
+        def remove_duplicate_chars(tokens):
+            return ''.join(sorted(set(''.join(tokens))))
+
+        wds = OneOrMore(wd).setParseAction(remove_duplicate_chars)
+        print(wds.parseString("slkdjs sld sldd sdlf sdljf"))
+    prints::
+        >>entering remove_duplicate_chars(line: 'slkdjs sld sldd sdlf sdljf', 0, (['slkdjs', 'sld', 'sldd', 'sdlf', 'sdljf'], {}))
+        <<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 C{combine=True} in the constructor.
+    If C{combine} is set to C{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 C{intExpr} is specified, it should be a pyparsing expression that produces an integer value.
+
+    Example::
+        countedArray(Word(alphas)).parseString('2 ab cd ef')  # -> ['ab', 'cd']
+
+        # in this parser, the leading integer value is given in binary,
+        # '10' indicating that 2 values are in the array
+        binaryConstant = Word('01').setParseAction(lambda t: int(t[0], 2))
+        countedArray(Word(alphas), intExpr=binaryConstant).parseString('10 ab cd ef')  # -> ['ab', 'cd']
+    """
+    arrayExpr = Forward()
+    def countFieldParseAction(s,l,t):
+        n = t[0]
+        arrayExpr << (n and Group(And([expr]*n)) or Group(empty))
+        return []
+    if intExpr is None:
+        intExpr = Word(nums).setParseAction(lambda t:int(t[0]))
+    else:
+        intExpr = intExpr.copy()
+    intExpr.setName("arrayLen")
+    intExpr.addParseAction(countFieldParseAction, callDuringTry=True)
+    return ( intExpr + arrayExpr ).setName('(len) ' + _ustr(expr) + '...')
+
+def _flatten(L):
+    ret = []
+    for i in L:
+        if isinstance(i,list):
+            ret.extend(_flatten(i))
+        else:
+            ret.append(i)
+    return ret
+
+def matchPreviousLiteral(expr):
+    """
+    Helper to define an expression that is indirectly defined from
+    the tokens matched in a previous expression, that is, it looks
+    for a 'repeat' of a previous expression.  For example::
+        first = Word(nums)
+        second = matchPreviousLiteral(first)
+        matchExpr = first + ":" + second
+    will match C{"1:1"}, but not C{"1:2"}.  Because this matches a
+    previous literal, will also match the leading C{"1:1"} in C{"1:10"}.
+    If this is not desired, use C{matchPreviousExpr}.
+    Do I{not} use with packrat parsing enabled.
+    """
+    rep = Forward()
+    def copyTokenToRepeater(s,l,t):
+        if t:
+            if len(t) == 1:
+                rep << t[0]
+            else:
+                # flatten t tokens
+                tflat = _flatten(t.asList())
+                rep << And(Literal(tt) for tt in tflat)
+        else:
+            rep << Empty()
+    expr.addParseAction(copyTokenToRepeater, callDuringTry=True)
+    rep.setName('(prev) ' + _ustr(expr))
+    return rep
+
+def matchPreviousExpr(expr):
+    """
+    Helper to define an expression that is indirectly defined from
+    the tokens matched in a previous expression, that is, it looks
+    for a 'repeat' of a previous expression.  For example::
+        first = Word(nums)
+        second = matchPreviousExpr(first)
+        matchExpr = first + ":" + second
+    will match C{"1:1"}, but not C{"1:2"}.  Because this matches by
+    expressions, will I{not} match the leading C{"1:1"} in C{"1:10"};
+    the expressions are evaluated first, and then compared, so
+    C{"1"} is compared with C{"10"}.
+    Do I{not} use with packrat parsing enabled.
+    """
+    rep = Forward()
+    e2 = expr.copy()
+    rep <<= e2
+    def copyTokenToRepeater(s,l,t):
+        matchTokens = _flatten(t.asList())
+        def mustMatchTheseTokens(s,l,t):
+            theseTokens = _flatten(t.asList())
+            if  theseTokens != matchTokens:
+                raise ParseException("",0,"")
+        rep.setParseAction( mustMatchTheseTokens, callDuringTry=True )
+    expr.addParseAction(copyTokenToRepeater, callDuringTry=True)
+    rep.setName('(prev) ' + _ustr(expr))
+    return rep
+
+def _escapeRegexRangeChars(s):
+    #~  escape these chars: ^-]
+    for c in r"\^-]":
+        s = s.replace(c,_bslash+c)
+    s = s.replace("\n",r"\n")
+    s = s.replace("\t",r"\t")
+    return _ustr(s)
+
+def oneOf( strs, caseless=False, useRegex=True ):
+    """
+    Helper to quickly define a set of alternative Literals, and makes sure to do
+    longest-first testing when there is a conflict, regardless of the input order,
+    but returns a C{L{MatchFirst}} for best performance.
+
+    Parameters:
+     - strs - a string of space-delimited literals, or a collection of string literals
+     - caseless - (default=C{False}) - treat all literals as caseless
+     - useRegex - (default=C{True}) - as an optimization, will generate a Regex
+          object; otherwise, will generate a C{MatchFirst} object (if C{caseless=True}, or
+          if creating a C{Regex} raises an exception)
+
+    Example::
+        comp_oper = oneOf("< = > <= >= !=")
+        var = Word(alphas)
+        number = Word(nums)
+        term = var | number
+        comparison_expr = term + comp_oper + term
+        print(comparison_expr.searchString("B = 12  AA=23 B<=AA AA>12"))
+    prints::
+        [['B', '=', '12'], ['AA', '=', '23'], ['B', '<=', 'AA'], ['AA', '>', '12']]
+    """
+    if caseless:
+        isequal = ( lambda a,b: a.upper() == b.upper() )
+        masks = ( lambda a,b: b.upper().startswith(a.upper()) )
+        parseElementClass = CaselessLiteral
+    else:
+        isequal = ( lambda a,b: a == b )
+        masks = ( lambda a,b: b.startswith(a) )
+        parseElementClass = Literal
+
+    symbols = []
+    if isinstance(strs,basestring):
+        symbols = strs.split()
+    elif isinstance(strs, Iterable):
+        symbols = list(strs)
+    else:
+        warnings.warn("Invalid argument to oneOf, expected string or iterable",
+                SyntaxWarning, stacklevel=2)
+    if not symbols:
+        return NoMatch()
+
+    i = 0
+    while i < len(symbols)-1:
+        cur = symbols[i]
+        for j,other in enumerate(symbols[i+1:]):
+            if ( isequal(other, cur) ):
+                del symbols[i+j+1]
+                break
+            elif ( masks(cur, other) ):
+                del symbols[i+j+1]
+                symbols.insert(i,other)
+                cur = other
+                break
+        else:
+            i += 1
+
+    if not caseless and useRegex:
+        #~ print (strs,"->", "|".join( [ _escapeRegexChars(sym) for sym in symbols] ))
+        try:
+            if len(symbols)==len("".join(symbols)):
+                return Regex( "[%s]" % "".join(_escapeRegexRangeChars(sym) for sym in symbols) ).setName(' | '.join(symbols))
+            else:
+                return Regex( "|".join(re.escape(sym) for sym in symbols) ).setName(' | '.join(symbols))
+        except Exception:
+            warnings.warn("Exception creating Regex for oneOf, building MatchFirst",
+                    SyntaxWarning, stacklevel=2)
+
+
+    # last resort, just use MatchFirst
+    return MatchFirst(parseElementClass(sym) for sym in symbols).setName(' | '.join(symbols))
+
+def dictOf( key, value ):
+    """
+    Helper to easily and clearly define a dictionary by specifying the respective patterns
+    for the key and value.  Takes care of defining the C{L{Dict}}, C{L{ZeroOrMore}}, and C{L{Group}} tokens
+    in the proper order.  The key pattern can include delimiting markers or punctuation,
+    as long as they are suppressed, thereby leaving the significant key text.  The value
+    pattern can include named results, so that the C{Dict} results can include named token
+    fields.
+
+    Example::
+        text = "shape: SQUARE posn: upper left color: light blue texture: burlap"
+        attr_expr = (label + Suppress(':') + OneOrMore(data_word, stopOn=label).setParseAction(' '.join))
+        print(OneOrMore(attr_expr).parseString(text).dump())
+        
+        attr_label = label
+        attr_value = Suppress(':') + OneOrMore(data_word, stopOn=label).setParseAction(' '.join)
+
+        # similar to Dict, but simpler call format
+        result = dictOf(attr_label, attr_value).parseString(text)
+        print(result.dump())
+        print(result['shape'])
+        print(result.shape)  # object attribute access works too
+        print(result.asDict())
+    prints::
+        [['shape', 'SQUARE'], ['posn', 'upper left'], ['color', 'light blue'], ['texture', 'burlap']]
+        - color: light blue
+        - posn: upper left
+        - shape: SQUARE
+        - texture: burlap
+        SQUARE
+        SQUARE
+        {'color': 'light blue', 'shape': 'SQUARE', 'posn': 'upper left', 'texture': 'burlap'}
+    """
+    return Dict( ZeroOrMore( Group ( key + value ) ) )
+
+def originalTextFor(expr, asString=True):
+    """
+    Helper to return the original, untokenized text for a given expression.  Useful to
+    restore the parsed fields of an HTML start tag into the raw tag text itself, or to
+    revert separate tokens with intervening whitespace back to the original matching
+    input text. By default, returns astring containing the original parsed text.  
+       
+    If the optional C{asString} argument is passed as C{False}, then the return value is a 
+    C{L{ParseResults}} containing any results names that were originally matched, and a 
+    single token containing the original matched text from the input string.  So if 
+    the expression passed to C{L{originalTextFor}} contains expressions with defined
+    results names, you must set C{asString} to C{False} if you want to preserve those
+    results name values.
+
+    Example::
+        src = "this is test <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).setParseAction(lambda t:t[0])
+
+def locatedExpr(expr):
+    """
+    Helper to decorate a returned token with its starting and ending locations in the input string.
+    This helper adds the following results names:
+     - locn_start = location where matched expression begins
+     - locn_end = location where matched expression ends
+     - value = the actual parsed results
+
+    Be careful if the input text contains C{<TAB>} characters, you may want to call
+    C{L{ParserElement.parseWithTabs}}
+
+    Example::
+        wd = Word(alphas)
+        for match in locatedExpr(wd).searchString("ljsdf123lksdjjf123lkkjj1222"):
+            print(match)
+    prints::
+        [[0, 'ljsdf', 5]]
+        [[8, 'lksdjjf', 15]]
+        [[18, 'lkkjj', 23]]
+    """
+    locator = Empty().setParseAction(lambda s,l,t: l)
+    return Group(locator("locn_start") + expr("value") + locator.copy().leaveWhitespace()("locn_end"))
+
+
+# convenience constants for positional expressions
+empty       = Empty().setName("empty")
+lineStart   = LineStart().setName("lineStart")
+lineEnd     = LineEnd().setName("lineEnd")
+stringStart = StringStart().setName("stringStart")
+stringEnd   = StringEnd().setName("stringEnd")
+
+_escapedPunc = Word( _bslash, r"\[]-*.$+^?()~ ", exact=2 ).setParseAction(lambda s,l,t:t[0][1])
+_escapedHexChar = Regex(r"\\0?[xX][0-9a-fA-F]+").setParseAction(lambda s,l,t:unichr(int(t[0].lstrip(r'\0x'),16)))
+_escapedOctChar = Regex(r"\\0[0-7]+").setParseAction(lambda s,l,t:unichr(int(t[0][1:],8)))
+_singleChar = _escapedPunc | _escapedHexChar | _escapedOctChar | CharsNotIn(r'\]', exact=1)
+_charRange = Group(_singleChar + Suppress("-") + _singleChar)
+_reBracketExpr = Literal("[") + Optional("^").setResultsName("negate") + Group( OneOrMore( _charRange | _singleChar ) ).setResultsName("body") + "]"
+
+def srange(s):
+    r"""
+    Helper to easily define string ranges for use in Word construction.  Borrows
+    syntax from regexp '[]' string range definitions::
+        srange("[0-9]")   -> "0123456789"
+        srange("[a-z]")   -> "abcdefghijklmnopqrstuvwxyz"
+        srange("[a-z$_]") -> "abcdefghijklmnopqrstuvwxyz$_"
+    The input string must be enclosed in []'s, and the returned string is the expanded
+    character set joined into a single string.
+    The values enclosed in the []'s may be:
+     - a single character
+     - an escaped character with a leading backslash (such as C{\-} or C{\]})
+     - an escaped hex character with a leading C{'\x'} (C{\x21}, which is a C{'!'} character) 
+         (C{\0x##} is also supported for backwards compatibility) 
+     - an escaped octal character with a leading C{'\0'} (C{\041}, which is a C{'!'} character)
+     - a range of any of the above, separated by a dash (C{'a-z'}, etc.)
+     - any combination of the above (C{'aeiouy'}, C{'a-zA-Z0-9_$'}, etc.)
+    """
+    _expanded = lambda p: p if not isinstance(p,ParseResults) else ''.join(unichr(c) for c in range(ord(p[0]),ord(p[1])+1))
+    try:
+        return "".join(_expanded(part) for part in _reBracketExpr.parseString(s).body)
+    except Exception:
+        return ""
+
+def matchOnlyAtCol(n):
+    """
+    Helper method for defining parse actions that require matching at a specific
+    column in the input text.
+    """
+    def verifyCol(strg,locn,toks):
+        if col(locn,strg) != n:
+            raise ParseException(strg,locn,"matched token not at column %d" % n)
+    return verifyCol
+
+def replaceWith(replStr):
+    """
+    Helper method for common parse actions that simply return a literal value.  Especially
+    useful when used with C{L{transformString<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 C{hex_integer = Word(hexnums).setParseAction(tokenMap(int, 16))}, which will convert the
+    parsed data to an integer using base 16.
+
+    Example (compare the last to example in L{ParserElement.transformString}::
+        hex_ints = OneOrMore(Word(hexnums)).setParseAction(tokenMap(int, 16))
+        hex_ints.runTests('''
+            00 11 22 aa FF 0a 0d 1a
+            ''')
+        
+        upperword = Word(alphas).setParseAction(tokenMap(str.upper))
+        OneOrMore(upperword).runTests('''
+            my kingdom for a horse
+            ''')
+
+        wd = Word(alphas).setParseAction(tokenMap(str.title))
+        OneOrMore(wd).setParseAction(' '.join).runTests('''
+            now is the winter of our discontent made glorious summer by this sun of york
+            ''')
+    prints::
+        00 11 22 aa FF 0a 0d 1a
+        [0, 17, 34, 170, 255, 10, 13, 26]
+
+        my kingdom for a horse
+        ['MY', 'KINGDOM', 'FOR', 'A', 'HORSE']
+
+        now is the winter of our discontent made glorious summer by this sun of york
+        ['Now Is The Winter Of Our Discontent Made Glorious Summer By This Sun Of York']
+    """
+    def pa(s,l,t):
+        return [func(tokn, *args) for tokn in t]
+
+    try:
+        func_name = getattr(func, '__name__', 
+                            getattr(func, '__class__').__name__)
+    except Exception:
+        func_name = str(func)
+    pa.__name__ = func_name
+
+    return pa
+
+upcaseTokens = tokenMap(lambda t: _ustr(t).upper())
+"""(Deprecated) Helper parse action to convert tokens to upper case. Deprecated in favor of L{pyparsing_common.upcaseTokens}"""
+
+downcaseTokens = tokenMap(lambda t: _ustr(t).lower())
+"""(Deprecated) Helper parse action to convert tokens to lower case. Deprecated in favor of L{pyparsing_common.downcaseTokens}"""
+    
+def _makeTags(tagStr, xml):
+    """Internal helper to construct opening and closing tag expressions, given a tag name"""
+    if isinstance(tagStr,basestring):
+        resname = tagStr
+        tagStr = Keyword(tagStr, caseless=not xml)
+    else:
+        resname = tagStr.name
+
+    tagAttrName = Word(alphas,alphanums+"_-:")
+    if (xml):
+        tagAttrValue = dblQuotedString.copy().setParseAction( removeQuotes )
+        openTag = Suppress("<") + tagStr("tag") + \
+                Dict(ZeroOrMore(Group( tagAttrName + Suppress("=") + tagAttrValue ))) + \
+                Optional("/",default=[False]).setResultsName("empty").setParseAction(lambda s,l,t:t[0]=='/') + Suppress(">")
+    else:
+        printablesLessRAbrack = "".join(c for c in printables if c not in ">")
+        tagAttrValue = quotedString.copy().setParseAction( removeQuotes ) | Word(printablesLessRAbrack)
+        openTag = Suppress("<") + tagStr("tag") + \
+                Dict(ZeroOrMore(Group( tagAttrName.setParseAction(downcaseTokens) + \
+                Optional( Suppress("=") + tagAttrValue ) ))) + \
+                Optional("/",default=[False]).setResultsName("empty").setParseAction(lambda s,l,t:t[0]=='/') + Suppress(">")
+    closeTag = Combine(_L("</") + tagStr + ">")
+
+    openTag = openTag.setResultsName("start"+"".join(resname.replace(":"," ").title().split())).setName("<%s>" % resname)
+    closeTag = closeTag.setResultsName("end"+"".join(resname.replace(":"," ").title().split())).setName("</%s>" % resname)
+    openTag.tag = resname
+    closeTag.tag = resname
+    return openTag, closeTag
+
+def makeHTMLTags(tagStr):
+    """
+    Helper to construct opening and closing tag expressions for HTML, given a tag name. Matches
+    tags in either upper or lower case, attributes with namespaces and with quoted or unquoted values.
+
+    Example::
+        text = '<td>More info at the <a href="http://pyparsing.wikispaces.com">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 -> http://pyparsing.wikispaces.com
+    """
+    return _makeTags( tagStr, False )
+
+def makeXMLTags(tagStr):
+    """
+    Helper to construct opening and closing tag expressions for XML, given a tag name. Matches
+    tags only in the given upper/lower case.
+
+    Example: similar to L{makeHTMLTags}
+    """
+    return _makeTags( tagStr, True )
+
+def withAttribute(*args,**attrDict):
+    """
+    Helper to create a validating parse action to be used with start tags created
+    with C{L{makeXMLTags}} or C{L{makeHTMLTags}}. Use C{withAttribute} to qualify a starting tag
+    with a required attribute value, to avoid false matches on common tags such as
+    C{<TD>} or C{<DIV>}.
+
+    Call C{withAttribute} with a series of attribute names and values. Specify the list
+    of filter attributes names and values as:
+     - keyword arguments, as in C{(align="right")}, or
+     - as an explicit dict with C{**} operator, when an attribute name is also a Python
+          reserved word, as in C{**{"class":"Customer", "align":"right"}}
+     - a list of name-value tuples, as in ( ("ns1:class", "Customer"), ("ns2:align","right") )
+    For attribute names with a namespace prefix, you must use the second form.  Attribute
+    names are matched insensitive to upper/lower case.
+       
+    If just testing for C{class} (with or without a namespace), use C{L{withClass}}.
+
+    To verify that the attribute exists, but without specifying a value, pass
+    C{withAttribute.ANY_VALUE} as the value.
+
+    Example::
+        html = '''
+            <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 C{L{withAttribute}} when matching on a div class - made
+    difficult because C{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 = _Constants()
+opAssoc.LEFT = object()
+opAssoc.RIGHT = object()
+
+def infixNotation( baseExpr, opList, lpar=Suppress('('), rpar=Suppress(')') ):
+    """
+    Helper method for constructing grammars of expressions made up of
+    operators working in a precedence hierarchy.  Operators may be unary or
+    binary, left- or right-associative.  Parse actions can also be attached
+    to operator expressions. The generated parser will also recognize the use 
+    of parentheses to override operator precedences (see example below).
+    
+    Note: if you define a deep operator list, you may see performance issues
+    when using infixNotation. See L{ParserElement.enablePackrat} for a
+    mechanism to potentially improve your parser performance.
+
+    Parameters:
+     - baseExpr - expression representing the most basic element for the nested
+     - opList - list of tuples, one for each operator precedence level in the
+      expression grammar; each tuple is of the form
+      (opExpr, numTerms, rightLeftAssoc, parseAction), where:
+       - opExpr is the pyparsing expression for the operator;
+          may also be a string, which will be converted to a Literal;
+          if numTerms is 3, opExpr is a tuple of two expressions, for the
+          two operators separating the 3 terms
+       - numTerms is the number of terms for this operator (must
+          be 1, 2, or 3)
+       - rightLeftAssoc is the indicator whether the operator is
+          right or left associative, using the pyparsing-defined
+          constants C{opAssoc.RIGHT} and C{opAssoc.LEFT}.
+       - parseAction is the parse action to be associated with
+          expressions matching this operator expression (the
+          parse action tuple member may be omitted); if the parse action
+          is passed a tuple or list of functions, this is equivalent to
+          calling C{setParseAction(*fn)} (L{ParserElement.setParseAction})
+     - lpar - expression for matching left-parentheses (default=C{Suppress('(')})
+     - rpar - expression for matching right-parentheses (default=C{Suppress(')')})
+
+    Example::
+        # simple example of four-function arithmetic with ints and variable names
+        integer = pyparsing_common.signed_integer
+        varname = pyparsing_common.identifier 
+        
+        arith_expr = infixNotation(integer | varname,
+            [
+            ('-', 1, opAssoc.RIGHT),
+            (oneOf('* /'), 2, opAssoc.LEFT),
+            (oneOf('+ -'), 2, opAssoc.LEFT),
+            ])
+        
+        arith_expr.runTests('''
+            5+3*6
+            (5+3)*6
+            -2--11
+            ''', fullDump=False)
+    prints::
+        5+3*6
+        [[5, '+', [3, '*', 6]]]
+
+        (5+3)*6
+        [[[5, '+', 3], '*', 6]]
+
+        -2--11
+        [[['-', 2], '-', ['-', 11]]]
+    """
+    ret = Forward()
+    lastExpr = baseExpr | ( lpar + ret + rpar )
+    for i,operDef in enumerate(opList):
+        opExpr,arity,rightLeftAssoc,pa = (operDef + (None,))[:4]
+        termName = "%s term" % opExpr if arity < 3 else "%s%s term" % opExpr
+        if arity == 3:
+            if opExpr is None or len(opExpr) != 2:
+                raise ValueError("if numterms=3, opExpr must be a tuple or list of two expressions")
+            opExpr1, opExpr2 = opExpr
+        thisExpr = Forward().setName(termName)
+        if rightLeftAssoc == opAssoc.LEFT:
+            if arity == 1:
+                matchExpr = FollowedBy(lastExpr + opExpr) + Group( lastExpr + OneOrMore( opExpr ) )
+            elif arity == 2:
+                if opExpr is not None:
+                    matchExpr = FollowedBy(lastExpr + opExpr + lastExpr) + Group( lastExpr + OneOrMore( opExpr + lastExpr ) )
+                else:
+                    matchExpr = FollowedBy(lastExpr+lastExpr) + Group( lastExpr + OneOrMore(lastExpr) )
+            elif arity == 3:
+                matchExpr = FollowedBy(lastExpr + opExpr1 + lastExpr + opExpr2 + lastExpr) + \
+                            Group( lastExpr + opExpr1 + lastExpr + opExpr2 + lastExpr )
+            else:
+                raise ValueError("operator must be unary (1), binary (2), or ternary (3)")
+        elif rightLeftAssoc == opAssoc.RIGHT:
+            if arity == 1:
+                # try to avoid LR with this extra test
+                if not isinstance(opExpr, Optional):
+                    opExpr = Optional(opExpr)
+                matchExpr = FollowedBy(opExpr.expr + thisExpr) + Group( opExpr + thisExpr )
+            elif arity == 2:
+                if opExpr is not None:
+                    matchExpr = FollowedBy(lastExpr + opExpr + thisExpr) + Group( lastExpr + OneOrMore( opExpr + thisExpr ) )
+                else:
+                    matchExpr = FollowedBy(lastExpr + thisExpr) + Group( lastExpr + OneOrMore( thisExpr ) )
+            elif arity == 3:
+                matchExpr = FollowedBy(lastExpr + opExpr1 + thisExpr + opExpr2 + thisExpr) + \
+                            Group( lastExpr + opExpr1 + thisExpr + opExpr2 + thisExpr )
+            else:
+                raise ValueError("operator must be unary (1), binary (2), or ternary (3)")
+        else:
+            raise ValueError("operator must indicate right or left associativity")
+        if pa:
+            if isinstance(pa, (tuple, list)):
+                matchExpr.setParseAction(*pa)
+            else:
+                matchExpr.setParseAction(pa)
+        thisExpr <<= ( matchExpr.setName(termName) | lastExpr )
+        lastExpr = thisExpr
+    ret <<= lastExpr
+    return ret
+
+operatorPrecedence = infixNotation
+"""(Deprecated) Former name of C{L{infixNotation}}, will be dropped in a future release."""
+
+dblQuotedString = Combine(Regex(r'"(?:[^"\n\r\\]|(?:"")|(?:\\(?:[^x]|x[0-9a-fA-F]+)))*')+'"').setName("string enclosed in double quotes")
+sglQuotedString = Combine(Regex(r"'(?:[^'\n\r\\]|(?:'')|(?:\\(?:[^x]|x[0-9a-fA-F]+)))*")+"'").setName("string enclosed in single quotes")
+quotedString = Combine(Regex(r'"(?:[^"\n\r\\]|(?:"")|(?:\\(?:[^x]|x[0-9a-fA-F]+)))*')+'"'|
+                       Regex(r"'(?:[^'\n\r\\]|(?:'')|(?:\\(?:[^x]|x[0-9a-fA-F]+)))*")+"'").setName("quotedString using single or double quotes")
+unicodeString = Combine(_L('u') + quotedString.copy()).setName("unicode string literal")
+
+def nestedExpr(opener="(", closer=")", content=None, ignoreExpr=quotedString.copy()):
+    """
+    Helper method for defining nested lists enclosed in opening and closing
+    delimiters ("(" and ")" are the default).
+
+    Parameters:
+     - opener - opening character for a nested list (default=C{"("}); can also be a pyparsing expression
+     - closer - closing character for a nested list (default=C{")"}); can also be a pyparsing expression
+     - content - expression for items within the nested lists (default=C{None})
+     - ignoreExpr - expression for ignoring opening and closing delimiters (default=C{quotedString})
+
+    If an expression is not provided for the content argument, the nested
+    expression will capture all whitespace-delimited content between delimiters
+    as a list of separate values.
+
+    Use the C{ignoreExpr} argument to define expressions that may contain
+    opening or closing characters that should not be treated as opening
+    or closing characters for nesting, such as quotedString or a comment
+    expression.  Specify multiple expressions using an C{L{Or}} or C{L{MatchFirst}}.
+    The default is L{quotedString}, but if no expressions are to be ignored,
+    then pass C{None} for this argument.
+
+    Example::
+        data_type = oneOf("void int short long char float double")
+        decl_data_type = Combine(data_type + Optional(Word('*')))
+        ident = Word(alphas+'_', alphanums+'_')
+        number = pyparsing_common.number
+        arg = Group(decl_data_type + ident)
+        LPAR,RPAR = map(Suppress, "()")
+
+        code_body = nestedExpr('{', '}', ignoreExpr=(quotedString | cStyleComment))
+
+        c_function = (decl_data_type("type") 
+                      + ident("name")
+                      + LPAR + Optional(delimitedList(arg), [])("args") + RPAR 
+                      + code_body("body"))
+        c_function.ignore(cStyleComment)
+        
+        source_code = '''
+            int is_odd(int x) { 
+                return (x%2); 
+            }
+                
+            int dec_to_hex(char hchar) { 
+                if (hchar >= '0' && hchar <= '9') { 
+                    return (ord(hchar)-ord('0')); 
+                } else { 
+                    return (10+ord(hchar)-ord('A'));
+                } 
+            }
+        '''
+        for func in c_function.searchString(source_code):
+            print("%(name)s (%(type)s) args: %(args)s" % func)
+
+    prints::
+        is_odd (int) args: [['int', 'x']]
+        dec_to_hex (int) args: [['char', 'hchar']]
+    """
+    if opener == closer:
+        raise ValueError("opening and closing strings cannot be the same")
+    if content is None:
+        if isinstance(opener,basestring) and isinstance(closer,basestring):
+            if len(opener) == 1 and len(closer)==1:
+                if ignoreExpr is not None:
+                    content = (Combine(OneOrMore(~ignoreExpr +
+                                    CharsNotIn(opener+closer+ParserElement.DEFAULT_WHITE_CHARS,exact=1))
+                                ).setParseAction(lambda t:t[0].strip()))
+                else:
+                    content = (empty.copy()+CharsNotIn(opener+closer+ParserElement.DEFAULT_WHITE_CHARS
+                                ).setParseAction(lambda t:t[0].strip()))
+            else:
+                if ignoreExpr is not None:
+                    content = (Combine(OneOrMore(~ignoreExpr + 
+                                    ~Literal(opener) + ~Literal(closer) +
+                                    CharsNotIn(ParserElement.DEFAULT_WHITE_CHARS,exact=1))
+                                ).setParseAction(lambda t:t[0].strip()))
+                else:
+                    content = (Combine(OneOrMore(~Literal(opener) + ~Literal(closer) +
+                                    CharsNotIn(ParserElement.DEFAULT_WHITE_CHARS,exact=1))
+                                ).setParseAction(lambda t:t[0].strip()))
+        else:
+            raise ValueError("opening and closing arguments must be strings if no content expression is given")
+    ret = Forward()
+    if ignoreExpr is not None:
+        ret <<= Group( Suppress(opener) + ZeroOrMore( ignoreExpr | ret | content ) + Suppress(closer) )
+    else:
+        ret <<= Group( Suppress(opener) + ZeroOrMore( ret | content )  + Suppress(closer) )
+    ret.setName('nested %s%s expression' % (opener,closer))
+    return ret
+
+def indentedBlock(blockStatementExpr, indentStack, indent=True):
+    """
+    Helper method for defining space-delimited indentation blocks, such as
+    those used to define block statements in Python source code.
+
+    Parameters:
+     - blockStatementExpr - expression defining syntax of statement that
+            is repeated within the indented block
+     - indentStack - list created by caller to manage indentation stack
+            (multiple statementWithIndentedBlock expressions within a single grammar
+            should share a common indentStack)
+     - indent - boolean indicating whether block must be indented beyond the
+            the current level; set to False for block of left-most statements
+            (default=C{True})
+
+    A valid block must contain at least one C{blockStatement}.
+
+    Example::
+        data = '''
+        def A(z):
+          A1
+          B = 100
+          G = A2
+          A2
+          A3
+        B
+        def BB(a,b,c):
+          BB1
+          def BBA():
+            bba1
+            bba2
+            bba3
+        C
+        D
+        def spam(x,y):
+             def eggs(z):
+                 pass
+        '''
+
+
+        indentStack = [1]
+        stmt = Forward()
+
+        identifier = Word(alphas, alphanums)
+        funcDecl = ("def" + identifier + Group( "(" + Optional( delimitedList(identifier) ) + ")" ) + ":")
+        func_body = indentedBlock(stmt, indentStack)
+        funcDef = Group( funcDecl + func_body )
+
+        rvalue = Forward()
+        funcCall = Group(identifier + "(" + Optional(delimitedList(rvalue)) + ")")
+        rvalue << (funcCall | identifier | Word(nums))
+        assignment = Group(identifier + "=" + rvalue)
+        stmt << ( funcDef | assignment | identifier )
+
+        module_body = OneOrMore(stmt)
+
+        parseTree = module_body.parseString(data)
+        parseTree.pprint()
+    prints::
+        [['def',
+          'A',
+          ['(', 'z', ')'],
+          ':',
+          [['A1'], [['B', '=', '100']], [['G', '=', 'A2']], ['A2'], ['A3']]],
+         'B',
+         ['def',
+          'BB',
+          ['(', 'a', 'b', 'c', ')'],
+          ':',
+          [['BB1'], [['def', 'BBA', ['(', ')'], ':', [['bba1'], ['bba2'], ['bba3']]]]]],
+         'C',
+         'D',
+         ['def',
+          'spam',
+          ['(', 'x', 'y', ')'],
+          ':',
+          [[['def', 'eggs', ['(', 'z', ')'], ':', [['pass']]]]]]] 
+    """
+    def checkPeerIndent(s,l,t):
+        if l >= len(s): return
+        curCol = col(l,s)
+        if curCol != indentStack[-1]:
+            if curCol > indentStack[-1]:
+                raise ParseFatalException(s,l,"illegal nesting")
+            raise ParseException(s,l,"not a peer entry")
+
+    def checkSubIndent(s,l,t):
+        curCol = col(l,s)
+        if curCol > indentStack[-1]:
+            indentStack.append( curCol )
+        else:
+            raise ParseException(s,l,"not a subentry")
+
+    def checkUnindent(s,l,t):
+        if l >= len(s): return
+        curCol = col(l,s)
+        if not(indentStack and curCol < indentStack[-1] and curCol <= indentStack[-2]):
+            raise ParseException(s,l,"not an unindent")
+        indentStack.pop()
+
+    NL = OneOrMore(LineEnd().setWhitespaceChars("\t ").suppress())
+    INDENT = (Empty() + Empty().setParseAction(checkSubIndent)).setName('INDENT')
+    PEER   = Empty().setParseAction(checkPeerIndent).setName('')
+    UNDENT = Empty().setParseAction(checkUnindent).setName('UNINDENT')
+    if indent:
+        smExpr = Group( Optional(NL) +
+            #~ FollowedBy(blockStatementExpr) +
+            INDENT + (OneOrMore( PEER + Group(blockStatementExpr) + Optional(NL) )) + UNDENT)
+    else:
+        smExpr = Group( Optional(NL) +
+            (OneOrMore( PEER + Group(blockStatementExpr) + Optional(NL) )) )
+    blockStatementExpr.ignore(_bslash + LineEnd())
+    return smExpr.setName('indented block')
+
+alphas8bit = srange(r"[\0xc0-\0xd6\0xd8-\0xf6\0xf8-\0xff]")
+punc8bit = srange(r"[\0xa1-\0xbf\0xd7\0xf7]")
+
+anyOpenTag,anyCloseTag = makeHTMLTags(Word(alphas,alphanums+"_:").setName('any tag'))
+_htmlEntityMap = dict(zip("gt lt amp nbsp quot apos".split(),'><& "\''))
+commonHTMLEntity = Regex('&(?P<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 C{/* ... */}"
+
+htmlComment = Regex(r"<!--[\s\S]*?-->").setName("HTML comment")
+"Comment of the form C{<!-- ... -->}"
+
+restOfLine = Regex(r".*").leaveWhitespace().setName("rest of line")
+dblSlashComment = Regex(r"//(?:\\\n|[^\n])*").setName("// comment")
+"Comment of the form C{// ... (to end of line)}"
+
+cppStyleComment = Combine(Regex(r"/\*(?:[^*]|\*(?!/))*") + '*/'| dblSlashComment).setName("C++ style comment")
+"Comment of either form C{L{cStyleComment}} or C{L{dblSlashComment}}"
+
+javaStyleComment = cppStyleComment
+"Same as C{L{cppStyleComment}}"
+
+pythonStyleComment = Regex(r"#.*").setName("Python style comment")
+"Comment of the form C{# ... (to end of line)}"
+
+_commasepitem = Combine(OneOrMore(Word(printables, excludeChars=',') +
+                                  Optional( Word(" \t") +
+                                            ~Literal(",") + ~LineEnd() ) ) ).streamline().setName("commaItem")
+commaSeparatedList = delimitedList( Optional( quotedString.copy() | _commasepitem, default="") ).setName("commaSeparatedList")
+"""(Deprecated) Predefined expression of 1 or more printable words or quoted strings, separated by commas.
+   This expression is deprecated in favor of L{pyparsing_common.comma_separated_list}."""
+
+# some other useful expressions - using lower-case class name since we are really using this as a namespace
+class pyparsing_common:
+    """
+    Here are some common low-level expressions that may be useful in jump-starting parser development:
+     - numeric forms (L{integers<integer>}, L{reals<real>}, L{scientific notation<sci_real>})
+     - common L{programming identifiers<identifier>}
+     - network addresses (L{MAC<mac_address>}, L{IPv4<ipv4_address>}, L{IPv6<ipv6_address>})
+     - ISO8601 L{dates<iso8601_date>} and L{datetime<iso8601_datetime>}
+     - L{UUID<uuid>}
+     - L{comma-separated list<comma_separated_list>}
+    Parse actions:
+     - C{L{convertToInteger}}
+     - C{L{convertToFloat}}
+     - C{L{convertToDate}}
+     - C{L{convertToDatetime}}
+     - C{L{stripHTMLTags}}
+     - C{L{upcaseTokens}}
+     - C{L{downcaseTokens}}
+
+    Example::
+        pyparsing_common.number.runTests('''
+            # any int or real number, returned as the appropriate type
+            100
+            -100
+            +100
+            3.14159
+            6.02e23
+            1e-12
+            ''')
+
+        pyparsing_common.fnumber.runTests('''
+            # any int or real number, returned as float
+            100
+            -100
+            +100
+            3.14159
+            6.02e23
+            1e-12
+            ''')
+
+        pyparsing_common.hex_integer.runTests('''
+            # hex numbers
+            100
+            FF
+            ''')
+
+        pyparsing_common.fraction.runTests('''
+            # fractions
+            1/2
+            -3/4
+            ''')
+
+        pyparsing_common.mixed_integer.runTests('''
+            # mixed fractions
+            1
+            1/2
+            -3/4
+            1-3/4
+            ''')
+
+        import uuid
+        pyparsing_common.uuid.setParseAction(tokenMap(uuid.UUID))
+        pyparsing_common.uuid.runTests('''
+            # uuid
+            12345678-1234-5678-1234-567812345678
+            ''')
+    prints::
+        # any int or real number, returned as the appropriate type
+        100
+        [100]
+
+        -100
+        [-100]
+
+        +100
+        [100]
+
+        3.14159
+        [3.14159]
+
+        6.02e23
+        [6.02e+23]
+
+        1e-12
+        [1e-12]
+
+        # any int or real number, returned as float
+        100
+        [100.0]
+
+        -100
+        [-100.0]
+
+        +100
+        [100.0]
+
+        3.14159
+        [3.14159]
+
+        6.02e23
+        [6.02e+23]
+
+        1e-12
+        [1e-12]
+
+        # hex numbers
+        100
+        [256]
+
+        FF
+        [255]
+
+        # fractions
+        1/2
+        [0.5]
+
+        -3/4
+        [-0.75]
+
+        # mixed fractions
+        1
+        [1]
+
+        1/2
+        [0.5]
+
+        -3/4
+        [-0.75]
+
+        1-3/4
+        [1.75]
+
+        # uuid
+        12345678-1234-5678-1234-567812345678
+        [UUID('12345678-1234-5678-1234-567812345678')]
+    """
+
+    convertToInteger = tokenMap(int)
+    """
+    Parse action for converting parsed integers to Python int
+    """
+
+    convertToFloat = tokenMap(float)
+    """
+    Parse action for converting parsed numbers to Python float
+    """
+
+    integer = Word(nums).setName("integer").setParseAction(convertToInteger)
+    """expression that parses an unsigned integer, returns an int"""
+
+    hex_integer = Word(hexnums).setName("hex integer").setParseAction(tokenMap(int,16))
+    """expression that parses a hexadecimal integer, returns an int"""
+
+    signed_integer = Regex(r'[+-]?\d+').setName("signed integer").setParseAction(convertToInteger)
+    """expression that parses an integer with optional leading sign, returns an int"""
+
+    fraction = (signed_integer().setParseAction(convertToFloat) + '/' + signed_integer().setParseAction(convertToFloat)).setName("fraction")
+    """fractional expression of an integer divided by an integer, returns a float"""
+    fraction.addParseAction(lambda t: t[0]/t[-1])
+
+    mixed_integer = (fraction | signed_integer + Optional(Optional('-').suppress() + fraction)).setName("fraction or mixed integer-fraction")
+    """mixed integer of the form 'integer - fraction', with optional leading integer, returns float"""
+    mixed_integer.addParseAction(sum)
+
+    real = Regex(r'[+-]?\d+\.\d*').setName("real number").setParseAction(convertToFloat)
+    """expression that parses a floating point number and returns a float"""
+
+    sci_real = Regex(r'[+-]?\d+([eE][+-]?\d+|\.\d*([eE][+-]?\d+)?)').setName("real number with scientific notation").setParseAction(convertToFloat)
+    """expression that parses a floating point number with optional scientific notation and returns a float"""
+
+    # streamlining this expression makes the docs nicer-looking
+    number = (sci_real | real | signed_integer).streamline()
+    """any numeric expression, returns the corresponding Python type"""
+
+    fnumber = Regex(r'[+-]?\d+\.?\d*([eE][+-]?\d+)?').setName("fnumber").setParseAction(convertToFloat)
+    """any int or real number, returned as float"""
+    
+    identifier = Word(alphas+'_', alphanums+'_').setName("identifier")
+    """typical code identifier (leading alpha or '_', followed by 0 or more alphas, nums, or '_')"""
+    
+    ipv4_address = Regex(r'(25[0-5]|2[0-4][0-9]|1?[0-9]{1,2})(\.(25[0-5]|2[0-4][0-9]|1?[0-9]{1,2})){3}').setName("IPv4 address")
+    "IPv4 address (C{0.0.0.0 - 255.255.255.255})"
+
+    _ipv6_part = Regex(r'[0-9a-fA-F]{1,4}').setName("hex_integer")
+    _full_ipv6_address = (_ipv6_part + (':' + _ipv6_part)*7).setName("full IPv6 address")
+    _short_ipv6_address = (Optional(_ipv6_part + (':' + _ipv6_part)*(0,6)) + "::" + Optional(_ipv6_part + (':' + _ipv6_part)*(0,6))).setName("short IPv6 address")
+    _short_ipv6_address.addCondition(lambda t: sum(1 for tt in t if pyparsing_common._ipv6_part.matches(tt)) < 8)
+    _mixed_ipv6_address = ("::ffff:" + ipv4_address).setName("mixed IPv6 address")
+    ipv6_address = Combine((_full_ipv6_address | _mixed_ipv6_address | _short_ipv6_address).setName("IPv6 address")).setName("IPv6 address")
+    "IPv6 address (long, short, or mixed form)"
+    
+    mac_address = Regex(r'[0-9a-fA-F]{2}([:.-])[0-9a-fA-F]{2}(?:\1[0-9a-fA-F]{2}){4}').setName("MAC address")
+    "MAC address xx:xx:xx:xx:xx (may also have '-' or '.' delimiters)"
+
+    @staticmethod
+    def convertToDate(fmt="%Y-%m-%d"):
+        """
+        Helper to create a parse action for converting parsed date string to Python datetime.date
+
+        Params -
+         - fmt - format to be passed to datetime.strptime (default=C{"%Y-%m-%d"})
+
+        Example::
+            date_expr = pyparsing_common.iso8601_date.copy()
+            date_expr.setParseAction(pyparsing_common.convertToDate())
+            print(date_expr.parseString("1999-12-31"))
+        prints::
+            [datetime.date(1999, 12, 31)]
+        """
+        def cvt_fn(s,l,t):
+            try:
+                return datetime.strptime(t[0], fmt).date()
+            except ValueError as ve:
+                raise ParseException(s, l, str(ve))
+        return cvt_fn
+
+    @staticmethod
+    def convertToDatetime(fmt="%Y-%m-%dT%H:%M:%S.%f"):
+        """
+        Helper to create a parse action for converting parsed datetime string to Python datetime.datetime
+
+        Params -
+         - fmt - format to be passed to datetime.strptime (default=C{"%Y-%m-%dT%H:%M:%S.%f"})
+
+        Example::
+            dt_expr = pyparsing_common.iso8601_datetime.copy()
+            dt_expr.setParseAction(pyparsing_common.convertToDatetime())
+            print(dt_expr.parseString("1999-12-31T23:59:59.999"))
+        prints::
+            [datetime.datetime(1999, 12, 31, 23, 59, 59, 999000)]
+        """
+        def cvt_fn(s,l,t):
+            try:
+                return datetime.strptime(t[0], fmt)
+            except ValueError as ve:
+                raise ParseException(s, l, str(ve))
+        return cvt_fn
+
+    iso8601_date = Regex(r'(?P<year>\d{4})(?:-(?P<month>\d\d)(?:-(?P<day>\d\d))?)?').setName("ISO8601 date")
+    "ISO8601 date (C{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 (C{yyyy-mm-ddThh:mm:ss.s(Z|+-00:00)}) - trailing seconds, milliseconds, and timezone optional; accepts separating C{'T'} or C{' '}"
+
+    uuid = Regex(r'[0-9a-fA-F]{8}(-[0-9a-fA-F]{4}){3}-[0-9a-fA-F]{12}').setName("UUID")
+    "UUID (C{xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx})"
+
+    _html_stripper = anyOpenTag.suppress() | anyCloseTag.suppress()
+    @staticmethod
+    def stripHTMLTags(s, l, tokens):
+        """
+        Parse action to remove HTML tags from web page HTML source
+
+        Example::
+            # strip HTML links from normal text 
+            text = '<td>More info at the <a href="http://pyparsing.wikispaces.com">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) # -> 'More info at the pyparsing wiki page'
+        """
+        return pyparsing_common._html_stripper.transformString(tokens[0])
+
+    _commasepitem = Combine(OneOrMore(~Literal(",") + ~LineEnd() + Word(printables, excludeChars=',') 
+                                        + Optional( White(" \t") ) ) ).streamline().setName("commaItem")
+    comma_separated_list = delimitedList( Optional( quotedString.copy() | _commasepitem, default="") ).setName("comma separated list")
+    """Predefined expression of 1 or more printable words or quoted strings, separated by commas."""
+
+    upcaseTokens = staticmethod(tokenMap(lambda t: _ustr(t).upper()))
+    """Parse action to convert tokens to upper case."""
+
+    downcaseTokens = staticmethod(tokenMap(lambda t: _ustr(t).lower()))
+    """Parse action to convert tokens to lower case."""
+
+
+if __name__ == "__main__":
+
+    selectToken    = CaselessLiteral("select")
+    fromToken      = CaselessLiteral("from")
+
+    ident          = Word(alphas, alphanums + "_$")
+
+    columnName     = delimitedList(ident, ".", combine=True).setParseAction(upcaseTokens)
+    columnNameList = Group(delimitedList(columnName)).setName("columns")
+    columnSpec     = ('*' | columnNameList)
+
+    tableName      = delimitedList(ident, ".", combine=True).setParseAction(upcaseTokens)
+    tableNameList  = Group(delimitedList(tableName)).setName("tables")
+    
+    simpleSQL      = selectToken("command") + columnSpec("columns") + fromToken + tableNameList("tables")
+
+    # demo runTests method, including embedded comments in test string
+    simpleSQL.runTests("""
+        # '*' as column list and dotted table name
+        select * from SYS.XYZZY
+
+        # caseless match on "SELECT", and casts back to "select"
+        SELECT * from XYZZY, ABC
+
+        # list of column names, and mixed case SELECT keyword
+        Select AA,BB,CC from Sys.dual
+
+        # multiple tables
+        Select A, B, C from Sys.dual, Table2
+
+        # invalid SELECT keyword - should fail
+        Xelect A, B, C from Sys.dual
+
+        # incomplete command - should fail
+        Select
+
+        # invalid column name - should fail
+        Select ^^^ frox Sys.dual
+
+        """)
+
+    pyparsing_common.number.runTests("""
+        100
+        -100
+        +100
+        3.14159
+        6.02e23
+        1e-12
+        """)
+
+    # any int or real number, returned as float
+    pyparsing_common.fnumber.runTests("""
+        100
+        -100
+        +100
+        3.14159
+        6.02e23
+        1e-12
+        """)
+
+    pyparsing_common.hex_integer.runTests("""
+        100
+        FF
+        """)
+
+    import uuid
+    pyparsing_common.uuid.setParseAction(tokenMap(uuid.UUID))
+    pyparsing_common.uuid.runTests("""
+        12345678-1234-5678-1234-567812345678
+        """)
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/_vendor/pyparsing.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/_vendor/pyparsing.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..805dd79862d117e4e1abd6f2e2685d0dc80eedb1
GIT binary patch
literal 258922
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%0A8#JDvV0|Nsn9TmHQw(WrDTT;O#e@ba??%-I2
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
E07^VyqyPW_

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/_vendor/six.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/_vendor/six.py
new file mode 100644
index 0000000..190c023
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/_vendor/six.py
@@ -0,0 +1,868 @@
+"""Utilities for writing code that runs on Python 2 and 3"""
+
+# Copyright (c) 2010-2015 Benjamin Peterson
+#
+# Permission is hereby granted, free of charge, to any person obtaining a copy
+# of this software and associated documentation files (the "Software"), to deal
+# in the Software without restriction, including without limitation the rights
+# to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
+# copies of the Software, and to permit persons to whom the Software is
+# furnished to do so, subject to the following conditions:
+#
+# The above copyright notice and this permission notice shall be included in all
+# copies or substantial portions of the Software.
+#
+# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
+# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
+# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
+# AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
+# LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
+# OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
+# SOFTWARE.
+
+from __future__ import absolute_import
+
+import functools
+import itertools
+import operator
+import sys
+import types
+
+__author__ = "Benjamin Peterson <benjamin@python.org>"
+__version__ = "1.10.0"
+
+
+# Useful for very coarse version differentiation.
+PY2 = sys.version_info[0] == 2
+PY3 = sys.version_info[0] == 3
+PY34 = sys.version_info[0:2] >= (3, 4)
+
+if PY3:
+    string_types = str,
+    integer_types = int,
+    class_types = type,
+    text_type = str
+    binary_type = bytes
+
+    MAXSIZE = sys.maxsize
+else:
+    string_types = basestring,
+    integer_types = (int, long)
+    class_types = (type, types.ClassType)
+    text_type = unicode
+    binary_type = str
+
+    if sys.platform.startswith("java"):
+        # Jython always uses 32 bits.
+        MAXSIZE = int((1 << 31) - 1)
+    else:
+        # It's possible to have sizeof(long) != sizeof(Py_ssize_t).
+        class X(object):
+
+            def __len__(self):
+                return 1 << 31
+        try:
+            len(X())
+        except OverflowError:
+            # 32-bit
+            MAXSIZE = int((1 << 31) - 1)
+        else:
+            # 64-bit
+            MAXSIZE = int((1 << 63) - 1)
+        del X
+
+
+def _add_doc(func, doc):
+    """Add documentation to a function."""
+    func.__doc__ = doc
+
+
+def _import_module(name):
+    """Import module, returning the module after the last dot."""
+    __import__(name)
+    return sys.modules[name]
+
+
+class _LazyDescr(object):
+
+    def __init__(self, name):
+        self.name = name
+
+    def __get__(self, obj, tp):
+        result = self._resolve()
+        setattr(obj, self.name, result)  # Invokes __set__.
+        try:
+            # This is a bit ugly, but it avoids running this again by
+            # removing this descriptor.
+            delattr(obj.__class__, self.name)
+        except AttributeError:
+            pass
+        return result
+
+
+class MovedModule(_LazyDescr):
+
+    def __init__(self, name, old, new=None):
+        super(MovedModule, self).__init__(name)
+        if PY3:
+            if new is None:
+                new = name
+            self.mod = new
+        else:
+            self.mod = old
+
+    def _resolve(self):
+        return _import_module(self.mod)
+
+    def __getattr__(self, attr):
+        _module = self._resolve()
+        value = getattr(_module, attr)
+        setattr(self, attr, value)
+        return value
+
+
+class _LazyModule(types.ModuleType):
+
+    def __init__(self, name):
+        super(_LazyModule, self).__init__(name)
+        self.__doc__ = self.__class__.__doc__
+
+    def __dir__(self):
+        attrs = ["__doc__", "__name__"]
+        attrs += [attr.name for attr in self._moved_attributes]
+        return attrs
+
+    # Subclasses should override this
+    _moved_attributes = []
+
+
+class MovedAttribute(_LazyDescr):
+
+    def __init__(self, name, old_mod, new_mod, old_attr=None, new_attr=None):
+        super(MovedAttribute, self).__init__(name)
+        if PY3:
+            if new_mod is None:
+                new_mod = name
+            self.mod = new_mod
+            if new_attr is None:
+                if old_attr is None:
+                    new_attr = name
+                else:
+                    new_attr = old_attr
+            self.attr = new_attr
+        else:
+            self.mod = old_mod
+            if old_attr is None:
+                old_attr = name
+            self.attr = old_attr
+
+    def _resolve(self):
+        module = _import_module(self.mod)
+        return getattr(module, self.attr)
+
+
+class _SixMetaPathImporter(object):
+
+    """
+    A meta path importer to import six.moves and its submodules.
+
+    This class implements a PEP302 finder and loader. It should be compatible
+    with Python 2.5 and all existing versions of Python3
+    """
+
+    def __init__(self, six_module_name):
+        self.name = six_module_name
+        self.known_modules = {}
+
+    def _add_module(self, mod, *fullnames):
+        for fullname in fullnames:
+            self.known_modules[self.name + "." + fullname] = mod
+
+    def _get_module(self, fullname):
+        return self.known_modules[self.name + "." + fullname]
+
+    def find_module(self, fullname, path=None):
+        if fullname in self.known_modules:
+            return self
+        return None
+
+    def __get_module(self, fullname):
+        try:
+            return self.known_modules[fullname]
+        except KeyError:
+            raise ImportError("This loader does not know module " + fullname)
+
+    def load_module(self, fullname):
+        try:
+            # in case of a reload
+            return sys.modules[fullname]
+        except KeyError:
+            pass
+        mod = self.__get_module(fullname)
+        if isinstance(mod, MovedModule):
+            mod = mod._resolve()
+        else:
+            mod.__loader__ = self
+        sys.modules[fullname] = mod
+        return mod
+
+    def is_package(self, fullname):
+        """
+        Return true, if the named module is a package.
+
+        We need this method to get correct spec objects with
+        Python 3.4 (see PEP451)
+        """
+        return hasattr(self.__get_module(fullname), "__path__")
+
+    def get_code(self, fullname):
+        """Return None
+
+        Required, if is_package is implemented"""
+        self.__get_module(fullname)  # eventually raises ImportError
+        return None
+    get_source = get_code  # same as get_code
+
+_importer = _SixMetaPathImporter(__name__)
+
+
+class _MovedItems(_LazyModule):
+
+    """Lazy loading of moved objects"""
+    __path__ = []  # mark as package
+
+
+_moved_attributes = [
+    MovedAttribute("cStringIO", "cStringIO", "io", "StringIO"),
+    MovedAttribute("filter", "itertools", "builtins", "ifilter", "filter"),
+    MovedAttribute("filterfalse", "itertools", "itertools", "ifilterfalse", "filterfalse"),
+    MovedAttribute("input", "__builtin__", "builtins", "raw_input", "input"),
+    MovedAttribute("intern", "__builtin__", "sys"),
+    MovedAttribute("map", "itertools", "builtins", "imap", "map"),
+    MovedAttribute("getcwd", "os", "os", "getcwdu", "getcwd"),
+    MovedAttribute("getcwdb", "os", "os", "getcwd", "getcwdb"),
+    MovedAttribute("range", "__builtin__", "builtins", "xrange", "range"),
+    MovedAttribute("reload_module", "__builtin__", "importlib" if PY34 else "imp", "reload"),
+    MovedAttribute("reduce", "__builtin__", "functools"),
+    MovedAttribute("shlex_quote", "pipes", "shlex", "quote"),
+    MovedAttribute("StringIO", "StringIO", "io"),
+    MovedAttribute("UserDict", "UserDict", "collections"),
+    MovedAttribute("UserList", "UserList", "collections"),
+    MovedAttribute("UserString", "UserString", "collections"),
+    MovedAttribute("xrange", "__builtin__", "builtins", "xrange", "range"),
+    MovedAttribute("zip", "itertools", "builtins", "izip", "zip"),
+    MovedAttribute("zip_longest", "itertools", "itertools", "izip_longest", "zip_longest"),
+    MovedModule("builtins", "__builtin__"),
+    MovedModule("configparser", "ConfigParser"),
+    MovedModule("copyreg", "copy_reg"),
+    MovedModule("dbm_gnu", "gdbm", "dbm.gnu"),
+    MovedModule("_dummy_thread", "dummy_thread", "_dummy_thread"),
+    MovedModule("http_cookiejar", "cookielib", "http.cookiejar"),
+    MovedModule("http_cookies", "Cookie", "http.cookies"),
+    MovedModule("html_entities", "htmlentitydefs", "html.entities"),
+    MovedModule("html_parser", "HTMLParser", "html.parser"),
+    MovedModule("http_client", "httplib", "http.client"),
+    MovedModule("email_mime_multipart", "email.MIMEMultipart", "email.mime.multipart"),
+    MovedModule("email_mime_nonmultipart", "email.MIMENonMultipart", "email.mime.nonmultipart"),
+    MovedModule("email_mime_text", "email.MIMEText", "email.mime.text"),
+    MovedModule("email_mime_base", "email.MIMEBase", "email.mime.base"),
+    MovedModule("BaseHTTPServer", "BaseHTTPServer", "http.server"),
+    MovedModule("CGIHTTPServer", "CGIHTTPServer", "http.server"),
+    MovedModule("SimpleHTTPServer", "SimpleHTTPServer", "http.server"),
+    MovedModule("cPickle", "cPickle", "pickle"),
+    MovedModule("queue", "Queue"),
+    MovedModule("reprlib", "repr"),
+    MovedModule("socketserver", "SocketServer"),
+    MovedModule("_thread", "thread", "_thread"),
+    MovedModule("tkinter", "Tkinter"),
+    MovedModule("tkinter_dialog", "Dialog", "tkinter.dialog"),
+    MovedModule("tkinter_filedialog", "FileDialog", "tkinter.filedialog"),
+    MovedModule("tkinter_scrolledtext", "ScrolledText", "tkinter.scrolledtext"),
+    MovedModule("tkinter_simpledialog", "SimpleDialog", "tkinter.simpledialog"),
+    MovedModule("tkinter_tix", "Tix", "tkinter.tix"),
+    MovedModule("tkinter_ttk", "ttk", "tkinter.ttk"),
+    MovedModule("tkinter_constants", "Tkconstants", "tkinter.constants"),
+    MovedModule("tkinter_dnd", "Tkdnd", "tkinter.dnd"),
+    MovedModule("tkinter_colorchooser", "tkColorChooser",
+                "tkinter.colorchooser"),
+    MovedModule("tkinter_commondialog", "tkCommonDialog",
+                "tkinter.commondialog"),
+    MovedModule("tkinter_tkfiledialog", "tkFileDialog", "tkinter.filedialog"),
+    MovedModule("tkinter_font", "tkFont", "tkinter.font"),
+    MovedModule("tkinter_messagebox", "tkMessageBox", "tkinter.messagebox"),
+    MovedModule("tkinter_tksimpledialog", "tkSimpleDialog",
+                "tkinter.simpledialog"),
+    MovedModule("urllib_parse", __name__ + ".moves.urllib_parse", "urllib.parse"),
+    MovedModule("urllib_error", __name__ + ".moves.urllib_error", "urllib.error"),
+    MovedModule("urllib", __name__ + ".moves.urllib", __name__ + ".moves.urllib"),
+    MovedModule("urllib_robotparser", "robotparser", "urllib.robotparser"),
+    MovedModule("xmlrpc_client", "xmlrpclib", "xmlrpc.client"),
+    MovedModule("xmlrpc_server", "SimpleXMLRPCServer", "xmlrpc.server"),
+]
+# Add windows specific modules.
+if sys.platform == "win32":
+    _moved_attributes += [
+        MovedModule("winreg", "_winreg"),
+    ]
+
+for attr in _moved_attributes:
+    setattr(_MovedItems, attr.name, attr)
+    if isinstance(attr, MovedModule):
+        _importer._add_module(attr, "moves." + attr.name)
+del attr
+
+_MovedItems._moved_attributes = _moved_attributes
+
+moves = _MovedItems(__name__ + ".moves")
+_importer._add_module(moves, "moves")
+
+
+class Module_six_moves_urllib_parse(_LazyModule):
+
+    """Lazy loading of moved objects in six.moves.urllib_parse"""
+
+
+_urllib_parse_moved_attributes = [
+    MovedAttribute("ParseResult", "urlparse", "urllib.parse"),
+    MovedAttribute("SplitResult", "urlparse", "urllib.parse"),
+    MovedAttribute("parse_qs", "urlparse", "urllib.parse"),
+    MovedAttribute("parse_qsl", "urlparse", "urllib.parse"),
+    MovedAttribute("urldefrag", "urlparse", "urllib.parse"),
+    MovedAttribute("urljoin", "urlparse", "urllib.parse"),
+    MovedAttribute("urlparse", "urlparse", "urllib.parse"),
+    MovedAttribute("urlsplit", "urlparse", "urllib.parse"),
+    MovedAttribute("urlunparse", "urlparse", "urllib.parse"),
+    MovedAttribute("urlunsplit", "urlparse", "urllib.parse"),
+    MovedAttribute("quote", "urllib", "urllib.parse"),
+    MovedAttribute("quote_plus", "urllib", "urllib.parse"),
+    MovedAttribute("unquote", "urllib", "urllib.parse"),
+    MovedAttribute("unquote_plus", "urllib", "urllib.parse"),
+    MovedAttribute("urlencode", "urllib", "urllib.parse"),
+    MovedAttribute("splitquery", "urllib", "urllib.parse"),
+    MovedAttribute("splittag", "urllib", "urllib.parse"),
+    MovedAttribute("splituser", "urllib", "urllib.parse"),
+    MovedAttribute("uses_fragment", "urlparse", "urllib.parse"),
+    MovedAttribute("uses_netloc", "urlparse", "urllib.parse"),
+    MovedAttribute("uses_params", "urlparse", "urllib.parse"),
+    MovedAttribute("uses_query", "urlparse", "urllib.parse"),
+    MovedAttribute("uses_relative", "urlparse", "urllib.parse"),
+]
+for attr in _urllib_parse_moved_attributes:
+    setattr(Module_six_moves_urllib_parse, attr.name, attr)
+del attr
+
+Module_six_moves_urllib_parse._moved_attributes = _urllib_parse_moved_attributes
+
+_importer._add_module(Module_six_moves_urllib_parse(__name__ + ".moves.urllib_parse"),
+                      "moves.urllib_parse", "moves.urllib.parse")
+
+
+class Module_six_moves_urllib_error(_LazyModule):
+
+    """Lazy loading of moved objects in six.moves.urllib_error"""
+
+
+_urllib_error_moved_attributes = [
+    MovedAttribute("URLError", "urllib2", "urllib.error"),
+    MovedAttribute("HTTPError", "urllib2", "urllib.error"),
+    MovedAttribute("ContentTooShortError", "urllib", "urllib.error"),
+]
+for attr in _urllib_error_moved_attributes:
+    setattr(Module_six_moves_urllib_error, attr.name, attr)
+del attr
+
+Module_six_moves_urllib_error._moved_attributes = _urllib_error_moved_attributes
+
+_importer._add_module(Module_six_moves_urllib_error(__name__ + ".moves.urllib.error"),
+                      "moves.urllib_error", "moves.urllib.error")
+
+
+class Module_six_moves_urllib_request(_LazyModule):
+
+    """Lazy loading of moved objects in six.moves.urllib_request"""
+
+
+_urllib_request_moved_attributes = [
+    MovedAttribute("urlopen", "urllib2", "urllib.request"),
+    MovedAttribute("install_opener", "urllib2", "urllib.request"),
+    MovedAttribute("build_opener", "urllib2", "urllib.request"),
+    MovedAttribute("pathname2url", "urllib", "urllib.request"),
+    MovedAttribute("url2pathname", "urllib", "urllib.request"),
+    MovedAttribute("getproxies", "urllib", "urllib.request"),
+    MovedAttribute("Request", "urllib2", "urllib.request"),
+    MovedAttribute("OpenerDirector", "urllib2", "urllib.request"),
+    MovedAttribute("HTTPDefaultErrorHandler", "urllib2", "urllib.request"),
+    MovedAttribute("HTTPRedirectHandler", "urllib2", "urllib.request"),
+    MovedAttribute("HTTPCookieProcessor", "urllib2", "urllib.request"),
+    MovedAttribute("ProxyHandler", "urllib2", "urllib.request"),
+    MovedAttribute("BaseHandler", "urllib2", "urllib.request"),
+    MovedAttribute("HTTPPasswordMgr", "urllib2", "urllib.request"),
+    MovedAttribute("HTTPPasswordMgrWithDefaultRealm", "urllib2", "urllib.request"),
+    MovedAttribute("AbstractBasicAuthHandler", "urllib2", "urllib.request"),
+    MovedAttribute("HTTPBasicAuthHandler", "urllib2", "urllib.request"),
+    MovedAttribute("ProxyBasicAuthHandler", "urllib2", "urllib.request"),
+    MovedAttribute("AbstractDigestAuthHandler", "urllib2", "urllib.request"),
+    MovedAttribute("HTTPDigestAuthHandler", "urllib2", "urllib.request"),
+    MovedAttribute("ProxyDigestAuthHandler", "urllib2", "urllib.request"),
+    MovedAttribute("HTTPHandler", "urllib2", "urllib.request"),
+    MovedAttribute("HTTPSHandler", "urllib2", "urllib.request"),
+    MovedAttribute("FileHandler", "urllib2", "urllib.request"),
+    MovedAttribute("FTPHandler", "urllib2", "urllib.request"),
+    MovedAttribute("CacheFTPHandler", "urllib2", "urllib.request"),
+    MovedAttribute("UnknownHandler", "urllib2", "urllib.request"),
+    MovedAttribute("HTTPErrorProcessor", "urllib2", "urllib.request"),
+    MovedAttribute("urlretrieve", "urllib", "urllib.request"),
+    MovedAttribute("urlcleanup", "urllib", "urllib.request"),
+    MovedAttribute("URLopener", "urllib", "urllib.request"),
+    MovedAttribute("FancyURLopener", "urllib", "urllib.request"),
+    MovedAttribute("proxy_bypass", "urllib", "urllib.request"),
+]
+for attr in _urllib_request_moved_attributes:
+    setattr(Module_six_moves_urllib_request, attr.name, attr)
+del attr
+
+Module_six_moves_urllib_request._moved_attributes = _urllib_request_moved_attributes
+
+_importer._add_module(Module_six_moves_urllib_request(__name__ + ".moves.urllib.request"),
+                      "moves.urllib_request", "moves.urllib.request")
+
+
+class Module_six_moves_urllib_response(_LazyModule):
+
+    """Lazy loading of moved objects in six.moves.urllib_response"""
+
+
+_urllib_response_moved_attributes = [
+    MovedAttribute("addbase", "urllib", "urllib.response"),
+    MovedAttribute("addclosehook", "urllib", "urllib.response"),
+    MovedAttribute("addinfo", "urllib", "urllib.response"),
+    MovedAttribute("addinfourl", "urllib", "urllib.response"),
+]
+for attr in _urllib_response_moved_attributes:
+    setattr(Module_six_moves_urllib_response, attr.name, attr)
+del attr
+
+Module_six_moves_urllib_response._moved_attributes = _urllib_response_moved_attributes
+
+_importer._add_module(Module_six_moves_urllib_response(__name__ + ".moves.urllib.response"),
+                      "moves.urllib_response", "moves.urllib.response")
+
+
+class Module_six_moves_urllib_robotparser(_LazyModule):
+
+    """Lazy loading of moved objects in six.moves.urllib_robotparser"""
+
+
+_urllib_robotparser_moved_attributes = [
+    MovedAttribute("RobotFileParser", "robotparser", "urllib.robotparser"),
+]
+for attr in _urllib_robotparser_moved_attributes:
+    setattr(Module_six_moves_urllib_robotparser, attr.name, attr)
+del attr
+
+Module_six_moves_urllib_robotparser._moved_attributes = _urllib_robotparser_moved_attributes
+
+_importer._add_module(Module_six_moves_urllib_robotparser(__name__ + ".moves.urllib.robotparser"),
+                      "moves.urllib_robotparser", "moves.urllib.robotparser")
+
+
+class Module_six_moves_urllib(types.ModuleType):
+
+    """Create a six.moves.urllib namespace that resembles the Python 3 namespace"""
+    __path__ = []  # mark as package
+    parse = _importer._get_module("moves.urllib_parse")
+    error = _importer._get_module("moves.urllib_error")
+    request = _importer._get_module("moves.urllib_request")
+    response = _importer._get_module("moves.urllib_response")
+    robotparser = _importer._get_module("moves.urllib_robotparser")
+
+    def __dir__(self):
+        return ['parse', 'error', 'request', 'response', 'robotparser']
+
+_importer._add_module(Module_six_moves_urllib(__name__ + ".moves.urllib"),
+                      "moves.urllib")
+
+
+def add_move(move):
+    """Add an item to six.moves."""
+    setattr(_MovedItems, move.name, move)
+
+
+def remove_move(name):
+    """Remove item from six.moves."""
+    try:
+        delattr(_MovedItems, name)
+    except AttributeError:
+        try:
+            del moves.__dict__[name]
+        except KeyError:
+            raise AttributeError("no such move, %r" % (name,))
+
+
+if PY3:
+    _meth_func = "__func__"
+    _meth_self = "__self__"
+
+    _func_closure = "__closure__"
+    _func_code = "__code__"
+    _func_defaults = "__defaults__"
+    _func_globals = "__globals__"
+else:
+    _meth_func = "im_func"
+    _meth_self = "im_self"
+
+    _func_closure = "func_closure"
+    _func_code = "func_code"
+    _func_defaults = "func_defaults"
+    _func_globals = "func_globals"
+
+
+try:
+    advance_iterator = next
+except NameError:
+    def advance_iterator(it):
+        return it.next()
+next = advance_iterator
+
+
+try:
+    callable = callable
+except NameError:
+    def callable(obj):
+        return any("__call__" in klass.__dict__ for klass in type(obj).__mro__)
+
+
+if PY3:
+    def get_unbound_function(unbound):
+        return unbound
+
+    create_bound_method = types.MethodType
+
+    def create_unbound_method(func, cls):
+        return func
+
+    Iterator = object
+else:
+    def get_unbound_function(unbound):
+        return unbound.im_func
+
+    def create_bound_method(func, obj):
+        return types.MethodType(func, obj, obj.__class__)
+
+    def create_unbound_method(func, cls):
+        return types.MethodType(func, None, cls)
+
+    class Iterator(object):
+
+        def next(self):
+            return type(self).__next__(self)
+
+    callable = callable
+_add_doc(get_unbound_function,
+         """Get the function out of a possibly unbound function""")
+
+
+get_method_function = operator.attrgetter(_meth_func)
+get_method_self = operator.attrgetter(_meth_self)
+get_function_closure = operator.attrgetter(_func_closure)
+get_function_code = operator.attrgetter(_func_code)
+get_function_defaults = operator.attrgetter(_func_defaults)
+get_function_globals = operator.attrgetter(_func_globals)
+
+
+if PY3:
+    def iterkeys(d, **kw):
+        return iter(d.keys(**kw))
+
+    def itervalues(d, **kw):
+        return iter(d.values(**kw))
+
+    def iteritems(d, **kw):
+        return iter(d.items(**kw))
+
+    def iterlists(d, **kw):
+        return iter(d.lists(**kw))
+
+    viewkeys = operator.methodcaller("keys")
+
+    viewvalues = operator.methodcaller("values")
+
+    viewitems = operator.methodcaller("items")
+else:
+    def iterkeys(d, **kw):
+        return d.iterkeys(**kw)
+
+    def itervalues(d, **kw):
+        return d.itervalues(**kw)
+
+    def iteritems(d, **kw):
+        return d.iteritems(**kw)
+
+    def iterlists(d, **kw):
+        return d.iterlists(**kw)
+
+    viewkeys = operator.methodcaller("viewkeys")
+
+    viewvalues = operator.methodcaller("viewvalues")
+
+    viewitems = operator.methodcaller("viewitems")
+
+_add_doc(iterkeys, "Return an iterator over the keys of a dictionary.")
+_add_doc(itervalues, "Return an iterator over the values of a dictionary.")
+_add_doc(iteritems,
+         "Return an iterator over the (key, value) pairs of a dictionary.")
+_add_doc(iterlists,
+         "Return an iterator over the (key, [values]) pairs of a dictionary.")
+
+
+if PY3:
+    def b(s):
+        return s.encode("latin-1")
+
+    def u(s):
+        return s
+    unichr = chr
+    import struct
+    int2byte = struct.Struct(">B").pack
+    del struct
+    byte2int = operator.itemgetter(0)
+    indexbytes = operator.getitem
+    iterbytes = iter
+    import io
+    StringIO = io.StringIO
+    BytesIO = io.BytesIO
+    _assertCountEqual = "assertCountEqual"
+    if sys.version_info[1] <= 1:
+        _assertRaisesRegex = "assertRaisesRegexp"
+        _assertRegex = "assertRegexpMatches"
+    else:
+        _assertRaisesRegex = "assertRaisesRegex"
+        _assertRegex = "assertRegex"
+else:
+    def b(s):
+        return s
+    # Workaround for standalone backslash
+
+    def u(s):
+        return unicode(s.replace(r'\\', r'\\\\'), "unicode_escape")
+    unichr = unichr
+    int2byte = chr
+
+    def byte2int(bs):
+        return ord(bs[0])
+
+    def indexbytes(buf, i):
+        return ord(buf[i])
+    iterbytes = functools.partial(itertools.imap, ord)
+    import StringIO
+    StringIO = BytesIO = StringIO.StringIO
+    _assertCountEqual = "assertItemsEqual"
+    _assertRaisesRegex = "assertRaisesRegexp"
+    _assertRegex = "assertRegexpMatches"
+_add_doc(b, """Byte literal""")
+_add_doc(u, """Text literal""")
+
+
+def assertCountEqual(self, *args, **kwargs):
+    return getattr(self, _assertCountEqual)(*args, **kwargs)
+
+
+def assertRaisesRegex(self, *args, **kwargs):
+    return getattr(self, _assertRaisesRegex)(*args, **kwargs)
+
+
+def assertRegex(self, *args, **kwargs):
+    return getattr(self, _assertRegex)(*args, **kwargs)
+
+
+if PY3:
+    exec_ = getattr(moves.builtins, "exec")
+
+    def reraise(tp, value, tb=None):
+        if value is None:
+            value = tp()
+        if value.__traceback__ is not tb:
+            raise value.with_traceback(tb)
+        raise value
+
+else:
+    def exec_(_code_, _globs_=None, _locs_=None):
+        """Execute code in a namespace."""
+        if _globs_ is None:
+            frame = sys._getframe(1)
+            _globs_ = frame.f_globals
+            if _locs_ is None:
+                _locs_ = frame.f_locals
+            del frame
+        elif _locs_ is None:
+            _locs_ = _globs_
+        exec("""exec _code_ in _globs_, _locs_""")
+
+    exec_("""def reraise(tp, value, tb=None):
+    raise tp, value, tb
+""")
+
+
+if sys.version_info[:2] == (3, 2):
+    exec_("""def raise_from(value, from_value):
+    if from_value is None:
+        raise value
+    raise value from from_value
+""")
+elif sys.version_info[:2] > (3, 2):
+    exec_("""def raise_from(value, from_value):
+    raise value from from_value
+""")
+else:
+    def raise_from(value, from_value):
+        raise value
+
+
+print_ = getattr(moves.builtins, "print", None)
+if print_ is None:
+    def print_(*args, **kwargs):
+        """The new-style print function for Python 2.4 and 2.5."""
+        fp = kwargs.pop("file", sys.stdout)
+        if fp is None:
+            return
+
+        def write(data):
+            if not isinstance(data, basestring):
+                data = str(data)
+            # If the file has an encoding, encode unicode with it.
+            if (isinstance(fp, file) and
+                    isinstance(data, unicode) and
+                    fp.encoding is not None):
+                errors = getattr(fp, "errors", None)
+                if errors is None:
+                    errors = "strict"
+                data = data.encode(fp.encoding, errors)
+            fp.write(data)
+        want_unicode = False
+        sep = kwargs.pop("sep", None)
+        if sep is not None:
+            if isinstance(sep, unicode):
+                want_unicode = True
+            elif not isinstance(sep, str):
+                raise TypeError("sep must be None or a string")
+        end = kwargs.pop("end", None)
+        if end is not None:
+            if isinstance(end, unicode):
+                want_unicode = True
+            elif not isinstance(end, str):
+                raise TypeError("end must be None or a string")
+        if kwargs:
+            raise TypeError("invalid keyword arguments to print()")
+        if not want_unicode:
+            for arg in args:
+                if isinstance(arg, unicode):
+                    want_unicode = True
+                    break
+        if want_unicode:
+            newline = unicode("\n")
+            space = unicode(" ")
+        else:
+            newline = "\n"
+            space = " "
+        if sep is None:
+            sep = space
+        if end is None:
+            end = newline
+        for i, arg in enumerate(args):
+            if i:
+                write(sep)
+            write(arg)
+        write(end)
+if sys.version_info[:2] < (3, 3):
+    _print = print_
+
+    def print_(*args, **kwargs):
+        fp = kwargs.get("file", sys.stdout)
+        flush = kwargs.pop("flush", False)
+        _print(*args, **kwargs)
+        if flush and fp is not None:
+            fp.flush()
+
+_add_doc(reraise, """Reraise an exception.""")
+
+if sys.version_info[0:2] < (3, 4):
+    def wraps(wrapped, assigned=functools.WRAPPER_ASSIGNMENTS,
+              updated=functools.WRAPPER_UPDATES):
+        def wrapper(f):
+            f = functools.wraps(wrapped, assigned, updated)(f)
+            f.__wrapped__ = wrapped
+            return f
+        return wrapper
+else:
+    wraps = functools.wraps
+
+
+def with_metaclass(meta, *bases):
+    """Create a base class with a metaclass."""
+    # This requires a bit of explanation: the basic idea is to make a dummy
+    # metaclass for one level of class instantiation that replaces itself with
+    # the actual metaclass.
+    class metaclass(meta):
+
+        def __new__(cls, name, this_bases, d):
+            return meta(name, bases, d)
+    return type.__new__(metaclass, 'temporary_class', (), {})
+
+
+def add_metaclass(metaclass):
+    """Class decorator for creating a class with a metaclass."""
+    def wrapper(cls):
+        orig_vars = cls.__dict__.copy()
+        slots = orig_vars.get('__slots__')
+        if slots is not None:
+            if isinstance(slots, str):
+                slots = [slots]
+            for slots_var in slots:
+                orig_vars.pop(slots_var)
+        orig_vars.pop('__dict__', None)
+        orig_vars.pop('__weakref__', None)
+        return metaclass(cls.__name__, cls.__bases__, orig_vars)
+    return wrapper
+
+
+def python_2_unicode_compatible(klass):
+    """
+    A decorator that defines __unicode__ and __str__ methods under Python 2.
+    Under Python 3 it does nothing.
+
+    To support Python 2 and 3 with a single code base, define a __str__ method
+    returning text and apply this decorator to the class.
+    """
+    if PY2:
+        if '__str__' not in klass.__dict__:
+            raise ValueError("@python_2_unicode_compatible cannot be applied "
+                             "to %s because it doesn't define __str__()." %
+                             klass.__name__)
+        klass.__unicode__ = klass.__str__
+        klass.__str__ = lambda self: self.__unicode__().encode('utf-8')
+    return klass
+
+
+# Complete the moves implementation.
+# This code is at the end of this module to speed up module loading.
+# Turn this module into a package.
+__path__ = []  # required for PEP 302 and PEP 451
+__package__ = __name__  # see PEP 366 @ReservedAssignment
+if globals().get("__spec__") is not None:
+    __spec__.submodule_search_locations = []  # PEP 451 @UndefinedVariable
+# Remove other six meta path importers, since they cause problems. This can
+# happen if six is removed from sys.modules and then reloaded. (Setuptools does
+# this for some reason.)
+if sys.meta_path:
+    for i, importer in enumerate(sys.meta_path):
+        # Here's some real nastiness: Another "instance" of the six module might
+        # be floating around. Therefore, we can't use isinstance() to check for
+        # the six meta path importer, since the other six instance will have
+        # inserted an importer with different class.
+        if (type(importer).__name__ == "_SixMetaPathImporter" and
+                importer.name == __name__):
+            del sys.meta_path[i]
+            break
+    del i, importer
+# Finally, add the importer to the meta path import hook.
+sys.meta_path.append(_importer)
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/_vendor/six.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/_vendor/six.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..11cd99f5f2b2fa1d5104e7116cc8db89b5de5680
GIT binary patch
literal 35865
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

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/archive_util.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/archive_util.py
new file mode 100644
index 0000000..8143604
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/archive_util.py
@@ -0,0 +1,173 @@
+"""Utilities for extracting common archive formats"""
+
+import zipfile
+import tarfile
+import os
+import shutil
+import posixpath
+import contextlib
+from distutils.errors import DistutilsError
+
+from pkg_resources import ensure_directory
+
+__all__ = [
+    "unpack_archive", "unpack_zipfile", "unpack_tarfile", "default_filter",
+    "UnrecognizedFormat", "extraction_drivers", "unpack_directory",
+]
+
+
+class UnrecognizedFormat(DistutilsError):
+    """Couldn't recognize the archive type"""
+
+
+def default_filter(src, dst):
+    """The default progress/filter callback; returns True for all files"""
+    return dst
+
+
+def unpack_archive(filename, extract_dir, progress_filter=default_filter,
+        drivers=None):
+    """Unpack `filename` to `extract_dir`, or raise ``UnrecognizedFormat``
+
+    `progress_filter` is a function taking two arguments: a source path
+    internal to the archive ('/'-separated), and a filesystem path where it
+    will be extracted.  The callback must return the desired extract path
+    (which may be the same as the one passed in), or else ``None`` to skip
+    that file or directory.  The callback can thus be used to report on the
+    progress of the extraction, as well as to filter the items extracted or
+    alter their extraction paths.
+
+    `drivers`, if supplied, must be a non-empty sequence of functions with the
+    same signature as this function (minus the `drivers` argument), that raise
+    ``UnrecognizedFormat`` if they do not support extracting the designated
+    archive type.  The `drivers` are tried in sequence until one is found that
+    does not raise an error, or until all are exhausted (in which case
+    ``UnrecognizedFormat`` is raised).  If you do not supply a sequence of
+    drivers, the module's ``extraction_drivers`` constant will be used, which
+    means that ``unpack_zipfile`` and ``unpack_tarfile`` will be tried, in that
+    order.
+    """
+    for driver in drivers or extraction_drivers:
+        try:
+            driver(filename, extract_dir, progress_filter)
+        except UnrecognizedFormat:
+            continue
+        else:
+            return
+    else:
+        raise UnrecognizedFormat(
+            "Not a recognized archive type: %s" % filename
+        )
+
+
+def unpack_directory(filename, extract_dir, progress_filter=default_filter):
+    """"Unpack" a directory, using the same interface as for archives
+
+    Raises ``UnrecognizedFormat`` if `filename` is not a directory
+    """
+    if not os.path.isdir(filename):
+        raise UnrecognizedFormat("%s is not a directory" % filename)
+
+    paths = {
+        filename: ('', extract_dir),
+    }
+    for base, dirs, files in os.walk(filename):
+        src, dst = paths[base]
+        for d in dirs:
+            paths[os.path.join(base, d)] = src + d + '/', os.path.join(dst, d)
+        for f in files:
+            target = os.path.join(dst, f)
+            target = progress_filter(src + f, target)
+            if not target:
+                # skip non-files
+                continue
+            ensure_directory(target)
+            f = os.path.join(base, f)
+            shutil.copyfile(f, target)
+            shutil.copystat(f, target)
+
+
+def unpack_zipfile(filename, extract_dir, progress_filter=default_filter):
+    """Unpack zip `filename` to `extract_dir`
+
+    Raises ``UnrecognizedFormat`` if `filename` is not a zipfile (as determined
+    by ``zipfile.is_zipfile()``).  See ``unpack_archive()`` for an explanation
+    of the `progress_filter` argument.
+    """
+
+    if not zipfile.is_zipfile(filename):
+        raise UnrecognizedFormat("%s is not a zip file" % (filename,))
+
+    with zipfile.ZipFile(filename) as z:
+        for info in z.infolist():
+            name = info.filename
+
+            # don't extract absolute paths or ones with .. in them
+            if name.startswith('/') or '..' in name.split('/'):
+                continue
+
+            target = os.path.join(extract_dir, *name.split('/'))
+            target = progress_filter(name, target)
+            if not target:
+                continue
+            if name.endswith('/'):
+                # directory
+                ensure_directory(target)
+            else:
+                # file
+                ensure_directory(target)
+                data = z.read(info.filename)
+                with open(target, 'wb') as f:
+                    f.write(data)
+            unix_attributes = info.external_attr >> 16
+            if unix_attributes:
+                os.chmod(target, unix_attributes)
+
+
+def unpack_tarfile(filename, extract_dir, progress_filter=default_filter):
+    """Unpack tar/tar.gz/tar.bz2 `filename` to `extract_dir`
+
+    Raises ``UnrecognizedFormat`` if `filename` is not a tarfile (as determined
+    by ``tarfile.open()``).  See ``unpack_archive()`` for an explanation
+    of the `progress_filter` argument.
+    """
+    try:
+        tarobj = tarfile.open(filename)
+    except tarfile.TarError:
+        raise UnrecognizedFormat(
+            "%s is not a compressed or uncompressed tar file" % (filename,)
+        )
+    with contextlib.closing(tarobj):
+        # don't do any chowning!
+        tarobj.chown = lambda *args: None
+        for member in tarobj:
+            name = member.name
+            # don't extract absolute paths or ones with .. in them
+            if not name.startswith('/') and '..' not in name.split('/'):
+                prelim_dst = os.path.join(extract_dir, *name.split('/'))
+
+                # resolve any links and to extract the link targets as normal
+                # files
+                while member is not None and (member.islnk() or member.issym()):
+                    linkpath = member.linkname
+                    if member.issym():
+                        base = posixpath.dirname(member.name)
+                        linkpath = posixpath.join(base, linkpath)
+                        linkpath = posixpath.normpath(linkpath)
+                    member = tarobj._getmember(linkpath)
+
+                if member is not None and (member.isfile() or member.isdir()):
+                    final_dst = progress_filter(name, prelim_dst)
+                    if final_dst:
+                        if final_dst.endswith(os.sep):
+                            final_dst = final_dst[:-1]
+                        try:
+                            # XXX Ugh
+                            tarobj._extract_member(member, final_dst)
+                        except tarfile.ExtractError:
+                            # chown/chmod/mkfifo/mknode/makedev failed
+                            pass
+        return True
+
+
+extraction_drivers = unpack_directory, unpack_zipfile, unpack_tarfile
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/archive_util.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/archive_util.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..2f17716b583064e788b49993a492ea13b69cad90
GIT binary patch
literal 6574
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

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/build_meta.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/build_meta.py
new file mode 100644
index 0000000..e40904a
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/build_meta.py
@@ -0,0 +1,254 @@
+"""A PEP 517 interface to setuptools
+
+Previously, when a user or a command line tool (let's call it a "frontend")
+needed to make a request of setuptools to take a certain action, for
+example, generating a list of installation requirements, the frontend would
+would call "setup.py egg_info" or "setup.py bdist_wheel" on the command line.
+
+PEP 517 defines a different method of interfacing with setuptools. Rather
+than calling "setup.py" directly, the frontend should:
+
+  1. Set the current directory to the directory with a setup.py file
+  2. Import this module into a safe python interpreter (one in which
+     setuptools can potentially set global variables or crash hard).
+  3. Call one of the functions defined in PEP 517.
+
+What each function does is defined in PEP 517. However, here is a "casual"
+definition of the functions (this definition should not be relied on for
+bug reports or API stability):
+
+  - `build_wheel`: build a wheel in the folder and return the basename
+  - `get_requires_for_build_wheel`: get the `setup_requires` to build
+  - `prepare_metadata_for_build_wheel`: get the `install_requires`
+  - `build_sdist`: build an sdist in the folder and return the basename
+  - `get_requires_for_build_sdist`: get the `setup_requires` to build
+
+Again, this is not a formal definition! Just a "taste" of the module.
+"""
+
+import io
+import os
+import sys
+import tokenize
+import shutil
+import contextlib
+
+import setuptools
+import distutils
+from setuptools.py31compat import TemporaryDirectory
+
+from pkg_resources import parse_requirements
+
+__all__ = ['get_requires_for_build_sdist',
+           'get_requires_for_build_wheel',
+           'prepare_metadata_for_build_wheel',
+           'build_wheel',
+           'build_sdist',
+           '__legacy__',
+           'SetupRequirementsError']
+
+class SetupRequirementsError(BaseException):
+    def __init__(self, specifiers):
+        self.specifiers = specifiers
+
+
+class Distribution(setuptools.dist.Distribution):
+    def fetch_build_eggs(self, specifiers):
+        specifier_list = list(map(str, parse_requirements(specifiers)))
+
+        raise SetupRequirementsError(specifier_list)
+
+    @classmethod
+    @contextlib.contextmanager
+    def patch(cls):
+        """
+        Replace
+        distutils.dist.Distribution with this class
+        for the duration of this context.
+        """
+        orig = distutils.core.Distribution
+        distutils.core.Distribution = cls
+        try:
+            yield
+        finally:
+            distutils.core.Distribution = orig
+
+
+def _to_str(s):
+    """
+    Convert a filename to a string (on Python 2, explicitly
+    a byte string, not Unicode) as distutils checks for the
+    exact type str.
+    """
+    if sys.version_info[0] == 2 and not isinstance(s, str):
+        # Assume it's Unicode, as that's what the PEP says
+        # should be provided.
+        return s.encode(sys.getfilesystemencoding())
+    return s
+
+
+def _get_immediate_subdirectories(a_dir):
+    return [name for name in os.listdir(a_dir)
+            if os.path.isdir(os.path.join(a_dir, name))]
+
+
+def _file_with_extension(directory, extension):
+    matching = (
+        f for f in os.listdir(directory)
+        if f.endswith(extension)
+    )
+    file, = matching
+    return file
+
+
+def _open_setup_script(setup_script):
+    if not os.path.exists(setup_script):
+        # Supply a default setup.py
+        return io.StringIO(u"from setuptools import setup; setup()")
+
+    return getattr(tokenize, 'open', open)(setup_script)
+
+
+class _BuildMetaBackend(object):
+
+    def _fix_config(self, config_settings):
+        config_settings = config_settings or {}
+        config_settings.setdefault('--global-option', [])
+        return config_settings
+
+    def _get_build_requires(self, config_settings, requirements):
+        config_settings = self._fix_config(config_settings)
+
+        sys.argv = sys.argv[:1] + ['egg_info'] + \
+            config_settings["--global-option"]
+        try:
+            with Distribution.patch():
+                self.run_setup()
+        except SetupRequirementsError as e:
+            requirements += e.specifiers
+
+        return requirements
+
+    def run_setup(self, setup_script='setup.py'):
+        # Note that we can reuse our build directory between calls
+        # Correctness comes first, then optimization later
+        __file__ = setup_script
+        __name__ = '__main__'
+
+        with _open_setup_script(__file__) as f:
+            code = f.read().replace(r'\r\n', r'\n')
+
+        exec(compile(code, __file__, 'exec'), locals())
+
+    def get_requires_for_build_wheel(self, config_settings=None):
+        config_settings = self._fix_config(config_settings)
+        return self._get_build_requires(config_settings, requirements=['wheel'])
+
+    def get_requires_for_build_sdist(self, config_settings=None):
+        config_settings = self._fix_config(config_settings)
+        return self._get_build_requires(config_settings, requirements=[])
+
+    def prepare_metadata_for_build_wheel(self, metadata_directory,
+                                         config_settings=None):
+        sys.argv = sys.argv[:1] + ['dist_info', '--egg-base',
+                                   _to_str(metadata_directory)]
+        self.run_setup()
+
+        dist_info_directory = metadata_directory
+        while True:
+            dist_infos = [f for f in os.listdir(dist_info_directory)
+                          if f.endswith('.dist-info')]
+
+            if (len(dist_infos) == 0 and
+                len(_get_immediate_subdirectories(dist_info_directory)) == 1):
+
+                dist_info_directory = os.path.join(
+                    dist_info_directory, os.listdir(dist_info_directory)[0])
+                continue
+
+            assert len(dist_infos) == 1
+            break
+
+        # PEP 517 requires that the .dist-info directory be placed in the
+        # metadata_directory. To comply, we MUST copy the directory to the root
+        if dist_info_directory != metadata_directory:
+            shutil.move(
+                os.path.join(dist_info_directory, dist_infos[0]),
+                metadata_directory)
+            shutil.rmtree(dist_info_directory, ignore_errors=True)
+
+        return dist_infos[0]
+
+    def build_wheel(self, wheel_directory, config_settings=None,
+                    metadata_directory=None):
+        config_settings = self._fix_config(config_settings)
+        wheel_directory = os.path.abspath(wheel_directory)
+
+        # Build the wheel in a temporary directory, then copy to the target
+        with TemporaryDirectory(dir=wheel_directory) as tmp_dist_dir:
+            sys.argv = (sys.argv[:1] +
+                        ['bdist_wheel', '--dist-dir', tmp_dist_dir] +
+                        config_settings["--global-option"])
+            self.run_setup()
+
+            wheel_basename = _file_with_extension(tmp_dist_dir, '.whl')
+            wheel_path = os.path.join(wheel_directory, wheel_basename)
+            if os.path.exists(wheel_path):
+                # os.rename will fail overwriting on non-unix env
+                os.remove(wheel_path)
+            os.rename(os.path.join(tmp_dist_dir, wheel_basename), wheel_path)
+
+        return wheel_basename
+
+    def build_sdist(self, sdist_directory, config_settings=None):
+        config_settings = self._fix_config(config_settings)
+        sdist_directory = os.path.abspath(sdist_directory)
+        sys.argv = sys.argv[:1] + ['sdist', '--formats', 'gztar'] + \
+            config_settings["--global-option"] + \
+            ["--dist-dir", sdist_directory]
+        self.run_setup()
+
+        return _file_with_extension(sdist_directory, '.tar.gz')
+
+
+class _BuildMetaLegacyBackend(_BuildMetaBackend):
+    """Compatibility backend for setuptools
+
+    This is a version of setuptools.build_meta that endeavors to maintain backwards
+    compatibility with pre-PEP 517 modes of invocation. It exists as a temporary
+    bridge between the old packaging mechanism and the new packaging mechanism,
+    and will eventually be removed.
+    """
+    def run_setup(self, setup_script='setup.py'):
+        # In order to maintain compatibility with scripts assuming that
+        # the setup.py script is in a directory on the PYTHONPATH, inject
+        # '' into sys.path. (pypa/setuptools#1642)
+        sys_path = list(sys.path)           # Save the original path
+
+        script_dir = os.path.dirname(os.path.abspath(setup_script))
+        if script_dir not in sys.path:
+            sys.path.insert(0, script_dir)
+
+        try:
+            super(_BuildMetaLegacyBackend,
+                  self).run_setup(setup_script=setup_script)
+        finally:
+            # While PEP 517 frontends should be calling each hook in a fresh
+            # subprocess according to the standard (and thus it should not be
+            # strictly necessary to restore the old sys.path), we'll restore
+            # the original path so that the path manipulation does not persist
+            # within the hook after run_setup is called.
+            sys.path[:] = sys_path
+
+# The primary backend
+_BACKEND = _BuildMetaBackend()
+
+get_requires_for_build_wheel = _BACKEND.get_requires_for_build_wheel
+get_requires_for_build_sdist = _BACKEND.get_requires_for_build_sdist
+prepare_metadata_for_build_wheel = _BACKEND.prepare_metadata_for_build_wheel
+build_wheel = _BACKEND.build_wheel
+build_sdist = _BACKEND.build_sdist
+
+
+# The legacy backend
+__legacy__ = _BuildMetaLegacyBackend()
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/build_meta.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/build_meta.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..e5929649e030664daf5e29e2038306e3e69e985f
GIT binary patch
literal 10676
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

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/cli-32.exe b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/cli-32.exe
new file mode 100644
index 0000000000000000000000000000000000000000..b1487b7819e7286577a043c7726fbe0ca1543083
GIT binary patch
literal 65536
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
Wd~sli`QpG3^2GskkPu7?OalPivUv{x

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/cli-64.exe b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/cli-64.exe
new file mode 100644
index 0000000000000000000000000000000000000000..675e6bf3743f3d3011c238657e7128ee9960ef7f
GIT binary patch
literal 74752
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%0DUkH(*X
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

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/cli.exe b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/cli.exe
new file mode 100644
index 0000000000000000000000000000000000000000..b1487b7819e7286577a043c7726fbe0ca1543083
GIT binary patch
literal 65536
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
Wd~sli`QpG3^2GskkPu7?OalPivUv{x

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/__init__.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/__init__.py
new file mode 100644
index 0000000..fe619e2
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/__init__.py
@@ -0,0 +1,18 @@
+__all__ = [
+    'alias', 'bdist_egg', 'bdist_rpm', 'build_ext', 'build_py', 'develop',
+    'easy_install', 'egg_info', 'install', 'install_lib', 'rotate', 'saveopts',
+    'sdist', 'setopt', 'test', 'install_egg_info', 'install_scripts',
+    'register', 'bdist_wininst', 'upload_docs', 'upload', 'build_clib',
+    'dist_info',
+]
+
+from distutils.command.bdist import bdist
+import sys
+
+from setuptools.command import install_scripts
+
+if 'egg' not in bdist.format_commands:
+    bdist.format_command['egg'] = ('bdist_egg', "Python .egg file")
+    bdist.format_commands.append('egg')
+
+del bdist, sys
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/__init__.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/__init__.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..fc50fa4f0c1e62105fdd047a57648c15e19f4b62
GIT binary patch
literal 936
zcmZSn%**AGdLky70Sd$!7#JKF7#NB-FfcHrFfgPrGNdpuq%bq2urQ>sGNiCEq_8uj
za4@8BGNf=Zq;NB&@GzwCGNkY^r0_GO2r#4wGNcGGqzE&lh%lsxGNgzxq>D2|F)*Zv
zGo(l`<S;ViGBHFkF))Jok_<V_3{lKrIVpx57KU6_hA37B#uRCWR3?TjHim3=hN5K*
zDY9TLJ41>zgAGI?ivz@IW@KQ@V_=A8Vu)sDNRea+){tXhU?^c_U|>kh$xJLR;bdT7
zNJ_~pE{RV~Pe<Yv734yArI|S?@u?LhB^)4?U|vCG2|LK^sb#4-`2{6B3=9mZiN%%i
znR&$}i8(o7m8t3J@tJvP`CyeW32p`k1}Hl|Co`#pje&uoD8D4JBo(ZuII%1>zo4WT
z?7U)-qrfVPQ%mv-N=jHj4o@vEDG@+21#S&Ll3;OiQ6|V3kc*2_(=&@pQj1D>LCy!6
z8DE~62XaIS$Tg(}Ir)hx@hSPq#bCQ2{1PsZVz6J6LGA<v5?Cw9N16Zs|NpPS2yzW5
z7{P((2j&NXTvoyi3Xb&jVh|^wvLquvPeCs=JzXI!GbdGpiGhJ32&5OgG{_=wh{eYz
z=H$f3mw?h5$mY_L%$#Dq<ow*+#Jm(eu$@65Ik0WTmBl4Opahv(Qd&@wpN~)paS<qN
z((;RP6HDTuCKQ+OF)%Qoih=!~SWu9fm!bhm=?J2@l!1Xkzo00yEU_e2zbvsxKP^8e
zCAFwnKPg4OJSizJ*EF}-$S}z~y(-<p)S^5mtIEs(1k&^LL-Y$W3v@x@otTrO>sIFB
zX&j(m40k9p6Y4ho`1s7c%#!$cy@E<`vard`PbtkwwF8A+u^0mbgAk(-BR?ZQBPX)}
PBM*}R6F(y_qc9TyBDL-3

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/alias.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/alias.py
new file mode 100644
index 0000000..4532b1c
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/alias.py
@@ -0,0 +1,80 @@
+from distutils.errors import DistutilsOptionError
+
+from setuptools.extern.six.moves import map
+
+from setuptools.command.setopt import edit_config, option_base, config_file
+
+
+def shquote(arg):
+    """Quote an argument for later parsing by shlex.split()"""
+    for c in '"', "'", "\\", "#":
+        if c in arg:
+            return repr(arg)
+    if arg.split() != [arg]:
+        return repr(arg)
+    return arg
+
+
+class alias(option_base):
+    """Define a shortcut that invokes one or more commands"""
+
+    description = "define a shortcut to invoke one or more commands"
+    command_consumes_arguments = True
+
+    user_options = [
+        ('remove', 'r', 'remove (unset) the alias'),
+    ] + option_base.user_options
+
+    boolean_options = option_base.boolean_options + ['remove']
+
+    def initialize_options(self):
+        option_base.initialize_options(self)
+        self.args = None
+        self.remove = None
+
+    def finalize_options(self):
+        option_base.finalize_options(self)
+        if self.remove and len(self.args) != 1:
+            raise DistutilsOptionError(
+                "Must specify exactly one argument (the alias name) when "
+                "using --remove"
+            )
+
+    def run(self):
+        aliases = self.distribution.get_option_dict('aliases')
+
+        if not self.args:
+            print("Command Aliases")
+            print("---------------")
+            for alias in aliases:
+                print("setup.py alias", format_alias(alias, aliases))
+            return
+
+        elif len(self.args) == 1:
+            alias, = self.args
+            if self.remove:
+                command = None
+            elif alias in aliases:
+                print("setup.py alias", format_alias(alias, aliases))
+                return
+            else:
+                print("No alias definition found for %r" % alias)
+                return
+        else:
+            alias = self.args[0]
+            command = ' '.join(map(shquote, self.args[1:]))
+
+        edit_config(self.filename, {'aliases': {alias: command}}, self.dry_run)
+
+
+def format_alias(name, aliases):
+    source, command = aliases[name]
+    if source == config_file('global'):
+        source = '--global-config '
+    elif source == config_file('user'):
+        source = '--user-config '
+    elif source == config_file('local'):
+        source = ''
+    else:
+        source = '--filename=%r' % source
+    return source + name + ' ' + command
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/alias.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/alias.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..d17d0f5747f0079471e9f5bb10406fd33ad87b6d
GIT binary patch
literal 3482
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
T1Q&w}1OX-iCK+Z<E-@1T>g*`L

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/bdist_egg.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/bdist_egg.py
new file mode 100644
index 0000000..9f8df91
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/bdist_egg.py
@@ -0,0 +1,502 @@
+"""setuptools.command.bdist_egg
+
+Build .egg distributions"""
+
+from distutils.errors import DistutilsSetupError
+from distutils.dir_util import remove_tree, mkpath
+from distutils import log
+from types import CodeType
+import sys
+import os
+import re
+import textwrap
+import marshal
+
+from setuptools.extern import six
+
+from pkg_resources import get_build_platform, Distribution, ensure_directory
+from pkg_resources import EntryPoint
+from setuptools.extension import Library
+from setuptools import Command
+
+try:
+    # Python 2.7 or >=3.2
+    from sysconfig import get_path, get_python_version
+
+    def _get_purelib():
+        return get_path("purelib")
+except ImportError:
+    from distutils.sysconfig import get_python_lib, get_python_version
+
+    def _get_purelib():
+        return get_python_lib(False)
+
+
+def strip_module(filename):
+    if '.' in filename:
+        filename = os.path.splitext(filename)[0]
+    if filename.endswith('module'):
+        filename = filename[:-6]
+    return filename
+
+
+def sorted_walk(dir):
+    """Do os.walk in a reproducible way,
+    independent of indeterministic filesystem readdir order
+    """
+    for base, dirs, files in os.walk(dir):
+        dirs.sort()
+        files.sort()
+        yield base, dirs, files
+
+
+def write_stub(resource, pyfile):
+    _stub_template = textwrap.dedent("""
+        def __bootstrap__():
+            global __bootstrap__, __loader__, __file__
+            import sys, pkg_resources, imp
+            __file__ = pkg_resources.resource_filename(__name__, %r)
+            __loader__ = None; del __bootstrap__, __loader__
+            imp.load_dynamic(__name__,__file__)
+        __bootstrap__()
+        """).lstrip()
+    with open(pyfile, 'w') as f:
+        f.write(_stub_template % resource)
+
+
+class bdist_egg(Command):
+    description = "create an \"egg\" distribution"
+
+    user_options = [
+        ('bdist-dir=', 'b',
+         "temporary directory for creating the distribution"),
+        ('plat-name=', 'p', "platform name to embed in generated filenames "
+                            "(default: %s)" % get_build_platform()),
+        ('exclude-source-files', None,
+         "remove all .py files from the generated egg"),
+        ('keep-temp', 'k',
+         "keep the pseudo-installation tree around after " +
+         "creating the distribution archive"),
+        ('dist-dir=', 'd',
+         "directory to put final built distributions in"),
+        ('skip-build', None,
+         "skip rebuilding everything (for testing/debugging)"),
+    ]
+
+    boolean_options = [
+        'keep-temp', 'skip-build', 'exclude-source-files'
+    ]
+
+    def initialize_options(self):
+        self.bdist_dir = None
+        self.plat_name = None
+        self.keep_temp = 0
+        self.dist_dir = None
+        self.skip_build = 0
+        self.egg_output = None
+        self.exclude_source_files = None
+
+    def finalize_options(self):
+        ei_cmd = self.ei_cmd = self.get_finalized_command("egg_info")
+        self.egg_info = ei_cmd.egg_info
+
+        if self.bdist_dir is None:
+            bdist_base = self.get_finalized_command('bdist').bdist_base
+            self.bdist_dir = os.path.join(bdist_base, 'egg')
+
+        if self.plat_name is None:
+            self.plat_name = get_build_platform()
+
+        self.set_undefined_options('bdist', ('dist_dir', 'dist_dir'))
+
+        if self.egg_output is None:
+
+            # Compute filename of the output egg
+            basename = Distribution(
+                None, None, ei_cmd.egg_name, ei_cmd.egg_version,
+                get_python_version(),
+                self.distribution.has_ext_modules() and self.plat_name
+            ).egg_name()
+
+            self.egg_output = os.path.join(self.dist_dir, basename + '.egg')
+
+    def do_install_data(self):
+        # Hack for packages that install data to install's --install-lib
+        self.get_finalized_command('install').install_lib = self.bdist_dir
+
+        site_packages = os.path.normcase(os.path.realpath(_get_purelib()))
+        old, self.distribution.data_files = self.distribution.data_files, []
+
+        for item in old:
+            if isinstance(item, tuple) and len(item) == 2:
+                if os.path.isabs(item[0]):
+                    realpath = os.path.realpath(item[0])
+                    normalized = os.path.normcase(realpath)
+                    if normalized == site_packages or normalized.startswith(
+                        site_packages + os.sep
+                    ):
+                        item = realpath[len(site_packages) + 1:], item[1]
+                        # XXX else: raise ???
+            self.distribution.data_files.append(item)
+
+        try:
+            log.info("installing package data to %s", self.bdist_dir)
+            self.call_command('install_data', force=0, root=None)
+        finally:
+            self.distribution.data_files = old
+
+    def get_outputs(self):
+        return [self.egg_output]
+
+    def call_command(self, cmdname, **kw):
+        """Invoke reinitialized command `cmdname` with keyword args"""
+        for dirname in INSTALL_DIRECTORY_ATTRS:
+            kw.setdefault(dirname, self.bdist_dir)
+        kw.setdefault('skip_build', self.skip_build)
+        kw.setdefault('dry_run', self.dry_run)
+        cmd = self.reinitialize_command(cmdname, **kw)
+        self.run_command(cmdname)
+        return cmd
+
+    def run(self):
+        # Generate metadata first
+        self.run_command("egg_info")
+        # We run install_lib before install_data, because some data hacks
+        # pull their data path from the install_lib command.
+        log.info("installing library code to %s", self.bdist_dir)
+        instcmd = self.get_finalized_command('install')
+        old_root = instcmd.root
+        instcmd.root = None
+        if self.distribution.has_c_libraries() and not self.skip_build:
+            self.run_command('build_clib')
+        cmd = self.call_command('install_lib', warn_dir=0)
+        instcmd.root = old_root
+
+        all_outputs, ext_outputs = self.get_ext_outputs()
+        self.stubs = []
+        to_compile = []
+        for (p, ext_name) in enumerate(ext_outputs):
+            filename, ext = os.path.splitext(ext_name)
+            pyfile = os.path.join(self.bdist_dir, strip_module(filename) +
+                                  '.py')
+            self.stubs.append(pyfile)
+            log.info("creating stub loader for %s", ext_name)
+            if not self.dry_run:
+                write_stub(os.path.basename(ext_name), pyfile)
+            to_compile.append(pyfile)
+            ext_outputs[p] = ext_name.replace(os.sep, '/')
+
+        if to_compile:
+            cmd.byte_compile(to_compile)
+        if self.distribution.data_files:
+            self.do_install_data()
+
+        # Make the EGG-INFO directory
+        archive_root = self.bdist_dir
+        egg_info = os.path.join(archive_root, 'EGG-INFO')
+        self.mkpath(egg_info)
+        if self.distribution.scripts:
+            script_dir = os.path.join(egg_info, 'scripts')
+            log.info("installing scripts to %s", script_dir)
+            self.call_command('install_scripts', install_dir=script_dir,
+                              no_ep=1)
+
+        self.copy_metadata_to(egg_info)
+        native_libs = os.path.join(egg_info, "native_libs.txt")
+        if all_outputs:
+            log.info("writing %s", native_libs)
+            if not self.dry_run:
+                ensure_directory(native_libs)
+                libs_file = open(native_libs, 'wt')
+                libs_file.write('\n'.join(all_outputs))
+                libs_file.write('\n')
+                libs_file.close()
+        elif os.path.isfile(native_libs):
+            log.info("removing %s", native_libs)
+            if not self.dry_run:
+                os.unlink(native_libs)
+
+        write_safety_flag(
+            os.path.join(archive_root, 'EGG-INFO'), self.zip_safe()
+        )
+
+        if os.path.exists(os.path.join(self.egg_info, 'depends.txt')):
+            log.warn(
+                "WARNING: 'depends.txt' will not be used by setuptools 0.6!\n"
+                "Use the install_requires/extras_require setup() args instead."
+            )
+
+        if self.exclude_source_files:
+            self.zap_pyfiles()
+
+        # Make the archive
+        make_zipfile(self.egg_output, archive_root, verbose=self.verbose,
+                     dry_run=self.dry_run, mode=self.gen_header())
+        if not self.keep_temp:
+            remove_tree(self.bdist_dir, dry_run=self.dry_run)
+
+        # Add to 'Distribution.dist_files' so that the "upload" command works
+        getattr(self.distribution, 'dist_files', []).append(
+            ('bdist_egg', get_python_version(), self.egg_output))
+
+    def zap_pyfiles(self):
+        log.info("Removing .py files from temporary directory")
+        for base, dirs, files in walk_egg(self.bdist_dir):
+            for name in files:
+                path = os.path.join(base, name)
+
+                if name.endswith('.py'):
+                    log.debug("Deleting %s", path)
+                    os.unlink(path)
+
+                if base.endswith('__pycache__'):
+                    path_old = path
+
+                    pattern = r'(?P<name>.+)\.(?P<magic>[^.]+)\.pyc'
+                    m = re.match(pattern, name)
+                    path_new = os.path.join(
+                        base, os.pardir, m.group('name') + '.pyc')
+                    log.info(
+                        "Renaming file from [%s] to [%s]"
+                        % (path_old, path_new))
+                    try:
+                        os.remove(path_new)
+                    except OSError:
+                        pass
+                    os.rename(path_old, path_new)
+
+    def zip_safe(self):
+        safe = getattr(self.distribution, 'zip_safe', None)
+        if safe is not None:
+            return safe
+        log.warn("zip_safe flag not set; analyzing archive contents...")
+        return analyze_egg(self.bdist_dir, self.stubs)
+
+    def gen_header(self):
+        epm = EntryPoint.parse_map(self.distribution.entry_points or '')
+        ep = epm.get('setuptools.installation', {}).get('eggsecutable')
+        if ep is None:
+            return 'w'  # not an eggsecutable, do it the usual way.
+
+        if not ep.attrs or ep.extras:
+            raise DistutilsSetupError(
+                "eggsecutable entry point (%r) cannot have 'extras' "
+                "or refer to a module" % (ep,)
+            )
+
+        pyver = sys.version[:3]
+        pkg = ep.module_name
+        full = '.'.join(ep.attrs)
+        base = ep.attrs[0]
+        basename = os.path.basename(self.egg_output)
+
+        header = (
+            "#!/bin/sh\n"
+            'if [ `basename $0` = "%(basename)s" ]\n'
+            'then exec python%(pyver)s -c "'
+            "import sys, os; sys.path.insert(0, os.path.abspath('$0')); "
+            "from %(pkg)s import %(base)s; sys.exit(%(full)s())"
+            '" "$@"\n'
+            'else\n'
+            '  echo $0 is not the correct name for this egg file.\n'
+            '  echo Please rename it back to %(basename)s and try again.\n'
+            '  exec false\n'
+            'fi\n'
+        ) % locals()
+
+        if not self.dry_run:
+            mkpath(os.path.dirname(self.egg_output), dry_run=self.dry_run)
+            f = open(self.egg_output, 'w')
+            f.write(header)
+            f.close()
+        return 'a'
+
+    def copy_metadata_to(self, target_dir):
+        "Copy metadata (egg info) to the target_dir"
+        # normalize the path (so that a forward-slash in egg_info will
+        # match using startswith below)
+        norm_egg_info = os.path.normpath(self.egg_info)
+        prefix = os.path.join(norm_egg_info, '')
+        for path in self.ei_cmd.filelist.files:
+            if path.startswith(prefix):
+                target = os.path.join(target_dir, path[len(prefix):])
+                ensure_directory(target)
+                self.copy_file(path, target)
+
+    def get_ext_outputs(self):
+        """Get a list of relative paths to C extensions in the output distro"""
+
+        all_outputs = []
+        ext_outputs = []
+
+        paths = {self.bdist_dir: ''}
+        for base, dirs, files in sorted_walk(self.bdist_dir):
+            for filename in files:
+                if os.path.splitext(filename)[1].lower() in NATIVE_EXTENSIONS:
+                    all_outputs.append(paths[base] + filename)
+            for filename in dirs:
+                paths[os.path.join(base, filename)] = (paths[base] +
+                                                       filename + '/')
+
+        if self.distribution.has_ext_modules():
+            build_cmd = self.get_finalized_command('build_ext')
+            for ext in build_cmd.extensions:
+                if isinstance(ext, Library):
+                    continue
+                fullname = build_cmd.get_ext_fullname(ext.name)
+                filename = build_cmd.get_ext_filename(fullname)
+                if not os.path.basename(filename).startswith('dl-'):
+                    if os.path.exists(os.path.join(self.bdist_dir, filename)):
+                        ext_outputs.append(filename)
+
+        return all_outputs, ext_outputs
+
+
+NATIVE_EXTENSIONS = dict.fromkeys('.dll .so .dylib .pyd'.split())
+
+
+def walk_egg(egg_dir):
+    """Walk an unpacked egg's contents, skipping the metadata directory"""
+    walker = sorted_walk(egg_dir)
+    base, dirs, files = next(walker)
+    if 'EGG-INFO' in dirs:
+        dirs.remove('EGG-INFO')
+    yield base, dirs, files
+    for bdf in walker:
+        yield bdf
+
+
+def analyze_egg(egg_dir, stubs):
+    # check for existing flag in EGG-INFO
+    for flag, fn in safety_flags.items():
+        if os.path.exists(os.path.join(egg_dir, 'EGG-INFO', fn)):
+            return flag
+    if not can_scan():
+        return False
+    safe = True
+    for base, dirs, files in walk_egg(egg_dir):
+        for name in files:
+            if name.endswith('.py') or name.endswith('.pyw'):
+                continue
+            elif name.endswith('.pyc') or name.endswith('.pyo'):
+                # always scan, even if we already know we're not safe
+                safe = scan_module(egg_dir, base, name, stubs) and safe
+    return safe
+
+
+def write_safety_flag(egg_dir, safe):
+    # Write or remove zip safety flag file(s)
+    for flag, fn in safety_flags.items():
+        fn = os.path.join(egg_dir, fn)
+        if os.path.exists(fn):
+            if safe is None or bool(safe) != flag:
+                os.unlink(fn)
+        elif safe is not None and bool(safe) == flag:
+            f = open(fn, 'wt')
+            f.write('\n')
+            f.close()
+
+
+safety_flags = {
+    True: 'zip-safe',
+    False: 'not-zip-safe',
+}
+
+
+def scan_module(egg_dir, base, name, stubs):
+    """Check whether module possibly uses unsafe-for-zipfile stuff"""
+
+    filename = os.path.join(base, name)
+    if filename[:-1] in stubs:
+        return True  # Extension module
+    pkg = base[len(egg_dir) + 1:].replace(os.sep, '.')
+    module = pkg + (pkg and '.' or '') + os.path.splitext(name)[0]
+    if six.PY2:
+        skip = 8  # skip magic & date
+    elif sys.version_info < (3, 7):
+        skip = 12  # skip magic & date & file size
+    else:
+        skip = 16  # skip magic & reserved? & date & file size
+    f = open(filename, 'rb')
+    f.read(skip)
+    code = marshal.load(f)
+    f.close()
+    safe = True
+    symbols = dict.fromkeys(iter_symbols(code))
+    for bad in ['__file__', '__path__']:
+        if bad in symbols:
+            log.warn("%s: module references %s", module, bad)
+            safe = False
+    if 'inspect' in symbols:
+        for bad in [
+            'getsource', 'getabsfile', 'getsourcefile', 'getfile'
+            'getsourcelines', 'findsource', 'getcomments', 'getframeinfo',
+            'getinnerframes', 'getouterframes', 'stack', 'trace'
+        ]:
+            if bad in symbols:
+                log.warn("%s: module MAY be using inspect.%s", module, bad)
+                safe = False
+    return safe
+
+
+def iter_symbols(code):
+    """Yield names and strings used by `code` and its nested code objects"""
+    for name in code.co_names:
+        yield name
+    for const in code.co_consts:
+        if isinstance(const, six.string_types):
+            yield const
+        elif isinstance(const, CodeType):
+            for name in iter_symbols(const):
+                yield name
+
+
+def can_scan():
+    if not sys.platform.startswith('java') and sys.platform != 'cli':
+        # CPython, PyPy, etc.
+        return True
+    log.warn("Unable to analyze compiled code on this platform.")
+    log.warn("Please ask the author to include a 'zip_safe'"
+             " setting (either True or False) in the package's setup.py")
+
+
+# Attribute names of options for commands that might need to be convinced to
+# install to the egg build directory
+
+INSTALL_DIRECTORY_ATTRS = [
+    'install_lib', 'install_dir', 'install_data', 'install_base'
+]
+
+
+def make_zipfile(zip_filename, base_dir, verbose=0, dry_run=0, compress=True,
+                 mode='w'):
+    """Create a zip file from all the files under 'base_dir'.  The output
+    zip file will be named 'base_dir' + ".zip".  Uses either the "zipfile"
+    Python module (if available) or the InfoZIP "zip" utility (if installed
+    and found on the default search path).  If neither tool is available,
+    raises DistutilsExecError.  Returns the name of the output zip file.
+    """
+    import zipfile
+
+    mkpath(os.path.dirname(zip_filename), dry_run=dry_run)
+    log.info("creating '%s' and adding '%s' to it", zip_filename, base_dir)
+
+    def visit(z, dirname, names):
+        for name in names:
+            path = os.path.normpath(os.path.join(dirname, name))
+            if os.path.isfile(path):
+                p = path[len(base_dir) + 1:]
+                if not dry_run:
+                    z.write(path, p)
+                log.debug("adding '%s'", p)
+
+    compression = zipfile.ZIP_DEFLATED if compress else zipfile.ZIP_STORED
+    if not dry_run:
+        z = zipfile.ZipFile(zip_filename, mode, compression=compression)
+        for dirname, dirs, files in sorted_walk(base_dir):
+            visit(z, dirname, files)
+        z.close()
+    else:
+        for dirname, dirs, files in sorted_walk(base_dir):
+            visit(None, dirname, files)
+    return zip_filename
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/bdist_egg.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/bdist_egg.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..b3296ac76429842eb65029ea37b6f604a8ffde6c
GIT binary patch
literal 19800
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
P>8c7R4=1k>3nwE0tug&i

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/bdist_rpm.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/bdist_rpm.py
new file mode 100644
index 0000000..7073092
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/bdist_rpm.py
@@ -0,0 +1,43 @@
+import distutils.command.bdist_rpm as orig
+
+
+class bdist_rpm(orig.bdist_rpm):
+    """
+    Override the default bdist_rpm behavior to do the following:
+
+    1. Run egg_info to ensure the name and version are properly calculated.
+    2. Always run 'install' using --single-version-externally-managed to
+       disable eggs in RPM distributions.
+    3. Replace dash with underscore in the version numbers for better RPM
+       compatibility.
+    """
+
+    def run(self):
+        # ensure distro name is up-to-date
+        self.run_command('egg_info')
+
+        orig.bdist_rpm.run(self)
+
+    def _make_spec_file(self):
+        version = self.distribution.get_version()
+        rpmversion = version.replace('-', '_')
+        spec = orig.bdist_rpm._make_spec_file(self)
+        line23 = '%define version ' + version
+        line24 = '%define version ' + rpmversion
+        spec = [
+            line.replace(
+                "Source0: %{name}-%{version}.tar",
+                "Source0: %{name}-%{unmangled_version}.tar"
+            ).replace(
+                "setup.py install ",
+                "setup.py install --single-version-externally-managed "
+            ).replace(
+                "%setup",
+                "%setup -n %{name}-%{unmangled_version}"
+            ).replace(line23, line24)
+            for line in spec
+        ]
+        insert_loc = spec.index(line24) + 1
+        unmangled_version = "%define unmangled_version " + version
+        spec.insert(insert_loc, unmangled_version)
+        return spec
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/bdist_rpm.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/bdist_rpm.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..084b0853369b3c80cfe2223ae808800677e29091
GIT binary patch
literal 2130
zcmZSn%**AGdLky70ScHI7#JKF7#NE685kH+7#LC*8FCmHvKSe%m>8m%8B&-SQkg;Q
zG)9ILW`-69hGqta$S5X|x?l|!1_p-A|NsC0_bcIKU|>i}$t*63FDl4|o6g9<z~BTj
zU4emtA(eq4iV<W7M0*PZ)B+HLg&`<d1LT(CG)4vnE(HYz1^=?tqN2={RE3g^RE3n(
zw8YY!5(T&w3Q4IMiDjAjMG7VP3Mu(uMQQmtIr-(8dFfVMU=s}W6oN|g6jIaE<1_Qp
z@<A$7^NLH0AV%gT=B6qn=A|f<r4|)u=I1FS7Nsf_6y+DB7UfhbBq!!1m*ymvq^9VB
z%`(zcaLg%BtSnY2D$P?+&&(?>NzBPnS12vc%u83$)df*Gsk%_JbW<xzQj78ub8;$m
za})Ct(^FFvO7g)5DJUqUWELkT<)nffR;-Yjrw|n23lb|S%1kOP$;{6yhFEE=rx27{
zkdv64s*sXcoS{&jS(2epnwOGVRGge&lnT-b3L2=D3VEfuNvTD}3TgR83Q4IYC8<Rq
zgJE_i=jRqAmSiSn=46&sLd;JF#SREFF)%PVgJMaMfq|ihfguZ=44N4k7)!wEAd49!
z3gV|QFa&FWl>3!%fMOIHvfzYJ!p*?IP*j>1pPZkYo0ykU0!khEMVaYAprlp;irk{o
zJPnYAV5#ENoHPxP6qqP3V_;y=FDS|^ODsv%FH0=aPs`5%c~w6tMZY{LDKFPFx7f%q
z$vnL(-NMwOJSVHl%m4(^^YlaX3o;9Ip;4miR_5Vp9H3vET2fk2lAoVbjLd|(O&^|)
z^a?72Kn~>x`5(k!VB%#0hYTo1v%*5=AUtHU7(rQ}mXV<b95yM8pghvd#8At`P{PcR
z#ln!q3JtAVW>A)?VPp`mWdXC87{qH?8PXXTYM2>ZVr>{|*%)frK$$Crg&~ENp_vKH
zW@AWUhp{;rQaGXP8Wx5cu$nj~hC)AvT4s<bS!`fIMurqF2Ju>Uh7@j)v&3sTz>@3?
zHS7#E93TT2YnT~=HFy{p82m~=F`x@3<BJ6t7#LJjQqwZ?QsMcaSe}7_AvnLZC^^-@
zN<p<6lu>GRRjZ*1tyZrjv8Y%RyPDFx+{C=}oYa(f6xD*D&;><^UO}Y-G@=xWO|gj*
zla-3uK+XooaIqSksi2#O<XTLZWP&_iECo^z^)ZGT1r1QLE&+uTs4RnJNO00lPc4CY
zs)QYs)FF8@2$ZlPNgR}h;&T(TQ{#&ZQj_D;GILT(Kq)9QFD1321mxz-yyDcN5)Dw&
z3IfT14T6SL2^YxFf?OCElo&zgfHmf1=A{}LBbX-OECdn-YlD~@pOc?l0t#vje}S_Y
zm>9@>1}Y##L2)hy%Jz)>j6#e;j9iRdOw3$vOu~#@i~@`r;7|cYLVP?Z-Nna){TCmf
zo1apelNuin4zc+7l>FrQcyPuI0+|Z-8iE)|PlCJ#jyh0$vvIO9ak4>*M`=(6n^{~^
uT9TPltOqTK^xy>%*ke#paB>1CEQFuHtO4{GxWKo8M1vhTCxPk#A!Y!-Yc;F@

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/bdist_wininst.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/bdist_wininst.py
new file mode 100644
index 0000000..073de97
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/bdist_wininst.py
@@ -0,0 +1,21 @@
+import distutils.command.bdist_wininst as orig
+
+
+class bdist_wininst(orig.bdist_wininst):
+    def reinitialize_command(self, command, reinit_subcommands=0):
+        """
+        Supplement reinitialize_command to work around
+        http://bugs.python.org/issue20819
+        """
+        cmd = self.distribution.reinitialize_command(
+            command, reinit_subcommands)
+        if command in ('install', 'install_lib'):
+            cmd.install_lib = None
+        return cmd
+
+    def run(self):
+        self._is_running = True
+        try:
+            orig.bdist_wininst.run(self)
+        finally:
+            self._is_running = False
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/bdist_wininst.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/bdist_wininst.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..677e073b686cb87a2023f604ef62b7b5c8de9ad3
GIT binary patch
literal 1425
zcmZSn%**AGdLky70ScHI7#JKF7#NE685kH+7#LC*8FCmHvKSe%m>8m%8B&-SQkg;Q
zG)9ILW`-69hGqta$S5X|x?l|!1_p-A|NsC0_bcILU|>i}$t*63FVD=&%quQ|+rY%Y
zz~BV3L6(7mA(eq4iV<p03nK%_ASRHhQOpcM!5SdPWP%))3}S&y2hq+T&4vsN3^fc4
zSzx!-Ff!CIF*GwV)G{;FfE||2#!#fokix=H!^{xR%#g<bVgzfjg0yBaFfec_KtXV6
zK|xMxZfahMLQ!gFUS>&VVoqjNYJ75jZf;^;ib6@gLV12swnAc2era9`Tw6v-Nr9EV
zeo|?Av0g!CNk)F2UVc%!er9oTX{wQdg`p)}WeGbdQ1XgP5_57&xDo95oXjK*P*@Zr
zDJVu$;0F%U5*|=oWEPhcWhRxDWaj6Uh%hiPU~_H>D2)8_^HPIACPOrXgo;yh(!dUZ
zdaFbTZa{o-X%bYlxC9iu$+;;SpfCp$#Z?Rp4EhB{nPrJ3srqG!Mfz#^IVq_{#rjDp
z`sGPUdAX*!#YTon=IK@G7N!>EIayU^1|X20ryrtUkXfJ$iu=Tz99_3E4^QI&{o>S;
z(t?uw{G4KBCe#7?C@Ds-pfU*LcyOd~ft<w3$;bnS$&3sP3?K}W1E&W)1_p)_aFU2;
zWT+BhC}CpAVrIx<0VR@VMh3?46b6P8RuC_qks%_5fgxA}q~A}24WtodO-NB`Dma4T
zGmGPkO7rqE^U}fLnO~Hd9t5%;96Uv(c_koQ-4b((Q^95gfs6o$7MK|5Ame3VU=RSM
za}JQ3895o58AX^NNdY7hAD@?)n;IWq0t(Ui_}u)I(wx-zcyLGuf%JksfglFjJ0MSh
zqNf-{urcy*L%bpn%@U<0nK{LJ(Db8+l750f84Db7K|Bl$3<xiQSp)2^5>Q;&KtkUR
MloE?UIaY`n0D<LahX4Qo

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/build_clib.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/build_clib.py
new file mode 100644
index 0000000..09caff6
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/build_clib.py
@@ -0,0 +1,98 @@
+import distutils.command.build_clib as orig
+from distutils.errors import DistutilsSetupError
+from distutils import log
+from setuptools.dep_util import newer_pairwise_group
+
+
+class build_clib(orig.build_clib):
+    """
+    Override the default build_clib behaviour to do the following:
+
+    1. Implement a rudimentary timestamp-based dependency system
+       so 'compile()' doesn't run every time.
+    2. Add more keys to the 'build_info' dictionary:
+        * obj_deps - specify dependencies for each object compiled.
+                     this should be a dictionary mapping a key
+                     with the source filename to a list of
+                     dependencies. Use an empty string for global
+                     dependencies.
+        * cflags   - specify a list of additional flags to pass to
+                     the compiler.
+    """
+
+    def build_libraries(self, libraries):
+        for (lib_name, build_info) in libraries:
+            sources = build_info.get('sources')
+            if sources is None or not isinstance(sources, (list, tuple)):
+                raise DistutilsSetupError(
+                       "in 'libraries' option (library '%s'), "
+                       "'sources' must be present and must be "
+                       "a list of source filenames" % lib_name)
+            sources = list(sources)
+
+            log.info("building '%s' library", lib_name)
+
+            # Make sure everything is the correct type.
+            # obj_deps should be a dictionary of keys as sources
+            # and a list/tuple of files that are its dependencies.
+            obj_deps = build_info.get('obj_deps', dict())
+            if not isinstance(obj_deps, dict):
+                raise DistutilsSetupError(
+                       "in 'libraries' option (library '%s'), "
+                       "'obj_deps' must be a dictionary of "
+                       "type 'source: list'" % lib_name)
+            dependencies = []
+
+            # Get the global dependencies that are specified by the '' key.
+            # These will go into every source's dependency list.
+            global_deps = obj_deps.get('', list())
+            if not isinstance(global_deps, (list, tuple)):
+                raise DistutilsSetupError(
+                       "in 'libraries' option (library '%s'), "
+                       "'obj_deps' must be a dictionary of "
+                       "type 'source: list'" % lib_name)
+
+            # Build the list to be used by newer_pairwise_group
+            # each source will be auto-added to its dependencies.
+            for source in sources:
+                src_deps = [source]
+                src_deps.extend(global_deps)
+                extra_deps = obj_deps.get(source, list())
+                if not isinstance(extra_deps, (list, tuple)):
+                    raise DistutilsSetupError(
+                           "in 'libraries' option (library '%s'), "
+                           "'obj_deps' must be a dictionary of "
+                           "type 'source: list'" % lib_name)
+                src_deps.extend(extra_deps)
+                dependencies.append(src_deps)
+
+            expected_objects = self.compiler.object_filenames(
+                    sources,
+                    output_dir=self.build_temp
+                    )
+
+            if newer_pairwise_group(dependencies, expected_objects) != ([], []):
+                # First, compile the source code to object files in the library
+                # directory.  (This should probably change to putting object
+                # files in a temporary build directory.)
+                macros = build_info.get('macros')
+                include_dirs = build_info.get('include_dirs')
+                cflags = build_info.get('cflags')
+                objects = self.compiler.compile(
+                        sources,
+                        output_dir=self.build_temp,
+                        macros=macros,
+                        include_dirs=include_dirs,
+                        extra_postargs=cflags,
+                        debug=self.debug
+                        )
+
+            # Now "link" the object files together into a static library.
+            # (On Unix at least, this isn't really linking -- it just
+            # builds an archive.  Whatever.)
+            self.compiler.create_static_lib(
+                    expected_objects,
+                    lib_name,
+                    output_dir=self.build_clib,
+                    debug=self.debug
+                    )
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/build_clib.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/build_clib.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..642a361be633631bf952390499c9abd66745cda0
GIT binary patch
literal 3006
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

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/build_ext.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/build_ext.py
new file mode 100644
index 0000000..60a8a32
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/build_ext.py
@@ -0,0 +1,321 @@
+import os
+import sys
+import itertools
+import imp
+from distutils.command.build_ext import build_ext as _du_build_ext
+from distutils.file_util import copy_file
+from distutils.ccompiler import new_compiler
+from distutils.sysconfig import customize_compiler, get_config_var
+from distutils.errors import DistutilsError
+from distutils import log
+
+from setuptools.extension import Library
+from setuptools.extern import six
+
+try:
+    # Attempt to use Cython for building extensions, if available
+    from Cython.Distutils.build_ext import build_ext as _build_ext
+    # Additionally, assert that the compiler module will load
+    # also. Ref #1229.
+    __import__('Cython.Compiler.Main')
+except ImportError:
+    _build_ext = _du_build_ext
+
+# make sure _config_vars is initialized
+get_config_var("LDSHARED")
+from distutils.sysconfig import _config_vars as _CONFIG_VARS
+
+
+def _customize_compiler_for_shlib(compiler):
+    if sys.platform == "darwin":
+        # building .dylib requires additional compiler flags on OSX; here we
+        # temporarily substitute the pyconfig.h variables so that distutils'
+        # 'customize_compiler' uses them before we build the shared libraries.
+        tmp = _CONFIG_VARS.copy()
+        try:
+            # XXX Help!  I don't have any idea whether these are right...
+            _CONFIG_VARS['LDSHARED'] = (
+                "gcc -Wl,-x -dynamiclib -undefined dynamic_lookup")
+            _CONFIG_VARS['CCSHARED'] = " -dynamiclib"
+            _CONFIG_VARS['SO'] = ".dylib"
+            customize_compiler(compiler)
+        finally:
+            _CONFIG_VARS.clear()
+            _CONFIG_VARS.update(tmp)
+    else:
+        customize_compiler(compiler)
+
+
+have_rtld = False
+use_stubs = False
+libtype = 'shared'
+
+if sys.platform == "darwin":
+    use_stubs = True
+elif os.name != 'nt':
+    try:
+        import dl
+        use_stubs = have_rtld = hasattr(dl, 'RTLD_NOW')
+    except ImportError:
+        pass
+
+if_dl = lambda s: s if have_rtld else ''
+
+
+def get_abi3_suffix():
+    """Return the file extension for an abi3-compliant Extension()"""
+    for suffix, _, _ in (s for s in imp.get_suffixes() if s[2] == imp.C_EXTENSION):
+        if '.abi3' in suffix:  # Unix
+            return suffix
+        elif suffix == '.pyd':  # Windows
+            return suffix
+
+
+class build_ext(_build_ext):
+    def run(self):
+        """Build extensions in build directory, then copy if --inplace"""
+        old_inplace, self.inplace = self.inplace, 0
+        _build_ext.run(self)
+        self.inplace = old_inplace
+        if old_inplace:
+            self.copy_extensions_to_source()
+
+    def copy_extensions_to_source(self):
+        build_py = self.get_finalized_command('build_py')
+        for ext in self.extensions:
+            fullname = self.get_ext_fullname(ext.name)
+            filename = self.get_ext_filename(fullname)
+            modpath = fullname.split('.')
+            package = '.'.join(modpath[:-1])
+            package_dir = build_py.get_package_dir(package)
+            dest_filename = os.path.join(package_dir,
+                                         os.path.basename(filename))
+            src_filename = os.path.join(self.build_lib, filename)
+
+            # Always copy, even if source is older than destination, to ensure
+            # that the right extensions for the current Python/platform are
+            # used.
+            copy_file(
+                src_filename, dest_filename, verbose=self.verbose,
+                dry_run=self.dry_run
+            )
+            if ext._needs_stub:
+                self.write_stub(package_dir or os.curdir, ext, True)
+
+    def get_ext_filename(self, fullname):
+        filename = _build_ext.get_ext_filename(self, fullname)
+        if fullname in self.ext_map:
+            ext = self.ext_map[fullname]
+            use_abi3 = (
+                six.PY3
+                and getattr(ext, 'py_limited_api')
+                and get_abi3_suffix()
+            )
+            if use_abi3:
+                so_ext = get_config_var('EXT_SUFFIX')
+                filename = filename[:-len(so_ext)]
+                filename = filename + get_abi3_suffix()
+            if isinstance(ext, Library):
+                fn, ext = os.path.splitext(filename)
+                return self.shlib_compiler.library_filename(fn, libtype)
+            elif use_stubs and ext._links_to_dynamic:
+                d, fn = os.path.split(filename)
+                return os.path.join(d, 'dl-' + fn)
+        return filename
+
+    def initialize_options(self):
+        _build_ext.initialize_options(self)
+        self.shlib_compiler = None
+        self.shlibs = []
+        self.ext_map = {}
+
+    def finalize_options(self):
+        _build_ext.finalize_options(self)
+        self.extensions = self.extensions or []
+        self.check_extensions_list(self.extensions)
+        self.shlibs = [ext for ext in self.extensions
+                       if isinstance(ext, Library)]
+        if self.shlibs:
+            self.setup_shlib_compiler()
+        for ext in self.extensions:
+            ext._full_name = self.get_ext_fullname(ext.name)
+        for ext in self.extensions:
+            fullname = ext._full_name
+            self.ext_map[fullname] = ext
+
+            # distutils 3.1 will also ask for module names
+            # XXX what to do with conflicts?
+            self.ext_map[fullname.split('.')[-1]] = ext
+
+            ltd = self.shlibs and self.links_to_dynamic(ext) or False
+            ns = ltd and use_stubs and not isinstance(ext, Library)
+            ext._links_to_dynamic = ltd
+            ext._needs_stub = ns
+            filename = ext._file_name = self.get_ext_filename(fullname)
+            libdir = os.path.dirname(os.path.join(self.build_lib, filename))
+            if ltd and libdir not in ext.library_dirs:
+                ext.library_dirs.append(libdir)
+            if ltd and use_stubs and os.curdir not in ext.runtime_library_dirs:
+                ext.runtime_library_dirs.append(os.curdir)
+
+    def setup_shlib_compiler(self):
+        compiler = self.shlib_compiler = new_compiler(
+            compiler=self.compiler, dry_run=self.dry_run, force=self.force
+        )
+        _customize_compiler_for_shlib(compiler)
+
+        if self.include_dirs is not None:
+            compiler.set_include_dirs(self.include_dirs)
+        if self.define is not None:
+            # 'define' option is a list of (name,value) tuples
+            for (name, value) in self.define:
+                compiler.define_macro(name, value)
+        if self.undef is not None:
+            for macro in self.undef:
+                compiler.undefine_macro(macro)
+        if self.libraries is not None:
+            compiler.set_libraries(self.libraries)
+        if self.library_dirs is not None:
+            compiler.set_library_dirs(self.library_dirs)
+        if self.rpath is not None:
+            compiler.set_runtime_library_dirs(self.rpath)
+        if self.link_objects is not None:
+            compiler.set_link_objects(self.link_objects)
+
+        # hack so distutils' build_extension() builds a library instead
+        compiler.link_shared_object = link_shared_object.__get__(compiler)
+
+    def get_export_symbols(self, ext):
+        if isinstance(ext, Library):
+            return ext.export_symbols
+        return _build_ext.get_export_symbols(self, ext)
+
+    def build_extension(self, ext):
+        ext._convert_pyx_sources_to_lang()
+        _compiler = self.compiler
+        try:
+            if isinstance(ext, Library):
+                self.compiler = self.shlib_compiler
+            _build_ext.build_extension(self, ext)
+            if ext._needs_stub:
+                cmd = self.get_finalized_command('build_py').build_lib
+                self.write_stub(cmd, ext)
+        finally:
+            self.compiler = _compiler
+
+    def links_to_dynamic(self, ext):
+        """Return true if 'ext' links to a dynamic lib in the same package"""
+        # XXX this should check to ensure the lib is actually being built
+        # XXX as dynamic, and not just using a locally-found version or a
+        # XXX static-compiled version
+        libnames = dict.fromkeys([lib._full_name for lib in self.shlibs])
+        pkg = '.'.join(ext._full_name.split('.')[:-1] + [''])
+        return any(pkg + libname in libnames for libname in ext.libraries)
+
+    def get_outputs(self):
+        return _build_ext.get_outputs(self) + self.__get_stubs_outputs()
+
+    def __get_stubs_outputs(self):
+        # assemble the base name for each extension that needs a stub
+        ns_ext_bases = (
+            os.path.join(self.build_lib, *ext._full_name.split('.'))
+            for ext in self.extensions
+            if ext._needs_stub
+        )
+        # pair each base with the extension
+        pairs = itertools.product(ns_ext_bases, self.__get_output_extensions())
+        return list(base + fnext for base, fnext in pairs)
+
+    def __get_output_extensions(self):
+        yield '.py'
+        yield '.pyc'
+        if self.get_finalized_command('build_py').optimize:
+            yield '.pyo'
+
+    def write_stub(self, output_dir, ext, compile=False):
+        log.info("writing stub loader for %s to %s", ext._full_name,
+                 output_dir)
+        stub_file = (os.path.join(output_dir, *ext._full_name.split('.')) +
+                     '.py')
+        if compile and os.path.exists(stub_file):
+            raise DistutilsError(stub_file + " already exists! Please delete.")
+        if not self.dry_run:
+            f = open(stub_file, 'w')
+            f.write(
+                '\n'.join([
+                    "def __bootstrap__():",
+                    "   global __bootstrap__, __file__, __loader__",
+                    "   import sys, os, pkg_resources, imp" + if_dl(", dl"),
+                    "   __file__ = pkg_resources.resource_filename"
+                    "(__name__,%r)"
+                    % os.path.basename(ext._file_name),
+                    "   del __bootstrap__",
+                    "   if '__loader__' in globals():",
+                    "       del __loader__",
+                    if_dl("   old_flags = sys.getdlopenflags()"),
+                    "   old_dir = os.getcwd()",
+                    "   try:",
+                    "     os.chdir(os.path.dirname(__file__))",
+                    if_dl("     sys.setdlopenflags(dl.RTLD_NOW)"),
+                    "     imp.load_dynamic(__name__,__file__)",
+                    "   finally:",
+                    if_dl("     sys.setdlopenflags(old_flags)"),
+                    "     os.chdir(old_dir)",
+                    "__bootstrap__()",
+                    ""  # terminal \n
+                ])
+            )
+            f.close()
+        if compile:
+            from distutils.util import byte_compile
+
+            byte_compile([stub_file], optimize=0,
+                         force=True, dry_run=self.dry_run)
+            optimize = self.get_finalized_command('install_lib').optimize
+            if optimize > 0:
+                byte_compile([stub_file], optimize=optimize,
+                             force=True, dry_run=self.dry_run)
+            if os.path.exists(stub_file) and not self.dry_run:
+                os.unlink(stub_file)
+
+
+if use_stubs or os.name == 'nt':
+    # Build shared libraries
+    #
+    def link_shared_object(
+            self, objects, output_libname, output_dir=None, libraries=None,
+            library_dirs=None, runtime_library_dirs=None, export_symbols=None,
+            debug=0, extra_preargs=None, extra_postargs=None, build_temp=None,
+            target_lang=None):
+        self.link(
+            self.SHARED_LIBRARY, objects, output_libname,
+            output_dir, libraries, library_dirs, runtime_library_dirs,
+            export_symbols, debug, extra_preargs, extra_postargs,
+            build_temp, target_lang
+        )
+else:
+    # Build static libraries everywhere else
+    libtype = 'static'
+
+    def link_shared_object(
+            self, objects, output_libname, output_dir=None, libraries=None,
+            library_dirs=None, runtime_library_dirs=None, export_symbols=None,
+            debug=0, extra_preargs=None, extra_postargs=None, build_temp=None,
+            target_lang=None):
+        # XXX we need to either disallow these attrs on Library instances,
+        # or warn/abort here if set, or something...
+        # libraries=None, library_dirs=None, runtime_library_dirs=None,
+        # export_symbols=None, extra_preargs=None, extra_postargs=None,
+        # build_temp=None
+
+        assert output_dir is None  # distutils build_ext doesn't pass this
+        output_dir, filename = os.path.split(output_libname)
+        basename, ext = os.path.splitext(filename)
+        if self.library_filename("x").startswith('lib'):
+            # strip 'lib' prefix; this is kludgy if some platform uses
+            # a different prefix
+            basename = basename[3:]
+
+        self.create_static_lib(
+            objects, basename, output_dir, debug, target_lang
+        )
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/build_ext.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/build_ext.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..59ec5f8a7f2249c228e56f6e7ee5bcd973fdeb62
GIT binary patch
literal 13452
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
Tf+!0cBPSydBR?k_GlT^Ie`gT@

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/build_py.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/build_py.py
new file mode 100644
index 0000000..b0314fd
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/build_py.py
@@ -0,0 +1,270 @@
+from glob import glob
+from distutils.util import convert_path
+import distutils.command.build_py as orig
+import os
+import fnmatch
+import textwrap
+import io
+import distutils.errors
+import itertools
+
+from setuptools.extern import six
+from setuptools.extern.six.moves import map, filter, filterfalse
+
+try:
+    from setuptools.lib2to3_ex import Mixin2to3
+except ImportError:
+
+    class Mixin2to3:
+        def run_2to3(self, files, doctests=True):
+            "do nothing"
+
+
+class build_py(orig.build_py, Mixin2to3):
+    """Enhanced 'build_py' command that includes data files with packages
+
+    The data files are specified via a 'package_data' argument to 'setup()'.
+    See 'setuptools.dist.Distribution' for more details.
+
+    Also, this version of the 'build_py' command allows you to specify both
+    'py_modules' and 'packages' in the same setup operation.
+    """
+
+    def finalize_options(self):
+        orig.build_py.finalize_options(self)
+        self.package_data = self.distribution.package_data
+        self.exclude_package_data = (self.distribution.exclude_package_data or
+                                     {})
+        if 'data_files' in self.__dict__:
+            del self.__dict__['data_files']
+        self.__updated_files = []
+        self.__doctests_2to3 = []
+
+    def run(self):
+        """Build modules, packages, and copy data files to build directory"""
+        if not self.py_modules and not self.packages:
+            return
+
+        if self.py_modules:
+            self.build_modules()
+
+        if self.packages:
+            self.build_packages()
+            self.build_package_data()
+
+        self.run_2to3(self.__updated_files, False)
+        self.run_2to3(self.__updated_files, True)
+        self.run_2to3(self.__doctests_2to3, True)
+
+        # Only compile actual .py files, using our base class' idea of what our
+        # output files are.
+        self.byte_compile(orig.build_py.get_outputs(self, include_bytecode=0))
+
+    def __getattr__(self, attr):
+        "lazily compute data files"
+        if attr == 'data_files':
+            self.data_files = self._get_data_files()
+            return self.data_files
+        return orig.build_py.__getattr__(self, attr)
+
+    def build_module(self, module, module_file, package):
+        if six.PY2 and isinstance(package, six.string_types):
+            # avoid errors on Python 2 when unicode is passed (#190)
+            package = package.split('.')
+        outfile, copied = orig.build_py.build_module(self, module, module_file,
+                                                     package)
+        if copied:
+            self.__updated_files.append(outfile)
+        return outfile, copied
+
+    def _get_data_files(self):
+        """Generate list of '(package,src_dir,build_dir,filenames)' tuples"""
+        self.analyze_manifest()
+        return list(map(self._get_pkg_data_files, self.packages or ()))
+
+    def _get_pkg_data_files(self, package):
+        # Locate package source directory
+        src_dir = self.get_package_dir(package)
+
+        # Compute package build directory
+        build_dir = os.path.join(*([self.build_lib] + package.split('.')))
+
+        # Strip directory from globbed filenames
+        filenames = [
+            os.path.relpath(file, src_dir)
+            for file in self.find_data_files(package, src_dir)
+        ]
+        return package, src_dir, build_dir, filenames
+
+    def find_data_files(self, package, src_dir):
+        """Return filenames for package's data files in 'src_dir'"""
+        patterns = self._get_platform_patterns(
+            self.package_data,
+            package,
+            src_dir,
+        )
+        globs_expanded = map(glob, patterns)
+        # flatten the expanded globs into an iterable of matches
+        globs_matches = itertools.chain.from_iterable(globs_expanded)
+        glob_files = filter(os.path.isfile, globs_matches)
+        files = itertools.chain(
+            self.manifest_files.get(package, []),
+            glob_files,
+        )
+        return self.exclude_data_files(package, src_dir, files)
+
+    def build_package_data(self):
+        """Copy data files into build directory"""
+        for package, src_dir, build_dir, filenames in self.data_files:
+            for filename in filenames:
+                target = os.path.join(build_dir, filename)
+                self.mkpath(os.path.dirname(target))
+                srcfile = os.path.join(src_dir, filename)
+                outf, copied = self.copy_file(srcfile, target)
+                srcfile = os.path.abspath(srcfile)
+                if (copied and
+                        srcfile in self.distribution.convert_2to3_doctests):
+                    self.__doctests_2to3.append(outf)
+
+    def analyze_manifest(self):
+        self.manifest_files = mf = {}
+        if not self.distribution.include_package_data:
+            return
+        src_dirs = {}
+        for package in self.packages or ():
+            # Locate package source directory
+            src_dirs[assert_relative(self.get_package_dir(package))] = package
+
+        self.run_command('egg_info')
+        ei_cmd = self.get_finalized_command('egg_info')
+        for path in ei_cmd.filelist.files:
+            d, f = os.path.split(assert_relative(path))
+            prev = None
+            oldf = f
+            while d and d != prev and d not in src_dirs:
+                prev = d
+                d, df = os.path.split(d)
+                f = os.path.join(df, f)
+            if d in src_dirs:
+                if path.endswith('.py') and f == oldf:
+                    continue  # it's a module, not data
+                mf.setdefault(src_dirs[d], []).append(path)
+
+    def get_data_files(self):
+        pass  # Lazily compute data files in _get_data_files() function.
+
+    def check_package(self, package, package_dir):
+        """Check namespace packages' __init__ for declare_namespace"""
+        try:
+            return self.packages_checked[package]
+        except KeyError:
+            pass
+
+        init_py = orig.build_py.check_package(self, package, package_dir)
+        self.packages_checked[package] = init_py
+
+        if not init_py or not self.distribution.namespace_packages:
+            return init_py
+
+        for pkg in self.distribution.namespace_packages:
+            if pkg == package or pkg.startswith(package + '.'):
+                break
+        else:
+            return init_py
+
+        with io.open(init_py, 'rb') as f:
+            contents = f.read()
+        if b'declare_namespace' not in contents:
+            raise distutils.errors.DistutilsError(
+                "Namespace package problem: %s is a namespace package, but "
+                "its\n__init__.py does not call declare_namespace()! Please "
+                'fix it.\n(See the setuptools manual under '
+                '"Namespace Packages" for details.)\n"' % (package,)
+            )
+        return init_py
+
+    def initialize_options(self):
+        self.packages_checked = {}
+        orig.build_py.initialize_options(self)
+
+    def get_package_dir(self, package):
+        res = orig.build_py.get_package_dir(self, package)
+        if self.distribution.src_root is not None:
+            return os.path.join(self.distribution.src_root, res)
+        return res
+
+    def exclude_data_files(self, package, src_dir, files):
+        """Filter filenames for package's data files in 'src_dir'"""
+        files = list(files)
+        patterns = self._get_platform_patterns(
+            self.exclude_package_data,
+            package,
+            src_dir,
+        )
+        match_groups = (
+            fnmatch.filter(files, pattern)
+            for pattern in patterns
+        )
+        # flatten the groups of matches into an iterable of matches
+        matches = itertools.chain.from_iterable(match_groups)
+        bad = set(matches)
+        keepers = (
+            fn
+            for fn in files
+            if fn not in bad
+        )
+        # ditch dupes
+        return list(_unique_everseen(keepers))
+
+    @staticmethod
+    def _get_platform_patterns(spec, package, src_dir):
+        """
+        yield platform-specific path patterns (suitable for glob
+        or fn_match) from a glob-based spec (such as
+        self.package_data or self.exclude_package_data)
+        matching package in src_dir.
+        """
+        raw_patterns = itertools.chain(
+            spec.get('', []),
+            spec.get(package, []),
+        )
+        return (
+            # Each pattern has to be converted to a platform-specific path
+            os.path.join(src_dir, convert_path(pattern))
+            for pattern in raw_patterns
+        )
+
+
+# from Python docs
+def _unique_everseen(iterable, key=None):
+    "List unique elements, preserving order. Remember all elements ever seen."
+    # unique_everseen('AAAABBBCCDAABBB') --> A B C D
+    # unique_everseen('ABBCcAD', str.lower) --> A B C D
+    seen = set()
+    seen_add = seen.add
+    if key is None:
+        for element in filterfalse(seen.__contains__, iterable):
+            seen_add(element)
+            yield element
+    else:
+        for element in iterable:
+            k = key(element)
+            if k not in seen:
+                seen_add(k)
+                yield element
+
+
+def assert_relative(path):
+    if not os.path.isabs(path):
+        return path
+    from distutils.errors import DistutilsSetupError
+
+    msg = textwrap.dedent("""
+        Error: setup script specifies an absolute path:
+
+            %s
+
+        setup() arguments must *always* be /-separated paths relative to the
+        setup.py directory, *never* absolute paths.
+        """).lstrip() % path
+    raise DistutilsSetupError(msg)
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/build_py.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/build_py.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..b8f8c36ff7ce06915b0e35f88333a7eb0817736c
GIT binary patch
literal 11963
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
IbAv|+0PM*g7ytkO

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/develop.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/develop.py
new file mode 100644
index 0000000..009e4f9
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/develop.py
@@ -0,0 +1,221 @@
+from distutils.util import convert_path
+from distutils import log
+from distutils.errors import DistutilsError, DistutilsOptionError
+import os
+import glob
+import io
+
+from setuptools.extern import six
+
+import pkg_resources
+from setuptools.command.easy_install import easy_install
+from setuptools import namespaces
+import setuptools
+
+__metaclass__ = type
+
+
+class develop(namespaces.DevelopInstaller, easy_install):
+    """Set up package for development"""
+
+    description = "install package in 'development mode'"
+
+    user_options = easy_install.user_options + [
+        ("uninstall", "u", "Uninstall this source package"),
+        ("egg-path=", None, "Set the path to be used in the .egg-link file"),
+    ]
+
+    boolean_options = easy_install.boolean_options + ['uninstall']
+
+    command_consumes_arguments = False  # override base
+
+    def run(self):
+        if self.uninstall:
+            self.multi_version = True
+            self.uninstall_link()
+            self.uninstall_namespaces()
+        else:
+            self.install_for_development()
+        self.warn_deprecated_options()
+
+    def initialize_options(self):
+        self.uninstall = None
+        self.egg_path = None
+        easy_install.initialize_options(self)
+        self.setup_path = None
+        self.always_copy_from = '.'  # always copy eggs installed in curdir
+
+    def finalize_options(self):
+        ei = self.get_finalized_command("egg_info")
+        if ei.broken_egg_info:
+            template = "Please rename %r to %r before using 'develop'"
+            args = ei.egg_info, ei.broken_egg_info
+            raise DistutilsError(template % args)
+        self.args = [ei.egg_name]
+
+        easy_install.finalize_options(self)
+        self.expand_basedirs()
+        self.expand_dirs()
+        # pick up setup-dir .egg files only: no .egg-info
+        self.package_index.scan(glob.glob('*.egg'))
+
+        egg_link_fn = ei.egg_name + '.egg-link'
+        self.egg_link = os.path.join(self.install_dir, egg_link_fn)
+        self.egg_base = ei.egg_base
+        if self.egg_path is None:
+            self.egg_path = os.path.abspath(ei.egg_base)
+
+        target = pkg_resources.normalize_path(self.egg_base)
+        egg_path = pkg_resources.normalize_path(
+            os.path.join(self.install_dir, self.egg_path))
+        if egg_path != target:
+            raise DistutilsOptionError(
+                "--egg-path must be a relative path from the install"
+                " directory to " + target
+            )
+
+        # Make a distribution for the package's source
+        self.dist = pkg_resources.Distribution(
+            target,
+            pkg_resources.PathMetadata(target, os.path.abspath(ei.egg_info)),
+            project_name=ei.egg_name
+        )
+
+        self.setup_path = self._resolve_setup_path(
+            self.egg_base,
+            self.install_dir,
+            self.egg_path,
+        )
+
+    @staticmethod
+    def _resolve_setup_path(egg_base, install_dir, egg_path):
+        """
+        Generate a path from egg_base back to '.' where the
+        setup script resides and ensure that path points to the
+        setup path from $install_dir/$egg_path.
+        """
+        path_to_setup = egg_base.replace(os.sep, '/').rstrip('/')
+        if path_to_setup != os.curdir:
+            path_to_setup = '../' * (path_to_setup.count('/') + 1)
+        resolved = pkg_resources.normalize_path(
+            os.path.join(install_dir, egg_path, path_to_setup)
+        )
+        if resolved != pkg_resources.normalize_path(os.curdir):
+            raise DistutilsOptionError(
+                "Can't get a consistent path to setup script from"
+                " installation directory", resolved,
+                pkg_resources.normalize_path(os.curdir))
+        return path_to_setup
+
+    def install_for_development(self):
+        if six.PY3 and getattr(self.distribution, 'use_2to3', False):
+            # If we run 2to3 we can not do this inplace:
+
+            # Ensure metadata is up-to-date
+            self.reinitialize_command('build_py', inplace=0)
+            self.run_command('build_py')
+            bpy_cmd = self.get_finalized_command("build_py")
+            build_path = pkg_resources.normalize_path(bpy_cmd.build_lib)
+
+            # Build extensions
+            self.reinitialize_command('egg_info', egg_base=build_path)
+            self.run_command('egg_info')
+
+            self.reinitialize_command('build_ext', inplace=0)
+            self.run_command('build_ext')
+
+            # Fixup egg-link and easy-install.pth
+            ei_cmd = self.get_finalized_command("egg_info")
+            self.egg_path = build_path
+            self.dist.location = build_path
+            # XXX
+            self.dist._provider = pkg_resources.PathMetadata(
+                build_path, ei_cmd.egg_info)
+        else:
+            # Without 2to3 inplace works fine:
+            self.run_command('egg_info')
+
+            # Build extensions in-place
+            self.reinitialize_command('build_ext', inplace=1)
+            self.run_command('build_ext')
+
+        self.install_site_py()  # ensure that target dir is site-safe
+        if setuptools.bootstrap_install_from:
+            self.easy_install(setuptools.bootstrap_install_from)
+            setuptools.bootstrap_install_from = None
+
+        self.install_namespaces()
+
+        # create an .egg-link in the installation dir, pointing to our egg
+        log.info("Creating %s (link to %s)", self.egg_link, self.egg_base)
+        if not self.dry_run:
+            with open(self.egg_link, "w") as f:
+                f.write(self.egg_path + "\n" + self.setup_path)
+        # postprocess the installed distro, fixing up .pth, installing scripts,
+        # and handling requirements
+        self.process_distribution(None, self.dist, not self.no_deps)
+
+    def uninstall_link(self):
+        if os.path.exists(self.egg_link):
+            log.info("Removing %s (link to %s)", self.egg_link, self.egg_base)
+            egg_link_file = open(self.egg_link)
+            contents = [line.rstrip() for line in egg_link_file]
+            egg_link_file.close()
+            if contents not in ([self.egg_path],
+                                [self.egg_path, self.setup_path]):
+                log.warn("Link points to %s: uninstall aborted", contents)
+                return
+            if not self.dry_run:
+                os.unlink(self.egg_link)
+        if not self.dry_run:
+            self.update_pth(self.dist)  # remove any .pth link to us
+        if self.distribution.scripts:
+            # XXX should also check for entry point scripts!
+            log.warn("Note: you must uninstall or replace scripts manually!")
+
+    def install_egg_scripts(self, dist):
+        if dist is not self.dist:
+            # Installing a dependency, so fall back to normal behavior
+            return easy_install.install_egg_scripts(self, dist)
+
+        # create wrapper scripts in the script dir, pointing to dist.scripts
+
+        # new-style...
+        self.install_wrapper_scripts(dist)
+
+        # ...and old-style
+        for script_name in self.distribution.scripts or []:
+            script_path = os.path.abspath(convert_path(script_name))
+            script_name = os.path.basename(script_path)
+            with io.open(script_path) as strm:
+                script_text = strm.read()
+            self.install_script(dist, script_name, script_text, script_path)
+
+    def install_wrapper_scripts(self, dist):
+        dist = VersionlessRequirement(dist)
+        return easy_install.install_wrapper_scripts(self, dist)
+
+
+class VersionlessRequirement:
+    """
+    Adapt a pkg_resources.Distribution to simply return the project
+    name as the 'requirement' so that scripts will work across
+    multiple versions.
+
+    >>> from pkg_resources import Distribution
+    >>> dist = Distribution(project_name='foo', version='1.0')
+    >>> str(dist.as_requirement())
+    'foo==1.0'
+    >>> adapted_dist = VersionlessRequirement(dist)
+    >>> str(adapted_dist.as_requirement())
+    'foo'
+    """
+
+    def __init__(self, dist):
+        self.__dist = dist
+
+    def __getattr__(self, name):
+        return getattr(self.__dist, name)
+
+    def as_requirement(self):
+        return self.project_name
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/develop.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/develop.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..29d1f8834b49e294dbfc1d5be74e8f24a98ec6df
GIT binary patch
literal 8733
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

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/dist_info.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/dist_info.py
new file mode 100644
index 0000000..c45258f
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/dist_info.py
@@ -0,0 +1,36 @@
+"""
+Create a dist_info directory
+As defined in the wheel specification
+"""
+
+import os
+
+from distutils.core import Command
+from distutils import log
+
+
+class dist_info(Command):
+
+    description = 'create a .dist-info directory'
+
+    user_options = [
+        ('egg-base=', 'e', "directory containing .egg-info directories"
+                           " (default: top of the source tree)"),
+    ]
+
+    def initialize_options(self):
+        self.egg_base = None
+
+    def finalize_options(self):
+        pass
+
+    def run(self):
+        egg_info = self.get_finalized_command('egg_info')
+        egg_info.egg_base = self.egg_base
+        egg_info.finalize_options()
+        egg_info.run()
+        dist_info_dir = egg_info.egg_info[:-len('.egg-info')] + '.dist-info'
+        log.info("creating '{}'".format(os.path.abspath(dist_info_dir)))
+
+        bdist_wheel = self.get_finalized_command('bdist_wheel')
+        bdist_wheel.egg2dist(egg_info.egg_info, dist_info_dir)
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/dist_info.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/dist_info.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..0b513c52835053021df3448c39c1cd11ff2b6ea8
GIT binary patch
literal 2069
zcmZSn%**AGdLky70ScHI7#JKF7#NCu7#J8*7#N}$7*ZG+QkWQW7#X4%!E9!R943Zb
zW`-zc21bw^3quYILoO>r6e|N`3M)e@Gea69Lkb&13j;$l14CpK8%TSw20O@97X}6f
zF6W}u#FA8nM1_>h;*$8xytI6Ul+2>k<dXcNN-oD@g_P8^%)HbTh0HvKl8jV^@{H8f
z9EIY7)a1;x%;dz9%=|pA%>V!Y|M$~iWME(@0U7L^pPQSQmjV$0`5`Aiy@V6w1(+2m
zK6C=P#fX7{A(a8_D+Y!rCWaJthIB@duToe*ZjWMNNMQvtSfRd&Vq*vj*5Cl?m1SUH
zNQQYs59AMBRDTqMEKf~O*G)<+PPHuoIW!d#rZAr>B<JUqBxdGi=A|p>fmEUxkeOPn
zpplZAmROooVx>@$U!ahm1`dtl{L-T2RE3hF)Ktx6kg*`l#K6Gd400DQ$jb~2H4F^#
zjG*WX28W2B21r2(3j+g#Uw&R{3CIhn>FMzxw}BOarHWH?(lkKH08A8@F)%Rb7Zhcd
zC6=V>mn9bIr{(9Qq!tzHC#C3@Cne?On&uW8877&hSEXB+T9oHxRhb!pKzg2jh<-t4
zfo^7AaY<rMj;>poho^CXesO9^X+cSTeoiqmGZ_+b`k){LCk4HN$`T<428PVM%#zH+
zoXo1!`1}G;oEM9NJP7g#10&qyAkTw64)R+H0|U&zU~hmVgV-1t7{DF^69efh0R{$!
zw9GsdKS`kZ3FHkB2K%X>0UVQA;4Ik8$WY4&ir6ehh8jjt^wuykWHEuV7$b<q3}>-0
zl(2%bTr(pBw?YatgLo|yLkSy07CS=<3quwMLkTBC78gSnH$x2*Lo*{3G1f3JfGlDK
z@oSkGYM2?act93qv4GVvF))II7ZjX+@B{=(vfz{sPr$`o3=9m23{eb9kl>60O6Ka-
zwdy6@3=9lO;OGWtYz>f#5>VWxr<TOS!Y3sjnlOS`85kIXKnb=4l&y<O^MW`*nI6Q+
zNzDra#W6Vbf}BzUa$Q<}QEp;M2`HiD7lWk=5=%0`r9@&<F_;Z9E;T*f2;>S4P;i4&
z3B+KKb3o$Y#2BBFSri2F5jgRHi2+POK|Bl$4AP(!14>E^jQor|j9iRdj1r7WO#F-*
zpdbN92B<IrWo_Faun@Q;r(&rCF3G`3AU-}XF*h|nz62CR@$tF&DWy3eE+~pqQj3#|
zGQl~w1my10;?yEoP7VSU+2BY8dkGw_2x1^Z7?f&2t_3G!HYPS^P8LpPPG*RgL9ULE
zPsvY?j}HRHKnWkHw9PCoDJ{v&Db`EQFG>vp6+G~Y2P_UwqCp^o5ncqd2GF12*t3De
UmmMer6oaw^8xs$c0HXji02@#Sa{vGU

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/easy_install.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/easy_install.py
new file mode 100644
index 0000000..06c9827
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/easy_install.py
@@ -0,0 +1,2342 @@
+#!/usr/bin/env python
+"""
+Easy Install
+------------
+
+A tool for doing automatic download/extract/build of distutils-based Python
+packages.  For detailed documentation, see the accompanying EasyInstall.txt
+file, or visit the `EasyInstall home page`__.
+
+__ https://setuptools.readthedocs.io/en/latest/easy_install.html
+
+"""
+
+from glob import glob
+from distutils.util import get_platform
+from distutils.util import convert_path, subst_vars
+from distutils.errors import (
+    DistutilsArgError, DistutilsOptionError,
+    DistutilsError, DistutilsPlatformError,
+)
+from distutils.command.install import INSTALL_SCHEMES, SCHEME_KEYS
+from distutils import log, dir_util
+from distutils.command.build_scripts import first_line_re
+from distutils.spawn import find_executable
+import sys
+import os
+import zipimport
+import shutil
+import tempfile
+import zipfile
+import re
+import stat
+import random
+import textwrap
+import warnings
+import site
+import struct
+import contextlib
+import subprocess
+import shlex
+import io
+
+
+from sysconfig import get_config_vars, get_path
+
+from setuptools import SetuptoolsDeprecationWarning
+
+from setuptools.extern import six
+from setuptools.extern.six.moves import configparser, map
+
+from setuptools import Command
+from setuptools.sandbox import run_setup
+from setuptools.py27compat import rmtree_safe
+from setuptools.command import setopt
+from setuptools.archive_util import unpack_archive
+from setuptools.package_index import (
+    PackageIndex, parse_requirement_arg, URL_SCHEME,
+)
+from setuptools.command import bdist_egg, egg_info
+from setuptools.wheel import Wheel
+from pkg_resources import (
+    yield_lines, normalize_path, resource_string, ensure_directory,
+    get_distribution, find_distributions, Environment, Requirement,
+    Distribution, PathMetadata, EggMetadata, WorkingSet, DistributionNotFound,
+    VersionConflict, DEVELOP_DIST,
+)
+import pkg_resources.py31compat
+
+__metaclass__ = type
+
+# Turn on PEP440Warnings
+warnings.filterwarnings("default", category=pkg_resources.PEP440Warning)
+
+__all__ = [
+    'samefile', 'easy_install', 'PthDistributions', 'extract_wininst_cfg',
+    'main', 'get_exe_prefixes',
+]
+
+
+def is_64bit():
+    return struct.calcsize("P") == 8
+
+
+def samefile(p1, p2):
+    """
+    Determine if two paths reference the same file.
+
+    Augments os.path.samefile to work on Windows and
+    suppresses errors if the path doesn't exist.
+    """
+    both_exist = os.path.exists(p1) and os.path.exists(p2)
+    use_samefile = hasattr(os.path, 'samefile') and both_exist
+    if use_samefile:
+        return os.path.samefile(p1, p2)
+    norm_p1 = os.path.normpath(os.path.normcase(p1))
+    norm_p2 = os.path.normpath(os.path.normcase(p2))
+    return norm_p1 == norm_p2
+
+
+if six.PY2:
+
+    def _to_bytes(s):
+        return s
+
+    def isascii(s):
+        try:
+            six.text_type(s, 'ascii')
+            return True
+        except UnicodeError:
+            return False
+else:
+
+    def _to_bytes(s):
+        return s.encode('utf8')
+
+    def isascii(s):
+        try:
+            s.encode('ascii')
+            return True
+        except UnicodeError:
+            return False
+
+
+_one_liner = lambda text: textwrap.dedent(text).strip().replace('\n', '; ')
+
+
+class easy_install(Command):
+    """Manage a download/build/install process"""
+    description = "Find/get/install Python packages"
+    command_consumes_arguments = True
+
+    user_options = [
+        ('prefix=', None, "installation prefix"),
+        ("zip-ok", "z", "install package as a zipfile"),
+        ("multi-version", "m", "make apps have to require() a version"),
+        ("upgrade", "U", "force upgrade (searches PyPI for latest versions)"),
+        ("install-dir=", "d", "install package to DIR"),
+        ("script-dir=", "s", "install scripts to DIR"),
+        ("exclude-scripts", "x", "Don't install scripts"),
+        ("always-copy", "a", "Copy all needed packages to install dir"),
+        ("index-url=", "i", "base URL of Python Package Index"),
+        ("find-links=", "f", "additional URL(s) to search for packages"),
+        ("build-directory=", "b",
+         "download/extract/build in DIR; keep the results"),
+        ('optimize=', 'O',
+         "also compile with optimization: -O1 for \"python -O\", "
+         "-O2 for \"python -OO\", and -O0 to disable [default: -O0]"),
+        ('record=', None,
+         "filename in which to record list of installed files"),
+        ('always-unzip', 'Z', "don't install as a zipfile, no matter what"),
+        ('site-dirs=', 'S', "list of directories where .pth files work"),
+        ('editable', 'e', "Install specified packages in editable form"),
+        ('no-deps', 'N', "don't install dependencies"),
+        ('allow-hosts=', 'H', "pattern(s) that hostnames must match"),
+        ('local-snapshots-ok', 'l',
+         "allow building eggs from local checkouts"),
+        ('version', None, "print version information and exit"),
+        ('no-find-links', None,
+         "Don't load find-links defined in packages being installed")
+    ]
+    boolean_options = [
+        'zip-ok', 'multi-version', 'exclude-scripts', 'upgrade', 'always-copy',
+        'editable',
+        'no-deps', 'local-snapshots-ok', 'version'
+    ]
+
+    if site.ENABLE_USER_SITE:
+        help_msg = "install in user site-package '%s'" % site.USER_SITE
+        user_options.append(('user', None, help_msg))
+        boolean_options.append('user')
+
+    negative_opt = {'always-unzip': 'zip-ok'}
+    create_index = PackageIndex
+
+    def initialize_options(self):
+        # the --user option seems to be an opt-in one,
+        # so the default should be False.
+        self.user = 0
+        self.zip_ok = self.local_snapshots_ok = None
+        self.install_dir = self.script_dir = self.exclude_scripts = None
+        self.index_url = None
+        self.find_links = None
+        self.build_directory = None
+        self.args = None
+        self.optimize = self.record = None
+        self.upgrade = self.always_copy = self.multi_version = None
+        self.editable = self.no_deps = self.allow_hosts = None
+        self.root = self.prefix = self.no_report = None
+        self.version = None
+        self.install_purelib = None  # for pure module distributions
+        self.install_platlib = None  # non-pure (dists w/ extensions)
+        self.install_headers = None  # for C/C++ headers
+        self.install_lib = None  # set to either purelib or platlib
+        self.install_scripts = None
+        self.install_data = None
+        self.install_base = None
+        self.install_platbase = None
+        if site.ENABLE_USER_SITE:
+            self.install_userbase = site.USER_BASE
+            self.install_usersite = site.USER_SITE
+        else:
+            self.install_userbase = None
+            self.install_usersite = None
+        self.no_find_links = None
+
+        # Options not specifiable via command line
+        self.package_index = None
+        self.pth_file = self.always_copy_from = None
+        self.site_dirs = None
+        self.installed_projects = {}
+        self.sitepy_installed = False
+        # Always read easy_install options, even if we are subclassed, or have
+        # an independent instance created.  This ensures that defaults will
+        # always come from the standard configuration file(s)' "easy_install"
+        # section, even if this is a "develop" or "install" command, or some
+        # other embedding.
+        self._dry_run = None
+        self.verbose = self.distribution.verbose
+        self.distribution._set_command_options(
+            self, self.distribution.get_option_dict('easy_install')
+        )
+
+    def delete_blockers(self, blockers):
+        extant_blockers = (
+            filename for filename in blockers
+            if os.path.exists(filename) or os.path.islink(filename)
+        )
+        list(map(self._delete_path, extant_blockers))
+
+    def _delete_path(self, path):
+        log.info("Deleting %s", path)
+        if self.dry_run:
+            return
+
+        is_tree = os.path.isdir(path) and not os.path.islink(path)
+        remover = rmtree if is_tree else os.unlink
+        remover(path)
+
+    @staticmethod
+    def _render_version():
+        """
+        Render the Setuptools version and installation details, then exit.
+        """
+        ver = sys.version[:3]
+        dist = get_distribution('setuptools')
+        tmpl = 'setuptools {dist.version} from {dist.location} (Python {ver})'
+        print(tmpl.format(**locals()))
+        raise SystemExit()
+
+    def finalize_options(self):
+        self.version and self._render_version()
+
+        py_version = sys.version.split()[0]
+        prefix, exec_prefix = get_config_vars('prefix', 'exec_prefix')
+
+        self.config_vars = {
+            'dist_name': self.distribution.get_name(),
+            'dist_version': self.distribution.get_version(),
+            'dist_fullname': self.distribution.get_fullname(),
+            'py_version': py_version,
+            'py_version_short': py_version[0:3],
+            'py_version_nodot': py_version[0] + py_version[2],
+            'sys_prefix': prefix,
+            'prefix': prefix,
+            'sys_exec_prefix': exec_prefix,
+            'exec_prefix': exec_prefix,
+            # Only python 3.2+ has abiflags
+            'abiflags': getattr(sys, 'abiflags', ''),
+        }
+
+        if site.ENABLE_USER_SITE:
+            self.config_vars['userbase'] = self.install_userbase
+            self.config_vars['usersite'] = self.install_usersite
+
+        self._fix_install_dir_for_user_site()
+
+        self.expand_basedirs()
+        self.expand_dirs()
+
+        self._expand(
+            'install_dir', 'script_dir', 'build_directory',
+            'site_dirs',
+        )
+        # If a non-default installation directory was specified, default the
+        # script directory to match it.
+        if self.script_dir is None:
+            self.script_dir = self.install_dir
+
+        if self.no_find_links is None:
+            self.no_find_links = False
+
+        # Let install_dir get set by install_lib command, which in turn
+        # gets its info from the install command, and takes into account
+        # --prefix and --home and all that other crud.
+        self.set_undefined_options(
+            'install_lib', ('install_dir', 'install_dir')
+        )
+        # Likewise, set default script_dir from 'install_scripts.install_dir'
+        self.set_undefined_options(
+            'install_scripts', ('install_dir', 'script_dir')
+        )
+
+        if self.user and self.install_purelib:
+            self.install_dir = self.install_purelib
+            self.script_dir = self.install_scripts
+        # default --record from the install command
+        self.set_undefined_options('install', ('record', 'record'))
+        # Should this be moved to the if statement below? It's not used
+        # elsewhere
+        normpath = map(normalize_path, sys.path)
+        self.all_site_dirs = get_site_dirs()
+        if self.site_dirs is not None:
+            site_dirs = [
+                os.path.expanduser(s.strip()) for s in
+                self.site_dirs.split(',')
+            ]
+            for d in site_dirs:
+                if not os.path.isdir(d):
+                    log.warn("%s (in --site-dirs) does not exist", d)
+                elif normalize_path(d) not in normpath:
+                    raise DistutilsOptionError(
+                        d + " (in --site-dirs) is not on sys.path"
+                    )
+                else:
+                    self.all_site_dirs.append(normalize_path(d))
+        if not self.editable:
+            self.check_site_dir()
+        self.index_url = self.index_url or "https://pypi.org/simple/"
+        self.shadow_path = self.all_site_dirs[:]
+        for path_item in self.install_dir, normalize_path(self.script_dir):
+            if path_item not in self.shadow_path:
+                self.shadow_path.insert(0, path_item)
+
+        if self.allow_hosts is not None:
+            hosts = [s.strip() for s in self.allow_hosts.split(',')]
+        else:
+            hosts = ['*']
+        if self.package_index is None:
+            self.package_index = self.create_index(
+                self.index_url, search_path=self.shadow_path, hosts=hosts,
+            )
+        self.local_index = Environment(self.shadow_path + sys.path)
+
+        if self.find_links is not None:
+            if isinstance(self.find_links, six.string_types):
+                self.find_links = self.find_links.split()
+        else:
+            self.find_links = []
+        if self.local_snapshots_ok:
+            self.package_index.scan_egg_links(self.shadow_path + sys.path)
+        if not self.no_find_links:
+            self.package_index.add_find_links(self.find_links)
+        self.set_undefined_options('install_lib', ('optimize', 'optimize'))
+        if not isinstance(self.optimize, int):
+            try:
+                self.optimize = int(self.optimize)
+                if not (0 <= self.optimize <= 2):
+                    raise ValueError
+            except ValueError:
+                raise DistutilsOptionError("--optimize must be 0, 1, or 2")
+
+        if self.editable and not self.build_directory:
+            raise DistutilsArgError(
+                "Must specify a build directory (-b) when using --editable"
+            )
+        if not self.args:
+            raise DistutilsArgError(
+                "No urls, filenames, or requirements specified (see --help)")
+
+        self.outputs = []
+
+    def _fix_install_dir_for_user_site(self):
+        """
+        Fix the install_dir if "--user" was used.
+        """
+        if not self.user or not site.ENABLE_USER_SITE:
+            return
+
+        self.create_home_path()
+        if self.install_userbase is None:
+            msg = "User base directory is not specified"
+            raise DistutilsPlatformError(msg)
+        self.install_base = self.install_platbase = self.install_userbase
+        scheme_name = os.name.replace('posix', 'unix') + '_user'
+        self.select_scheme(scheme_name)
+
+    def _expand_attrs(self, attrs):
+        for attr in attrs:
+            val = getattr(self, attr)
+            if val is not None:
+                if os.name == 'posix' or os.name == 'nt':
+                    val = os.path.expanduser(val)
+                val = subst_vars(val, self.config_vars)
+                setattr(self, attr, val)
+
+    def expand_basedirs(self):
+        """Calls `os.path.expanduser` on install_base, install_platbase and
+        root."""
+        self._expand_attrs(['install_base', 'install_platbase', 'root'])
+
+    def expand_dirs(self):
+        """Calls `os.path.expanduser` on install dirs."""
+        dirs = [
+            'install_purelib',
+            'install_platlib',
+            'install_lib',
+            'install_headers',
+            'install_scripts',
+            'install_data',
+        ]
+        self._expand_attrs(dirs)
+
+    def run(self):
+        if self.verbose != self.distribution.verbose:
+            log.set_verbosity(self.verbose)
+        try:
+            for spec in self.args:
+                self.easy_install(spec, not self.no_deps)
+            if self.record:
+                outputs = self.outputs
+                if self.root:  # strip any package prefix
+                    root_len = len(self.root)
+                    for counter in range(len(outputs)):
+                        outputs[counter] = outputs[counter][root_len:]
+                from distutils import file_util
+
+                self.execute(
+                    file_util.write_file, (self.record, outputs),
+                    "writing list of installed files to '%s'" %
+                    self.record
+                )
+            self.warn_deprecated_options()
+        finally:
+            log.set_verbosity(self.distribution.verbose)
+
+    def pseudo_tempname(self):
+        """Return a pseudo-tempname base in the install directory.
+        This code is intentionally naive; if a malicious party can write to
+        the target directory you're already in deep doodoo.
+        """
+        try:
+            pid = os.getpid()
+        except Exception:
+            pid = random.randint(0, sys.maxsize)
+        return os.path.join(self.install_dir, "test-easy-install-%s" % pid)
+
+    def warn_deprecated_options(self):
+        pass
+
+    def check_site_dir(self):
+        """Verify that self.install_dir is .pth-capable dir, if needed"""
+
+        instdir = normalize_path(self.install_dir)
+        pth_file = os.path.join(instdir, 'easy-install.pth')
+
+        # Is it a configured, PYTHONPATH, implicit, or explicit site dir?
+        is_site_dir = instdir in self.all_site_dirs
+
+        if not is_site_dir and not self.multi_version:
+            # No?  Then directly test whether it does .pth file processing
+            is_site_dir = self.check_pth_processing()
+        else:
+            # make sure we can write to target dir
+            testfile = self.pseudo_tempname() + '.write-test'
+            test_exists = os.path.exists(testfile)
+            try:
+                if test_exists:
+                    os.unlink(testfile)
+                open(testfile, 'w').close()
+                os.unlink(testfile)
+            except (OSError, IOError):
+                self.cant_write_to_target()
+
+        if not is_site_dir and not self.multi_version:
+            # Can't install non-multi to non-site dir
+            raise DistutilsError(self.no_default_version_msg())
+
+        if is_site_dir:
+            if self.pth_file is None:
+                self.pth_file = PthDistributions(pth_file, self.all_site_dirs)
+        else:
+            self.pth_file = None
+
+        if instdir not in map(normalize_path, _pythonpath()):
+            # only PYTHONPATH dirs need a site.py, so pretend it's there
+            self.sitepy_installed = True
+        elif self.multi_version and not os.path.exists(pth_file):
+            self.sitepy_installed = True  # don't need site.py in this case
+            self.pth_file = None  # and don't create a .pth file
+        self.install_dir = instdir
+
+    __cant_write_msg = textwrap.dedent("""
+        can't create or remove files in install directory
+
+        The following error occurred while trying to add or remove files in the
+        installation directory:
+
+            %s
+
+        The installation directory you specified (via --install-dir, --prefix, or
+        the distutils default setting) was:
+
+            %s
+        """).lstrip()
+
+    __not_exists_id = textwrap.dedent("""
+        This directory does not currently exist.  Please create it and try again, or
+        choose a different installation directory (using the -d or --install-dir
+        option).
+        """).lstrip()
+
+    __access_msg = textwrap.dedent("""
+        Perhaps your account does not have write access to this directory?  If the
+        installation directory is a system-owned directory, you may need to sign in
+        as the administrator or "root" account.  If you do not have administrative
+        access to this machine, you may wish to choose a different installation
+        directory, preferably one that is listed in your PYTHONPATH environment
+        variable.
+
+        For information on other options, you may wish to consult the
+        documentation at:
+
+          https://setuptools.readthedocs.io/en/latest/easy_install.html
+
+        Please make the appropriate changes for your system and try again.
+        """).lstrip()
+
+    def cant_write_to_target(self):
+        msg = self.__cant_write_msg % (sys.exc_info()[1], self.install_dir,)
+
+        if not os.path.exists(self.install_dir):
+            msg += '\n' + self.__not_exists_id
+        else:
+            msg += '\n' + self.__access_msg
+        raise DistutilsError(msg)
+
+    def check_pth_processing(self):
+        """Empirically verify whether .pth files are supported in inst. dir"""
+        instdir = self.install_dir
+        log.info("Checking .pth file support in %s", instdir)
+        pth_file = self.pseudo_tempname() + ".pth"
+        ok_file = pth_file + '.ok'
+        ok_exists = os.path.exists(ok_file)
+        tmpl = _one_liner("""
+            import os
+            f = open({ok_file!r}, 'w')
+            f.write('OK')
+            f.close()
+            """) + '\n'
+        try:
+            if ok_exists:
+                os.unlink(ok_file)
+            dirname = os.path.dirname(ok_file)
+            pkg_resources.py31compat.makedirs(dirname, exist_ok=True)
+            f = open(pth_file, 'w')
+        except (OSError, IOError):
+            self.cant_write_to_target()
+        else:
+            try:
+                f.write(tmpl.format(**locals()))
+                f.close()
+                f = None
+                executable = sys.executable
+                if os.name == 'nt':
+                    dirname, basename = os.path.split(executable)
+                    alt = os.path.join(dirname, 'pythonw.exe')
+                    use_alt = (
+                        basename.lower() == 'python.exe' and
+                        os.path.exists(alt)
+                    )
+                    if use_alt:
+                        # use pythonw.exe to avoid opening a console window
+                        executable = alt
+
+                from distutils.spawn import spawn
+
+                spawn([executable, '-E', '-c', 'pass'], 0)
+
+                if os.path.exists(ok_file):
+                    log.info(
+                        "TEST PASSED: %s appears to support .pth files",
+                        instdir
+                    )
+                    return True
+            finally:
+                if f:
+                    f.close()
+                if os.path.exists(ok_file):
+                    os.unlink(ok_file)
+                if os.path.exists(pth_file):
+                    os.unlink(pth_file)
+        if not self.multi_version:
+            log.warn("TEST FAILED: %s does NOT support .pth files", instdir)
+        return False
+
+    def install_egg_scripts(self, dist):
+        """Write all the scripts for `dist`, unless scripts are excluded"""
+        if not self.exclude_scripts and dist.metadata_isdir('scripts'):
+            for script_name in dist.metadata_listdir('scripts'):
+                if dist.metadata_isdir('scripts/' + script_name):
+                    # The "script" is a directory, likely a Python 3
+                    # __pycache__ directory, so skip it.
+                    continue
+                self.install_script(
+                    dist, script_name,
+                    dist.get_metadata('scripts/' + script_name)
+                )
+        self.install_wrapper_scripts(dist)
+
+    def add_output(self, path):
+        if os.path.isdir(path):
+            for base, dirs, files in os.walk(path):
+                for filename in files:
+                    self.outputs.append(os.path.join(base, filename))
+        else:
+            self.outputs.append(path)
+
+    def not_editable(self, spec):
+        if self.editable:
+            raise DistutilsArgError(
+                "Invalid argument %r: you can't use filenames or URLs "
+                "with --editable (except via the --find-links option)."
+                % (spec,)
+            )
+
+    def check_editable(self, spec):
+        if not self.editable:
+            return
+
+        if os.path.exists(os.path.join(self.build_directory, spec.key)):
+            raise DistutilsArgError(
+                "%r already exists in %s; can't do a checkout there" %
+                (spec.key, self.build_directory)
+            )
+
+    @contextlib.contextmanager
+    def _tmpdir(self):
+        tmpdir = tempfile.mkdtemp(prefix=u"easy_install-")
+        try:
+            # cast to str as workaround for #709 and #710 and #712
+            yield str(tmpdir)
+        finally:
+            os.path.exists(tmpdir) and rmtree(rmtree_safe(tmpdir))
+
+    def easy_install(self, spec, deps=False):
+        if not self.editable:
+            self.install_site_py()
+
+        with self._tmpdir() as tmpdir:
+            if not isinstance(spec, Requirement):
+                if URL_SCHEME(spec):
+                    # It's a url, download it to tmpdir and process
+                    self.not_editable(spec)
+                    dl = self.package_index.download(spec, tmpdir)
+                    return self.install_item(None, dl, tmpdir, deps, True)
+
+                elif os.path.exists(spec):
+                    # Existing file or directory, just process it directly
+                    self.not_editable(spec)
+                    return self.install_item(None, spec, tmpdir, deps, True)
+                else:
+                    spec = parse_requirement_arg(spec)
+
+            self.check_editable(spec)
+            dist = self.package_index.fetch_distribution(
+                spec, tmpdir, self.upgrade, self.editable,
+                not self.always_copy, self.local_index
+            )
+            if dist is None:
+                msg = "Could not find suitable distribution for %r" % spec
+                if self.always_copy:
+                    msg += " (--always-copy skips system and development eggs)"
+                raise DistutilsError(msg)
+            elif dist.precedence == DEVELOP_DIST:
+                # .egg-info dists don't need installing, just process deps
+                self.process_distribution(spec, dist, deps, "Using")
+                return dist
+            else:
+                return self.install_item(spec, dist.location, tmpdir, deps)
+
+    def install_item(self, spec, download, tmpdir, deps, install_needed=False):
+
+        # Installation is also needed if file in tmpdir or is not an egg
+        install_needed = install_needed or self.always_copy
+        install_needed = install_needed or os.path.dirname(download) == tmpdir
+        install_needed = install_needed or not download.endswith('.egg')
+        install_needed = install_needed or (
+            self.always_copy_from is not None and
+            os.path.dirname(normalize_path(download)) ==
+            normalize_path(self.always_copy_from)
+        )
+
+        if spec and not install_needed:
+            # at this point, we know it's a local .egg, we just don't know if
+            # it's already installed.
+            for dist in self.local_index[spec.project_name]:
+                if dist.location == download:
+                    break
+            else:
+                install_needed = True  # it's not in the local index
+
+        log.info("Processing %s", os.path.basename(download))
+
+        if install_needed:
+            dists = self.install_eggs(spec, download, tmpdir)
+            for dist in dists:
+                self.process_distribution(spec, dist, deps)
+        else:
+            dists = [self.egg_distribution(download)]
+            self.process_distribution(spec, dists[0], deps, "Using")
+
+        if spec is not None:
+            for dist in dists:
+                if dist in spec:
+                    return dist
+
+    def select_scheme(self, name):
+        """Sets the install directories by applying the install schemes."""
+        # it's the caller's problem if they supply a bad name!
+        scheme = INSTALL_SCHEMES[name]
+        for key in SCHEME_KEYS:
+            attrname = 'install_' + key
+            if getattr(self, attrname) is None:
+                setattr(self, attrname, scheme[key])
+
+    def process_distribution(self, requirement, dist, deps=True, *info):
+        self.update_pth(dist)
+        self.package_index.add(dist)
+        if dist in self.local_index[dist.key]:
+            self.local_index.remove(dist)
+        self.local_index.add(dist)
+        self.install_egg_scripts(dist)
+        self.installed_projects[dist.key] = dist
+        log.info(self.installation_report(requirement, dist, *info))
+        if (dist.has_metadata('dependency_links.txt') and
+                not self.no_find_links):
+            self.package_index.add_find_links(
+                dist.get_metadata_lines('dependency_links.txt')
+            )
+        if not deps and not self.always_copy:
+            return
+        elif requirement is not None and dist.key != requirement.key:
+            log.warn("Skipping dependencies for %s", dist)
+            return  # XXX this is not the distribution we were looking for
+        elif requirement is None or dist not in requirement:
+            # if we wound up with a different version, resolve what we've got
+            distreq = dist.as_requirement()
+            requirement = Requirement(str(distreq))
+        log.info("Processing dependencies for %s", requirement)
+        try:
+            distros = WorkingSet([]).resolve(
+                [requirement], self.local_index, self.easy_install
+            )
+        except DistributionNotFound as e:
+            raise DistutilsError(str(e))
+        except VersionConflict as e:
+            raise DistutilsError(e.report())
+        if self.always_copy or self.always_copy_from:
+            # Force all the relevant distros to be copied or activated
+            for dist in distros:
+                if dist.key not in self.installed_projects:
+                    self.easy_install(dist.as_requirement())
+        log.info("Finished processing dependencies for %s", requirement)
+
+    def should_unzip(self, dist):
+        if self.zip_ok is not None:
+            return not self.zip_ok
+        if dist.has_metadata('not-zip-safe'):
+            return True
+        if not dist.has_metadata('zip-safe'):
+            return True
+        return False
+
+    def maybe_move(self, spec, dist_filename, setup_base):
+        dst = os.path.join(self.build_directory, spec.key)
+        if os.path.exists(dst):
+            msg = (
+                "%r already exists in %s; build directory %s will not be kept"
+            )
+            log.warn(msg, spec.key, self.build_directory, setup_base)
+            return setup_base
+        if os.path.isdir(dist_filename):
+            setup_base = dist_filename
+        else:
+            if os.path.dirname(dist_filename) == setup_base:
+                os.unlink(dist_filename)  # get it out of the tmp dir
+            contents = os.listdir(setup_base)
+            if len(contents) == 1:
+                dist_filename = os.path.join(setup_base, contents[0])
+                if os.path.isdir(dist_filename):
+                    # if the only thing there is a directory, move it instead
+                    setup_base = dist_filename
+        ensure_directory(dst)
+        shutil.move(setup_base, dst)
+        return dst
+
+    def install_wrapper_scripts(self, dist):
+        if self.exclude_scripts:
+            return
+        for args in ScriptWriter.best().get_args(dist):
+            self.write_script(*args)
+
+    def install_script(self, dist, script_name, script_text, dev_path=None):
+        """Generate a legacy script wrapper and install it"""
+        spec = str(dist.as_requirement())
+        is_script = is_python_script(script_text, script_name)
+
+        if is_script:
+            body = self._load_template(dev_path) % locals()
+            script_text = ScriptWriter.get_header(script_text) + body
+        self.write_script(script_name, _to_bytes(script_text), 'b')
+
+    @staticmethod
+    def _load_template(dev_path):
+        """
+        There are a couple of template scripts in the package. This
+        function loads one of them and prepares it for use.
+        """
+        # See https://github.com/pypa/setuptools/issues/134 for info
+        # on script file naming and downstream issues with SVR4
+        name = 'script.tmpl'
+        if dev_path:
+            name = name.replace('.tmpl', ' (dev).tmpl')
+
+        raw_bytes = resource_string('setuptools', name)
+        return raw_bytes.decode('utf-8')
+
+    def write_script(self, script_name, contents, mode="t", blockers=()):
+        """Write an executable file to the scripts directory"""
+        self.delete_blockers(  # clean up old .py/.pyw w/o a script
+            [os.path.join(self.script_dir, x) for x in blockers]
+        )
+        log.info("Installing %s script to %s", script_name, self.script_dir)
+        target = os.path.join(self.script_dir, script_name)
+        self.add_output(target)
+
+        if self.dry_run:
+            return
+
+        mask = current_umask()
+        ensure_directory(target)
+        if os.path.exists(target):
+            os.unlink(target)
+        with open(target, "w" + mode) as f:
+            f.write(contents)
+        chmod(target, 0o777 - mask)
+
+    def install_eggs(self, spec, dist_filename, tmpdir):
+        # .egg dirs or files are already built, so just return them
+        if dist_filename.lower().endswith('.egg'):
+            return [self.install_egg(dist_filename, tmpdir)]
+        elif dist_filename.lower().endswith('.exe'):
+            return [self.install_exe(dist_filename, tmpdir)]
+        elif dist_filename.lower().endswith('.whl'):
+            return [self.install_wheel(dist_filename, tmpdir)]
+
+        # Anything else, try to extract and build
+        setup_base = tmpdir
+        if os.path.isfile(dist_filename) and not dist_filename.endswith('.py'):
+            unpack_archive(dist_filename, tmpdir, self.unpack_progress)
+        elif os.path.isdir(dist_filename):
+            setup_base = os.path.abspath(dist_filename)
+
+        if (setup_base.startswith(tmpdir)  # something we downloaded
+                and self.build_directory and spec is not None):
+            setup_base = self.maybe_move(spec, dist_filename, setup_base)
+
+        # Find the setup.py file
+        setup_script = os.path.join(setup_base, 'setup.py')
+
+        if not os.path.exists(setup_script):
+            setups = glob(os.path.join(setup_base, '*', 'setup.py'))
+            if not setups:
+                raise DistutilsError(
+                    "Couldn't find a setup script in %s" %
+                    os.path.abspath(dist_filename)
+                )
+            if len(setups) > 1:
+                raise DistutilsError(
+                    "Multiple setup scripts in %s" %
+                    os.path.abspath(dist_filename)
+                )
+            setup_script = setups[0]
+
+        # Now run it, and return the result
+        if self.editable:
+            log.info(self.report_editable(spec, setup_script))
+            return []
+        else:
+            return self.build_and_install(setup_script, setup_base)
+
+    def egg_distribution(self, egg_path):
+        if os.path.isdir(egg_path):
+            metadata = PathMetadata(egg_path, os.path.join(egg_path,
+                                                           'EGG-INFO'))
+        else:
+            metadata = EggMetadata(zipimport.zipimporter(egg_path))
+        return Distribution.from_filename(egg_path, metadata=metadata)
+
+    def install_egg(self, egg_path, tmpdir):
+        destination = os.path.join(
+            self.install_dir,
+            os.path.basename(egg_path),
+        )
+        destination = os.path.abspath(destination)
+        if not self.dry_run:
+            ensure_directory(destination)
+
+        dist = self.egg_distribution(egg_path)
+        if not samefile(egg_path, destination):
+            if os.path.isdir(destination) and not os.path.islink(destination):
+                dir_util.remove_tree(destination, dry_run=self.dry_run)
+            elif os.path.exists(destination):
+                self.execute(
+                    os.unlink,
+                    (destination,),
+                    "Removing " + destination,
+                )
+            try:
+                new_dist_is_zipped = False
+                if os.path.isdir(egg_path):
+                    if egg_path.startswith(tmpdir):
+                        f, m = shutil.move, "Moving"
+                    else:
+                        f, m = shutil.copytree, "Copying"
+                elif self.should_unzip(dist):
+                    self.mkpath(destination)
+                    f, m = self.unpack_and_compile, "Extracting"
+                else:
+                    new_dist_is_zipped = True
+                    if egg_path.startswith(tmpdir):
+                        f, m = shutil.move, "Moving"
+                    else:
+                        f, m = shutil.copy2, "Copying"
+                self.execute(
+                    f,
+                    (egg_path, destination),
+                    (m + " %s to %s") % (
+                        os.path.basename(egg_path),
+                        os.path.dirname(destination)
+                    ),
+                )
+                update_dist_caches(
+                    destination,
+                    fix_zipimporter_caches=new_dist_is_zipped,
+                )
+            except Exception:
+                update_dist_caches(destination, fix_zipimporter_caches=False)
+                raise
+
+        self.add_output(destination)
+        return self.egg_distribution(destination)
+
+    def install_exe(self, dist_filename, tmpdir):
+        # See if it's valid, get data
+        cfg = extract_wininst_cfg(dist_filename)
+        if cfg is None:
+            raise DistutilsError(
+                "%s is not a valid distutils Windows .exe" % dist_filename
+            )
+        # Create a dummy distribution object until we build the real distro
+        dist = Distribution(
+            None,
+            project_name=cfg.get('metadata', 'name'),
+            version=cfg.get('metadata', 'version'), platform=get_platform(),
+        )
+
+        # Convert the .exe to an unpacked egg
+        egg_path = os.path.join(tmpdir, dist.egg_name() + '.egg')
+        dist.location = egg_path
+        egg_tmp = egg_path + '.tmp'
+        _egg_info = os.path.join(egg_tmp, 'EGG-INFO')
+        pkg_inf = os.path.join(_egg_info, 'PKG-INFO')
+        ensure_directory(pkg_inf)  # make sure EGG-INFO dir exists
+        dist._provider = PathMetadata(egg_tmp, _egg_info)  # XXX
+        self.exe_to_egg(dist_filename, egg_tmp)
+
+        # Write EGG-INFO/PKG-INFO
+        if not os.path.exists(pkg_inf):
+            f = open(pkg_inf, 'w')
+            f.write('Metadata-Version: 1.0\n')
+            for k, v in cfg.items('metadata'):
+                if k != 'target_version':
+                    f.write('%s: %s\n' % (k.replace('_', '-').title(), v))
+            f.close()
+        script_dir = os.path.join(_egg_info, 'scripts')
+        # delete entry-point scripts to avoid duping
+        self.delete_blockers([
+            os.path.join(script_dir, args[0])
+            for args in ScriptWriter.get_args(dist)
+        ])
+        # Build .egg file from tmpdir
+        bdist_egg.make_zipfile(
+            egg_path, egg_tmp, verbose=self.verbose, dry_run=self.dry_run,
+        )
+        # install the .egg
+        return self.install_egg(egg_path, tmpdir)
+
+    def exe_to_egg(self, dist_filename, egg_tmp):
+        """Extract a bdist_wininst to the directories an egg would use"""
+        # Check for .pth file and set up prefix translations
+        prefixes = get_exe_prefixes(dist_filename)
+        to_compile = []
+        native_libs = []
+        top_level = {}
+
+        def process(src, dst):
+            s = src.lower()
+            for old, new in prefixes:
+                if s.startswith(old):
+                    src = new + src[len(old):]
+                    parts = src.split('/')
+                    dst = os.path.join(egg_tmp, *parts)
+                    dl = dst.lower()
+                    if dl.endswith('.pyd') or dl.endswith('.dll'):
+                        parts[-1] = bdist_egg.strip_module(parts[-1])
+                        top_level[os.path.splitext(parts[0])[0]] = 1
+                        native_libs.append(src)
+                    elif dl.endswith('.py') and old != 'SCRIPTS/':
+                        top_level[os.path.splitext(parts[0])[0]] = 1
+                        to_compile.append(dst)
+                    return dst
+            if not src.endswith('.pth'):
+                log.warn("WARNING: can't process %s", src)
+            return None
+
+        # extract, tracking .pyd/.dll->native_libs and .py -> to_compile
+        unpack_archive(dist_filename, egg_tmp, process)
+        stubs = []
+        for res in native_libs:
+            if res.lower().endswith('.pyd'):  # create stubs for .pyd's
+                parts = res.split('/')
+                resource = parts[-1]
+                parts[-1] = bdist_egg.strip_module(parts[-1]) + '.py'
+                pyfile = os.path.join(egg_tmp, *parts)
+                to_compile.append(pyfile)
+                stubs.append(pyfile)
+                bdist_egg.write_stub(resource, pyfile)
+        self.byte_compile(to_compile)  # compile .py's
+        bdist_egg.write_safety_flag(
+            os.path.join(egg_tmp, 'EGG-INFO'),
+            bdist_egg.analyze_egg(egg_tmp, stubs))  # write zip-safety flag
+
+        for name in 'top_level', 'native_libs':
+            if locals()[name]:
+                txt = os.path.join(egg_tmp, 'EGG-INFO', name + '.txt')
+                if not os.path.exists(txt):
+                    f = open(txt, 'w')
+                    f.write('\n'.join(locals()[name]) + '\n')
+                    f.close()
+
+    def install_wheel(self, wheel_path, tmpdir):
+        wheel = Wheel(wheel_path)
+        assert wheel.is_compatible()
+        destination = os.path.join(self.install_dir, wheel.egg_name())
+        destination = os.path.abspath(destination)
+        if not self.dry_run:
+            ensure_directory(destination)
+        if os.path.isdir(destination) and not os.path.islink(destination):
+            dir_util.remove_tree(destination, dry_run=self.dry_run)
+        elif os.path.exists(destination):
+            self.execute(
+                os.unlink,
+                (destination,),
+                "Removing " + destination,
+            )
+        try:
+            self.execute(
+                wheel.install_as_egg,
+                (destination,),
+                ("Installing %s to %s") % (
+                    os.path.basename(wheel_path),
+                    os.path.dirname(destination)
+                ),
+            )
+        finally:
+            update_dist_caches(destination, fix_zipimporter_caches=False)
+        self.add_output(destination)
+        return self.egg_distribution(destination)
+
+    __mv_warning = textwrap.dedent("""
+        Because this distribution was installed --multi-version, before you can
+        import modules from this package in an application, you will need to
+        'import pkg_resources' and then use a 'require()' call similar to one of
+        these examples, in order to select the desired version:
+
+            pkg_resources.require("%(name)s")  # latest installed version
+            pkg_resources.require("%(name)s==%(version)s")  # this exact version
+            pkg_resources.require("%(name)s>=%(version)s")  # this version or higher
+        """).lstrip()
+
+    __id_warning = textwrap.dedent("""
+        Note also that the installation directory must be on sys.path at runtime for
+        this to work.  (e.g. by being the application's script directory, by being on
+        PYTHONPATH, or by being added to sys.path by your code.)
+        """)
+
+    def installation_report(self, req, dist, what="Installed"):
+        """Helpful installation message for display to package users"""
+        msg = "\n%(what)s %(eggloc)s%(extras)s"
+        if self.multi_version and not self.no_report:
+            msg += '\n' + self.__mv_warning
+            if self.install_dir not in map(normalize_path, sys.path):
+                msg += '\n' + self.__id_warning
+
+        eggloc = dist.location
+        name = dist.project_name
+        version = dist.version
+        extras = ''  # TODO: self.report_extras(req, dist)
+        return msg % locals()
+
+    __editable_msg = textwrap.dedent("""
+        Extracted editable version of %(spec)s to %(dirname)s
+
+        If it uses setuptools in its setup script, you can activate it in
+        "development" mode by going to that directory and running::
+
+            %(python)s setup.py develop
+
+        See the setuptools documentation for the "develop" command for more info.
+        """).lstrip()
+
+    def report_editable(self, spec, setup_script):
+        dirname = os.path.dirname(setup_script)
+        python = sys.executable
+        return '\n' + self.__editable_msg % locals()
+
+    def run_setup(self, setup_script, setup_base, args):
+        sys.modules.setdefault('distutils.command.bdist_egg', bdist_egg)
+        sys.modules.setdefault('distutils.command.egg_info', egg_info)
+
+        args = list(args)
+        if self.verbose > 2:
+            v = 'v' * (self.verbose - 1)
+            args.insert(0, '-' + v)
+        elif self.verbose < 2:
+            args.insert(0, '-q')
+        if self.dry_run:
+            args.insert(0, '-n')
+        log.info(
+            "Running %s %s", setup_script[len(setup_base) + 1:], ' '.join(args)
+        )
+        try:
+            run_setup(setup_script, args)
+        except SystemExit as v:
+            raise DistutilsError("Setup script exited with %s" % (v.args[0],))
+
+    def build_and_install(self, setup_script, setup_base):
+        args = ['bdist_egg', '--dist-dir']
+
+        dist_dir = tempfile.mkdtemp(
+            prefix='egg-dist-tmp-', dir=os.path.dirname(setup_script)
+        )
+        try:
+            self._set_fetcher_options(os.path.dirname(setup_script))
+            args.append(dist_dir)
+
+            self.run_setup(setup_script, setup_base, args)
+            all_eggs = Environment([dist_dir])
+            eggs = []
+            for key in all_eggs:
+                for dist in all_eggs[key]:
+                    eggs.append(self.install_egg(dist.location, setup_base))
+            if not eggs and not self.dry_run:
+                log.warn("No eggs found in %s (setup script problem?)",
+                         dist_dir)
+            return eggs
+        finally:
+            rmtree(dist_dir)
+            log.set_verbosity(self.verbose)  # restore our log verbosity
+
+    def _set_fetcher_options(self, base):
+        """
+        When easy_install is about to run bdist_egg on a source dist, that
+        source dist might have 'setup_requires' directives, requiring
+        additional fetching. Ensure the fetcher options given to easy_install
+        are available to that command as well.
+        """
+        # find the fetch options from easy_install and write them out
+        # to the setup.cfg file.
+        ei_opts = self.distribution.get_option_dict('easy_install').copy()
+        fetch_directives = (
+            'find_links', 'site_dirs', 'index_url', 'optimize',
+            'site_dirs', 'allow_hosts',
+        )
+        fetch_options = {}
+        for key, val in ei_opts.items():
+            if key not in fetch_directives:
+                continue
+            fetch_options[key.replace('_', '-')] = val[1]
+        # create a settings dictionary suitable for `edit_config`
+        settings = dict(easy_install=fetch_options)
+        cfg_filename = os.path.join(base, 'setup.cfg')
+        setopt.edit_config(cfg_filename, settings)
+
+    def update_pth(self, dist):
+        if self.pth_file is None:
+            return
+
+        for d in self.pth_file[dist.key]:  # drop old entries
+            if self.multi_version or d.location != dist.location:
+                log.info("Removing %s from easy-install.pth file", d)
+                self.pth_file.remove(d)
+                if d.location in self.shadow_path:
+                    self.shadow_path.remove(d.location)
+
+        if not self.multi_version:
+            if dist.location in self.pth_file.paths:
+                log.info(
+                    "%s is already the active version in easy-install.pth",
+                    dist,
+                )
+            else:
+                log.info("Adding %s to easy-install.pth file", dist)
+                self.pth_file.add(dist)  # add new entry
+                if dist.location not in self.shadow_path:
+                    self.shadow_path.append(dist.location)
+
+        if not self.dry_run:
+
+            self.pth_file.save()
+
+            if dist.key == 'setuptools':
+                # Ensure that setuptools itself never becomes unavailable!
+                # XXX should this check for latest version?
+                filename = os.path.join(self.install_dir, 'setuptools.pth')
+                if os.path.islink(filename):
+                    os.unlink(filename)
+                f = open(filename, 'wt')
+                f.write(self.pth_file.make_relative(dist.location) + '\n')
+                f.close()
+
+    def unpack_progress(self, src, dst):
+        # Progress filter for unpacking
+        log.debug("Unpacking %s to %s", src, dst)
+        return dst  # only unpack-and-compile skips files for dry run
+
+    def unpack_and_compile(self, egg_path, destination):
+        to_compile = []
+        to_chmod = []
+
+        def pf(src, dst):
+            if dst.endswith('.py') and not src.startswith('EGG-INFO/'):
+                to_compile.append(dst)
+            elif dst.endswith('.dll') or dst.endswith('.so'):
+                to_chmod.append(dst)
+            self.unpack_progress(src, dst)
+            return not self.dry_run and dst or None
+
+        unpack_archive(egg_path, destination, pf)
+        self.byte_compile(to_compile)
+        if not self.dry_run:
+            for f in to_chmod:
+                mode = ((os.stat(f)[stat.ST_MODE]) | 0o555) & 0o7755
+                chmod(f, mode)
+
+    def byte_compile(self, to_compile):
+        if sys.dont_write_bytecode:
+            return
+
+        from distutils.util import byte_compile
+
+        try:
+            # try to make the byte compile messages quieter
+            log.set_verbosity(self.verbose - 1)
+
+            byte_compile(to_compile, optimize=0, force=1, dry_run=self.dry_run)
+            if self.optimize:
+                byte_compile(
+                    to_compile, optimize=self.optimize, force=1,
+                    dry_run=self.dry_run,
+                )
+        finally:
+            log.set_verbosity(self.verbose)  # restore original verbosity
+
+    __no_default_msg = textwrap.dedent("""
+        bad install directory or PYTHONPATH
+
+        You are attempting to install a package to a directory that is not
+        on PYTHONPATH and which Python does not read ".pth" files from.  The
+        installation directory you specified (via --install-dir, --prefix, or
+        the distutils default setting) was:
+
+            %s
+
+        and your PYTHONPATH environment variable currently contains:
+
+            %r
+
+        Here are some of your options for correcting the problem:
+
+        * You can choose a different installation directory, i.e., one that is
+          on PYTHONPATH or supports .pth files
+
+        * You can add the installation directory to the PYTHONPATH environment
+          variable.  (It must then also be on PYTHONPATH whenever you run
+          Python and want to use the package(s) you are installing.)
+
+        * You can set up the installation directory to support ".pth" files by
+          using one of the approaches described here:
+
+          https://setuptools.readthedocs.io/en/latest/easy_install.html#custom-installation-locations
+
+
+        Please make the appropriate changes for your system and try again.""").lstrip()
+
+    def no_default_version_msg(self):
+        template = self.__no_default_msg
+        return template % (self.install_dir, os.environ.get('PYTHONPATH', ''))
+
+    def install_site_py(self):
+        """Make sure there's a site.py in the target dir, if needed"""
+
+        if self.sitepy_installed:
+            return  # already did it, or don't need to
+
+        sitepy = os.path.join(self.install_dir, "site.py")
+        source = resource_string("setuptools", "site-patch.py")
+        source = source.decode('utf-8')
+        current = ""
+
+        if os.path.exists(sitepy):
+            log.debug("Checking existing site.py in %s", self.install_dir)
+            with io.open(sitepy) as strm:
+                current = strm.read()
+
+            if not current.startswith('def __boot():'):
+                raise DistutilsError(
+                    "%s is not a setuptools-generated site.py; please"
+                    " remove it." % sitepy
+                )
+
+        if current != source:
+            log.info("Creating %s", sitepy)
+            if not self.dry_run:
+                ensure_directory(sitepy)
+                with io.open(sitepy, 'w', encoding='utf-8') as strm:
+                    strm.write(source)
+            self.byte_compile([sitepy])
+
+        self.sitepy_installed = True
+
+    def create_home_path(self):
+        """Create directories under ~."""
+        if not self.user:
+            return
+        home = convert_path(os.path.expanduser("~"))
+        for name, path in six.iteritems(self.config_vars):
+            if path.startswith(home) and not os.path.isdir(path):
+                self.debug_print("os.makedirs('%s', 0o700)" % path)
+                os.makedirs(path, 0o700)
+
+    INSTALL_SCHEMES = dict(
+        posix=dict(
+            install_dir='$base/lib/python$py_version_short/site-packages',
+            script_dir='$base/bin',
+        ),
+    )
+
+    DEFAULT_SCHEME = dict(
+        install_dir='$base/Lib/site-packages',
+        script_dir='$base/Scripts',
+    )
+
+    def _expand(self, *attrs):
+        config_vars = self.get_finalized_command('install').config_vars
+
+        if self.prefix:
+            # Set default install_dir/scripts from --prefix
+            config_vars = config_vars.copy()
+            config_vars['base'] = self.prefix
+            scheme = self.INSTALL_SCHEMES.get(os.name, self.DEFAULT_SCHEME)
+            for attr, val in scheme.items():
+                if getattr(self, attr, None) is None:
+                    setattr(self, attr, val)
+
+        from distutils.util import subst_vars
+
+        for attr in attrs:
+            val = getattr(self, attr)
+            if val is not None:
+                val = subst_vars(val, config_vars)
+                if os.name == 'posix':
+                    val = os.path.expanduser(val)
+                setattr(self, attr, val)
+
+
+def _pythonpath():
+    items = os.environ.get('PYTHONPATH', '').split(os.pathsep)
+    return filter(None, items)
+
+
+def get_site_dirs():
+    """
+    Return a list of 'site' dirs
+    """
+
+    sitedirs = []
+
+    # start with PYTHONPATH
+    sitedirs.extend(_pythonpath())
+
+    prefixes = [sys.prefix]
+    if sys.exec_prefix != sys.prefix:
+        prefixes.append(sys.exec_prefix)
+    for prefix in prefixes:
+        if prefix:
+            if sys.platform in ('os2emx', 'riscos'):
+                sitedirs.append(os.path.join(prefix, "Lib", "site-packages"))
+            elif os.sep == '/':
+                sitedirs.extend([
+                    os.path.join(
+                        prefix,
+                        "lib",
+                        "python" + sys.version[:3],
+                        "site-packages",
+                    ),
+                    os.path.join(prefix, "lib", "site-python"),
+                ])
+            else:
+                sitedirs.extend([
+                    prefix,
+                    os.path.join(prefix, "lib", "site-packages"),
+                ])
+            if sys.platform == 'darwin':
+                # for framework builds *only* we add the standard Apple
+                # locations. Currently only per-user, but /Library and
+                # /Network/Library could be added too
+                if 'Python.framework' in prefix:
+                    home = os.environ.get('HOME')
+                    if home:
+                        home_sp = os.path.join(
+                            home,
+                            'Library',
+                            'Python',
+                            sys.version[:3],
+                            'site-packages',
+                        )
+                        sitedirs.append(home_sp)
+    lib_paths = get_path('purelib'), get_path('platlib')
+    for site_lib in lib_paths:
+        if site_lib not in sitedirs:
+            sitedirs.append(site_lib)
+
+    if site.ENABLE_USER_SITE:
+        sitedirs.append(site.USER_SITE)
+
+    try:
+        sitedirs.extend(site.getsitepackages())
+    except AttributeError:
+        pass
+
+    sitedirs = list(map(normalize_path, sitedirs))
+
+    return sitedirs
+
+
+def expand_paths(inputs):
+    """Yield sys.path directories that might contain "old-style" packages"""
+
+    seen = {}
+
+    for dirname in inputs:
+        dirname = normalize_path(dirname)
+        if dirname in seen:
+            continue
+
+        seen[dirname] = 1
+        if not os.path.isdir(dirname):
+            continue
+
+        files = os.listdir(dirname)
+        yield dirname, files
+
+        for name in files:
+            if not name.endswith('.pth'):
+                # We only care about the .pth files
+                continue
+            if name in ('easy-install.pth', 'setuptools.pth'):
+                # Ignore .pth files that we control
+                continue
+
+            # Read the .pth file
+            f = open(os.path.join(dirname, name))
+            lines = list(yield_lines(f))
+            f.close()
+
+            # Yield existing non-dupe, non-import directory lines from it
+            for line in lines:
+                if not line.startswith("import"):
+                    line = normalize_path(line.rstrip())
+                    if line not in seen:
+                        seen[line] = 1
+                        if not os.path.isdir(line):
+                            continue
+                        yield line, os.listdir(line)
+
+
+def extract_wininst_cfg(dist_filename):
+    """Extract configuration data from a bdist_wininst .exe
+
+    Returns a configparser.RawConfigParser, or None
+    """
+    f = open(dist_filename, 'rb')
+    try:
+        endrec = zipfile._EndRecData(f)
+        if endrec is None:
+            return None
+
+        prepended = (endrec[9] - endrec[5]) - endrec[6]
+        if prepended < 12:  # no wininst data here
+            return None
+        f.seek(prepended - 12)
+
+        tag, cfglen, bmlen = struct.unpack("<iii", f.read(12))
+        if tag not in (0x1234567A, 0x1234567B):
+            return None  # not a valid tag
+
+        f.seek(prepended - (12 + cfglen))
+        init = {'version': '', 'target_version': ''}
+        cfg = configparser.RawConfigParser(init)
+        try:
+            part = f.read(cfglen)
+            # Read up to the first null byte.
+            config = part.split(b'\0', 1)[0]
+            # Now the config is in bytes, but for RawConfigParser, it should
+            #  be text, so decode it.
+            config = config.decode(sys.getfilesystemencoding())
+            cfg.readfp(six.StringIO(config))
+        except configparser.Error:
+            return None
+        if not cfg.has_section('metadata') or not cfg.has_section('Setup'):
+            return None
+        return cfg
+
+    finally:
+        f.close()
+
+
+def get_exe_prefixes(exe_filename):
+    """Get exe->egg path translations for a given .exe file"""
+
+    prefixes = [
+        ('PURELIB/', ''),
+        ('PLATLIB/pywin32_system32', ''),
+        ('PLATLIB/', ''),
+        ('SCRIPTS/', 'EGG-INFO/scripts/'),
+        ('DATA/lib/site-packages', ''),
+    ]
+    z = zipfile.ZipFile(exe_filename)
+    try:
+        for info in z.infolist():
+            name = info.filename
+            parts = name.split('/')
+            if len(parts) == 3 and parts[2] == 'PKG-INFO':
+                if parts[1].endswith('.egg-info'):
+                    prefixes.insert(0, ('/'.join(parts[:2]), 'EGG-INFO/'))
+                    break
+            if len(parts) != 2 or not name.endswith('.pth'):
+                continue
+            if name.endswith('-nspkg.pth'):
+                continue
+            if parts[0].upper() in ('PURELIB', 'PLATLIB'):
+                contents = z.read(name)
+                if six.PY3:
+                    contents = contents.decode()
+                for pth in yield_lines(contents):
+                    pth = pth.strip().replace('\\', '/')
+                    if not pth.startswith('import'):
+                        prefixes.append((('%s/%s/' % (parts[0], pth)), ''))
+    finally:
+        z.close()
+    prefixes = [(x.lower(), y) for x, y in prefixes]
+    prefixes.sort()
+    prefixes.reverse()
+    return prefixes
+
+
+class PthDistributions(Environment):
+    """A .pth file with Distribution paths in it"""
+
+    dirty = False
+
+    def __init__(self, filename, sitedirs=()):
+        self.filename = filename
+        self.sitedirs = list(map(normalize_path, sitedirs))
+        self.basedir = normalize_path(os.path.dirname(self.filename))
+        self._load()
+        Environment.__init__(self, [], None, None)
+        for path in yield_lines(self.paths):
+            list(map(self.add, find_distributions(path, True)))
+
+    def _load(self):
+        self.paths = []
+        saw_import = False
+        seen = dict.fromkeys(self.sitedirs)
+        if os.path.isfile(self.filename):
+            f = open(self.filename, 'rt')
+            for line in f:
+                if line.startswith('import'):
+                    saw_import = True
+                    continue
+                path = line.rstrip()
+                self.paths.append(path)
+                if not path.strip() or path.strip().startswith('#'):
+                    continue
+                # skip non-existent paths, in case somebody deleted a package
+                # manually, and duplicate paths as well
+                path = self.paths[-1] = normalize_path(
+                    os.path.join(self.basedir, path)
+                )
+                if not os.path.exists(path) or path in seen:
+                    self.paths.pop()  # skip it
+                    self.dirty = True  # we cleaned up, so we're dirty now :)
+                    continue
+                seen[path] = 1
+            f.close()
+
+        if self.paths and not saw_import:
+            self.dirty = True  # ensure anything we touch has import wrappers
+        while self.paths and not self.paths[-1].strip():
+            self.paths.pop()
+
+    def save(self):
+        """Write changed .pth file back to disk"""
+        if not self.dirty:
+            return
+
+        rel_paths = list(map(self.make_relative, self.paths))
+        if rel_paths:
+            log.debug("Saving %s", self.filename)
+            lines = self._wrap_lines(rel_paths)
+            data = '\n'.join(lines) + '\n'
+
+            if os.path.islink(self.filename):
+                os.unlink(self.filename)
+            with open(self.filename, 'wt') as f:
+                f.write(data)
+
+        elif os.path.exists(self.filename):
+            log.debug("Deleting empty %s", self.filename)
+            os.unlink(self.filename)
+
+        self.dirty = False
+
+    @staticmethod
+    def _wrap_lines(lines):
+        return lines
+
+    def add(self, dist):
+        """Add `dist` to the distribution map"""
+        new_path = (
+            dist.location not in self.paths and (
+                dist.location not in self.sitedirs or
+                # account for '.' being in PYTHONPATH
+                dist.location == os.getcwd()
+            )
+        )
+        if new_path:
+            self.paths.append(dist.location)
+            self.dirty = True
+        Environment.add(self, dist)
+
+    def remove(self, dist):
+        """Remove `dist` from the distribution map"""
+        while dist.location in self.paths:
+            self.paths.remove(dist.location)
+            self.dirty = True
+        Environment.remove(self, dist)
+
+    def make_relative(self, path):
+        npath, last = os.path.split(normalize_path(path))
+        baselen = len(self.basedir)
+        parts = [last]
+        sep = os.altsep == '/' and '/' or os.sep
+        while len(npath) >= baselen:
+            if npath == self.basedir:
+                parts.append(os.curdir)
+                parts.reverse()
+                return sep.join(parts)
+            npath, last = os.path.split(npath)
+            parts.append(last)
+        else:
+            return path
+
+
+class RewritePthDistributions(PthDistributions):
+    @classmethod
+    def _wrap_lines(cls, lines):
+        yield cls.prelude
+        for line in lines:
+            yield line
+        yield cls.postlude
+
+    prelude = _one_liner("""
+        import sys
+        sys.__plen = len(sys.path)
+        """)
+    postlude = _one_liner("""
+        import sys
+        new = sys.path[sys.__plen:]
+        del sys.path[sys.__plen:]
+        p = getattr(sys, '__egginsert', 0)
+        sys.path[p:p] = new
+        sys.__egginsert = p + len(new)
+        """)
+
+
+if os.environ.get('SETUPTOOLS_SYS_PATH_TECHNIQUE', 'raw') == 'rewrite':
+    PthDistributions = RewritePthDistributions
+
+
+def _first_line_re():
+    """
+    Return a regular expression based on first_line_re suitable for matching
+    strings.
+    """
+    if isinstance(first_line_re.pattern, str):
+        return first_line_re
+
+    # first_line_re in Python >=3.1.4 and >=3.2.1 is a bytes pattern.
+    return re.compile(first_line_re.pattern.decode())
+
+
+def auto_chmod(func, arg, exc):
+    if func in [os.unlink, os.remove] and os.name == 'nt':
+        chmod(arg, stat.S_IWRITE)
+        return func(arg)
+    et, ev, _ = sys.exc_info()
+    six.reraise(et, (ev[0], ev[1] + (" %s %s" % (func, arg))))
+
+
+def update_dist_caches(dist_path, fix_zipimporter_caches):
+    """
+    Fix any globally cached `dist_path` related data
+
+    `dist_path` should be a path of a newly installed egg distribution (zipped
+    or unzipped).
+
+    sys.path_importer_cache contains finder objects that have been cached when
+    importing data from the original distribution. Any such finders need to be
+    cleared since the replacement distribution might be packaged differently,
+    e.g. a zipped egg distribution might get replaced with an unzipped egg
+    folder or vice versa. Having the old finders cached may then cause Python
+    to attempt loading modules from the replacement distribution using an
+    incorrect loader.
+
+    zipimport.zipimporter objects are Python loaders charged with importing
+    data packaged inside zip archives. If stale loaders referencing the
+    original distribution, are left behind, they can fail to load modules from
+    the replacement distribution. E.g. if an old zipimport.zipimporter instance
+    is used to load data from a new zipped egg archive, it may cause the
+    operation to attempt to locate the requested data in the wrong location -
+    one indicated by the original distribution's zip archive directory
+    information. Such an operation may then fail outright, e.g. report having
+    read a 'bad local file header', or even worse, it may fail silently &
+    return invalid data.
+
+    zipimport._zip_directory_cache contains cached zip archive directory
+    information for all existing zipimport.zipimporter instances and all such
+    instances connected to the same archive share the same cached directory
+    information.
+
+    If asked, and the underlying Python implementation allows it, we can fix
+    all existing zipimport.zipimporter instances instead of having to track
+    them down and remove them one by one, by updating their shared cached zip
+    archive directory information. This, of course, assumes that the
+    replacement distribution is packaged as a zipped egg.
+
+    If not asked to fix existing zipimport.zipimporter instances, we still do
+    our best to clear any remaining zipimport.zipimporter related cached data
+    that might somehow later get used when attempting to load data from the new
+    distribution and thus cause such load operations to fail. Note that when
+    tracking down such remaining stale data, we can not catch every conceivable
+    usage from here, and we clear only those that we know of and have found to
+    cause problems if left alive. Any remaining caches should be updated by
+    whomever is in charge of maintaining them, i.e. they should be ready to
+    handle us replacing their zip archives with new distributions at runtime.
+
+    """
+    # There are several other known sources of stale zipimport.zipimporter
+    # instances that we do not clear here, but might if ever given a reason to
+    # do so:
+    # * Global setuptools pkg_resources.working_set (a.k.a. 'master working
+    # set') may contain distributions which may in turn contain their
+    #   zipimport.zipimporter loaders.
+    # * Several zipimport.zipimporter loaders held by local variables further
+    #   up the function call stack when running the setuptools installation.
+    # * Already loaded modules may have their __loader__ attribute set to the
+    #   exact loader instance used when importing them. Python 3.4 docs state
+    #   that this information is intended mostly for introspection and so is
+    #   not expected to cause us problems.
+    normalized_path = normalize_path(dist_path)
+    _uncache(normalized_path, sys.path_importer_cache)
+    if fix_zipimporter_caches:
+        _replace_zip_directory_cache_data(normalized_path)
+    else:
+        # Here, even though we do not want to fix existing and now stale
+        # zipimporter cache information, we still want to remove it. Related to
+        # Python's zip archive directory information cache, we clear each of
+        # its stale entries in two phases:
+        #   1. Clear the entry so attempting to access zip archive information
+        #      via any existing stale zipimport.zipimporter instances fails.
+        #   2. Remove the entry from the cache so any newly constructed
+        #      zipimport.zipimporter instances do not end up using old stale
+        #      zip archive directory information.
+        # This whole stale data removal step does not seem strictly necessary,
+        # but has been left in because it was done before we started replacing
+        # the zip archive directory information cache content if possible, and
+        # there are no relevant unit tests that we can depend on to tell us if
+        # this is really needed.
+        _remove_and_clear_zip_directory_cache_data(normalized_path)
+
+
+def _collect_zipimporter_cache_entries(normalized_path, cache):
+    """
+    Return zipimporter cache entry keys related to a given normalized path.
+
+    Alternative path spellings (e.g. those using different character case or
+    those using alternative path separators) related to the same path are
+    included. Any sub-path entries are included as well, i.e. those
+    corresponding to zip archives embedded in other zip archives.
+
+    """
+    result = []
+    prefix_len = len(normalized_path)
+    for p in cache:
+        np = normalize_path(p)
+        if (np.startswith(normalized_path) and
+                np[prefix_len:prefix_len + 1] in (os.sep, '')):
+            result.append(p)
+    return result
+
+
+def _update_zipimporter_cache(normalized_path, cache, updater=None):
+    """
+    Update zipimporter cache data for a given normalized path.
+
+    Any sub-path entries are processed as well, i.e. those corresponding to zip
+    archives embedded in other zip archives.
+
+    Given updater is a callable taking a cache entry key and the original entry
+    (after already removing the entry from the cache), and expected to update
+    the entry and possibly return a new one to be inserted in its place.
+    Returning None indicates that the entry should not be replaced with a new
+    one. If no updater is given, the cache entries are simply removed without
+    any additional processing, the same as if the updater simply returned None.
+
+    """
+    for p in _collect_zipimporter_cache_entries(normalized_path, cache):
+        # N.B. pypy's custom zipimport._zip_directory_cache implementation does
+        # not support the complete dict interface:
+        # * Does not support item assignment, thus not allowing this function
+        #    to be used only for removing existing cache entries.
+        #  * Does not support the dict.pop() method, forcing us to use the
+        #    get/del patterns instead. For more detailed information see the
+        #    following links:
+        #      https://github.com/pypa/setuptools/issues/202#issuecomment-202913420
+        #      http://bit.ly/2h9itJX
+        old_entry = cache[p]
+        del cache[p]
+        new_entry = updater and updater(p, old_entry)
+        if new_entry is not None:
+            cache[p] = new_entry
+
+
+def _uncache(normalized_path, cache):
+    _update_zipimporter_cache(normalized_path, cache)
+
+
+def _remove_and_clear_zip_directory_cache_data(normalized_path):
+    def clear_and_remove_cached_zip_archive_directory_data(path, old_entry):
+        old_entry.clear()
+
+    _update_zipimporter_cache(
+        normalized_path, zipimport._zip_directory_cache,
+        updater=clear_and_remove_cached_zip_archive_directory_data)
+
+
+# PyPy Python implementation does not allow directly writing to the
+# zipimport._zip_directory_cache and so prevents us from attempting to correct
+# its content. The best we can do there is clear the problematic cache content
+# and have PyPy repopulate it as needed. The downside is that if there are any
+# stale zipimport.zipimporter instances laying around, attempting to use them
+# will fail due to not having its zip archive directory information available
+# instead of being automatically corrected to use the new correct zip archive
+# directory information.
+if '__pypy__' in sys.builtin_module_names:
+    _replace_zip_directory_cache_data = \
+        _remove_and_clear_zip_directory_cache_data
+else:
+
+    def _replace_zip_directory_cache_data(normalized_path):
+        def replace_cached_zip_archive_directory_data(path, old_entry):
+            # N.B. In theory, we could load the zip directory information just
+            # once for all updated path spellings, and then copy it locally and
+            # update its contained path strings to contain the correct
+            # spelling, but that seems like a way too invasive move (this cache
+            # structure is not officially documented anywhere and could in
+            # theory change with new Python releases) for no significant
+            # benefit.
+            old_entry.clear()
+            zipimport.zipimporter(path)
+            old_entry.update(zipimport._zip_directory_cache[path])
+            return old_entry
+
+        _update_zipimporter_cache(
+            normalized_path, zipimport._zip_directory_cache,
+            updater=replace_cached_zip_archive_directory_data)
+
+
+def is_python(text, filename='<string>'):
+    "Is this string a valid Python script?"
+    try:
+        compile(text, filename, 'exec')
+    except (SyntaxError, TypeError):
+        return False
+    else:
+        return True
+
+
+def is_sh(executable):
+    """Determine if the specified executable is a .sh (contains a #! line)"""
+    try:
+        with io.open(executable, encoding='latin-1') as fp:
+            magic = fp.read(2)
+    except (OSError, IOError):
+        return executable
+    return magic == '#!'
+
+
+def nt_quote_arg(arg):
+    """Quote a command line argument according to Windows parsing rules"""
+    return subprocess.list2cmdline([arg])
+
+
+def is_python_script(script_text, filename):
+    """Is this text, as a whole, a Python script? (as opposed to shell/bat/etc.
+    """
+    if filename.endswith('.py') or filename.endswith('.pyw'):
+        return True  # extension says it's Python
+    if is_python(script_text, filename):
+        return True  # it's syntactically valid Python
+    if script_text.startswith('#!'):
+        # It begins with a '#!' line, so check if 'python' is in it somewhere
+        return 'python' in script_text.splitlines()[0].lower()
+
+    return False  # Not any Python I can recognize
+
+
+try:
+    from os import chmod as _chmod
+except ImportError:
+    # Jython compatibility
+    def _chmod(*args):
+        pass
+
+
+def chmod(path, mode):
+    log.debug("changing mode of %s to %o", path, mode)
+    try:
+        _chmod(path, mode)
+    except os.error as e:
+        log.debug("chmod failed: %s", e)
+
+
+class CommandSpec(list):
+    """
+    A command spec for a #! header, specified as a list of arguments akin to
+    those passed to Popen.
+    """
+
+    options = []
+    split_args = dict()
+
+    @classmethod
+    def best(cls):
+        """
+        Choose the best CommandSpec class based on environmental conditions.
+        """
+        return cls
+
+    @classmethod
+    def _sys_executable(cls):
+        _default = os.path.normpath(sys.executable)
+        return os.environ.get('__PYVENV_LAUNCHER__', _default)
+
+    @classmethod
+    def from_param(cls, param):
+        """
+        Construct a CommandSpec from a parameter to build_scripts, which may
+        be None.
+        """
+        if isinstance(param, cls):
+            return param
+        if isinstance(param, list):
+            return cls(param)
+        if param is None:
+            return cls.from_environment()
+        # otherwise, assume it's a string.
+        return cls.from_string(param)
+
+    @classmethod
+    def from_environment(cls):
+        return cls([cls._sys_executable()])
+
+    @classmethod
+    def from_string(cls, string):
+        """
+        Construct a command spec from a simple string representing a command
+        line parseable by shlex.split.
+        """
+        items = shlex.split(string, **cls.split_args)
+        return cls(items)
+
+    def install_options(self, script_text):
+        self.options = shlex.split(self._extract_options(script_text))
+        cmdline = subprocess.list2cmdline(self)
+        if not isascii(cmdline):
+            self.options[:0] = ['-x']
+
+    @staticmethod
+    def _extract_options(orig_script):
+        """
+        Extract any options from the first line of the script.
+        """
+        first = (orig_script + '\n').splitlines()[0]
+        match = _first_line_re().match(first)
+        options = match.group(1) or '' if match else ''
+        return options.strip()
+
+    def as_header(self):
+        return self._render(self + list(self.options))
+
+    @staticmethod
+    def _strip_quotes(item):
+        _QUOTES = '"\''
+        for q in _QUOTES:
+            if item.startswith(q) and item.endswith(q):
+                return item[1:-1]
+        return item
+
+    @staticmethod
+    def _render(items):
+        cmdline = subprocess.list2cmdline(
+            CommandSpec._strip_quotes(item.strip()) for item in items)
+        return '#!' + cmdline + '\n'
+
+
+# For pbr compat; will be removed in a future version.
+sys_executable = CommandSpec._sys_executable()
+
+
+class WindowsCommandSpec(CommandSpec):
+    split_args = dict(posix=False)
+
+
+class ScriptWriter:
+    """
+    Encapsulates behavior around writing entry point scripts for console and
+    gui apps.
+    """
+
+    template = textwrap.dedent(r"""
+        # EASY-INSTALL-ENTRY-SCRIPT: %(spec)r,%(group)r,%(name)r
+        __requires__ = %(spec)r
+        import re
+        import sys
+        from pkg_resources import load_entry_point
+
+        if __name__ == '__main__':
+            sys.argv[0] = re.sub(r'(-script\.pyw?|\.exe)?$', '', sys.argv[0])
+            sys.exit(
+                load_entry_point(%(spec)r, %(group)r, %(name)r)()
+            )
+    """).lstrip()
+
+    command_spec_class = CommandSpec
+
+    @classmethod
+    def get_script_args(cls, dist, executable=None, wininst=False):
+        # for backward compatibility
+        warnings.warn("Use get_args", EasyInstallDeprecationWarning)
+        writer = (WindowsScriptWriter if wininst else ScriptWriter).best()
+        header = cls.get_script_header("", executable, wininst)
+        return writer.get_args(dist, header)
+
+    @classmethod
+    def get_script_header(cls, script_text, executable=None, wininst=False):
+        # for backward compatibility
+        warnings.warn("Use get_header", EasyInstallDeprecationWarning, stacklevel=2)
+        if wininst:
+            executable = "python.exe"
+        return cls.get_header(script_text, executable)
+
+    @classmethod
+    def get_args(cls, dist, header=None):
+        """
+        Yield write_script() argument tuples for a distribution's
+        console_scripts and gui_scripts entry points.
+        """
+        if header is None:
+            header = cls.get_header()
+        spec = str(dist.as_requirement())
+        for type_ in 'console', 'gui':
+            group = type_ + '_scripts'
+            for name, ep in dist.get_entry_map(group).items():
+                cls._ensure_safe_name(name)
+                script_text = cls.template % locals()
+                args = cls._get_script_args(type_, name, header, script_text)
+                for res in args:
+                    yield res
+
+    @staticmethod
+    def _ensure_safe_name(name):
+        """
+        Prevent paths in *_scripts entry point names.
+        """
+        has_path_sep = re.search(r'[\\/]', name)
+        if has_path_sep:
+            raise ValueError("Path separators not allowed in script names")
+
+    @classmethod
+    def get_writer(cls, force_windows):
+        # for backward compatibility
+        warnings.warn("Use best", EasyInstallDeprecationWarning)
+        return WindowsScriptWriter.best() if force_windows else cls.best()
+
+    @classmethod
+    def best(cls):
+        """
+        Select the best ScriptWriter for this environment.
+        """
+        if sys.platform == 'win32' or (os.name == 'java' and os._name == 'nt'):
+            return WindowsScriptWriter.best()
+        else:
+            return cls
+
+    @classmethod
+    def _get_script_args(cls, type_, name, header, script_text):
+        # Simply write the stub with no extension.
+        yield (name, header + script_text)
+
+    @classmethod
+    def get_header(cls, script_text="", executable=None):
+        """Create a #! line, getting options (if any) from script_text"""
+        cmd = cls.command_spec_class.best().from_param(executable)
+        cmd.install_options(script_text)
+        return cmd.as_header()
+
+
+class WindowsScriptWriter(ScriptWriter):
+    command_spec_class = WindowsCommandSpec
+
+    @classmethod
+    def get_writer(cls):
+        # for backward compatibility
+        warnings.warn("Use best", EasyInstallDeprecationWarning)
+        return cls.best()
+
+    @classmethod
+    def best(cls):
+        """
+        Select the best ScriptWriter suitable for Windows
+        """
+        writer_lookup = dict(
+            executable=WindowsExecutableLauncherWriter,
+            natural=cls,
+        )
+        # for compatibility, use the executable launcher by default
+        launcher = os.environ.get('SETUPTOOLS_LAUNCHER', 'executable')
+        return writer_lookup[launcher]
+
+    @classmethod
+    def _get_script_args(cls, type_, name, header, script_text):
+        "For Windows, add a .py extension"
+        ext = dict(console='.pya', gui='.pyw')[type_]
+        if ext not in os.environ['PATHEXT'].lower().split(';'):
+            msg = (
+                "{ext} not listed in PATHEXT; scripts will not be "
+                "recognized as executables."
+            ).format(**locals())
+            warnings.warn(msg, UserWarning)
+        old = ['.pya', '.py', '-script.py', '.pyc', '.pyo', '.pyw', '.exe']
+        old.remove(ext)
+        header = cls._adjust_header(type_, header)
+        blockers = [name + x for x in old]
+        yield name + ext, header + script_text, 't', blockers
+
+    @classmethod
+    def _adjust_header(cls, type_, orig_header):
+        """
+        Make sure 'pythonw' is used for gui and and 'python' is used for
+        console (regardless of what sys.executable is).
+        """
+        pattern = 'pythonw.exe'
+        repl = 'python.exe'
+        if type_ == 'gui':
+            pattern, repl = repl, pattern
+        pattern_ob = re.compile(re.escape(pattern), re.IGNORECASE)
+        new_header = pattern_ob.sub(string=orig_header, repl=repl)
+        return new_header if cls._use_header(new_header) else orig_header
+
+    @staticmethod
+    def _use_header(new_header):
+        """
+        Should _adjust_header use the replaced header?
+
+        On non-windows systems, always use. On
+        Windows systems, only use the replaced header if it resolves
+        to an executable on the system.
+        """
+        clean_header = new_header[2:-1].strip('"')
+        return sys.platform != 'win32' or find_executable(clean_header)
+
+
+class WindowsExecutableLauncherWriter(WindowsScriptWriter):
+    @classmethod
+    def _get_script_args(cls, type_, name, header, script_text):
+        """
+        For Windows, add a .py extension and an .exe launcher
+        """
+        if type_ == 'gui':
+            launcher_type = 'gui'
+            ext = '-script.pyw'
+            old = ['.pyw']
+        else:
+            launcher_type = 'cli'
+            ext = '-script.py'
+            old = ['.py', '.pyc', '.pyo']
+        hdr = cls._adjust_header(type_, header)
+        blockers = [name + x for x in old]
+        yield (name + ext, hdr + script_text, 't', blockers)
+        yield (
+            name + '.exe', get_win_launcher(launcher_type),
+            'b'  # write in binary mode
+        )
+        if not is_64bit():
+            # install a manifest for the launcher to prevent Windows
+            # from detecting it as an installer (which it will for
+            #  launchers like easy_install.exe). Consider only
+            #  adding a manifest for launchers detected as installers.
+            #  See Distribute #143 for details.
+            m_name = name + '.exe.manifest'
+            yield (m_name, load_launcher_manifest(name), 't')
+
+
+# for backward-compatibility
+get_script_args = ScriptWriter.get_script_args
+get_script_header = ScriptWriter.get_script_header
+
+
+def get_win_launcher(type):
+    """
+    Load the Windows launcher (executable) suitable for launching a script.
+
+    `type` should be either 'cli' or 'gui'
+
+    Returns the executable as a byte string.
+    """
+    launcher_fn = '%s.exe' % type
+    if is_64bit():
+        launcher_fn = launcher_fn.replace(".", "-64.")
+    else:
+        launcher_fn = launcher_fn.replace(".", "-32.")
+    return resource_string('setuptools', launcher_fn)
+
+
+def load_launcher_manifest(name):
+    manifest = pkg_resources.resource_string(__name__, 'launcher manifest.xml')
+    if six.PY2:
+        return manifest % vars()
+    else:
+        return manifest.decode('utf-8') % vars()
+
+
+def rmtree(path, ignore_errors=False, onerror=auto_chmod):
+    return shutil.rmtree(path, ignore_errors, onerror)
+
+
+def current_umask():
+    tmp = os.umask(0o022)
+    os.umask(tmp)
+    return tmp
+
+
+def bootstrap():
+    # This function is called when setuptools*.egg is run using /bin/sh
+    import setuptools
+
+    argv0 = os.path.dirname(setuptools.__path__[0])
+    sys.argv[0] = argv0
+    sys.argv.append(argv0)
+    main()
+
+
+def main(argv=None, **kw):
+    from setuptools import setup
+    from setuptools.dist import Distribution
+
+    class DistributionWithoutHelpCommands(Distribution):
+        common_usage = ""
+
+        def _show_help(self, *args, **kw):
+            with _patch_usage():
+                Distribution._show_help(self, *args, **kw)
+
+    if argv is None:
+        argv = sys.argv[1:]
+
+    with _patch_usage():
+        setup(
+            script_args=['-q', 'easy_install', '-v'] + argv,
+            script_name=sys.argv[0] or 'easy_install',
+            distclass=DistributionWithoutHelpCommands,
+            **kw
+        )
+
+
+@contextlib.contextmanager
+def _patch_usage():
+    import distutils.core
+    USAGE = textwrap.dedent("""
+        usage: %(script)s [options] requirement_or_url ...
+           or: %(script)s --help
+        """).lstrip()
+
+    def gen_usage(script_name):
+        return USAGE % dict(
+            script=os.path.basename(script_name),
+        )
+
+    saved = distutils.core.gen_usage
+    distutils.core.gen_usage = gen_usage
+    try:
+        yield
+    finally:
+        distutils.core.gen_usage = saved
+
+class EasyInstallDeprecationWarning(SetuptoolsDeprecationWarning):
+    """Class for warning about deprecations in EasyInstall in SetupTools. Not ignored by default, unlike DeprecationWarning."""
+    
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/easy_install.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/easy_install.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..731682075f2543bc8daf31b3b7fbd08b1af79fab
GIT binary patch
literal 88096
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
KPA(pCArSy7@UZy+

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/egg_info.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/egg_info.py
new file mode 100644
index 0000000..5d8f451
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/egg_info.py
@@ -0,0 +1,717 @@
+"""setuptools.command.egg_info
+
+Create a distribution's .egg-info directory and contents"""
+
+from distutils.filelist import FileList as _FileList
+from distutils.errors import DistutilsInternalError
+from distutils.util import convert_path
+from distutils import log
+import distutils.errors
+import distutils.filelist
+import os
+import re
+import sys
+import io
+import warnings
+import time
+import collections
+
+from setuptools.extern import six
+from setuptools.extern.six.moves import map
+
+from setuptools import Command
+from setuptools.command.sdist import sdist
+from setuptools.command.sdist import walk_revctrl
+from setuptools.command.setopt import edit_config
+from setuptools.command import bdist_egg
+from pkg_resources import (
+    parse_requirements, safe_name, parse_version,
+    safe_version, yield_lines, EntryPoint, iter_entry_points, to_filename)
+import setuptools.unicode_utils as unicode_utils
+from setuptools.glob import glob
+
+from setuptools.extern import packaging
+from setuptools import SetuptoolsDeprecationWarning
+
+def translate_pattern(glob):
+    """
+    Translate a file path glob like '*.txt' in to a regular expression.
+    This differs from fnmatch.translate which allows wildcards to match
+    directory separators. It also knows about '**/' which matches any number of
+    directories.
+    """
+    pat = ''
+
+    # This will split on '/' within [character classes]. This is deliberate.
+    chunks = glob.split(os.path.sep)
+
+    sep = re.escape(os.sep)
+    valid_char = '[^%s]' % (sep,)
+
+    for c, chunk in enumerate(chunks):
+        last_chunk = c == len(chunks) - 1
+
+        # Chunks that are a literal ** are globstars. They match anything.
+        if chunk == '**':
+            if last_chunk:
+                # Match anything if this is the last component
+                pat += '.*'
+            else:
+                # Match '(name/)*'
+                pat += '(?:%s+%s)*' % (valid_char, sep)
+            continue  # Break here as the whole path component has been handled
+
+        # Find any special characters in the remainder
+        i = 0
+        chunk_len = len(chunk)
+        while i < chunk_len:
+            char = chunk[i]
+            if char == '*':
+                # Match any number of name characters
+                pat += valid_char + '*'
+            elif char == '?':
+                # Match a name character
+                pat += valid_char
+            elif char == '[':
+                # Character class
+                inner_i = i + 1
+                # Skip initial !/] chars
+                if inner_i < chunk_len and chunk[inner_i] == '!':
+                    inner_i = inner_i + 1
+                if inner_i < chunk_len and chunk[inner_i] == ']':
+                    inner_i = inner_i + 1
+
+                # Loop till the closing ] is found
+                while inner_i < chunk_len and chunk[inner_i] != ']':
+                    inner_i = inner_i + 1
+
+                if inner_i >= chunk_len:
+                    # Got to the end of the string without finding a closing ]
+                    # Do not treat this as a matching group, but as a literal [
+                    pat += re.escape(char)
+                else:
+                    # Grab the insides of the [brackets]
+                    inner = chunk[i + 1:inner_i]
+                    char_class = ''
+
+                    # Class negation
+                    if inner[0] == '!':
+                        char_class = '^'
+                        inner = inner[1:]
+
+                    char_class += re.escape(inner)
+                    pat += '[%s]' % (char_class,)
+
+                    # Skip to the end ]
+                    i = inner_i
+            else:
+                pat += re.escape(char)
+            i += 1
+
+        # Join each chunk with the dir separator
+        if not last_chunk:
+            pat += sep
+
+    pat += r'\Z'
+    return re.compile(pat, flags=re.MULTILINE|re.DOTALL)
+
+
+class InfoCommon:
+    tag_build = None
+    tag_date = None
+
+    @property
+    def name(self):
+        return safe_name(self.distribution.get_name())
+
+    def tagged_version(self):
+        version = self.distribution.get_version()
+        # egg_info may be called more than once for a distribution,
+        # in which case the version string already contains all tags.
+        if self.vtags and version.endswith(self.vtags):
+            return safe_version(version)
+        return safe_version(version + self.vtags)
+
+    def tags(self):
+        version = ''
+        if self.tag_build:
+            version += self.tag_build
+        if self.tag_date:
+            version += time.strftime("-%Y%m%d")
+        return version
+    vtags = property(tags)
+
+
+class egg_info(InfoCommon, Command):
+    description = "create a distribution's .egg-info directory"
+
+    user_options = [
+        ('egg-base=', 'e', "directory containing .egg-info directories"
+                           " (default: top of the source tree)"),
+        ('tag-date', 'd', "Add date stamp (e.g. 20050528) to version number"),
+        ('tag-build=', 'b', "Specify explicit tag to add to version number"),
+        ('no-date', 'D', "Don't include date stamp [default]"),
+    ]
+
+    boolean_options = ['tag-date']
+    negative_opt = {
+        'no-date': 'tag-date',
+    }
+
+    def initialize_options(self):
+        self.egg_base = None
+        self.egg_name = None
+        self.egg_info = None
+        self.egg_version = None
+        self.broken_egg_info = False
+
+    ####################################
+    # allow the 'tag_svn_revision' to be detected and
+    # set, supporting sdists built on older Setuptools.
+    @property
+    def tag_svn_revision(self):
+        pass
+
+    @tag_svn_revision.setter
+    def tag_svn_revision(self, value):
+        pass
+    ####################################
+
+    def save_version_info(self, filename):
+        """
+        Materialize the value of date into the
+        build tag. Install build keys in a deterministic order
+        to avoid arbitrary reordering on subsequent builds.
+        """
+        egg_info = collections.OrderedDict()
+        # follow the order these keys would have been added
+        # when PYTHONHASHSEED=0
+        egg_info['tag_build'] = self.tags()
+        egg_info['tag_date'] = 0
+        edit_config(filename, dict(egg_info=egg_info))
+
+    def finalize_options(self):
+        # Note: we need to capture the current value returned
+        # by `self.tagged_version()`, so we can later update
+        # `self.distribution.metadata.version` without
+        # repercussions.
+        self.egg_name = self.name
+        self.egg_version = self.tagged_version()
+        parsed_version = parse_version(self.egg_version)
+
+        try:
+            is_version = isinstance(parsed_version, packaging.version.Version)
+            spec = (
+                "%s==%s" if is_version else "%s===%s"
+            )
+            list(
+                parse_requirements(spec % (self.egg_name, self.egg_version))
+            )
+        except ValueError:
+            raise distutils.errors.DistutilsOptionError(
+                "Invalid distribution name or version syntax: %s-%s" %
+                (self.egg_name, self.egg_version)
+            )
+
+        if self.egg_base is None:
+            dirs = self.distribution.package_dir
+            self.egg_base = (dirs or {}).get('', os.curdir)
+
+        self.ensure_dirname('egg_base')
+        self.egg_info = to_filename(self.egg_name) + '.egg-info'
+        if self.egg_base != os.curdir:
+            self.egg_info = os.path.join(self.egg_base, self.egg_info)
+        if '-' in self.egg_name:
+            self.check_broken_egg_info()
+
+        # Set package version for the benefit of dumber commands
+        # (e.g. sdist, bdist_wininst, etc.)
+        #
+        self.distribution.metadata.version = self.egg_version
+
+        # If we bootstrapped around the lack of a PKG-INFO, as might be the
+        # case in a fresh checkout, make sure that any special tags get added
+        # to the version info
+        #
+        pd = self.distribution._patched_dist
+        if pd is not None and pd.key == self.egg_name.lower():
+            pd._version = self.egg_version
+            pd._parsed_version = parse_version(self.egg_version)
+            self.distribution._patched_dist = None
+
+    def write_or_delete_file(self, what, filename, data, force=False):
+        """Write `data` to `filename` or delete if empty
+
+        If `data` is non-empty, this routine is the same as ``write_file()``.
+        If `data` is empty but not ``None``, this is the same as calling
+        ``delete_file(filename)`.  If `data` is ``None``, then this is a no-op
+        unless `filename` exists, in which case a warning is issued about the
+        orphaned file (if `force` is false), or deleted (if `force` is true).
+        """
+        if data:
+            self.write_file(what, filename, data)
+        elif os.path.exists(filename):
+            if data is None and not force:
+                log.warn(
+                    "%s not set in setup(), but %s exists", what, filename
+                )
+                return
+            else:
+                self.delete_file(filename)
+
+    def write_file(self, what, filename, data):
+        """Write `data` to `filename` (if not a dry run) after announcing it
+
+        `what` is used in a log message to identify what is being written
+        to the file.
+        """
+        log.info("writing %s to %s", what, filename)
+        if six.PY3:
+            data = data.encode("utf-8")
+        if not self.dry_run:
+            f = open(filename, 'wb')
+            f.write(data)
+            f.close()
+
+    def delete_file(self, filename):
+        """Delete `filename` (if not a dry run) after announcing it"""
+        log.info("deleting %s", filename)
+        if not self.dry_run:
+            os.unlink(filename)
+
+    def run(self):
+        self.mkpath(self.egg_info)
+        os.utime(self.egg_info, None)
+        installer = self.distribution.fetch_build_egg
+        for ep in iter_entry_points('egg_info.writers'):
+            ep.require(installer=installer)
+            writer = ep.resolve()
+            writer(self, ep.name, os.path.join(self.egg_info, ep.name))
+
+        # Get rid of native_libs.txt if it was put there by older bdist_egg
+        nl = os.path.join(self.egg_info, "native_libs.txt")
+        if os.path.exists(nl):
+            self.delete_file(nl)
+
+        self.find_sources()
+
+    def find_sources(self):
+        """Generate SOURCES.txt manifest file"""
+        manifest_filename = os.path.join(self.egg_info, "SOURCES.txt")
+        mm = manifest_maker(self.distribution)
+        mm.manifest = manifest_filename
+        mm.run()
+        self.filelist = mm.filelist
+
+    def check_broken_egg_info(self):
+        bei = self.egg_name + '.egg-info'
+        if self.egg_base != os.curdir:
+            bei = os.path.join(self.egg_base, bei)
+        if os.path.exists(bei):
+            log.warn(
+                "-" * 78 + '\n'
+                "Note: Your current .egg-info directory has a '-' in its name;"
+                '\nthis will not work correctly with "setup.py develop".\n\n'
+                'Please rename %s to %s to correct this problem.\n' + '-' * 78,
+                bei, self.egg_info
+            )
+            self.broken_egg_info = self.egg_info
+            self.egg_info = bei  # make it work for now
+
+
+class FileList(_FileList):
+    # Implementations of the various MANIFEST.in commands
+
+    def process_template_line(self, line):
+        # Parse the line: split it up, make sure the right number of words
+        # is there, and return the relevant words.  'action' is always
+        # defined: it's the first word of the line.  Which of the other
+        # three are defined depends on the action; it'll be either
+        # patterns, (dir and patterns), or (dir_pattern).
+        (action, patterns, dir, dir_pattern) = self._parse_template_line(line)
+
+        # OK, now we know that the action is valid and we have the
+        # right number of words on the line for that action -- so we
+        # can proceed with minimal error-checking.
+        if action == 'include':
+            self.debug_print("include " + ' '.join(patterns))
+            for pattern in patterns:
+                if not self.include(pattern):
+                    log.warn("warning: no files found matching '%s'", pattern)
+
+        elif action == 'exclude':
+            self.debug_print("exclude " + ' '.join(patterns))
+            for pattern in patterns:
+                if not self.exclude(pattern):
+                    log.warn(("warning: no previously-included files "
+                              "found matching '%s'"), pattern)
+
+        elif action == 'global-include':
+            self.debug_print("global-include " + ' '.join(patterns))
+            for pattern in patterns:
+                if not self.global_include(pattern):
+                    log.warn(("warning: no files found matching '%s' "
+                              "anywhere in distribution"), pattern)
+
+        elif action == 'global-exclude':
+            self.debug_print("global-exclude " + ' '.join(patterns))
+            for pattern in patterns:
+                if not self.global_exclude(pattern):
+                    log.warn(("warning: no previously-included files matching "
+                              "'%s' found anywhere in distribution"),
+                             pattern)
+
+        elif action == 'recursive-include':
+            self.debug_print("recursive-include %s %s" %
+                             (dir, ' '.join(patterns)))
+            for pattern in patterns:
+                if not self.recursive_include(dir, pattern):
+                    log.warn(("warning: no files found matching '%s' "
+                              "under directory '%s'"),
+                             pattern, dir)
+
+        elif action == 'recursive-exclude':
+            self.debug_print("recursive-exclude %s %s" %
+                             (dir, ' '.join(patterns)))
+            for pattern in patterns:
+                if not self.recursive_exclude(dir, pattern):
+                    log.warn(("warning: no previously-included files matching "
+                              "'%s' found under directory '%s'"),
+                             pattern, dir)
+
+        elif action == 'graft':
+            self.debug_print("graft " + dir_pattern)
+            if not self.graft(dir_pattern):
+                log.warn("warning: no directories found matching '%s'",
+                         dir_pattern)
+
+        elif action == 'prune':
+            self.debug_print("prune " + dir_pattern)
+            if not self.prune(dir_pattern):
+                log.warn(("no previously-included directories found "
+                          "matching '%s'"), dir_pattern)
+
+        else:
+            raise DistutilsInternalError(
+                "this cannot happen: invalid action '%s'" % action)
+
+    def _remove_files(self, predicate):
+        """
+        Remove all files from the file list that match the predicate.
+        Return True if any matching files were removed
+        """
+        found = False
+        for i in range(len(self.files) - 1, -1, -1):
+            if predicate(self.files[i]):
+                self.debug_print(" removing " + self.files[i])
+                del self.files[i]
+                found = True
+        return found
+
+    def include(self, pattern):
+        """Include files that match 'pattern'."""
+        found = [f for f in glob(pattern) if not os.path.isdir(f)]
+        self.extend(found)
+        return bool(found)
+
+    def exclude(self, pattern):
+        """Exclude files that match 'pattern'."""
+        match = translate_pattern(pattern)
+        return self._remove_files(match.match)
+
+    def recursive_include(self, dir, pattern):
+        """
+        Include all files anywhere in 'dir/' that match the pattern.
+        """
+        full_pattern = os.path.join(dir, '**', pattern)
+        found = [f for f in glob(full_pattern, recursive=True)
+                 if not os.path.isdir(f)]
+        self.extend(found)
+        return bool(found)
+
+    def recursive_exclude(self, dir, pattern):
+        """
+        Exclude any file anywhere in 'dir/' that match the pattern.
+        """
+        match = translate_pattern(os.path.join(dir, '**', pattern))
+        return self._remove_files(match.match)
+
+    def graft(self, dir):
+        """Include all files from 'dir/'."""
+        found = [
+            item
+            for match_dir in glob(dir)
+            for item in distutils.filelist.findall(match_dir)
+        ]
+        self.extend(found)
+        return bool(found)
+
+    def prune(self, dir):
+        """Filter out files from 'dir/'."""
+        match = translate_pattern(os.path.join(dir, '**'))
+        return self._remove_files(match.match)
+
+    def global_include(self, pattern):
+        """
+        Include all files anywhere in the current directory that match the
+        pattern. This is very inefficient on large file trees.
+        """
+        if self.allfiles is None:
+            self.findall()
+        match = translate_pattern(os.path.join('**', pattern))
+        found = [f for f in self.allfiles if match.match(f)]
+        self.extend(found)
+        return bool(found)
+
+    def global_exclude(self, pattern):
+        """
+        Exclude all files anywhere that match the pattern.
+        """
+        match = translate_pattern(os.path.join('**', pattern))
+        return self._remove_files(match.match)
+
+    def append(self, item):
+        if item.endswith('\r'):  # Fix older sdists built on Windows
+            item = item[:-1]
+        path = convert_path(item)
+
+        if self._safe_path(path):
+            self.files.append(path)
+
+    def extend(self, paths):
+        self.files.extend(filter(self._safe_path, paths))
+
+    def _repair(self):
+        """
+        Replace self.files with only safe paths
+
+        Because some owners of FileList manipulate the underlying
+        ``files`` attribute directly, this method must be called to
+        repair those paths.
+        """
+        self.files = list(filter(self._safe_path, self.files))
+
+    def _safe_path(self, path):
+        enc_warn = "'%s' not %s encodable -- skipping"
+
+        # To avoid accidental trans-codings errors, first to unicode
+        u_path = unicode_utils.filesys_decode(path)
+        if u_path is None:
+            log.warn("'%s' in unexpected encoding -- skipping" % path)
+            return False
+
+        # Must ensure utf-8 encodability
+        utf8_path = unicode_utils.try_encode(u_path, "utf-8")
+        if utf8_path is None:
+            log.warn(enc_warn, path, 'utf-8')
+            return False
+
+        try:
+            # accept is either way checks out
+            if os.path.exists(u_path) or os.path.exists(utf8_path):
+                return True
+        # this will catch any encode errors decoding u_path
+        except UnicodeEncodeError:
+            log.warn(enc_warn, path, sys.getfilesystemencoding())
+
+
+class manifest_maker(sdist):
+    template = "MANIFEST.in"
+
+    def initialize_options(self):
+        self.use_defaults = 1
+        self.prune = 1
+        self.manifest_only = 1
+        self.force_manifest = 1
+
+    def finalize_options(self):
+        pass
+
+    def run(self):
+        self.filelist = FileList()
+        if not os.path.exists(self.manifest):
+            self.write_manifest()  # it must exist so it'll get in the list
+        self.add_defaults()
+        if os.path.exists(self.template):
+            self.read_template()
+        self.prune_file_list()
+        self.filelist.sort()
+        self.filelist.remove_duplicates()
+        self.write_manifest()
+
+    def _manifest_normalize(self, path):
+        path = unicode_utils.filesys_decode(path)
+        return path.replace(os.sep, '/')
+
+    def write_manifest(self):
+        """
+        Write the file list in 'self.filelist' to the manifest file
+        named by 'self.manifest'.
+        """
+        self.filelist._repair()
+
+        # Now _repairs should encodability, but not unicode
+        files = [self._manifest_normalize(f) for f in self.filelist.files]
+        msg = "writing manifest file '%s'" % self.manifest
+        self.execute(write_file, (self.manifest, files), msg)
+
+    def warn(self, msg):
+        if not self._should_suppress_warning(msg):
+            sdist.warn(self, msg)
+
+    @staticmethod
+    def _should_suppress_warning(msg):
+        """
+        suppress missing-file warnings from sdist
+        """
+        return re.match(r"standard file .*not found", msg)
+
+    def add_defaults(self):
+        sdist.add_defaults(self)
+        self.check_license()
+        self.filelist.append(self.template)
+        self.filelist.append(self.manifest)
+        rcfiles = list(walk_revctrl())
+        if rcfiles:
+            self.filelist.extend(rcfiles)
+        elif os.path.exists(self.manifest):
+            self.read_manifest()
+
+        if os.path.exists("setup.py"):
+            # setup.py should be included by default, even if it's not
+            # the script called to create the sdist
+            self.filelist.append("setup.py")
+
+        ei_cmd = self.get_finalized_command('egg_info')
+        self.filelist.graft(ei_cmd.egg_info)
+
+    def prune_file_list(self):
+        build = self.get_finalized_command('build')
+        base_dir = self.distribution.get_fullname()
+        self.filelist.prune(build.build_base)
+        self.filelist.prune(base_dir)
+        sep = re.escape(os.sep)
+        self.filelist.exclude_pattern(r'(^|' + sep + r')(RCS|CVS|\.svn)' + sep,
+                                      is_regex=1)
+
+
+def write_file(filename, contents):
+    """Create a file with the specified name and write 'contents' (a
+    sequence of strings without line terminators) to it.
+    """
+    contents = "\n".join(contents)
+
+    # assuming the contents has been vetted for utf-8 encoding
+    contents = contents.encode("utf-8")
+
+    with open(filename, "wb") as f:  # always write POSIX-style manifest
+        f.write(contents)
+
+
+def write_pkg_info(cmd, basename, filename):
+    log.info("writing %s", filename)
+    if not cmd.dry_run:
+        metadata = cmd.distribution.metadata
+        metadata.version, oldver = cmd.egg_version, metadata.version
+        metadata.name, oldname = cmd.egg_name, metadata.name
+
+        try:
+            # write unescaped data to PKG-INFO, so older pkg_resources
+            # can still parse it
+            metadata.write_pkg_info(cmd.egg_info)
+        finally:
+            metadata.name, metadata.version = oldname, oldver
+
+        safe = getattr(cmd.distribution, 'zip_safe', None)
+
+        bdist_egg.write_safety_flag(cmd.egg_info, safe)
+
+
+def warn_depends_obsolete(cmd, basename, filename):
+    if os.path.exists(filename):
+        log.warn(
+            "WARNING: 'depends.txt' is not used by setuptools 0.6!\n"
+            "Use the install_requires/extras_require setup() args instead."
+        )
+
+
+def _write_requirements(stream, reqs):
+    lines = yield_lines(reqs or ())
+    append_cr = lambda line: line + '\n'
+    lines = map(append_cr, lines)
+    stream.writelines(lines)
+
+
+def write_requirements(cmd, basename, filename):
+    dist = cmd.distribution
+    data = six.StringIO()
+    _write_requirements(data, dist.install_requires)
+    extras_require = dist.extras_require or {}
+    for extra in sorted(extras_require):
+        data.write('\n[{extra}]\n'.format(**vars()))
+        _write_requirements(data, extras_require[extra])
+    cmd.write_or_delete_file("requirements", filename, data.getvalue())
+
+
+def write_setup_requirements(cmd, basename, filename):
+    data = io.StringIO()
+    _write_requirements(data, cmd.distribution.setup_requires)
+    cmd.write_or_delete_file("setup-requirements", filename, data.getvalue())
+
+
+def write_toplevel_names(cmd, basename, filename):
+    pkgs = dict.fromkeys(
+        [
+            k.split('.', 1)[0]
+            for k in cmd.distribution.iter_distribution_names()
+        ]
+    )
+    cmd.write_file("top-level names", filename, '\n'.join(sorted(pkgs)) + '\n')
+
+
+def overwrite_arg(cmd, basename, filename):
+    write_arg(cmd, basename, filename, True)
+
+
+def write_arg(cmd, basename, filename, force=False):
+    argname = os.path.splitext(basename)[0]
+    value = getattr(cmd.distribution, argname, None)
+    if value is not None:
+        value = '\n'.join(value) + '\n'
+    cmd.write_or_delete_file(argname, filename, value, force)
+
+
+def write_entries(cmd, basename, filename):
+    ep = cmd.distribution.entry_points
+
+    if isinstance(ep, six.string_types) or ep is None:
+        data = ep
+    elif ep is not None:
+        data = []
+        for section, contents in sorted(ep.items()):
+            if not isinstance(contents, six.string_types):
+                contents = EntryPoint.parse_group(section, contents)
+                contents = '\n'.join(sorted(map(str, contents.values())))
+            data.append('[%s]\n%s\n\n' % (section, contents))
+        data = ''.join(data)
+
+    cmd.write_or_delete_file('entry points', filename, data, True)
+
+
+def get_pkg_info_revision():
+    """
+    Get a -r### off of PKG-INFO Version in case this is an sdist of
+    a subversion revision.
+    """
+    warnings.warn("get_pkg_info_revision is deprecated.", EggInfoDeprecationWarning)
+    if os.path.exists('PKG-INFO'):
+        with io.open('PKG-INFO') as f:
+            for line in f:
+                match = re.match(r"Version:.*-r(\d+)\s*$", line)
+                if match:
+                    return int(match.group(1))
+    return 0
+
+
+class EggInfoDeprecationWarning(SetuptoolsDeprecationWarning):
+    """Class for warning about deprecations in eggInfo in setupTools. Not ignored by default, unlike DeprecationWarning."""
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/egg_info.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/egg_info.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..8c1dfb6b7e1f40c656fa11a39d9eef900c892e9a
GIT binary patch
literal 29768
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

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/install.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/install.py
new file mode 100644
index 0000000..31a5ddb
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/install.py
@@ -0,0 +1,125 @@
+from distutils.errors import DistutilsArgError
+import inspect
+import glob
+import warnings
+import platform
+import distutils.command.install as orig
+
+import setuptools
+
+# Prior to numpy 1.9, NumPy relies on the '_install' name, so provide it for
+# now. See https://github.com/pypa/setuptools/issues/199/
+_install = orig.install
+
+
+class install(orig.install):
+    """Use easy_install to install the package, w/dependencies"""
+
+    user_options = orig.install.user_options + [
+        ('old-and-unmanageable', None, "Try not to use this!"),
+        ('single-version-externally-managed', None,
+         "used by system package builders to create 'flat' eggs"),
+    ]
+    boolean_options = orig.install.boolean_options + [
+        'old-and-unmanageable', 'single-version-externally-managed',
+    ]
+    new_commands = [
+        ('install_egg_info', lambda self: True),
+        ('install_scripts', lambda self: True),
+    ]
+    _nc = dict(new_commands)
+
+    def initialize_options(self):
+        orig.install.initialize_options(self)
+        self.old_and_unmanageable = None
+        self.single_version_externally_managed = None
+
+    def finalize_options(self):
+        orig.install.finalize_options(self)
+        if self.root:
+            self.single_version_externally_managed = True
+        elif self.single_version_externally_managed:
+            if not self.root and not self.record:
+                raise DistutilsArgError(
+                    "You must specify --record or --root when building system"
+                    " packages"
+                )
+
+    def handle_extra_path(self):
+        if self.root or self.single_version_externally_managed:
+            # explicit backward-compatibility mode, allow extra_path to work
+            return orig.install.handle_extra_path(self)
+
+        # Ignore extra_path when installing an egg (or being run by another
+        # command without --root or --single-version-externally-managed
+        self.path_file = None
+        self.extra_dirs = ''
+
+    def run(self):
+        # Explicit request for old-style install?  Just do it
+        if self.old_and_unmanageable or self.single_version_externally_managed:
+            return orig.install.run(self)
+
+        if not self._called_from_setup(inspect.currentframe()):
+            # Run in backward-compatibility mode to support bdist_* commands.
+            orig.install.run(self)
+        else:
+            self.do_egg_install()
+
+    @staticmethod
+    def _called_from_setup(run_frame):
+        """
+        Attempt to detect whether run() was called from setup() or by another
+        command.  If called by setup(), the parent caller will be the
+        'run_command' method in 'distutils.dist', and *its* caller will be
+        the 'run_commands' method.  If called any other way, the
+        immediate caller *might* be 'run_command', but it won't have been
+        called by 'run_commands'. Return True in that case or if a call stack
+        is unavailable. Return False otherwise.
+        """
+        if run_frame is None:
+            msg = "Call stack not available. bdist_* commands may fail."
+            warnings.warn(msg)
+            if platform.python_implementation() == 'IronPython':
+                msg = "For best results, pass -X:Frames to enable call stack."
+                warnings.warn(msg)
+            return True
+        res = inspect.getouterframes(run_frame)[2]
+        caller, = res[:1]
+        info = inspect.getframeinfo(caller)
+        caller_module = caller.f_globals.get('__name__', '')
+        return (
+            caller_module == 'distutils.dist'
+            and info.function == 'run_commands'
+        )
+
+    def do_egg_install(self):
+
+        easy_install = self.distribution.get_command_class('easy_install')
+
+        cmd = easy_install(
+            self.distribution, args="x", root=self.root, record=self.record,
+        )
+        cmd.ensure_finalized()  # finalize before bdist_egg munges install cmd
+        cmd.always_copy_from = '.'  # make sure local-dir eggs get installed
+
+        # pick up setup-dir .egg files only: no .egg-info
+        cmd.package_index.scan(glob.glob('*.egg'))
+
+        self.run_command('bdist_egg')
+        args = [self.distribution.get_command_obj('bdist_egg').egg_output]
+
+        if setuptools.bootstrap_install_from:
+            # Bootstrap self-installation of setuptools
+            args.insert(0, setuptools.bootstrap_install_from)
+
+        cmd.args = args
+        cmd.run()
+        setuptools.bootstrap_install_from = None
+
+
+# XXX Python 3.1 doesn't see _nc if this is inside the class
+install.sub_commands = (
+    [cmd for cmd in orig.install.sub_commands if cmd[0] not in install._nc] +
+    install.new_commands
+)
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/install.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/install.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..f8e5159d03c59d6446ffabf258ac5957b035dc65
GIT binary patch
literal 5493
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

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/install_egg_info.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/install_egg_info.py
new file mode 100644
index 0000000..edc4718
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/install_egg_info.py
@@ -0,0 +1,62 @@
+from distutils import log, dir_util
+import os
+
+from setuptools import Command
+from setuptools import namespaces
+from setuptools.archive_util import unpack_archive
+import pkg_resources
+
+
+class install_egg_info(namespaces.Installer, Command):
+    """Install an .egg-info directory for the package"""
+
+    description = "Install an .egg-info directory for the package"
+
+    user_options = [
+        ('install-dir=', 'd', "directory to install to"),
+    ]
+
+    def initialize_options(self):
+        self.install_dir = None
+
+    def finalize_options(self):
+        self.set_undefined_options('install_lib',
+                                   ('install_dir', 'install_dir'))
+        ei_cmd = self.get_finalized_command("egg_info")
+        basename = pkg_resources.Distribution(
+            None, None, ei_cmd.egg_name, ei_cmd.egg_version
+        ).egg_name() + '.egg-info'
+        self.source = ei_cmd.egg_info
+        self.target = os.path.join(self.install_dir, basename)
+        self.outputs = []
+
+    def run(self):
+        self.run_command('egg_info')
+        if os.path.isdir(self.target) and not os.path.islink(self.target):
+            dir_util.remove_tree(self.target, dry_run=self.dry_run)
+        elif os.path.exists(self.target):
+            self.execute(os.unlink, (self.target,), "Removing " + self.target)
+        if not self.dry_run:
+            pkg_resources.ensure_directory(self.target)
+        self.execute(
+            self.copytree, (), "Copying %s to %s" % (self.source, self.target)
+        )
+        self.install_namespaces()
+
+    def get_outputs(self):
+        return self.outputs
+
+    def copytree(self):
+        # Copy the .egg-info tree to site-packages
+        def skimmer(src, dst):
+            # filter out source-control directories; note that 'src' is always
+            # a '/'-separated path, regardless of platform.  'dst' is a
+            # platform-specific path.
+            for skip in '.svn/', 'CVS/':
+                if src.startswith(skip) or '/' + skip in src:
+                    return None
+            self.outputs.append(dst)
+            log.debug("Copying %s to %s", src, dst)
+            return dst
+
+        unpack_archive(self.source, self.target, skimmer)
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/install_egg_info.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/install_egg_info.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..04a6ccdf6bc3a6034c542dccf78366fb6b049b19
GIT binary patch
literal 3639
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
S74+cLCC13ZB)|xQJj?)sq+SyM

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/install_lib.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/install_lib.py
new file mode 100644
index 0000000..2b31c3e
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/install_lib.py
@@ -0,0 +1,121 @@
+import os
+import imp
+from itertools import product, starmap
+import distutils.command.install_lib as orig
+
+
+class install_lib(orig.install_lib):
+    """Don't add compiled flags to filenames of non-Python files"""
+
+    def run(self):
+        self.build()
+        outfiles = self.install()
+        if outfiles is not None:
+            # always compile, in case we have any extension stubs to deal with
+            self.byte_compile(outfiles)
+
+    def get_exclusions(self):
+        """
+        Return a collections.Sized collections.Container of paths to be
+        excluded for single_version_externally_managed installations.
+        """
+        all_packages = (
+            pkg
+            for ns_pkg in self._get_SVEM_NSPs()
+            for pkg in self._all_packages(ns_pkg)
+        )
+
+        excl_specs = product(all_packages, self._gen_exclusion_paths())
+        return set(starmap(self._exclude_pkg_path, excl_specs))
+
+    def _exclude_pkg_path(self, pkg, exclusion_path):
+        """
+        Given a package name and exclusion path within that package,
+        compute the full exclusion path.
+        """
+        parts = pkg.split('.') + [exclusion_path]
+        return os.path.join(self.install_dir, *parts)
+
+    @staticmethod
+    def _all_packages(pkg_name):
+        """
+        >>> list(install_lib._all_packages('foo.bar.baz'))
+        ['foo.bar.baz', 'foo.bar', 'foo']
+        """
+        while pkg_name:
+            yield pkg_name
+            pkg_name, sep, child = pkg_name.rpartition('.')
+
+    def _get_SVEM_NSPs(self):
+        """
+        Get namespace packages (list) but only for
+        single_version_externally_managed installations and empty otherwise.
+        """
+        # TODO: is it necessary to short-circuit here? i.e. what's the cost
+        # if get_finalized_command is called even when namespace_packages is
+        # False?
+        if not self.distribution.namespace_packages:
+            return []
+
+        install_cmd = self.get_finalized_command('install')
+        svem = install_cmd.single_version_externally_managed
+
+        return self.distribution.namespace_packages if svem else []
+
+    @staticmethod
+    def _gen_exclusion_paths():
+        """
+        Generate file paths to be excluded for namespace packages (bytecode
+        cache files).
+        """
+        # always exclude the package module itself
+        yield '__init__.py'
+
+        yield '__init__.pyc'
+        yield '__init__.pyo'
+
+        if not hasattr(imp, 'get_tag'):
+            return
+
+        base = os.path.join('__pycache__', '__init__.' + imp.get_tag())
+        yield base + '.pyc'
+        yield base + '.pyo'
+        yield base + '.opt-1.pyc'
+        yield base + '.opt-2.pyc'
+
+    def copy_tree(
+            self, infile, outfile,
+            preserve_mode=1, preserve_times=1, preserve_symlinks=0, level=1
+    ):
+        assert preserve_mode and preserve_times and not preserve_symlinks
+        exclude = self.get_exclusions()
+
+        if not exclude:
+            return orig.install_lib.copy_tree(self, infile, outfile)
+
+        # Exclude namespace package __init__.py* files from the output
+
+        from setuptools.archive_util import unpack_directory
+        from distutils import log
+
+        outfiles = []
+
+        def pf(src, dst):
+            if dst in exclude:
+                log.warn("Skipping installation of %s (namespace package)",
+                         dst)
+                return False
+
+            log.info("copying %s -> %s", src, os.path.dirname(dst))
+            outfiles.append(dst)
+            return dst
+
+        unpack_directory(infile, outfile, pf)
+        return outfiles
+
+    def get_outputs(self):
+        outputs = orig.install_lib.get_outputs(self)
+        exclude = self.get_exclusions()
+        if exclude:
+            return [f for f in outputs if f not in exclude]
+        return outputs
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/install_lib.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/install_lib.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..9e57b25d98f465a9a3de78cf179ebddf06a7857d
GIT binary patch
literal 5518
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
H6k-Mdh|Npp

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/install_scripts.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/install_scripts.py
new file mode 100644
index 0000000..1623427
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/install_scripts.py
@@ -0,0 +1,65 @@
+from distutils import log
+import distutils.command.install_scripts as orig
+import os
+import sys
+
+from pkg_resources import Distribution, PathMetadata, ensure_directory
+
+
+class install_scripts(orig.install_scripts):
+    """Do normal script install, plus any egg_info wrapper scripts"""
+
+    def initialize_options(self):
+        orig.install_scripts.initialize_options(self)
+        self.no_ep = False
+
+    def run(self):
+        import setuptools.command.easy_install as ei
+
+        self.run_command("egg_info")
+        if self.distribution.scripts:
+            orig.install_scripts.run(self)  # run first to set up self.outfiles
+        else:
+            self.outfiles = []
+        if self.no_ep:
+            # don't install entry point scripts into .egg file!
+            return
+
+        ei_cmd = self.get_finalized_command("egg_info")
+        dist = Distribution(
+            ei_cmd.egg_base, PathMetadata(ei_cmd.egg_base, ei_cmd.egg_info),
+            ei_cmd.egg_name, ei_cmd.egg_version,
+        )
+        bs_cmd = self.get_finalized_command('build_scripts')
+        exec_param = getattr(bs_cmd, 'executable', None)
+        bw_cmd = self.get_finalized_command("bdist_wininst")
+        is_wininst = getattr(bw_cmd, '_is_running', False)
+        writer = ei.ScriptWriter
+        if is_wininst:
+            exec_param = "python.exe"
+            writer = ei.WindowsScriptWriter
+        if exec_param == sys.executable:
+            # In case the path to the Python executable contains a space, wrap
+            # it so it's not split up.
+            exec_param = [exec_param]
+        # resolve the writer to the environment
+        writer = writer.best()
+        cmd = writer.command_spec_class.best().from_param(exec_param)
+        for args in writer.get_args(dist, cmd.as_header()):
+            self.write_script(*args)
+
+    def write_script(self, script_name, contents, mode="t", *ignored):
+        """Write an executable file to the scripts directory"""
+        from setuptools.command.easy_install import chmod, current_umask
+
+        log.info("Installing %s script to %s", script_name, self.install_dir)
+        target = os.path.join(self.install_dir, script_name)
+        self.outfiles.append(target)
+
+        mask = current_umask()
+        if not self.dry_run:
+            ensure_directory(target)
+            f = open(target, "w" + mode)
+            f.write(contents)
+            f.close()
+            chmod(target, 0o777 - mask)
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/install_scripts.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/install_scripts.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..3c912180dfa592ad4ea9e67a282d1e8ec10e7c83
GIT binary patch
literal 3161
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

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/launcher manifest.xml b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/launcher manifest.xml
new file mode 100644
index 0000000..5972a96
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/launcher manifest.xml	
@@ -0,0 +1,15 @@
+<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
+<assembly xmlns="urn:schemas-microsoft-com:asm.v1" manifestVersion="1.0">
+    <assemblyIdentity version="1.0.0.0"
+                      processorArchitecture="X86"
+                      name="%(name)s"
+                      type="win32"/>
+    <!-- Identify the application security requirements. -->
+    <trustInfo xmlns="urn:schemas-microsoft-com:asm.v3">
+        <security>
+            <requestedPrivileges>
+                <requestedExecutionLevel level="asInvoker" uiAccess="false"/>
+            </requestedPrivileges>
+        </security>
+    </trustInfo>
+</assembly>
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/py36compat.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/py36compat.py
new file mode 100644
index 0000000..61063e7
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/py36compat.py
@@ -0,0 +1,136 @@
+import os
+from glob import glob
+from distutils.util import convert_path
+from distutils.command import sdist
+
+from setuptools.extern.six.moves import filter
+
+
+class sdist_add_defaults:
+    """
+    Mix-in providing forward-compatibility for functionality as found in
+    distutils on Python 3.7.
+
+    Do not edit the code in this class except to update functionality
+    as implemented in distutils. Instead, override in the subclass.
+    """
+
+    def add_defaults(self):
+        """Add all the default files to self.filelist:
+          - README or README.txt
+          - setup.py
+          - test/test*.py
+          - all pure Python modules mentioned in setup script
+          - all files pointed by package_data (build_py)
+          - all files defined in data_files.
+          - all files defined as scripts.
+          - all C sources listed as part of extensions or C libraries
+            in the setup script (doesn't catch C headers!)
+        Warns if (README or README.txt) or setup.py are missing; everything
+        else is optional.
+        """
+        self._add_defaults_standards()
+        self._add_defaults_optional()
+        self._add_defaults_python()
+        self._add_defaults_data_files()
+        self._add_defaults_ext()
+        self._add_defaults_c_libs()
+        self._add_defaults_scripts()
+
+    @staticmethod
+    def _cs_path_exists(fspath):
+        """
+        Case-sensitive path existence check
+
+        >>> sdist_add_defaults._cs_path_exists(__file__)
+        True
+        >>> sdist_add_defaults._cs_path_exists(__file__.upper())
+        False
+        """
+        if not os.path.exists(fspath):
+            return False
+        # make absolute so we always have a directory
+        abspath = os.path.abspath(fspath)
+        directory, filename = os.path.split(abspath)
+        return filename in os.listdir(directory)
+
+    def _add_defaults_standards(self):
+        standards = [self.READMES, self.distribution.script_name]
+        for fn in standards:
+            if isinstance(fn, tuple):
+                alts = fn
+                got_it = False
+                for fn in alts:
+                    if self._cs_path_exists(fn):
+                        got_it = True
+                        self.filelist.append(fn)
+                        break
+
+                if not got_it:
+                    self.warn("standard file not found: should have one of " +
+                              ', '.join(alts))
+            else:
+                if self._cs_path_exists(fn):
+                    self.filelist.append(fn)
+                else:
+                    self.warn("standard file '%s' not found" % fn)
+
+    def _add_defaults_optional(self):
+        optional = ['test/test*.py', 'setup.cfg']
+        for pattern in optional:
+            files = filter(os.path.isfile, glob(pattern))
+            self.filelist.extend(files)
+
+    def _add_defaults_python(self):
+        # build_py is used to get:
+        #  - python modules
+        #  - files defined in package_data
+        build_py = self.get_finalized_command('build_py')
+
+        # getting python files
+        if self.distribution.has_pure_modules():
+            self.filelist.extend(build_py.get_source_files())
+
+        # getting package_data files
+        # (computed in build_py.data_files by build_py.finalize_options)
+        for pkg, src_dir, build_dir, filenames in build_py.data_files:
+            for filename in filenames:
+                self.filelist.append(os.path.join(src_dir, filename))
+
+    def _add_defaults_data_files(self):
+        # getting distribution.data_files
+        if self.distribution.has_data_files():
+            for item in self.distribution.data_files:
+                if isinstance(item, str):
+                    # plain file
+                    item = convert_path(item)
+                    if os.path.isfile(item):
+                        self.filelist.append(item)
+                else:
+                    # a (dirname, filenames) tuple
+                    dirname, filenames = item
+                    for f in filenames:
+                        f = convert_path(f)
+                        if os.path.isfile(f):
+                            self.filelist.append(f)
+
+    def _add_defaults_ext(self):
+        if self.distribution.has_ext_modules():
+            build_ext = self.get_finalized_command('build_ext')
+            self.filelist.extend(build_ext.get_source_files())
+
+    def _add_defaults_c_libs(self):
+        if self.distribution.has_c_libraries():
+            build_clib = self.get_finalized_command('build_clib')
+            self.filelist.extend(build_clib.get_source_files())
+
+    def _add_defaults_scripts(self):
+        if self.distribution.has_scripts():
+            build_scripts = self.get_finalized_command('build_scripts')
+            self.filelist.extend(build_scripts.get_source_files())
+
+
+if hasattr(sdist.sdist, '_add_defaults_standards'):
+    # disable the functionality already available upstream
+    class sdist_add_defaults:
+        pass
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/py36compat.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/py36compat.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..60123e5666aa92bed7316497e23effe85436b34d
GIT binary patch
literal 6198
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
DX1w00

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/register.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/register.py
new file mode 100644
index 0000000..98bc015
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/register.py
@@ -0,0 +1,18 @@
+from distutils import log
+import distutils.command.register as orig
+
+
+class register(orig.register):
+    __doc__ = orig.register.__doc__
+
+    def run(self):
+        try:
+            # Make sure that we are using valid current name/version info
+            self.run_command('egg_info')
+            orig.register.run(self)
+        finally:
+            self.announce(
+                "WARNING: Registering is deprecated, use twine to "
+                "upload instead (https://pypi.org/p/twine/)",
+                log.WARN
+            )
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/register.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/register.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..6dc77c540443e70c4523e70a0557ee19fa104b08
GIT binary patch
literal 1080
zcmZSn%**AGdLky70ScHI7#JKF7#ND}85kH+7#LC*8FCmHav2$-7#SErd?tn*CWb6#
zhAb9_C{~6PW`<N&5Ic>LA%%sZg@K`&fgv)Ag&~EBAy|Wzfq^0O|NsC0H5eHf7)n59
z=j5mRm2faHFchVxXBL;F7Qt->DRBbXEX%;akjenEFcoeS3&<@k3?M6mg2ARGgVcjC
z8v_G_Gf1Be0|P^qB0~)WLl)TG&5R6;C5#MNU_)vc7(o2+6b7&Yumek28M4?Inwc0F
zBT^U`f;B+ygE%fVJv}}%FD<_~nt_2K+%d?{)6d;XAqeW^%)E4k%wmO<)Pkba<iwKH
z6di@q;#7r_^31$cg_3-Q(t@1)#1w_hyyBA7#1sXMjFOUqVk>?9g35wSz5Jqd{Q`Zk
zT769oc2Kx*gMy<pFFrXxH#adarG$lnfg!&rGd&38J#eTMmF9s1Eio@Izcep7H3$@2
zV09qJfx`pLD^ATx(*VhViQ-ZQ1_u3tqRg_yl2rY&#3KE){G623qGJ7|6#ep~q`X|y
z++ricB=hvDbPH39@|>(HGXoGv&(jalFUTy=1$iMcCr8(<%)`?-K)*P(q_m(UKR>4!
znF)2aJ}gG{3Mzv@F%OF6Vjhrd7@3)P8AX`b7@3(gK+y&EOMHA@Vs2`Dd<ho=14Dd#
zZhlH>PHKF75XkospMwG?K0YNsIX)h2AlOp~VgS7diWra=i$RWMW8{H)ixZS*GK)(}
zOEPncA#o&yETjhwDm_?Gm4Lhm6$JYk?0bY4!K{JvCpeyLATeVH@-x`K0*pe;0Do}_
Ar2qf`

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/rotate.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/rotate.py
new file mode 100644
index 0000000..b89353f
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/rotate.py
@@ -0,0 +1,66 @@
+from distutils.util import convert_path
+from distutils import log
+from distutils.errors import DistutilsOptionError
+import os
+import shutil
+
+from setuptools.extern import six
+
+from setuptools import Command
+
+
+class rotate(Command):
+    """Delete older distributions"""
+
+    description = "delete older distributions, keeping N newest files"
+    user_options = [
+        ('match=', 'm', "patterns to match (required)"),
+        ('dist-dir=', 'd', "directory where the distributions are"),
+        ('keep=', 'k', "number of matching distributions to keep"),
+    ]
+
+    boolean_options = []
+
+    def initialize_options(self):
+        self.match = None
+        self.dist_dir = None
+        self.keep = None
+
+    def finalize_options(self):
+        if self.match is None:
+            raise DistutilsOptionError(
+                "Must specify one or more (comma-separated) match patterns "
+                "(e.g. '.zip' or '.egg')"
+            )
+        if self.keep is None:
+            raise DistutilsOptionError("Must specify number of files to keep")
+        try:
+            self.keep = int(self.keep)
+        except ValueError:
+            raise DistutilsOptionError("--keep must be an integer")
+        if isinstance(self.match, six.string_types):
+            self.match = [
+                convert_path(p.strip()) for p in self.match.split(',')
+            ]
+        self.set_undefined_options('bdist', ('dist_dir', 'dist_dir'))
+
+    def run(self):
+        self.run_command("egg_info")
+        from glob import glob
+
+        for pattern in self.match:
+            pattern = self.distribution.get_name() + '*' + pattern
+            files = glob(os.path.join(self.dist_dir, pattern))
+            files = [(os.path.getmtime(f), f) for f in files]
+            files.sort()
+            files.reverse()
+
+            log.info("%d file(s) matching %s", len(files), pattern)
+            files = files[self.keep:]
+            for (t, f) in files:
+                log.info("Deleting %s", f)
+                if not self.dry_run:
+                    if os.path.isdir(f):
+                        shutil.rmtree(f)
+                    else:
+                        os.unlink(f)
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/rotate.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/rotate.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..c04a8bcd6fae722296564771a8a3b6de23419bcd
GIT binary patch
literal 3322
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

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/saveopts.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/saveopts.py
new file mode 100644
index 0000000..611cec5
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/saveopts.py
@@ -0,0 +1,22 @@
+from setuptools.command.setopt import edit_config, option_base
+
+
+class saveopts(option_base):
+    """Save command-line options to a file"""
+
+    description = "save supplied options to setup.cfg or other config file"
+
+    def run(self):
+        dist = self.distribution
+        settings = {}
+
+        for cmd in dist.command_options:
+
+            if cmd == 'saveopts':
+                continue  # don't save our own options!
+
+            for opt, (src, val) in dist.get_option_dict(cmd).items():
+                if src == "command line":
+                    settings.setdefault(cmd, {})[opt] = val
+
+        edit_config(self.filename, settings, self.dry_run)
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/saveopts.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/saveopts.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..d4c564f3934f2600843dffd6b38ccc2f53358000
GIT binary patch
literal 1291
zcmZSn%**AGdLky70ScHI7#JKF7#NBT7#J8*7#LC*8FCmHav2$-7#VVz7^0XM7*m)S
zQkfXi7#UKS8Cn<^ni&`(qnH^|SQvseSQ!`?GXMYo|6hZNfq|ifn}LBLH6^noJ~=-x
zEi)a=&o3y+%+HHYN-Rz-;Q(2bSeBY!P*Mzc0V4wggA+(X7Nna2WN``u$l?@629P~W
zAWNfI7=nT|K#na|W?*0lPAp4RNY2mAP0UNt&B@G5Re)GitWc7#kf@NBnUh*<4l)y@
zuDG<IASW|51zAmTYDsB<UUFKxLVl4#eo01ZkpjfcV7<v8H?cD?Ft9N&FgSzES-`-+
zP{Y8G#lTR@$dJjvP|L(nQNmEe$dJXz;1Zk3P|M6v!wd?%Y$k>xLxw_0hCBv_3O}$4
zCXiG!BSRK5DC}Hf%^6~t7;0I-Br8KL8$%5%LkbfENT)kP4I4uZ6GIjYNKYmMLo*XY
z4GV)!p*usNJ41M(Btv)!E7&1mWgr)^Gc+?ZFs3jtK!V3F2ow{=JPZsB(C|?Jg^va(
z=u1GNDVfD3MVU#Zpjav4M<|Pjh9FohJ+%bNk59==E-3-Wb4hA$aS0bFG*U}aQqvMk
zb4r3hsR$gcpdimn%uOu;1zSo{WqeU-o(70r!UEQjlLlshYzM0^PAw_P%u6pW0mW%@
zZVH&rFDL=i#YM?rx-2nA17ri3C@y7SV9+lp$}CGPN!2e)EYeTQ&q+xwD%MX*(JxO*
z%F8v)EjBVtGEc8cw=lIR&&jGXGXR0~JpB;;g3JQl%)H`~#GD*mw=xe;;{bhd8Ys!n
z&nZS`LPJfz7@AJ?3M#>FDJsq51o=b=<RC^)Mm8n^CLTsMCJja&MnxuYP5^r>J{}Yd
z@$ul0ijU9DPbtkwjgJS1OMHAvesX*~IA5fs7AF^Ff-^^uAOiyf*pCQe;Cu^CK;TFN
zrG7R>HYPSEKMjyTi6kfhKsg5-YI@M1(ko6a$uEGUg&<JQ0h@sE3Yax;{sG5|4J01y
MK+Y=$<q$Du00JXKTmS$7

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/sdist.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/sdist.py
new file mode 100644
index 0000000..dc25398
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/sdist.py
@@ -0,0 +1,221 @@
+from distutils import log
+import distutils.command.sdist as orig
+import os
+import sys
+import io
+import contextlib
+
+from setuptools.extern import six
+
+from .py36compat import sdist_add_defaults
+
+import pkg_resources
+
+_default_revctrl = list
+
+
+def walk_revctrl(dirname=''):
+    """Find all files under revision control"""
+    for ep in pkg_resources.iter_entry_points('setuptools.file_finders'):
+        for item in ep.load()(dirname):
+            yield item
+
+
+class sdist(sdist_add_defaults, orig.sdist):
+    """Smart sdist that finds anything supported by revision control"""
+
+    user_options = [
+        ('formats=', None,
+         "formats for source distribution (comma-separated list)"),
+        ('keep-temp', 'k',
+         "keep the distribution tree around after creating " +
+         "archive file(s)"),
+        ('dist-dir=', 'd',
+         "directory to put the source distribution archive(s) in "
+         "[default: dist]"),
+    ]
+
+    negative_opt = {}
+
+    README_EXTENSIONS = ['', '.rst', '.txt', '.md']
+    READMES = tuple('README{0}'.format(ext) for ext in README_EXTENSIONS)
+
+    def run(self):
+        self.run_command('egg_info')
+        ei_cmd = self.get_finalized_command('egg_info')
+        self.filelist = ei_cmd.filelist
+        self.filelist.append(os.path.join(ei_cmd.egg_info, 'SOURCES.txt'))
+        self.check_readme()
+
+        # Run sub commands
+        for cmd_name in self.get_sub_commands():
+            self.run_command(cmd_name)
+
+        self.make_distribution()
+
+        dist_files = getattr(self.distribution, 'dist_files', [])
+        for file in self.archive_files:
+            data = ('sdist', '', file)
+            if data not in dist_files:
+                dist_files.append(data)
+
+    def initialize_options(self):
+        orig.sdist.initialize_options(self)
+
+        self._default_to_gztar()
+
+    def _default_to_gztar(self):
+        # only needed on Python prior to 3.6.
+        if sys.version_info >= (3, 6, 0, 'beta', 1):
+            return
+        self.formats = ['gztar']
+
+    def make_distribution(self):
+        """
+        Workaround for #516
+        """
+        with self._remove_os_link():
+            orig.sdist.make_distribution(self)
+
+    @staticmethod
+    @contextlib.contextmanager
+    def _remove_os_link():
+        """
+        In a context, remove and restore os.link if it exists
+        """
+
+        class NoValue:
+            pass
+
+        orig_val = getattr(os, 'link', NoValue)
+        try:
+            del os.link
+        except Exception:
+            pass
+        try:
+            yield
+        finally:
+            if orig_val is not NoValue:
+                setattr(os, 'link', orig_val)
+
+    def __read_template_hack(self):
+        # This grody hack closes the template file (MANIFEST.in) if an
+        #  exception occurs during read_template.
+        # Doing so prevents an error when easy_install attempts to delete the
+        #  file.
+        try:
+            orig.sdist.read_template(self)
+        except Exception:
+            _, _, tb = sys.exc_info()
+            tb.tb_next.tb_frame.f_locals['template'].close()
+            raise
+
+    # Beginning with Python 2.7.2, 3.1.4, and 3.2.1, this leaky file handle
+    #  has been fixed, so only override the method if we're using an earlier
+    #  Python.
+    has_leaky_handle = (
+        sys.version_info < (2, 7, 2)
+        or (3, 0) <= sys.version_info < (3, 1, 4)
+        or (3, 2) <= sys.version_info < (3, 2, 1)
+    )
+    if has_leaky_handle:
+        read_template = __read_template_hack
+
+    def _add_defaults_python(self):
+        """getting python files"""
+        if self.distribution.has_pure_modules():
+            build_py = self.get_finalized_command('build_py')
+            self.filelist.extend(build_py.get_source_files())
+            # This functionality is incompatible with include_package_data, and
+            # will in fact create an infinite recursion if include_package_data
+            # is True.  Use of include_package_data will imply that
+            # distutils-style automatic handling of package_data is disabled
+            if not self.distribution.include_package_data:
+                for _, src_dir, _, filenames in build_py.data_files:
+                    self.filelist.extend([os.path.join(src_dir, filename)
+                                          for filename in filenames])
+
+    def _add_defaults_data_files(self):
+        try:
+            if six.PY2:
+                sdist_add_defaults._add_defaults_data_files(self)
+            else:
+                super()._add_defaults_data_files()
+        except TypeError:
+            log.warn("data_files contains unexpected objects")
+
+    def check_readme(self):
+        for f in self.READMES:
+            if os.path.exists(f):
+                return
+        else:
+            self.warn(
+                "standard file not found: should have one of " +
+                ', '.join(self.READMES)
+            )
+
+    def make_release_tree(self, base_dir, files):
+        orig.sdist.make_release_tree(self, base_dir, files)
+
+        # Save any egg_info command line options used to create this sdist
+        dest = os.path.join(base_dir, 'setup.cfg')
+        if hasattr(os, 'link') and os.path.exists(dest):
+            # unlink and re-copy, since it might be hard-linked, and
+            # we don't want to change the source version
+            os.unlink(dest)
+            self.copy_file('setup.cfg', dest)
+
+        self.get_finalized_command('egg_info').save_version_info(dest)
+
+    def _manifest_is_not_generated(self):
+        # check for special comment used in 2.7.1 and higher
+        if not os.path.isfile(self.manifest):
+            return False
+
+        with io.open(self.manifest, 'rb') as fp:
+            first_line = fp.readline()
+        return (first_line !=
+                '# file GENERATED by distutils, do NOT edit\n'.encode())
+
+    def read_manifest(self):
+        """Read the manifest file (named by 'self.manifest') and use it to
+        fill in 'self.filelist', the list of files to include in the source
+        distribution.
+        """
+        log.info("reading manifest file '%s'", self.manifest)
+        manifest = open(self.manifest, 'rb')
+        for line in manifest:
+            # The manifest must contain UTF-8. See #303.
+            if six.PY3:
+                try:
+                    line = line.decode('UTF-8')
+                except UnicodeDecodeError:
+                    log.warn("%r not UTF-8 decodable -- skipping" % line)
+                    continue
+            # ignore comments and blank lines
+            line = line.strip()
+            if line.startswith('#') or not line:
+                continue
+            self.filelist.append(line)
+        manifest.close()
+
+    def check_license(self):
+        """Checks if license_file' is configured and adds it to
+        'self.filelist' if the value contains a valid path.
+        """
+
+        opts = self.distribution.get_option_dict('metadata')
+
+        # ignore the source of the value
+        _, license_file = opts.get('license_file', (None, None))
+
+        if license_file is None:
+            log.debug("'license_file' option was not specified")
+            return
+
+        if not os.path.exists(license_file):
+            log.warn("warning: Failed to find the configured license file '%s'",
+                    license_file)
+            return
+
+        self.filelist.append(license_file)
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/sdist.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/sdist.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..cb9285e707873efb7792f6b5eaf164ce00a1c8e7
GIT binary patch
literal 9479
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
MfQg5RjhTlX0DbGZ8vp<R

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/setopt.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/setopt.py
new file mode 100644
index 0000000..7e57cc0
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/setopt.py
@@ -0,0 +1,149 @@
+from distutils.util import convert_path
+from distutils import log
+from distutils.errors import DistutilsOptionError
+import distutils
+import os
+
+from setuptools.extern.six.moves import configparser
+
+from setuptools import Command
+
+__all__ = ['config_file', 'edit_config', 'option_base', 'setopt']
+
+
+def config_file(kind="local"):
+    """Get the filename of the distutils, local, global, or per-user config
+
+    `kind` must be one of "local", "global", or "user"
+    """
+    if kind == 'local':
+        return 'setup.cfg'
+    if kind == 'global':
+        return os.path.join(
+            os.path.dirname(distutils.__file__), 'distutils.cfg'
+        )
+    if kind == 'user':
+        dot = os.name == 'posix' and '.' or ''
+        return os.path.expanduser(convert_path("~/%spydistutils.cfg" % dot))
+    raise ValueError(
+        "config_file() type must be 'local', 'global', or 'user'", kind
+    )
+
+
+def edit_config(filename, settings, dry_run=False):
+    """Edit a configuration file to include `settings`
+
+    `settings` is a dictionary of dictionaries or ``None`` values, keyed by
+    command/section name.  A ``None`` value means to delete the entire section,
+    while a dictionary lists settings to be changed or deleted in that section.
+    A setting of ``None`` means to delete that setting.
+    """
+    log.debug("Reading configuration from %s", filename)
+    opts = configparser.RawConfigParser()
+    opts.read([filename])
+    for section, options in settings.items():
+        if options is None:
+            log.info("Deleting section [%s] from %s", section, filename)
+            opts.remove_section(section)
+        else:
+            if not opts.has_section(section):
+                log.debug("Adding new section [%s] to %s", section, filename)
+                opts.add_section(section)
+            for option, value in options.items():
+                if value is None:
+                    log.debug(
+                        "Deleting %s.%s from %s",
+                        section, option, filename
+                    )
+                    opts.remove_option(section, option)
+                    if not opts.options(section):
+                        log.info("Deleting empty [%s] section from %s",
+                                 section, filename)
+                        opts.remove_section(section)
+                else:
+                    log.debug(
+                        "Setting %s.%s to %r in %s",
+                        section, option, value, filename
+                    )
+                    opts.set(section, option, value)
+
+    log.info("Writing %s", filename)
+    if not dry_run:
+        with open(filename, 'w') as f:
+            opts.write(f)
+
+
+class option_base(Command):
+    """Abstract base class for commands that mess with config files"""
+
+    user_options = [
+        ('global-config', 'g',
+         "save options to the site-wide distutils.cfg file"),
+        ('user-config', 'u',
+         "save options to the current user's pydistutils.cfg file"),
+        ('filename=', 'f',
+         "configuration file to use (default=setup.cfg)"),
+    ]
+
+    boolean_options = [
+        'global-config', 'user-config',
+    ]
+
+    def initialize_options(self):
+        self.global_config = None
+        self.user_config = None
+        self.filename = None
+
+    def finalize_options(self):
+        filenames = []
+        if self.global_config:
+            filenames.append(config_file('global'))
+        if self.user_config:
+            filenames.append(config_file('user'))
+        if self.filename is not None:
+            filenames.append(self.filename)
+        if not filenames:
+            filenames.append(config_file('local'))
+        if len(filenames) > 1:
+            raise DistutilsOptionError(
+                "Must specify only one configuration file option",
+                filenames
+            )
+        self.filename, = filenames
+
+
+class setopt(option_base):
+    """Save command-line options to a file"""
+
+    description = "set an option in setup.cfg or another config file"
+
+    user_options = [
+        ('command=', 'c', 'command to set an option for'),
+        ('option=', 'o', 'option to set'),
+        ('set-value=', 's', 'value of the option'),
+        ('remove', 'r', 'remove (unset) the value'),
+    ] + option_base.user_options
+
+    boolean_options = option_base.boolean_options + ['remove']
+
+    def initialize_options(self):
+        option_base.initialize_options(self)
+        self.command = None
+        self.option = None
+        self.set_value = None
+        self.remove = None
+
+    def finalize_options(self):
+        option_base.finalize_options(self)
+        if self.command is None or self.option is None:
+            raise DistutilsOptionError("Must specify --command *and* --option")
+        if self.set_value is None and not self.remove:
+            raise DistutilsOptionError("Must specify --set-value or --remove")
+
+    def run(self):
+        edit_config(
+            self.filename, {
+                self.command: {self.option.replace('-', '_'): self.set_value}
+            },
+            self.dry_run
+        )
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/setopt.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/setopt.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..05de856cfa24e38d32e4e75c49ca20d639f4ee6a
GIT binary patch
literal 6596
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
L^9b{3i>U(uX9G^m

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/test.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/test.py
new file mode 100644
index 0000000..973e4eb
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/test.py
@@ -0,0 +1,271 @@
+import os
+import operator
+import sys
+import contextlib
+import itertools
+import unittest
+from distutils.errors import DistutilsError, DistutilsOptionError
+from distutils import log
+from unittest import TestLoader
+
+from setuptools.extern import six
+from setuptools.extern.six.moves import map, filter
+
+from pkg_resources import (resource_listdir, resource_exists, normalize_path,
+                           working_set, _namespace_packages, evaluate_marker,
+                           add_activation_listener, require, EntryPoint)
+from setuptools import Command
+from .build_py import _unique_everseen
+
+__metaclass__ = type
+
+
+class ScanningLoader(TestLoader):
+
+    def __init__(self):
+        TestLoader.__init__(self)
+        self._visited = set()
+
+    def loadTestsFromModule(self, module, pattern=None):
+        """Return a suite of all tests cases contained in the given module
+
+        If the module is a package, load tests from all the modules in it.
+        If the module has an ``additional_tests`` function, call it and add
+        the return value to the tests.
+        """
+        if module in self._visited:
+            return None
+        self._visited.add(module)
+
+        tests = []
+        tests.append(TestLoader.loadTestsFromModule(self, module))
+
+        if hasattr(module, "additional_tests"):
+            tests.append(module.additional_tests())
+
+        if hasattr(module, '__path__'):
+            for file in resource_listdir(module.__name__, ''):
+                if file.endswith('.py') and file != '__init__.py':
+                    submodule = module.__name__ + '.' + file[:-3]
+                else:
+                    if resource_exists(module.__name__, file + '/__init__.py'):
+                        submodule = module.__name__ + '.' + file
+                    else:
+                        continue
+                tests.append(self.loadTestsFromName(submodule))
+
+        if len(tests) != 1:
+            return self.suiteClass(tests)
+        else:
+            return tests[0]  # don't create a nested suite for only one return
+
+
+# adapted from jaraco.classes.properties:NonDataProperty
+class NonDataProperty:
+    def __init__(self, fget):
+        self.fget = fget
+
+    def __get__(self, obj, objtype=None):
+        if obj is None:
+            return self
+        return self.fget(obj)
+
+
+class test(Command):
+    """Command to run unit tests after in-place build"""
+
+    description = "run unit tests after in-place build"
+
+    user_options = [
+        ('test-module=', 'm', "Run 'test_suite' in specified module"),
+        ('test-suite=', 's',
+         "Run single test, case or suite (e.g. 'module.test_suite')"),
+        ('test-runner=', 'r', "Test runner to use"),
+    ]
+
+    def initialize_options(self):
+        self.test_suite = None
+        self.test_module = None
+        self.test_loader = None
+        self.test_runner = None
+
+    def finalize_options(self):
+
+        if self.test_suite and self.test_module:
+            msg = "You may specify a module or a suite, but not both"
+            raise DistutilsOptionError(msg)
+
+        if self.test_suite is None:
+            if self.test_module is None:
+                self.test_suite = self.distribution.test_suite
+            else:
+                self.test_suite = self.test_module + ".test_suite"
+
+        if self.test_loader is None:
+            self.test_loader = getattr(self.distribution, 'test_loader', None)
+        if self.test_loader is None:
+            self.test_loader = "setuptools.command.test:ScanningLoader"
+        if self.test_runner is None:
+            self.test_runner = getattr(self.distribution, 'test_runner', None)
+
+    @NonDataProperty
+    def test_args(self):
+        return list(self._test_args())
+
+    def _test_args(self):
+        if not self.test_suite and sys.version_info >= (2, 7):
+            yield 'discover'
+        if self.verbose:
+            yield '--verbose'
+        if self.test_suite:
+            yield self.test_suite
+
+    def with_project_on_sys_path(self, func):
+        """
+        Backward compatibility for project_on_sys_path context.
+        """
+        with self.project_on_sys_path():
+            func()
+
+    @contextlib.contextmanager
+    def project_on_sys_path(self, include_dists=[]):
+        with_2to3 = six.PY3 and getattr(self.distribution, 'use_2to3', False)
+
+        if with_2to3:
+            # If we run 2to3 we can not do this inplace:
+
+            # Ensure metadata is up-to-date
+            self.reinitialize_command('build_py', inplace=0)
+            self.run_command('build_py')
+            bpy_cmd = self.get_finalized_command("build_py")
+            build_path = normalize_path(bpy_cmd.build_lib)
+
+            # Build extensions
+            self.reinitialize_command('egg_info', egg_base=build_path)
+            self.run_command('egg_info')
+
+            self.reinitialize_command('build_ext', inplace=0)
+            self.run_command('build_ext')
+        else:
+            # Without 2to3 inplace works fine:
+            self.run_command('egg_info')
+
+            # Build extensions in-place
+            self.reinitialize_command('build_ext', inplace=1)
+            self.run_command('build_ext')
+
+        ei_cmd = self.get_finalized_command("egg_info")
+
+        old_path = sys.path[:]
+        old_modules = sys.modules.copy()
+
+        try:
+            project_path = normalize_path(ei_cmd.egg_base)
+            sys.path.insert(0, project_path)
+            working_set.__init__()
+            add_activation_listener(lambda dist: dist.activate())
+            require('%s==%s' % (ei_cmd.egg_name, ei_cmd.egg_version))
+            with self.paths_on_pythonpath([project_path]):
+                yield
+        finally:
+            sys.path[:] = old_path
+            sys.modules.clear()
+            sys.modules.update(old_modules)
+            working_set.__init__()
+
+    @staticmethod
+    @contextlib.contextmanager
+    def paths_on_pythonpath(paths):
+        """
+        Add the indicated paths to the head of the PYTHONPATH environment
+        variable so that subprocesses will also see the packages at
+        these paths.
+
+        Do this in a context that restores the value on exit.
+        """
+        nothing = object()
+        orig_pythonpath = os.environ.get('PYTHONPATH', nothing)
+        current_pythonpath = os.environ.get('PYTHONPATH', '')
+        try:
+            prefix = os.pathsep.join(_unique_everseen(paths))
+            to_join = filter(None, [prefix, current_pythonpath])
+            new_path = os.pathsep.join(to_join)
+            if new_path:
+                os.environ['PYTHONPATH'] = new_path
+            yield
+        finally:
+            if orig_pythonpath is nothing:
+                os.environ.pop('PYTHONPATH', None)
+            else:
+                os.environ['PYTHONPATH'] = orig_pythonpath
+
+    @staticmethod
+    def install_dists(dist):
+        """
+        Install the requirements indicated by self.distribution and
+        return an iterable of the dists that were built.
+        """
+        ir_d = dist.fetch_build_eggs(dist.install_requires)
+        tr_d = dist.fetch_build_eggs(dist.tests_require or [])
+        er_d = dist.fetch_build_eggs(
+            v for k, v in dist.extras_require.items()
+            if k.startswith(':') and evaluate_marker(k[1:])
+        )
+        return itertools.chain(ir_d, tr_d, er_d)
+
+    def run(self):
+        installed_dists = self.install_dists(self.distribution)
+
+        cmd = ' '.join(self._argv)
+        if self.dry_run:
+            self.announce('skipping "%s" (dry run)' % cmd)
+            return
+
+        self.announce('running "%s"' % cmd)
+
+        paths = map(operator.attrgetter('location'), installed_dists)
+        with self.paths_on_pythonpath(paths):
+            with self.project_on_sys_path():
+                self.run_tests()
+
+    def run_tests(self):
+        # Purge modules under test from sys.modules. The test loader will
+        # re-import them from the build location. Required when 2to3 is used
+        # with namespace packages.
+        if six.PY3 and getattr(self.distribution, 'use_2to3', False):
+            module = self.test_suite.split('.')[0]
+            if module in _namespace_packages:
+                del_modules = []
+                if module in sys.modules:
+                    del_modules.append(module)
+                module += '.'
+                for name in sys.modules:
+                    if name.startswith(module):
+                        del_modules.append(name)
+                list(map(sys.modules.__delitem__, del_modules))
+
+        test = unittest.main(
+            None, None, self._argv,
+            testLoader=self._resolve_as_ep(self.test_loader),
+            testRunner=self._resolve_as_ep(self.test_runner),
+            exit=False,
+        )
+        if not test.result.wasSuccessful():
+            msg = 'Test failed: %s' % test.result
+            self.announce(msg, log.ERROR)
+            raise DistutilsError(msg)
+
+    @property
+    def _argv(self):
+        return ['unittest'] + self.test_args
+
+    @staticmethod
+    def _resolve_as_ep(val):
+        """
+        Load the indicated attribute value, called, as a as if it were
+        specified as an entry point.
+        """
+        if val is None:
+            return
+        parsed = EntryPoint.parse("x=" + val)
+        return parsed.resolve()()
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/test.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/test.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..57cd6070f82ff1ee84fa60bd2889133b7348c1df
GIT binary patch
literal 11758
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

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/upload.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/upload.py
new file mode 100644
index 0000000..6db8888
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/upload.py
@@ -0,0 +1,196 @@
+import io
+import os
+import hashlib
+import getpass
+
+from base64 import standard_b64encode
+
+from distutils import log
+from distutils.command import upload as orig
+from distutils.spawn import spawn
+
+from distutils.errors import DistutilsError
+
+from setuptools.extern.six.moves.urllib.request import urlopen, Request
+from setuptools.extern.six.moves.urllib.error import HTTPError
+from setuptools.extern.six.moves.urllib.parse import urlparse
+
+
+class upload(orig.upload):
+    """
+    Override default upload behavior to obtain password
+    in a variety of different ways.
+    """
+    def run(self):
+        try:
+            orig.upload.run(self)
+        finally:
+            self.announce(
+                "WARNING: Uploading via this command is deprecated, use twine "
+                "to upload instead (https://pypi.org/p/twine/)",
+                log.WARN
+            )
+
+    def finalize_options(self):
+        orig.upload.finalize_options(self)
+        self.username = (
+            self.username or
+            getpass.getuser()
+        )
+        # Attempt to obtain password. Short circuit evaluation at the first
+        # sign of success.
+        self.password = (
+            self.password or
+            self._load_password_from_keyring() or
+            self._prompt_for_password()
+        )
+
+    def upload_file(self, command, pyversion, filename):
+        # Makes sure the repository URL is compliant
+        schema, netloc, url, params, query, fragments = \
+            urlparse(self.repository)
+        if params or query or fragments:
+            raise AssertionError("Incompatible url %s" % self.repository)
+
+        if schema not in ('http', 'https'):
+            raise AssertionError("unsupported schema " + schema)
+
+        # Sign if requested
+        if self.sign:
+            gpg_args = ["gpg", "--detach-sign", "-a", filename]
+            if self.identity:
+                gpg_args[2:2] = ["--local-user", self.identity]
+            spawn(gpg_args,
+                  dry_run=self.dry_run)
+
+        # Fill in the data - send all the meta-data in case we need to
+        # register a new release
+        with open(filename, 'rb') as f:
+            content = f.read()
+
+        meta = self.distribution.metadata
+
+        data = {
+            # action
+            ':action': 'file_upload',
+            'protocol_version': '1',
+
+            # identify release
+            'name': meta.get_name(),
+            'version': meta.get_version(),
+
+            # file content
+            'content': (os.path.basename(filename), content),
+            'filetype': command,
+            'pyversion': pyversion,
+            'md5_digest': hashlib.md5(content).hexdigest(),
+
+            # additional meta-data
+            'metadata_version': str(meta.get_metadata_version()),
+            'summary': meta.get_description(),
+            'home_page': meta.get_url(),
+            'author': meta.get_contact(),
+            'author_email': meta.get_contact_email(),
+            'license': meta.get_licence(),
+            'description': meta.get_long_description(),
+            'keywords': meta.get_keywords(),
+            'platform': meta.get_platforms(),
+            'classifiers': meta.get_classifiers(),
+            'download_url': meta.get_download_url(),
+            # PEP 314
+            'provides': meta.get_provides(),
+            'requires': meta.get_requires(),
+            'obsoletes': meta.get_obsoletes(),
+            }
+
+        data['comment'] = ''
+
+        if self.sign:
+            data['gpg_signature'] = (os.path.basename(filename) + ".asc",
+                                     open(filename+".asc", "rb").read())
+
+        # set up the authentication
+        user_pass = (self.username + ":" + self.password).encode('ascii')
+        # The exact encoding of the authentication string is debated.
+        # Anyway PyPI only accepts ascii for both username or password.
+        auth = "Basic " + standard_b64encode(user_pass).decode('ascii')
+
+        # Build up the MIME payload for the POST data
+        boundary = '--------------GHSKFJDLGDS7543FJKLFHRE75642756743254'
+        sep_boundary = b'\r\n--' + boundary.encode('ascii')
+        end_boundary = sep_boundary + b'--\r\n'
+        body = io.BytesIO()
+        for key, value in data.items():
+            title = '\r\nContent-Disposition: form-data; name="%s"' % key
+            # handle multiple entries for the same name
+            if not isinstance(value, list):
+                value = [value]
+            for value in value:
+                if type(value) is tuple:
+                    title += '; filename="%s"' % value[0]
+                    value = value[1]
+                else:
+                    value = str(value).encode('utf-8')
+                body.write(sep_boundary)
+                body.write(title.encode('utf-8'))
+                body.write(b"\r\n\r\n")
+                body.write(value)
+        body.write(end_boundary)
+        body = body.getvalue()
+
+        msg = "Submitting %s to %s" % (filename, self.repository)
+        self.announce(msg, log.INFO)
+
+        # build the Request
+        headers = {
+            'Content-type': 'multipart/form-data; boundary=%s' % boundary,
+            'Content-length': str(len(body)),
+            'Authorization': auth,
+        }
+
+        request = Request(self.repository, data=body,
+                          headers=headers)
+        # send the data
+        try:
+            result = urlopen(request)
+            status = result.getcode()
+            reason = result.msg
+        except HTTPError as e:
+            status = e.code
+            reason = e.msg
+        except OSError as e:
+            self.announce(str(e), log.ERROR)
+            raise
+
+        if status == 200:
+            self.announce('Server response (%s): %s' % (status, reason),
+                          log.INFO)
+            if self.show_response:
+                text = getattr(self, '_read_pypi_response',
+                               lambda x: None)(result)
+                if text is not None:
+                    msg = '\n'.join(('-' * 75, text, '-' * 75))
+                    self.announce(msg, log.INFO)
+        else:
+            msg = 'Upload failed (%s): %s' % (status, reason)
+            self.announce(msg, log.ERROR)
+            raise DistutilsError(msg)
+
+    def _load_password_from_keyring(self):
+        """
+        Attempt to load password from keyring. Suppress Exceptions.
+        """
+        try:
+            keyring = __import__('keyring')
+            return keyring.get_password(self.repository, self.username)
+        except Exception:
+            pass
+
+    def _prompt_for_password(self):
+        """
+        Prompt for a password on the tty. Suppress Exceptions.
+        """
+        try:
+            return getpass.getpass()
+        except (Exception, KeyboardInterrupt):
+            pass
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/upload.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/upload.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..aa61920582fcbc98a63d93d67aaf78314a824639
GIT binary patch
literal 6915
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
M6krly5(Cl904!%(PXGV_

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/upload_docs.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/upload_docs.py
new file mode 100644
index 0000000..07aa564
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/upload_docs.py
@@ -0,0 +1,206 @@
+# -*- coding: utf-8 -*-
+"""upload_docs
+
+Implements a Distutils 'upload_docs' subcommand (upload documentation to
+PyPI's pythonhosted.org).
+"""
+
+from base64 import standard_b64encode
+from distutils import log
+from distutils.errors import DistutilsOptionError
+import os
+import socket
+import zipfile
+import tempfile
+import shutil
+import itertools
+import functools
+
+from setuptools.extern import six
+from setuptools.extern.six.moves import http_client, urllib
+
+from pkg_resources import iter_entry_points
+from .upload import upload
+
+
+def _encode(s):
+    errors = 'surrogateescape' if six.PY3 else 'strict'
+    return s.encode('utf-8', errors)
+
+
+class upload_docs(upload):
+    # override the default repository as upload_docs isn't
+    # supported by Warehouse (and won't be).
+    DEFAULT_REPOSITORY = 'https://pypi.python.org/pypi/'
+
+    description = 'Upload documentation to PyPI'
+
+    user_options = [
+        ('repository=', 'r',
+         "url of repository [default: %s]" % upload.DEFAULT_REPOSITORY),
+        ('show-response', None,
+         'display full response text from server'),
+        ('upload-dir=', None, 'directory to upload'),
+    ]
+    boolean_options = upload.boolean_options
+
+    def has_sphinx(self):
+        if self.upload_dir is None:
+            for ep in iter_entry_points('distutils.commands', 'build_sphinx'):
+                return True
+
+    sub_commands = [('build_sphinx', has_sphinx)]
+
+    def initialize_options(self):
+        upload.initialize_options(self)
+        self.upload_dir = None
+        self.target_dir = None
+
+    def finalize_options(self):
+        upload.finalize_options(self)
+        if self.upload_dir is None:
+            if self.has_sphinx():
+                build_sphinx = self.get_finalized_command('build_sphinx')
+                self.target_dir = build_sphinx.builder_target_dir
+            else:
+                build = self.get_finalized_command('build')
+                self.target_dir = os.path.join(build.build_base, 'docs')
+        else:
+            self.ensure_dirname('upload_dir')
+            self.target_dir = self.upload_dir
+        if 'pypi.python.org' in self.repository:
+            log.warn("Upload_docs command is deprecated. Use RTD instead.")
+        self.announce('Using upload directory %s' % self.target_dir)
+
+    def create_zipfile(self, filename):
+        zip_file = zipfile.ZipFile(filename, "w")
+        try:
+            self.mkpath(self.target_dir)  # just in case
+            for root, dirs, files in os.walk(self.target_dir):
+                if root == self.target_dir and not files:
+                    tmpl = "no files found in upload directory '%s'"
+                    raise DistutilsOptionError(tmpl % self.target_dir)
+                for name in files:
+                    full = os.path.join(root, name)
+                    relative = root[len(self.target_dir):].lstrip(os.path.sep)
+                    dest = os.path.join(relative, name)
+                    zip_file.write(full, dest)
+        finally:
+            zip_file.close()
+
+    def run(self):
+        # Run sub commands
+        for cmd_name in self.get_sub_commands():
+            self.run_command(cmd_name)
+
+        tmp_dir = tempfile.mkdtemp()
+        name = self.distribution.metadata.get_name()
+        zip_file = os.path.join(tmp_dir, "%s.zip" % name)
+        try:
+            self.create_zipfile(zip_file)
+            self.upload_file(zip_file)
+        finally:
+            shutil.rmtree(tmp_dir)
+
+    @staticmethod
+    def _build_part(item, sep_boundary):
+        key, values = item
+        title = '\nContent-Disposition: form-data; name="%s"' % key
+        # handle multiple entries for the same name
+        if not isinstance(values, list):
+            values = [values]
+        for value in values:
+            if isinstance(value, tuple):
+                title += '; filename="%s"' % value[0]
+                value = value[1]
+            else:
+                value = _encode(value)
+            yield sep_boundary
+            yield _encode(title)
+            yield b"\n\n"
+            yield value
+            if value and value[-1:] == b'\r':
+                yield b'\n'  # write an extra newline (lurve Macs)
+
+    @classmethod
+    def _build_multipart(cls, data):
+        """
+        Build up the MIME payload for the POST data
+        """
+        boundary = b'--------------GHSKFJDLGDS7543FJKLFHRE75642756743254'
+        sep_boundary = b'\n--' + boundary
+        end_boundary = sep_boundary + b'--'
+        end_items = end_boundary, b"\n",
+        builder = functools.partial(
+            cls._build_part,
+            sep_boundary=sep_boundary,
+        )
+        part_groups = map(builder, data.items())
+        parts = itertools.chain.from_iterable(part_groups)
+        body_items = itertools.chain(parts, end_items)
+        content_type = 'multipart/form-data; boundary=%s' % boundary.decode('ascii')
+        return b''.join(body_items), content_type
+
+    def upload_file(self, filename):
+        with open(filename, 'rb') as f:
+            content = f.read()
+        meta = self.distribution.metadata
+        data = {
+            ':action': 'doc_upload',
+            'name': meta.get_name(),
+            'content': (os.path.basename(filename), content),
+        }
+        # set up the authentication
+        credentials = _encode(self.username + ':' + self.password)
+        credentials = standard_b64encode(credentials)
+        if six.PY3:
+            credentials = credentials.decode('ascii')
+        auth = "Basic " + credentials
+
+        body, ct = self._build_multipart(data)
+
+        msg = "Submitting documentation to %s" % (self.repository)
+        self.announce(msg, log.INFO)
+
+        # build the Request
+        # We can't use urllib2 since we need to send the Basic
+        # auth right with the first request
+        schema, netloc, url, params, query, fragments = \
+            urllib.parse.urlparse(self.repository)
+        assert not params and not query and not fragments
+        if schema == 'http':
+            conn = http_client.HTTPConnection(netloc)
+        elif schema == 'https':
+            conn = http_client.HTTPSConnection(netloc)
+        else:
+            raise AssertionError("unsupported schema " + schema)
+
+        data = ''
+        try:
+            conn.connect()
+            conn.putrequest("POST", url)
+            content_type = ct
+            conn.putheader('Content-type', content_type)
+            conn.putheader('Content-length', str(len(body)))
+            conn.putheader('Authorization', auth)
+            conn.endheaders()
+            conn.send(body)
+        except socket.error as e:
+            self.announce(str(e), log.ERROR)
+            return
+
+        r = conn.getresponse()
+        if r.status == 200:
+            msg = 'Server response (%s): %s' % (r.status, r.reason)
+            self.announce(msg, log.INFO)
+        elif r.status == 301:
+            location = r.getheader('Location')
+            if location is None:
+                location = 'https://pythonhosted.org/%s/' % meta.get_name()
+            msg = 'Upload successful. Visit %s' % location
+            self.announce(msg, log.INFO)
+        else:
+            msg = 'Upload failed (%s): %s' % (r.status, r.reason)
+            self.announce(msg, log.ERROR)
+        if self.show_response:
+            print('-' * 75, r.read(), '-' * 75)
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/upload_docs.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/command/upload_docs.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..a78ac571de3193d342ccb8cbe2df688382184aae
GIT binary patch
literal 8436
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

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/config.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/config.py
new file mode 100644
index 0000000..b662604
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/config.py
@@ -0,0 +1,656 @@
+from __future__ import absolute_import, unicode_literals
+import io
+import os
+import sys
+
+import warnings
+import functools
+from collections import defaultdict
+from functools import partial
+from functools import wraps
+from importlib import import_module
+
+from distutils.errors import DistutilsOptionError, DistutilsFileError
+from setuptools.extern.packaging.version import LegacyVersion, parse
+from setuptools.extern.six import string_types, PY3
+
+
+__metaclass__ = type
+
+
+def read_configuration(
+        filepath, find_others=False, ignore_option_errors=False):
+    """Read given configuration file and returns options from it as a dict.
+
+    :param str|unicode filepath: Path to configuration file
+        to get options from.
+
+    :param bool find_others: Whether to search for other configuration files
+        which could be on in various places.
+
+    :param bool ignore_option_errors: Whether to silently ignore
+        options, values of which could not be resolved (e.g. due to exceptions
+        in directives such as file:, attr:, etc.).
+        If False exceptions are propagated as expected.
+
+    :rtype: dict
+    """
+    from setuptools.dist import Distribution, _Distribution
+
+    filepath = os.path.abspath(filepath)
+
+    if not os.path.isfile(filepath):
+        raise DistutilsFileError(
+            'Configuration file %s does not exist.' % filepath)
+
+    current_directory = os.getcwd()
+    os.chdir(os.path.dirname(filepath))
+
+    try:
+        dist = Distribution()
+
+        filenames = dist.find_config_files() if find_others else []
+        if filepath not in filenames:
+            filenames.append(filepath)
+
+        _Distribution.parse_config_files(dist, filenames=filenames)
+
+        handlers = parse_configuration(
+            dist, dist.command_options,
+            ignore_option_errors=ignore_option_errors)
+
+    finally:
+        os.chdir(current_directory)
+
+    return configuration_to_dict(handlers)
+
+
+def _get_option(target_obj, key):
+    """
+    Given a target object and option key, get that option from
+    the target object, either through a get_{key} method or
+    from an attribute directly.
+    """
+    getter_name = 'get_{key}'.format(**locals())
+    by_attribute = functools.partial(getattr, target_obj, key)
+    getter = getattr(target_obj, getter_name, by_attribute)
+    return getter()
+
+
+def configuration_to_dict(handlers):
+    """Returns configuration data gathered by given handlers as a dict.
+
+    :param list[ConfigHandler] handlers: Handlers list,
+        usually from parse_configuration()
+
+    :rtype: dict
+    """
+    config_dict = defaultdict(dict)
+
+    for handler in handlers:
+        for option in handler.set_options:
+            value = _get_option(handler.target_obj, option)
+            config_dict[handler.section_prefix][option] = value
+
+    return config_dict
+
+
+def parse_configuration(
+        distribution, command_options, ignore_option_errors=False):
+    """Performs additional parsing of configuration options
+    for a distribution.
+
+    Returns a list of used option handlers.
+
+    :param Distribution distribution:
+    :param dict command_options:
+    :param bool ignore_option_errors: Whether to silently ignore
+        options, values of which could not be resolved (e.g. due to exceptions
+        in directives such as file:, attr:, etc.).
+        If False exceptions are propagated as expected.
+    :rtype: list
+    """
+    options = ConfigOptionsHandler(
+        distribution, command_options, ignore_option_errors)
+    options.parse()
+
+    meta = ConfigMetadataHandler(
+        distribution.metadata, command_options, ignore_option_errors,
+        distribution.package_dir)
+    meta.parse()
+
+    return meta, options
+
+
+class ConfigHandler:
+    """Handles metadata supplied in configuration files."""
+
+    section_prefix = None
+    """Prefix for config sections handled by this handler.
+    Must be provided by class heirs.
+
+    """
+
+    aliases = {}
+    """Options aliases.
+    For compatibility with various packages. E.g.: d2to1 and pbr.
+    Note: `-` in keys is replaced with `_` by config parser.
+
+    """
+
+    def __init__(self, target_obj, options, ignore_option_errors=False):
+        sections = {}
+
+        section_prefix = self.section_prefix
+        for section_name, section_options in options.items():
+            if not section_name.startswith(section_prefix):
+                continue
+
+            section_name = section_name.replace(section_prefix, '').strip('.')
+            sections[section_name] = section_options
+
+        self.ignore_option_errors = ignore_option_errors
+        self.target_obj = target_obj
+        self.sections = sections
+        self.set_options = []
+
+    @property
+    def parsers(self):
+        """Metadata item name to parser function mapping."""
+        raise NotImplementedError(
+            '%s must provide .parsers property' % self.__class__.__name__)
+
+    def __setitem__(self, option_name, value):
+        unknown = tuple()
+        target_obj = self.target_obj
+
+        # Translate alias into real name.
+        option_name = self.aliases.get(option_name, option_name)
+
+        current_value = getattr(target_obj, option_name, unknown)
+
+        if current_value is unknown:
+            raise KeyError(option_name)
+
+        if current_value:
+            # Already inhabited. Skipping.
+            return
+
+        skip_option = False
+        parser = self.parsers.get(option_name)
+        if parser:
+            try:
+                value = parser(value)
+
+            except Exception:
+                skip_option = True
+                if not self.ignore_option_errors:
+                    raise
+
+        if skip_option:
+            return
+
+        setter = getattr(target_obj, 'set_%s' % option_name, None)
+        if setter is None:
+            setattr(target_obj, option_name, value)
+        else:
+            setter(value)
+
+        self.set_options.append(option_name)
+
+    @classmethod
+    def _parse_list(cls, value, separator=','):
+        """Represents value as a list.
+
+        Value is split either by separator (defaults to comma) or by lines.
+
+        :param value:
+        :param separator: List items separator character.
+        :rtype: list
+        """
+        if isinstance(value, list):  # _get_parser_compound case
+            return value
+
+        if '\n' in value:
+            value = value.splitlines()
+        else:
+            value = value.split(separator)
+
+        return [chunk.strip() for chunk in value if chunk.strip()]
+
+    @classmethod
+    def _parse_dict(cls, value):
+        """Represents value as a dict.
+
+        :param value:
+        :rtype: dict
+        """
+        separator = '='
+        result = {}
+        for line in cls._parse_list(value):
+            key, sep, val = line.partition(separator)
+            if sep != separator:
+                raise DistutilsOptionError(
+                    'Unable to parse option value to dict: %s' % value)
+            result[key.strip()] = val.strip()
+
+        return result
+
+    @classmethod
+    def _parse_bool(cls, value):
+        """Represents value as boolean.
+
+        :param value:
+        :rtype: bool
+        """
+        value = value.lower()
+        return value in ('1', 'true', 'yes')
+
+    @classmethod
+    def _exclude_files_parser(cls, key):
+        """Returns a parser function to make sure field inputs
+        are not files.
+
+        Parses a value after getting the key so error messages are
+        more informative.
+
+        :param key:
+        :rtype: callable
+        """
+        def parser(value):
+            exclude_directive = 'file:'
+            if value.startswith(exclude_directive):
+                raise ValueError(
+                    'Only strings are accepted for the {0} field, '
+                    'files are not accepted'.format(key))
+            return value
+        return parser
+
+    @classmethod
+    def _parse_file(cls, value):
+        """Represents value as a string, allowing including text
+        from nearest files using `file:` directive.
+
+        Directive is sandboxed and won't reach anything outside
+        directory with setup.py.
+
+        Examples:
+            file: README.rst, CHANGELOG.md, src/file.txt
+
+        :param str value:
+        :rtype: str
+        """
+        include_directive = 'file:'
+
+        if not isinstance(value, string_types):
+            return value
+
+        if not value.startswith(include_directive):
+            return value
+
+        spec = value[len(include_directive):]
+        filepaths = (os.path.abspath(path.strip()) for path in spec.split(','))
+        return '\n'.join(
+            cls._read_file(path)
+            for path in filepaths
+            if (cls._assert_local(path) or True)
+            and os.path.isfile(path)
+        )
+
+    @staticmethod
+    def _assert_local(filepath):
+        if not filepath.startswith(os.getcwd()):
+            raise DistutilsOptionError(
+                '`file:` directive can not access %s' % filepath)
+
+    @staticmethod
+    def _read_file(filepath):
+        with io.open(filepath, encoding='utf-8') as f:
+            return f.read()
+
+    @classmethod
+    def _parse_attr(cls, value, package_dir=None):
+        """Represents value as a module attribute.
+
+        Examples:
+            attr: package.attr
+            attr: package.module.attr
+
+        :param str value:
+        :rtype: str
+        """
+        attr_directive = 'attr:'
+        if not value.startswith(attr_directive):
+            return value
+
+        attrs_path = value.replace(attr_directive, '').strip().split('.')
+        attr_name = attrs_path.pop()
+
+        module_name = '.'.join(attrs_path)
+        module_name = module_name or '__init__'
+
+        parent_path = os.getcwd()
+        if package_dir:
+            if attrs_path[0] in package_dir:
+                # A custom path was specified for the module we want to import
+                custom_path = package_dir[attrs_path[0]]
+                parts = custom_path.rsplit('/', 1)
+                if len(parts) > 1:
+                    parent_path = os.path.join(os.getcwd(), parts[0])
+                    module_name = parts[1]
+                else:
+                    module_name = custom_path
+            elif '' in package_dir:
+                # A custom parent directory was specified for all root modules
+                parent_path = os.path.join(os.getcwd(), package_dir[''])
+        sys.path.insert(0, parent_path)
+        try:
+            module = import_module(module_name)
+            value = getattr(module, attr_name)
+
+        finally:
+            sys.path = sys.path[1:]
+
+        return value
+
+    @classmethod
+    def _get_parser_compound(cls, *parse_methods):
+        """Returns parser function to represents value as a list.
+
+        Parses a value applying given methods one after another.
+
+        :param parse_methods:
+        :rtype: callable
+        """
+        def parse(value):
+            parsed = value
+
+            for method in parse_methods:
+                parsed = method(parsed)
+
+            return parsed
+
+        return parse
+
+    @classmethod
+    def _parse_section_to_dict(cls, section_options, values_parser=None):
+        """Parses section options into a dictionary.
+
+        Optionally applies a given parser to values.
+
+        :param dict section_options:
+        :param callable values_parser:
+        :rtype: dict
+        """
+        value = {}
+        values_parser = values_parser or (lambda val: val)
+        for key, (_, val) in section_options.items():
+            value[key] = values_parser(val)
+        return value
+
+    def parse_section(self, section_options):
+        """Parses configuration file section.
+
+        :param dict section_options:
+        """
+        for (name, (_, value)) in section_options.items():
+            try:
+                self[name] = value
+
+            except KeyError:
+                pass  # Keep silent for a new option may appear anytime.
+
+    def parse(self):
+        """Parses configuration file items from one
+        or more related sections.
+
+        """
+        for section_name, section_options in self.sections.items():
+
+            method_postfix = ''
+            if section_name:  # [section.option] variant
+                method_postfix = '_%s' % section_name
+
+            section_parser_method = getattr(
+                self,
+                # Dots in section names are translated into dunderscores.
+                ('parse_section%s' % method_postfix).replace('.', '__'),
+                None)
+
+            if section_parser_method is None:
+                raise DistutilsOptionError(
+                    'Unsupported distribution option section: [%s.%s]' % (
+                        self.section_prefix, section_name))
+
+            section_parser_method(section_options)
+
+    def _deprecated_config_handler(self, func, msg, warning_class):
+        """ this function will wrap around parameters that are deprecated
+
+        :param msg: deprecation message
+        :param warning_class: class of warning exception to be raised
+        :param func: function to be wrapped around
+        """
+        @wraps(func)
+        def config_handler(*args, **kwargs):
+            warnings.warn(msg, warning_class)
+            return func(*args, **kwargs)
+
+        return config_handler
+
+
+class ConfigMetadataHandler(ConfigHandler):
+
+    section_prefix = 'metadata'
+
+    aliases = {
+        'home_page': 'url',
+        'summary': 'description',
+        'classifier': 'classifiers',
+        'platform': 'platforms',
+    }
+
+    strict_mode = False
+    """We need to keep it loose, to be partially compatible with
+    `pbr` and `d2to1` packages which also uses `metadata` section.
+
+    """
+
+    def __init__(self, target_obj, options, ignore_option_errors=False,
+                 package_dir=None):
+        super(ConfigMetadataHandler, self).__init__(target_obj, options,
+                                                    ignore_option_errors)
+        self.package_dir = package_dir
+
+    @property
+    def parsers(self):
+        """Metadata item name to parser function mapping."""
+        parse_list = self._parse_list
+        parse_file = self._parse_file
+        parse_dict = self._parse_dict
+        exclude_files_parser = self._exclude_files_parser
+
+        return {
+            'platforms': parse_list,
+            'keywords': parse_list,
+            'provides': parse_list,
+            'requires': self._deprecated_config_handler(
+                parse_list,
+                "The requires parameter is deprecated, please use "
+                "install_requires for runtime dependencies.",
+                DeprecationWarning),
+            'obsoletes': parse_list,
+            'classifiers': self._get_parser_compound(parse_file, parse_list),
+            'license': exclude_files_parser('license'),
+            'description': parse_file,
+            'long_description': parse_file,
+            'version': self._parse_version,
+            'project_urls': parse_dict,
+        }
+
+    def _parse_version(self, value):
+        """Parses `version` option value.
+
+        :param value:
+        :rtype: str
+
+        """
+        version = self._parse_file(value)
+
+        if version != value:
+            version = version.strip()
+            # Be strict about versions loaded from file because it's easy to
+            # accidentally include newlines and other unintended content
+            if isinstance(parse(version), LegacyVersion):
+                tmpl = (
+                    'Version loaded from {value} does not '
+                    'comply with PEP 440: {version}'
+                )
+                raise DistutilsOptionError(tmpl.format(**locals()))
+
+            return version
+
+        version = self._parse_attr(value, self.package_dir)
+
+        if callable(version):
+            version = version()
+
+        if not isinstance(version, string_types):
+            if hasattr(version, '__iter__'):
+                version = '.'.join(map(str, version))
+            else:
+                version = '%s' % version
+
+        return version
+
+
+class ConfigOptionsHandler(ConfigHandler):
+
+    section_prefix = 'options'
+
+    @property
+    def parsers(self):
+        """Metadata item name to parser function mapping."""
+        parse_list = self._parse_list
+        parse_list_semicolon = partial(self._parse_list, separator=';')
+        parse_bool = self._parse_bool
+        parse_dict = self._parse_dict
+
+        return {
+            'zip_safe': parse_bool,
+            'use_2to3': parse_bool,
+            'include_package_data': parse_bool,
+            'package_dir': parse_dict,
+            'use_2to3_fixers': parse_list,
+            'use_2to3_exclude_fixers': parse_list,
+            'convert_2to3_doctests': parse_list,
+            'scripts': parse_list,
+            'eager_resources': parse_list,
+            'dependency_links': parse_list,
+            'namespace_packages': parse_list,
+            'install_requires': parse_list_semicolon,
+            'setup_requires': parse_list_semicolon,
+            'tests_require': parse_list_semicolon,
+            'packages': self._parse_packages,
+            'entry_points': self._parse_file,
+            'py_modules': parse_list,
+        }
+
+    def _parse_packages(self, value):
+        """Parses `packages` option value.
+
+        :param value:
+        :rtype: list
+        """
+        find_directives = ['find:', 'find_namespace:']
+        trimmed_value = value.strip()
+
+        if trimmed_value not in find_directives:
+            return self._parse_list(value)
+
+        findns = trimmed_value == find_directives[1]
+        if findns and not PY3:
+            raise DistutilsOptionError(
+                'find_namespace: directive is unsupported on Python < 3.3')
+
+        # Read function arguments from a dedicated section.
+        find_kwargs = self.parse_section_packages__find(
+            self.sections.get('packages.find', {}))
+
+        if findns:
+            from setuptools import find_namespace_packages as find_packages
+        else:
+            from setuptools import find_packages
+
+        return find_packages(**find_kwargs)
+
+    def parse_section_packages__find(self, section_options):
+        """Parses `packages.find` configuration file section.
+
+        To be used in conjunction with _parse_packages().
+
+        :param dict section_options:
+        """
+        section_data = self._parse_section_to_dict(
+            section_options, self._parse_list)
+
+        valid_keys = ['where', 'include', 'exclude']
+
+        find_kwargs = dict(
+            [(k, v) for k, v in section_data.items() if k in valid_keys and v])
+
+        where = find_kwargs.get('where')
+        if where is not None:
+            find_kwargs['where'] = where[0]  # cast list to single val
+
+        return find_kwargs
+
+    def parse_section_entry_points(self, section_options):
+        """Parses `entry_points` configuration file section.
+
+        :param dict section_options:
+        """
+        parsed = self._parse_section_to_dict(section_options, self._parse_list)
+        self['entry_points'] = parsed
+
+    def _parse_package_data(self, section_options):
+        parsed = self._parse_section_to_dict(section_options, self._parse_list)
+
+        root = parsed.get('*')
+        if root:
+            parsed[''] = root
+            del parsed['*']
+
+        return parsed
+
+    def parse_section_package_data(self, section_options):
+        """Parses `package_data` configuration file section.
+
+        :param dict section_options:
+        """
+        self['package_data'] = self._parse_package_data(section_options)
+
+    def parse_section_exclude_package_data(self, section_options):
+        """Parses `exclude_package_data` configuration file section.
+
+        :param dict section_options:
+        """
+        self['exclude_package_data'] = self._parse_package_data(
+            section_options)
+
+    def parse_section_extras_require(self, section_options):
+        """Parses `extras_require` configuration file section.
+
+        :param dict section_options:
+        """
+        parse_list = partial(self._parse_list, separator=';')
+        self['extras_require'] = self._parse_section_to_dict(
+            section_options, parse_list)
+
+    def parse_section_data_files(self, section_options):
+        """Parses `data_files` configuration file section.
+
+        :param dict section_options:
+        """
+        parsed = self._parse_section_to_dict(section_options, self._parse_list)
+        self['data_files'] = [(k, v) for k, v in parsed.items()]
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/config.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/config.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..fa7aa21428096b74dc3cfbc028f5de5d96f59bcd
GIT binary patch
literal 22827
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

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/dep_util.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/dep_util.py
new file mode 100644
index 0000000..2931c13
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/dep_util.py
@@ -0,0 +1,23 @@
+from distutils.dep_util import newer_group
+
+# yes, this is was almost entirely copy-pasted from
+# 'newer_pairwise()', this is just another convenience
+# function.
+def newer_pairwise_group(sources_groups, targets):
+    """Walk both arguments in parallel, testing if each source group is newer
+    than its corresponding target. Returns a pair of lists (sources_groups,
+    targets) where sources is newer than target, according to the semantics
+    of 'newer_group()'.
+    """
+    if len(sources_groups) != len(targets):
+        raise ValueError("'sources_group' and 'targets' must be the same length")
+
+    # build a pair of lists (sources_groups, targets) where source is newer
+    n_sources = []
+    n_targets = []
+    for i in range(len(sources_groups)):
+        if newer_group(sources_groups[i], targets[i]):
+            n_sources.append(sources_groups[i])
+            n_targets.append(targets[i])
+
+    return n_sources, n_targets
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/dep_util.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/dep_util.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..f50653b37c3dea669393e9a7f4926fdc4bfdeaf6
GIT binary patch
literal 1073
zcmZSn%**AGdLky70ScHH7#JKF7#NCW85kH+7#LC*8FCmHav2$-7#SE-m>60Z7^0XM
zQkWTnHCPxJ7&8C=|Nmcuk%57sgqwkZAuqK&wJ1KlD8IBI8DtVG0|NsHJA+J|22#bq
zP{Y8`%*ar}z)-^oVq`Nj6sa?mFoJAqW@Kn$WXNM+NM~TEWdf7T3>9GvB}`!TV2#a;
z3@))w47Dr_CCnhRYFHQ~YZw_oR5KGpksCt|6GIjYOs1KUfw6`eEC5x*$iP_W#!%?S
z5MIN?P{YiS#>5b;0di~cZw3a2@Wh;Kg{1tF428s^^wQkaypm#t%shpH#G=HUoYWj0
zg_6|blFYnxh0HXC)WqZrh2s3uqU2Nsu$L7wixt2jz@?y|piq*Ln5U3gQml}iUsRM@
zT#%oa0@7HLSd^YxqNfm)T2fk+SFDhzP>`5eq>!Jckds+lQmmi>F|imDip4q*v%s2)
zH5JM;Qj1cdmKMY9gV+TzSw|r;IXS-wVpqOGNk*zdacXX2UP)$hG1#p9GzE3AD<L*$
zXsYXh#fwcD7#P%1Y*$xE%u7*FhZtO}u8><=T%wSa3NbV>H&r1gH7~s+Ljx4WCCm&A
z3^}QJC0q;)3}J~mrKzq(MfpV~Ai1K%y!6x{PzozyV_;xNEGS6LOM&R(1Emab7{Yv9
z!VXF&5D%Adf)Z6c)KO3#)Hx-fRF|m%G8Ie|=Q1!b=ob`amL-;?>X#)J>8IuAq@)%V
z>nEk?mnS9V<(lRe8yO~<r&pz0m|B$QWL23NfIxbleu#cSW`S;IUU5lcPL8fynTMxw
zfPQgmNohezetu3dGBYK$AilIDGe@tWvP1;rI&hK)#bJ47aVjKCL7prY0=bM$f{~w@
zjggH}l2M#dkWqrkPXiQAB_PR^%;FM|NyU0FGr>U=1PVZ~j}XKF_>F^sfx#v>KczG$
O)eaQW#h^SQzzP7HDI$#k

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/depends.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/depends.py
new file mode 100644
index 0000000..45e7052
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/depends.py
@@ -0,0 +1,186 @@
+import sys
+import imp
+import marshal
+from distutils.version import StrictVersion
+from imp import PKG_DIRECTORY, PY_COMPILED, PY_SOURCE, PY_FROZEN
+
+from .py33compat import Bytecode
+
+
+__all__ = [
+    'Require', 'find_module', 'get_module_constant', 'extract_constant'
+]
+
+
+class Require:
+    """A prerequisite to building or installing a distribution"""
+
+    def __init__(self, name, requested_version, module, homepage='',
+            attribute=None, format=None):
+
+        if format is None and requested_version is not None:
+            format = StrictVersion
+
+        if format is not None:
+            requested_version = format(requested_version)
+            if attribute is None:
+                attribute = '__version__'
+
+        self.__dict__.update(locals())
+        del self.self
+
+    def full_name(self):
+        """Return full package/distribution name, w/version"""
+        if self.requested_version is not None:
+            return '%s-%s' % (self.name, self.requested_version)
+        return self.name
+
+    def version_ok(self, version):
+        """Is 'version' sufficiently up-to-date?"""
+        return self.attribute is None or self.format is None or \
+            str(version) != "unknown" and version >= self.requested_version
+
+    def get_version(self, paths=None, default="unknown"):
+        """Get version number of installed module, 'None', or 'default'
+
+        Search 'paths' for module.  If not found, return 'None'.  If found,
+        return the extracted version attribute, or 'default' if no version
+        attribute was specified, or the value cannot be determined without
+        importing the module.  The version is formatted according to the
+        requirement's version format (if any), unless it is 'None' or the
+        supplied 'default'.
+        """
+
+        if self.attribute is None:
+            try:
+                f, p, i = find_module(self.module, paths)
+                if f:
+                    f.close()
+                return default
+            except ImportError:
+                return None
+
+        v = get_module_constant(self.module, self.attribute, default, paths)
+
+        if v is not None and v is not default and self.format is not None:
+            return self.format(v)
+
+        return v
+
+    def is_present(self, paths=None):
+        """Return true if dependency is present on 'paths'"""
+        return self.get_version(paths) is not None
+
+    def is_current(self, paths=None):
+        """Return true if dependency is present and up-to-date on 'paths'"""
+        version = self.get_version(paths)
+        if version is None:
+            return False
+        return self.version_ok(version)
+
+
+def find_module(module, paths=None):
+    """Just like 'imp.find_module()', but with package support"""
+
+    parts = module.split('.')
+
+    while parts:
+        part = parts.pop(0)
+        f, path, (suffix, mode, kind) = info = imp.find_module(part, paths)
+
+        if kind == PKG_DIRECTORY:
+            parts = parts or ['__init__']
+            paths = [path]
+
+        elif parts:
+            raise ImportError("Can't find %r in %s" % (parts, module))
+
+    return info
+
+
+def get_module_constant(module, symbol, default=-1, paths=None):
+    """Find 'module' by searching 'paths', and extract 'symbol'
+
+    Return 'None' if 'module' does not exist on 'paths', or it does not define
+    'symbol'.  If the module defines 'symbol' as a constant, return the
+    constant.  Otherwise, return 'default'."""
+
+    try:
+        f, path, (suffix, mode, kind) = find_module(module, paths)
+    except ImportError:
+        # Module doesn't exist
+        return None
+
+    try:
+        if kind == PY_COMPILED:
+            f.read(8)  # skip magic & date
+            code = marshal.load(f)
+        elif kind == PY_FROZEN:
+            code = imp.get_frozen_object(module)
+        elif kind == PY_SOURCE:
+            code = compile(f.read(), path, 'exec')
+        else:
+            # Not something we can parse; we'll have to import it.  :(
+            if module not in sys.modules:
+                imp.load_module(module, f, path, (suffix, mode, kind))
+            return getattr(sys.modules[module], symbol, None)
+
+    finally:
+        if f:
+            f.close()
+
+    return extract_constant(code, symbol, default)
+
+
+def extract_constant(code, symbol, default=-1):
+    """Extract the constant value of 'symbol' from 'code'
+
+    If the name 'symbol' is bound to a constant value by the Python code
+    object 'code', return that value.  If 'symbol' is bound to an expression,
+    return 'default'.  Otherwise, return 'None'.
+
+    Return value is based on the first assignment to 'symbol'.  'symbol' must
+    be a global, or at least a non-"fast" local in the code block.  That is,
+    only 'STORE_NAME' and 'STORE_GLOBAL' opcodes are checked, and 'symbol'
+    must be present in 'code.co_names'.
+    """
+    if symbol not in code.co_names:
+        # name's not there, can't possibly be an assignment
+        return None
+
+    name_idx = list(code.co_names).index(symbol)
+
+    STORE_NAME = 90
+    STORE_GLOBAL = 97
+    LOAD_CONST = 100
+
+    const = default
+
+    for byte_code in Bytecode(code):
+        op = byte_code.opcode
+        arg = byte_code.arg
+
+        if op == LOAD_CONST:
+            const = code.co_consts[arg]
+        elif arg == name_idx and (op == STORE_NAME or op == STORE_GLOBAL):
+            return const
+        else:
+            const = default
+
+
+def _update_globals():
+    """
+    Patch the globals to remove the objects not available on some platforms.
+
+    XXX it'd be better to test assertions about bytecode instead.
+    """
+
+    if not sys.platform.startswith('java') and sys.platform != 'cli':
+        return
+    incompatible = 'extract_constant', 'get_module_constant'
+    for name in incompatible:
+        del globals()[name]
+        __all__.remove(name)
+
+
+_update_globals()
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/depends.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/depends.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..fee411735deceed33004224e8e917c6034d0ac7a
GIT binary patch
literal 7166
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

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/dist.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/dist.py
new file mode 100644
index 0000000..9a165de
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/dist.py
@@ -0,0 +1,1278 @@
+# -*- coding: utf-8 -*-
+__all__ = ['Distribution']
+
+import io
+import sys
+import re
+import os
+import warnings
+import numbers
+import distutils.log
+import distutils.core
+import distutils.cmd
+import distutils.dist
+from distutils.util import strtobool
+from distutils.debug import DEBUG
+from distutils.fancy_getopt import translate_longopt
+import itertools
+
+from collections import defaultdict
+from email import message_from_file
+
+from distutils.errors import (
+    DistutilsOptionError, DistutilsPlatformError, DistutilsSetupError,
+)
+from distutils.util import rfc822_escape
+from distutils.version import StrictVersion
+
+from setuptools.extern import six
+from setuptools.extern import packaging
+from setuptools.extern.six.moves import map, filter, filterfalse
+
+from . import SetuptoolsDeprecationWarning
+
+from setuptools.depends import Require
+from setuptools import windows_support
+from setuptools.monkey import get_unpatched
+from setuptools.config import parse_configuration
+import pkg_resources
+
+__import__('setuptools.extern.packaging.specifiers')
+__import__('setuptools.extern.packaging.version')
+
+
+def _get_unpatched(cls):
+    warnings.warn("Do not call this function", DistDeprecationWarning)
+    return get_unpatched(cls)
+
+
+def get_metadata_version(self):
+    mv = getattr(self, 'metadata_version', None)
+
+    if mv is None:
+        if self.long_description_content_type or self.provides_extras:
+            mv = StrictVersion('2.1')
+        elif (self.maintainer is not None or
+              self.maintainer_email is not None or
+              getattr(self, 'python_requires', None) is not None):
+            mv = StrictVersion('1.2')
+        elif (self.provides or self.requires or self.obsoletes or
+                self.classifiers or self.download_url):
+            mv = StrictVersion('1.1')
+        else:
+            mv = StrictVersion('1.0')
+
+        self.metadata_version = mv
+
+    return mv
+
+
+def read_pkg_file(self, file):
+    """Reads the metadata values from a file object."""
+    msg = message_from_file(file)
+
+    def _read_field(name):
+        value = msg[name]
+        if value == 'UNKNOWN':
+            return None
+        return value
+
+    def _read_list(name):
+        values = msg.get_all(name, None)
+        if values == []:
+            return None
+        return values
+
+    self.metadata_version = StrictVersion(msg['metadata-version'])
+    self.name = _read_field('name')
+    self.version = _read_field('version')
+    self.description = _read_field('summary')
+    # we are filling author only.
+    self.author = _read_field('author')
+    self.maintainer = None
+    self.author_email = _read_field('author-email')
+    self.maintainer_email = None
+    self.url = _read_field('home-page')
+    self.license = _read_field('license')
+
+    if 'download-url' in msg:
+        self.download_url = _read_field('download-url')
+    else:
+        self.download_url = None
+
+    self.long_description = _read_field('description')
+    self.description = _read_field('summary')
+
+    if 'keywords' in msg:
+        self.keywords = _read_field('keywords').split(',')
+
+    self.platforms = _read_list('platform')
+    self.classifiers = _read_list('classifier')
+
+    # PEP 314 - these fields only exist in 1.1
+    if self.metadata_version == StrictVersion('1.1'):
+        self.requires = _read_list('requires')
+        self.provides = _read_list('provides')
+        self.obsoletes = _read_list('obsoletes')
+    else:
+        self.requires = None
+        self.provides = None
+        self.obsoletes = None
+
+
+# Based on Python 3.5 version
+def write_pkg_file(self, file):
+    """Write the PKG-INFO format data to a file object.
+    """
+    version = self.get_metadata_version()
+
+    if six.PY2:
+        def write_field(key, value):
+            file.write("%s: %s\n" % (key, self._encode_field(value)))
+    else:
+        def write_field(key, value):
+            file.write("%s: %s\n" % (key, value))
+
+    write_field('Metadata-Version', str(version))
+    write_field('Name', self.get_name())
+    write_field('Version', self.get_version())
+    write_field('Summary', self.get_description())
+    write_field('Home-page', self.get_url())
+
+    if version < StrictVersion('1.2'):
+        write_field('Author', self.get_contact())
+        write_field('Author-email', self.get_contact_email())
+    else:
+        optional_fields = (
+            ('Author', 'author'),
+            ('Author-email', 'author_email'),
+            ('Maintainer', 'maintainer'),
+            ('Maintainer-email', 'maintainer_email'),
+        )
+
+        for field, attr in optional_fields:
+            attr_val = getattr(self, attr)
+
+            if attr_val is not None:
+                write_field(field, attr_val)
+
+    write_field('License', self.get_license())
+    if self.download_url:
+        write_field('Download-URL', self.download_url)
+    for project_url in self.project_urls.items():
+        write_field('Project-URL',  '%s, %s' % project_url)
+
+    long_desc = rfc822_escape(self.get_long_description())
+    write_field('Description', long_desc)
+
+    keywords = ','.join(self.get_keywords())
+    if keywords:
+        write_field('Keywords', keywords)
+
+    if version >= StrictVersion('1.2'):
+        for platform in self.get_platforms():
+            write_field('Platform', platform)
+    else:
+        self._write_list(file, 'Platform', self.get_platforms())
+
+    self._write_list(file, 'Classifier', self.get_classifiers())
+
+    # PEP 314
+    self._write_list(file, 'Requires', self.get_requires())
+    self._write_list(file, 'Provides', self.get_provides())
+    self._write_list(file, 'Obsoletes', self.get_obsoletes())
+
+    # Setuptools specific for PEP 345
+    if hasattr(self, 'python_requires'):
+        write_field('Requires-Python', self.python_requires)
+
+    # PEP 566
+    if self.long_description_content_type:
+        write_field(
+            'Description-Content-Type',
+            self.long_description_content_type
+        )
+    if self.provides_extras:
+        for extra in self.provides_extras:
+            write_field('Provides-Extra', extra)
+
+
+sequence = tuple, list
+
+
+def check_importable(dist, attr, value):
+    try:
+        ep = pkg_resources.EntryPoint.parse('x=' + value)
+        assert not ep.extras
+    except (TypeError, ValueError, AttributeError, AssertionError):
+        raise DistutilsSetupError(
+            "%r must be importable 'module:attrs' string (got %r)"
+            % (attr, value)
+        )
+
+
+def assert_string_list(dist, attr, value):
+    """Verify that value is a string list or None"""
+    try:
+        assert ''.join(value) != value
+    except (TypeError, ValueError, AttributeError, AssertionError):
+        raise DistutilsSetupError(
+            "%r must be a list of strings (got %r)" % (attr, value)
+        )
+
+
+def check_nsp(dist, attr, value):
+    """Verify that namespace packages are valid"""
+    ns_packages = value
+    assert_string_list(dist, attr, ns_packages)
+    for nsp in ns_packages:
+        if not dist.has_contents_for(nsp):
+            raise DistutilsSetupError(
+                "Distribution contains no modules or packages for " +
+                "namespace package %r" % nsp
+            )
+        parent, sep, child = nsp.rpartition('.')
+        if parent and parent not in ns_packages:
+            distutils.log.warn(
+                "WARNING: %r is declared as a package namespace, but %r"
+                " is not: please correct this in setup.py", nsp, parent
+            )
+
+
+def check_extras(dist, attr, value):
+    """Verify that extras_require mapping is valid"""
+    try:
+        list(itertools.starmap(_check_extra, value.items()))
+    except (TypeError, ValueError, AttributeError):
+        raise DistutilsSetupError(
+            "'extras_require' must be a dictionary whose values are "
+            "strings or lists of strings containing valid project/version "
+            "requirement specifiers."
+        )
+
+
+def _check_extra(extra, reqs):
+    name, sep, marker = extra.partition(':')
+    if marker and pkg_resources.invalid_marker(marker):
+        raise DistutilsSetupError("Invalid environment marker: " + marker)
+    list(pkg_resources.parse_requirements(reqs))
+
+
+def assert_bool(dist, attr, value):
+    """Verify that value is True, False, 0, or 1"""
+    if bool(value) != value:
+        tmpl = "{attr!r} must be a boolean value (got {value!r})"
+        raise DistutilsSetupError(tmpl.format(attr=attr, value=value))
+
+
+def check_requirements(dist, attr, value):
+    """Verify that install_requires is a valid requirements list"""
+    try:
+        list(pkg_resources.parse_requirements(value))
+        if isinstance(value, (dict, set)):
+            raise TypeError("Unordered types are not allowed")
+    except (TypeError, ValueError) as error:
+        tmpl = (
+            "{attr!r} must be a string or list of strings "
+            "containing valid project/version requirement specifiers; {error}"
+        )
+        raise DistutilsSetupError(tmpl.format(attr=attr, error=error))
+
+
+def check_specifier(dist, attr, value):
+    """Verify that value is a valid version specifier"""
+    try:
+        packaging.specifiers.SpecifierSet(value)
+    except packaging.specifiers.InvalidSpecifier as error:
+        tmpl = (
+            "{attr!r} must be a string "
+            "containing valid version specifiers; {error}"
+        )
+        raise DistutilsSetupError(tmpl.format(attr=attr, error=error))
+
+
+def check_entry_points(dist, attr, value):
+    """Verify that entry_points map is parseable"""
+    try:
+        pkg_resources.EntryPoint.parse_map(value)
+    except ValueError as e:
+        raise DistutilsSetupError(e)
+
+
+def check_test_suite(dist, attr, value):
+    if not isinstance(value, six.string_types):
+        raise DistutilsSetupError("test_suite must be a string")
+
+
+def check_package_data(dist, attr, value):
+    """Verify that value is a dictionary of package names to glob lists"""
+    if isinstance(value, dict):
+        for k, v in value.items():
+            if not isinstance(k, str):
+                break
+            try:
+                iter(v)
+            except TypeError:
+                break
+        else:
+            return
+    raise DistutilsSetupError(
+        attr + " must be a dictionary mapping package names to lists of "
+        "wildcard patterns"
+    )
+
+
+def check_packages(dist, attr, value):
+    for pkgname in value:
+        if not re.match(r'\w+(\.\w+)*', pkgname):
+            distutils.log.warn(
+                "WARNING: %r not a valid package name; please use only "
+                ".-separated package names in setup.py", pkgname
+            )
+
+
+_Distribution = get_unpatched(distutils.core.Distribution)
+
+
+class Distribution(_Distribution):
+    """Distribution with support for features, tests, and package data
+
+    This is an enhanced version of 'distutils.dist.Distribution' that
+    effectively adds the following new optional keyword arguments to 'setup()':
+
+     'install_requires' -- a string or sequence of strings specifying project
+        versions that the distribution requires when installed, in the format
+        used by 'pkg_resources.require()'.  They will be installed
+        automatically when the package is installed.  If you wish to use
+        packages that are not available in PyPI, or want to give your users an
+        alternate download location, you can add a 'find_links' option to the
+        '[easy_install]' section of your project's 'setup.cfg' file, and then
+        setuptools will scan the listed web pages for links that satisfy the
+        requirements.
+
+     'extras_require' -- a dictionary mapping names of optional "extras" to the
+        additional requirement(s) that using those extras incurs. For example,
+        this::
+
+            extras_require = dict(reST = ["docutils>=0.3", "reSTedit"])
+
+        indicates that the distribution can optionally provide an extra
+        capability called "reST", but it can only be used if docutils and
+        reSTedit are installed.  If the user installs your package using
+        EasyInstall and requests one of your extras, the corresponding
+        additional requirements will be installed if needed.
+
+     'features' **deprecated** -- a dictionary mapping option names to
+        'setuptools.Feature'
+        objects.  Features are a portion of the distribution that can be
+        included or excluded based on user options, inter-feature dependencies,
+        and availability on the current system.  Excluded features are omitted
+        from all setup commands, including source and binary distributions, so
+        you can create multiple distributions from the same source tree.
+        Feature names should be valid Python identifiers, except that they may
+        contain the '-' (minus) sign.  Features can be included or excluded
+        via the command line options '--with-X' and '--without-X', where 'X' is
+        the name of the feature.  Whether a feature is included by default, and
+        whether you are allowed to control this from the command line, is
+        determined by the Feature object.  See the 'Feature' class for more
+        information.
+
+     'test_suite' -- the name of a test suite to run for the 'test' command.
+        If the user runs 'python setup.py test', the package will be installed,
+        and the named test suite will be run.  The format is the same as
+        would be used on a 'unittest.py' command line.  That is, it is the
+        dotted name of an object to import and call to generate a test suite.
+
+     'package_data' -- a dictionary mapping package names to lists of filenames
+        or globs to use to find data files contained in the named packages.
+        If the dictionary has filenames or globs listed under '""' (the empty
+        string), those names will be searched for in every package, in addition
+        to any names for the specific package.  Data files found using these
+        names/globs will be installed along with the package, in the same
+        location as the package.  Note that globs are allowed to reference
+        the contents of non-package subdirectories, as long as you use '/' as
+        a path separator.  (Globs are automatically converted to
+        platform-specific paths at runtime.)
+
+    In addition to these new keywords, this class also has several new methods
+    for manipulating the distribution's contents.  For example, the 'include()'
+    and 'exclude()' methods can be thought of as in-place add and subtract
+    commands that add or remove packages, modules, extensions, and so on from
+    the distribution.  They are used by the feature subsystem to configure the
+    distribution for the included and excluded features.
+    """
+
+    _DISTUTILS_UNSUPPORTED_METADATA = {
+        'long_description_content_type': None,
+        'project_urls': dict,
+        'provides_extras': set,
+    }
+
+    _patched_dist = None
+
+    def patch_missing_pkg_info(self, attrs):
+        # Fake up a replacement for the data that would normally come from
+        # PKG-INFO, but which might not yet be built if this is a fresh
+        # checkout.
+        #
+        if not attrs or 'name' not in attrs or 'version' not in attrs:
+            return
+        key = pkg_resources.safe_name(str(attrs['name'])).lower()
+        dist = pkg_resources.working_set.by_key.get(key)
+        if dist is not None and not dist.has_metadata('PKG-INFO'):
+            dist._version = pkg_resources.safe_version(str(attrs['version']))
+            self._patched_dist = dist
+
+    def __init__(self, attrs=None):
+        have_package_data = hasattr(self, "package_data")
+        if not have_package_data:
+            self.package_data = {}
+        attrs = attrs or {}
+        if 'features' in attrs or 'require_features' in attrs:
+            Feature.warn_deprecated()
+        self.require_features = []
+        self.features = {}
+        self.dist_files = []
+        # Filter-out setuptools' specific options.
+        self.src_root = attrs.pop("src_root", None)
+        self.patch_missing_pkg_info(attrs)
+        self.dependency_links = attrs.pop('dependency_links', [])
+        self.setup_requires = attrs.pop('setup_requires', [])
+        for ep in pkg_resources.iter_entry_points('distutils.setup_keywords'):
+            vars(self).setdefault(ep.name, None)
+        _Distribution.__init__(self, {
+            k: v for k, v in attrs.items()
+            if k not in self._DISTUTILS_UNSUPPORTED_METADATA
+        })
+
+        # Fill-in missing metadata fields not supported by distutils.
+        # Note some fields may have been set by other tools (e.g. pbr)
+        # above; they are taken preferrentially to setup() arguments
+        for option, default in self._DISTUTILS_UNSUPPORTED_METADATA.items():
+            for source in self.metadata.__dict__, attrs:
+                if option in source:
+                    value = source[option]
+                    break
+            else:
+                value = default() if default else None
+            setattr(self.metadata, option, value)
+
+        if isinstance(self.metadata.version, numbers.Number):
+            # Some people apparently take "version number" too literally :)
+            self.metadata.version = str(self.metadata.version)
+
+        if self.metadata.version is not None:
+            try:
+                ver = packaging.version.Version(self.metadata.version)
+                normalized_version = str(ver)
+                if self.metadata.version != normalized_version:
+                    warnings.warn(
+                        "Normalizing '%s' to '%s'" % (
+                            self.metadata.version,
+                            normalized_version,
+                        )
+                    )
+                    self.metadata.version = normalized_version
+            except (packaging.version.InvalidVersion, TypeError):
+                warnings.warn(
+                    "The version specified (%r) is an invalid version, this "
+                    "may not work as expected with newer versions of "
+                    "setuptools, pip, and PyPI. Please see PEP 440 for more "
+                    "details." % self.metadata.version
+                )
+        self._finalize_requires()
+
+    def _finalize_requires(self):
+        """
+        Set `metadata.python_requires` and fix environment markers
+        in `install_requires` and `extras_require`.
+        """
+        if getattr(self, 'python_requires', None):
+            self.metadata.python_requires = self.python_requires
+
+        if getattr(self, 'extras_require', None):
+            for extra in self.extras_require.keys():
+                # Since this gets called multiple times at points where the
+                # keys have become 'converted' extras, ensure that we are only
+                # truly adding extras we haven't seen before here.
+                extra = extra.split(':')[0]
+                if extra:
+                    self.metadata.provides_extras.add(extra)
+
+        self._convert_extras_requirements()
+        self._move_install_requirements_markers()
+
+    def _convert_extras_requirements(self):
+        """
+        Convert requirements in `extras_require` of the form
+        `"extra": ["barbazquux; {marker}"]` to
+        `"extra:{marker}": ["barbazquux"]`.
+        """
+        spec_ext_reqs = getattr(self, 'extras_require', None) or {}
+        self._tmp_extras_require = defaultdict(list)
+        for section, v in spec_ext_reqs.items():
+            # Do not strip empty sections.
+            self._tmp_extras_require[section]
+            for r in pkg_resources.parse_requirements(v):
+                suffix = self._suffix_for(r)
+                self._tmp_extras_require[section + suffix].append(r)
+
+    @staticmethod
+    def _suffix_for(req):
+        """
+        For a requirement, return the 'extras_require' suffix for
+        that requirement.
+        """
+        return ':' + str(req.marker) if req.marker else ''
+
+    def _move_install_requirements_markers(self):
+        """
+        Move requirements in `install_requires` that are using environment
+        markers `extras_require`.
+        """
+
+        # divide the install_requires into two sets, simple ones still
+        # handled by install_requires and more complex ones handled
+        # by extras_require.
+
+        def is_simple_req(req):
+            return not req.marker
+
+        spec_inst_reqs = getattr(self, 'install_requires', None) or ()
+        inst_reqs = list(pkg_resources.parse_requirements(spec_inst_reqs))
+        simple_reqs = filter(is_simple_req, inst_reqs)
+        complex_reqs = filterfalse(is_simple_req, inst_reqs)
+        self.install_requires = list(map(str, simple_reqs))
+
+        for r in complex_reqs:
+            self._tmp_extras_require[':' + str(r.marker)].append(r)
+        self.extras_require = dict(
+            (k, [str(r) for r in map(self._clean_req, v)])
+            for k, v in self._tmp_extras_require.items()
+        )
+
+    def _clean_req(self, req):
+        """
+        Given a Requirement, remove environment markers and return it.
+        """
+        req.marker = None
+        return req
+
+    def _parse_config_files(self, filenames=None):
+        """
+        Adapted from distutils.dist.Distribution.parse_config_files,
+        this method provides the same functionality in subtly-improved
+        ways.
+        """
+        from setuptools.extern.six.moves.configparser import ConfigParser
+
+        # Ignore install directory options if we have a venv
+        if six.PY3 and sys.prefix != sys.base_prefix:
+            ignore_options = [
+                'install-base', 'install-platbase', 'install-lib',
+                'install-platlib', 'install-purelib', 'install-headers',
+                'install-scripts', 'install-data', 'prefix', 'exec-prefix',
+                'home', 'user', 'root']
+        else:
+            ignore_options = []
+
+        ignore_options = frozenset(ignore_options)
+
+        if filenames is None:
+            filenames = self.find_config_files()
+
+        if DEBUG:
+            self.announce("Distribution.parse_config_files():")
+
+        parser = ConfigParser()
+        for filename in filenames:
+            with io.open(filename, encoding='utf-8') as reader:
+                if DEBUG:
+                    self.announce("  reading {filename}".format(**locals()))
+                (parser.read_file if six.PY3 else parser.readfp)(reader)
+            for section in parser.sections():
+                options = parser.options(section)
+                opt_dict = self.get_option_dict(section)
+
+                for opt in options:
+                    if opt != '__name__' and opt not in ignore_options:
+                        val = self._try_str(parser.get(section, opt))
+                        opt = opt.replace('-', '_')
+                        opt_dict[opt] = (filename, val)
+
+            # Make the ConfigParser forget everything (so we retain
+            # the original filenames that options come from)
+            parser.__init__()
+
+        # If there was a "global" section in the config file, use it
+        # to set Distribution options.
+
+        if 'global' in self.command_options:
+            for (opt, (src, val)) in self.command_options['global'].items():
+                alias = self.negative_opt.get(opt)
+                try:
+                    if alias:
+                        setattr(self, alias, not strtobool(val))
+                    elif opt in ('verbose', 'dry_run'):  # ugh!
+                        setattr(self, opt, strtobool(val))
+                    else:
+                        setattr(self, opt, val)
+                except ValueError as msg:
+                    raise DistutilsOptionError(msg)
+
+    @staticmethod
+    def _try_str(val):
+        """
+        On Python 2, much of distutils relies on string values being of
+        type 'str' (bytes) and not unicode text. If the value can be safely
+        encoded to bytes using the default encoding, prefer that.
+
+        Why the default encoding? Because that value can be implicitly
+        decoded back to text if needed.
+
+        Ref #1653
+        """
+        if six.PY3:
+            return val
+        try:
+            return val.encode()
+        except UnicodeEncodeError:
+            pass
+        return val
+
+    def _set_command_options(self, command_obj, option_dict=None):
+        """
+        Set the options for 'command_obj' from 'option_dict'.  Basically
+        this means copying elements of a dictionary ('option_dict') to
+        attributes of an instance ('command').
+
+        'command_obj' must be a Command instance.  If 'option_dict' is not
+        supplied, uses the standard option dictionary for this command
+        (from 'self.command_options').
+
+        (Adopted from distutils.dist.Distribution._set_command_options)
+        """
+        command_name = command_obj.get_command_name()
+        if option_dict is None:
+            option_dict = self.get_option_dict(command_name)
+
+        if DEBUG:
+            self.announce("  setting options for '%s' command:" % command_name)
+        for (option, (source, value)) in option_dict.items():
+            if DEBUG:
+                self.announce("    %s = %s (from %s)" % (option, value,
+                                                         source))
+            try:
+                bool_opts = [translate_longopt(o)
+                             for o in command_obj.boolean_options]
+            except AttributeError:
+                bool_opts = []
+            try:
+                neg_opt = command_obj.negative_opt
+            except AttributeError:
+                neg_opt = {}
+
+            try:
+                is_string = isinstance(value, six.string_types)
+                if option in neg_opt and is_string:
+                    setattr(command_obj, neg_opt[option], not strtobool(value))
+                elif option in bool_opts and is_string:
+                    setattr(command_obj, option, strtobool(value))
+                elif hasattr(command_obj, option):
+                    setattr(command_obj, option, value)
+                else:
+                    raise DistutilsOptionError(
+                        "error in %s: command '%s' has no such option '%s'"
+                        % (source, command_name, option))
+            except ValueError as msg:
+                raise DistutilsOptionError(msg)
+
+    def parse_config_files(self, filenames=None, ignore_option_errors=False):
+        """Parses configuration files from various levels
+        and loads configuration.
+
+        """
+        self._parse_config_files(filenames=filenames)
+
+        parse_configuration(self, self.command_options,
+                            ignore_option_errors=ignore_option_errors)
+        self._finalize_requires()
+
+    def parse_command_line(self):
+        """Process features after parsing command line options"""
+        result = _Distribution.parse_command_line(self)
+        if self.features:
+            self._finalize_features()
+        return result
+
+    def _feature_attrname(self, name):
+        """Convert feature name to corresponding option attribute name"""
+        return 'with_' + name.replace('-', '_')
+
+    def fetch_build_eggs(self, requires):
+        """Resolve pre-setup requirements"""
+        resolved_dists = pkg_resources.working_set.resolve(
+            pkg_resources.parse_requirements(requires),
+            installer=self.fetch_build_egg,
+            replace_conflicting=True,
+        )
+        for dist in resolved_dists:
+            pkg_resources.working_set.add(dist, replace=True)
+        return resolved_dists
+
+    def finalize_options(self):
+        _Distribution.finalize_options(self)
+        if self.features:
+            self._set_global_opts_from_features()
+
+        for ep in pkg_resources.iter_entry_points('distutils.setup_keywords'):
+            value = getattr(self, ep.name, None)
+            if value is not None:
+                ep.require(installer=self.fetch_build_egg)
+                ep.load()(self, ep.name, value)
+        if getattr(self, 'convert_2to3_doctests', None):
+            # XXX may convert to set here when we can rely on set being builtin
+            self.convert_2to3_doctests = [
+                os.path.abspath(p)
+                for p in self.convert_2to3_doctests
+            ]
+        else:
+            self.convert_2to3_doctests = []
+
+    def get_egg_cache_dir(self):
+        egg_cache_dir = os.path.join(os.curdir, '.eggs')
+        if not os.path.exists(egg_cache_dir):
+            os.mkdir(egg_cache_dir)
+            windows_support.hide_file(egg_cache_dir)
+            readme_txt_filename = os.path.join(egg_cache_dir, 'README.txt')
+            with open(readme_txt_filename, 'w') as f:
+                f.write('This directory contains eggs that were downloaded '
+                        'by setuptools to build, test, and run plug-ins.\n\n')
+                f.write('This directory caches those eggs to prevent '
+                        'repeated downloads.\n\n')
+                f.write('However, it is safe to delete this directory.\n\n')
+
+        return egg_cache_dir
+
+    def fetch_build_egg(self, req):
+        """Fetch an egg needed for building"""
+        from setuptools.command.easy_install import easy_install
+        dist = self.__class__({'script_args': ['easy_install']})
+        opts = dist.get_option_dict('easy_install')
+        opts.clear()
+        opts.update(
+            (k, v)
+            for k, v in self.get_option_dict('easy_install').items()
+            if k in (
+                # don't use any other settings
+                'find_links', 'site_dirs', 'index_url',
+                'optimize', 'site_dirs', 'allow_hosts',
+            ))
+        if self.dependency_links:
+            links = self.dependency_links[:]
+            if 'find_links' in opts:
+                links = opts['find_links'][1] + links
+            opts['find_links'] = ('setup', links)
+        install_dir = self.get_egg_cache_dir()
+        cmd = easy_install(
+            dist, args=["x"], install_dir=install_dir,
+            exclude_scripts=True,
+            always_copy=False, build_directory=None, editable=False,
+            upgrade=False, multi_version=True, no_report=True, user=False
+        )
+        cmd.ensure_finalized()
+        return cmd.easy_install(req)
+
+    def _set_global_opts_from_features(self):
+        """Add --with-X/--without-X options based on optional features"""
+
+        go = []
+        no = self.negative_opt.copy()
+
+        for name, feature in self.features.items():
+            self._set_feature(name, None)
+            feature.validate(self)
+
+            if feature.optional:
+                descr = feature.description
+                incdef = ' (default)'
+                excdef = ''
+                if not feature.include_by_default():
+                    excdef, incdef = incdef, excdef
+
+                new = (
+                    ('with-' + name, None, 'include ' + descr + incdef),
+                    ('without-' + name, None, 'exclude ' + descr + excdef),
+                )
+                go.extend(new)
+                no['without-' + name] = 'with-' + name
+
+        self.global_options = self.feature_options = go + self.global_options
+        self.negative_opt = self.feature_negopt = no
+
+    def _finalize_features(self):
+        """Add/remove features and resolve dependencies between them"""
+
+        # First, flag all the enabled items (and thus their dependencies)
+        for name, feature in self.features.items():
+            enabled = self.feature_is_included(name)
+            if enabled or (enabled is None and feature.include_by_default()):
+                feature.include_in(self)
+                self._set_feature(name, 1)
+
+        # Then disable the rest, so that off-by-default features don't
+        # get flagged as errors when they're required by an enabled feature
+        for name, feature in self.features.items():
+            if not self.feature_is_included(name):
+                feature.exclude_from(self)
+                self._set_feature(name, 0)
+
+    def get_command_class(self, command):
+        """Pluggable version of get_command_class()"""
+        if command in self.cmdclass:
+            return self.cmdclass[command]
+
+        eps = pkg_resources.iter_entry_points('distutils.commands', command)
+        for ep in eps:
+            ep.require(installer=self.fetch_build_egg)
+            self.cmdclass[command] = cmdclass = ep.load()
+            return cmdclass
+        else:
+            return _Distribution.get_command_class(self, command)
+
+    def print_commands(self):
+        for ep in pkg_resources.iter_entry_points('distutils.commands'):
+            if ep.name not in self.cmdclass:
+                # don't require extras as the commands won't be invoked
+                cmdclass = ep.resolve()
+                self.cmdclass[ep.name] = cmdclass
+        return _Distribution.print_commands(self)
+
+    def get_command_list(self):
+        for ep in pkg_resources.iter_entry_points('distutils.commands'):
+            if ep.name not in self.cmdclass:
+                # don't require extras as the commands won't be invoked
+                cmdclass = ep.resolve()
+                self.cmdclass[ep.name] = cmdclass
+        return _Distribution.get_command_list(self)
+
+    def _set_feature(self, name, status):
+        """Set feature's inclusion status"""
+        setattr(self, self._feature_attrname(name), status)
+
+    def feature_is_included(self, name):
+        """Return 1 if feature is included, 0 if excluded, 'None' if unknown"""
+        return getattr(self, self._feature_attrname(name))
+
+    def include_feature(self, name):
+        """Request inclusion of feature named 'name'"""
+
+        if self.feature_is_included(name) == 0:
+            descr = self.features[name].description
+            raise DistutilsOptionError(
+                descr + " is required, but was excluded or is not available"
+            )
+        self.features[name].include_in(self)
+        self._set_feature(name, 1)
+
+    def include(self, **attrs):
+        """Add items to distribution that are named in keyword arguments
+
+        For example, 'dist.include(py_modules=["x"])' would add 'x' to
+        the distribution's 'py_modules' attribute, if it was not already
+        there.
+
+        Currently, this method only supports inclusion for attributes that are
+        lists or tuples.  If you need to add support for adding to other
+        attributes in this or a subclass, you can add an '_include_X' method,
+        where 'X' is the name of the attribute.  The method will be called with
+        the value passed to 'include()'.  So, 'dist.include(foo={"bar":"baz"})'
+        will try to call 'dist._include_foo({"bar":"baz"})', which can then
+        handle whatever special inclusion logic is needed.
+        """
+        for k, v in attrs.items():
+            include = getattr(self, '_include_' + k, None)
+            if include:
+                include(v)
+            else:
+                self._include_misc(k, v)
+
+    def exclude_package(self, package):
+        """Remove packages, modules, and extensions in named package"""
+
+        pfx = package + '.'
+        if self.packages:
+            self.packages = [
+                p for p in self.packages
+                if p != package and not p.startswith(pfx)
+            ]
+
+        if self.py_modules:
+            self.py_modules = [
+                p for p in self.py_modules
+                if p != package and not p.startswith(pfx)
+            ]
+
+        if self.ext_modules:
+            self.ext_modules = [
+                p for p in self.ext_modules
+                if p.name != package and not p.name.startswith(pfx)
+            ]
+
+    def has_contents_for(self, package):
+        """Return true if 'exclude_package(package)' would do something"""
+
+        pfx = package + '.'
+
+        for p in self.iter_distribution_names():
+            if p == package or p.startswith(pfx):
+                return True
+
+    def _exclude_misc(self, name, value):
+        """Handle 'exclude()' for list/tuple attrs without a special handler"""
+        if not isinstance(value, sequence):
+            raise DistutilsSetupError(
+                "%s: setting must be a list or tuple (%r)" % (name, value)
+            )
+        try:
+            old = getattr(self, name)
+        except AttributeError:
+            raise DistutilsSetupError(
+                "%s: No such distribution setting" % name
+            )
+        if old is not None and not isinstance(old, sequence):
+            raise DistutilsSetupError(
+                name + ": this setting cannot be changed via include/exclude"
+            )
+        elif old:
+            setattr(self, name, [item for item in old if item not in value])
+
+    def _include_misc(self, name, value):
+        """Handle 'include()' for list/tuple attrs without a special handler"""
+
+        if not isinstance(value, sequence):
+            raise DistutilsSetupError(
+                "%s: setting must be a list (%r)" % (name, value)
+            )
+        try:
+            old = getattr(self, name)
+        except AttributeError:
+            raise DistutilsSetupError(
+                "%s: No such distribution setting" % name
+            )
+        if old is None:
+            setattr(self, name, value)
+        elif not isinstance(old, sequence):
+            raise DistutilsSetupError(
+                name + ": this setting cannot be changed via include/exclude"
+            )
+        else:
+            new = [item for item in value if item not in old]
+            setattr(self, name, old + new)
+
+    def exclude(self, **attrs):
+        """Remove items from distribution that are named in keyword arguments
+
+        For example, 'dist.exclude(py_modules=["x"])' would remove 'x' from
+        the distribution's 'py_modules' attribute.  Excluding packages uses
+        the 'exclude_package()' method, so all of the package's contained
+        packages, modules, and extensions are also excluded.
+
+        Currently, this method only supports exclusion from attributes that are
+        lists or tuples.  If you need to add support for excluding from other
+        attributes in this or a subclass, you can add an '_exclude_X' method,
+        where 'X' is the name of the attribute.  The method will be called with
+        the value passed to 'exclude()'.  So, 'dist.exclude(foo={"bar":"baz"})'
+        will try to call 'dist._exclude_foo({"bar":"baz"})', which can then
+        handle whatever special exclusion logic is needed.
+        """
+        for k, v in attrs.items():
+            exclude = getattr(self, '_exclude_' + k, None)
+            if exclude:
+                exclude(v)
+            else:
+                self._exclude_misc(k, v)
+
+    def _exclude_packages(self, packages):
+        if not isinstance(packages, sequence):
+            raise DistutilsSetupError(
+                "packages: setting must be a list or tuple (%r)" % (packages,)
+            )
+        list(map(self.exclude_package, packages))
+
+    def _parse_command_opts(self, parser, args):
+        # Remove --with-X/--without-X options when processing command args
+        self.global_options = self.__class__.global_options
+        self.negative_opt = self.__class__.negative_opt
+
+        # First, expand any aliases
+        command = args[0]
+        aliases = self.get_option_dict('aliases')
+        while command in aliases:
+            src, alias = aliases[command]
+            del aliases[command]  # ensure each alias can expand only once!
+            import shlex
+            args[:1] = shlex.split(alias, True)
+            command = args[0]
+
+        nargs = _Distribution._parse_command_opts(self, parser, args)
+
+        # Handle commands that want to consume all remaining arguments
+        cmd_class = self.get_command_class(command)
+        if getattr(cmd_class, 'command_consumes_arguments', None):
+            self.get_option_dict(command)['args'] = ("command line", nargs)
+            if nargs is not None:
+                return []
+
+        return nargs
+
+    def get_cmdline_options(self):
+        """Return a '{cmd: {opt:val}}' map of all command-line options
+
+        Option names are all long, but do not include the leading '--', and
+        contain dashes rather than underscores.  If the option doesn't take
+        an argument (e.g. '--quiet'), the 'val' is 'None'.
+
+        Note that options provided by config files are intentionally excluded.
+        """
+
+        d = {}
+
+        for cmd, opts in self.command_options.items():
+
+            for opt, (src, val) in opts.items():
+
+                if src != "command line":
+                    continue
+
+                opt = opt.replace('_', '-')
+
+                if val == 0:
+                    cmdobj = self.get_command_obj(cmd)
+                    neg_opt = self.negative_opt.copy()
+                    neg_opt.update(getattr(cmdobj, 'negative_opt', {}))
+                    for neg, pos in neg_opt.items():
+                        if pos == opt:
+                            opt = neg
+                            val = None
+                            break
+                    else:
+                        raise AssertionError("Shouldn't be able to get here")
+
+                elif val == 1:
+                    val = None
+
+                d.setdefault(cmd, {})[opt] = val
+
+        return d
+
+    def iter_distribution_names(self):
+        """Yield all packages, modules, and extension names in distribution"""
+
+        for pkg in self.packages or ():
+            yield pkg
+
+        for module in self.py_modules or ():
+            yield module
+
+        for ext in self.ext_modules or ():
+            if isinstance(ext, tuple):
+                name, buildinfo = ext
+            else:
+                name = ext.name
+            if name.endswith('module'):
+                name = name[:-6]
+            yield name
+
+    def handle_display_options(self, option_order):
+        """If there were any non-global "display-only" options
+        (--help-commands or the metadata display options) on the command
+        line, display the requested info and return true; else return
+        false.
+        """
+        import sys
+
+        if six.PY2 or self.help_commands:
+            return _Distribution.handle_display_options(self, option_order)
+
+        # Stdout may be StringIO (e.g. in tests)
+        if not isinstance(sys.stdout, io.TextIOWrapper):
+            return _Distribution.handle_display_options(self, option_order)
+
+        # Don't wrap stdout if utf-8 is already the encoding. Provides
+        #  workaround for #334.
+        if sys.stdout.encoding.lower() in ('utf-8', 'utf8'):
+            return _Distribution.handle_display_options(self, option_order)
+
+        # Print metadata in UTF-8 no matter the platform
+        encoding = sys.stdout.encoding
+        errors = sys.stdout.errors
+        newline = sys.platform != 'win32' and '\n' or None
+        line_buffering = sys.stdout.line_buffering
+
+        sys.stdout = io.TextIOWrapper(
+            sys.stdout.detach(), 'utf-8', errors, newline, line_buffering)
+        try:
+            return _Distribution.handle_display_options(self, option_order)
+        finally:
+            sys.stdout = io.TextIOWrapper(
+                sys.stdout.detach(), encoding, errors, newline, line_buffering)
+
+
+class Feature:
+    """
+    **deprecated** -- The `Feature` facility was never completely implemented
+    or supported, `has reported issues
+    <https://github.com/pypa/setuptools/issues/58>`_ and will be removed in
+    a future version.
+
+    A subset of the distribution that can be excluded if unneeded/wanted
+
+    Features are created using these keyword arguments:
+
+      'description' -- a short, human readable description of the feature, to
+         be used in error messages, and option help messages.
+
+      'standard' -- if true, the feature is included by default if it is
+         available on the current system.  Otherwise, the feature is only
+         included if requested via a command line '--with-X' option, or if
+         another included feature requires it.  The default setting is 'False'.
+
+      'available' -- if true, the feature is available for installation on the
+         current system.  The default setting is 'True'.
+
+      'optional' -- if true, the feature's inclusion can be controlled from the
+         command line, using the '--with-X' or '--without-X' options.  If
+         false, the feature's inclusion status is determined automatically,
+         based on 'availabile', 'standard', and whether any other feature
+         requires it.  The default setting is 'True'.
+
+      'require_features' -- a string or sequence of strings naming features
+         that should also be included if this feature is included.  Defaults to
+         empty list.  May also contain 'Require' objects that should be
+         added/removed from the distribution.
+
+      'remove' -- a string or list of strings naming packages to be removed
+         from the distribution if this feature is *not* included.  If the
+         feature *is* included, this argument is ignored.  This argument exists
+         to support removing features that "crosscut" a distribution, such as
+         defining a 'tests' feature that removes all the 'tests' subpackages
+         provided by other features.  The default for this argument is an empty
+         list.  (Note: the named package(s) or modules must exist in the base
+         distribution when the 'setup()' function is initially called.)
+
+      other keywords -- any other keyword arguments are saved, and passed to
+         the distribution's 'include()' and 'exclude()' methods when the
+         feature is included or excluded, respectively.  So, for example, you
+         could pass 'packages=["a","b"]' to cause packages 'a' and 'b' to be
+         added or removed from the distribution as appropriate.
+
+    A feature must include at least one 'requires', 'remove', or other
+    keyword argument.  Otherwise, it can't affect the distribution in any way.
+    Note also that you can subclass 'Feature' to create your own specialized
+    feature types that modify the distribution in other ways when included or
+    excluded.  See the docstrings for the various methods here for more detail.
+    Aside from the methods, the only feature attributes that distributions look
+    at are 'description' and 'optional'.
+    """
+
+    @staticmethod
+    def warn_deprecated():
+        msg = (
+            "Features are deprecated and will be removed in a future "
+            "version. See https://github.com/pypa/setuptools/issues/65."
+        )
+        warnings.warn(msg, DistDeprecationWarning, stacklevel=3)
+
+    def __init__(
+            self, description, standard=False, available=True,
+            optional=True, require_features=(), remove=(), **extras):
+        self.warn_deprecated()
+
+        self.description = description
+        self.standard = standard
+        self.available = available
+        self.optional = optional
+        if isinstance(require_features, (str, Require)):
+            require_features = require_features,
+
+        self.require_features = [
+            r for r in require_features if isinstance(r, str)
+        ]
+        er = [r for r in require_features if not isinstance(r, str)]
+        if er:
+            extras['require_features'] = er
+
+        if isinstance(remove, str):
+            remove = remove,
+        self.remove = remove
+        self.extras = extras
+
+        if not remove and not require_features and not extras:
+            raise DistutilsSetupError(
+                "Feature %s: must define 'require_features', 'remove', or "
+                "at least one of 'packages', 'py_modules', etc."
+            )
+
+    def include_by_default(self):
+        """Should this feature be included by default?"""
+        return self.available and self.standard
+
+    def include_in(self, dist):
+        """Ensure feature and its requirements are included in distribution
+
+        You may override this in a subclass to perform additional operations on
+        the distribution.  Note that this method may be called more than once
+        per feature, and so should be idempotent.
+
+        """
+
+        if not self.available:
+            raise DistutilsPlatformError(
+                self.description + " is required, "
+                "but is not available on this platform"
+            )
+
+        dist.include(**self.extras)
+
+        for f in self.require_features:
+            dist.include_feature(f)
+
+    def exclude_from(self, dist):
+        """Ensure feature is excluded from distribution
+
+        You may override this in a subclass to perform additional operations on
+        the distribution.  This method will be called at most once per
+        feature, and only after all included features have been asked to
+        include themselves.
+        """
+
+        dist.exclude(**self.extras)
+
+        if self.remove:
+            for item in self.remove:
+                dist.exclude_package(item)
+
+    def validate(self, dist):
+        """Verify that feature makes sense in context of distribution
+
+        This method is called by the distribution just before it parses its
+        command line.  It checks to ensure that the 'remove' attribute, if any,
+        contains only valid package/module names that are present in the base
+        distribution when 'setup()' is called.  You may override it in a
+        subclass to perform any other required validation of the feature
+        against a target distribution.
+        """
+
+        for item in self.remove:
+            if not dist.has_contents_for(item):
+                raise DistutilsSetupError(
+                    "%s wants to be able to remove %s, but the distribution"
+                    " doesn't contain any packages or modules under %s"
+                    % (self.description, item, item)
+                )
+
+
+class DistDeprecationWarning(SetuptoolsDeprecationWarning):
+    """Class for warning about deprecations in dist in
+    setuptools. Not ignored by default, unlike DeprecationWarning."""
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/dist.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/dist.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..c48a06e53f09db9b07a9484de439da2bac6a44fe
GIT binary patch
literal 51591
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
IMTBPo08U#RZvX%Q

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/extension.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/extension.py
new file mode 100644
index 0000000..2946889
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/extension.py
@@ -0,0 +1,57 @@
+import re
+import functools
+import distutils.core
+import distutils.errors
+import distutils.extension
+
+from setuptools.extern.six.moves import map
+
+from .monkey import get_unpatched
+
+
+def _have_cython():
+    """
+    Return True if Cython can be imported.
+    """
+    cython_impl = 'Cython.Distutils.build_ext'
+    try:
+        # from (cython_impl) import build_ext
+        __import__(cython_impl, fromlist=['build_ext']).build_ext
+        return True
+    except Exception:
+        pass
+    return False
+
+
+# for compatibility
+have_pyrex = _have_cython
+
+_Extension = get_unpatched(distutils.core.Extension)
+
+
+class Extension(_Extension):
+    """Extension that uses '.c' files in place of '.pyx' files"""
+
+    def __init__(self, name, sources, *args, **kw):
+        # The *args is needed for compatibility as calls may use positional
+        # arguments. py_limited_api may be set only via keyword.
+        self.py_limited_api = kw.pop("py_limited_api", False)
+        _Extension.__init__(self, name, sources, *args, **kw)
+
+    def _convert_pyx_sources_to_lang(self):
+        """
+        Replace sources with .pyx extensions to sources with the target
+        language extension. This mechanism allows language authors to supply
+        pre-converted sources but to prefer the .pyx sources.
+        """
+        if _have_cython():
+            # the build has Cython, so allow it to compile the .pyx files
+            return
+        lang = self.language or ''
+        target_ext = '.cpp' if lang.lower() == 'c++' else '.c'
+        sub = functools.partial(re.sub, '.pyx$', target_ext)
+        self.sources = list(map(sub, self.sources))
+
+
+class Library(Extension):
+    """Just like a regular Extension, but built as a library instead"""
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/extension.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/extension.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..e2b79e3c369d2870726d4182664aa92a07e275e1
GIT binary patch
literal 2742
zcmZSn%**AGdLky70ScHI7#JKF7#NDzGB7ZtFfgPrGUPBYM8VmN3{i|QaVCZ+W*D0V
ziOmXQGcn|_G32r{M6ok4rZ6+4urTCsFywMFL~$}Orm!-!Ffc@MF{E-aL~%2uax$bc
zGi32FWbraIGcrW+F{H3Dr1CMOF*2mEgH$#%FhoZ2GNf=Yr1FAAIpL!GAXf%!a4|42
zWd8sE|G%FGBLf3N3CJtCi3OP;4n%~Pfq@}CwIseYuOP7`IU_X%>}`-dD+2?AGsxRE
zAa64=)G{zs$}yBMFw`(Gq%bk0Ff*hxGBh(XW-&4_mM}2{hvx}0u#_+}WOFeTnKLjl
zGUhQdM3k^F1Z%K>Ofg_!VBk_vP*4a;Eh#O^QwS+4O;yNDQ*f><$;i)BNKVXCNJ>@6
z%q_?-DoIVz11l|-0=WUKK+h$!xTLfsGpATDsWdYuB|f#Hq=bWkfg!CZKQ||{xTJ)W
zfq?-or2%q%3CR2L@eniP<AXrHF9A6QWH(s7YejNuK}lwQUI|FOTVhUeDkNCA85kIn
z!4`wG=V*YE0+=YyV_;y=FDS|^ODsv%FH0=aPs`6qNi8bYPfF1*PfE(mHO(zHGE6d0
zuS&NtwJ6WYsxmVGf%H865dDJ80^Q8K;*!Li99_3E4^QI&{o>S;(t?uw{G4KBW@<%A
zYF=?>ex6=IWeE=h14Dd9Vp(cD#7Q82F(1fDENqO-Ok#{2jJ%92j8GpzHG<<2qy`k1
zPM{c2U|?WKWq>BuC?-$}0VOwPP;7!2EDS-x8lW&LHfLa9aD}-*p(G=*M4_}ewOB!2
zFIin7Ei)&zSRpe{p&%zQIaMJ)O+j6+pt1rgkqj~b6qsxb3=IAtYmFEf7;0D;vcMUq
zgpr|{36z53nLw#Aiv`54VPvRbVyIyTDeGfqU`%0P2-aX?U|{eo0r|3^GCn6WH?t%)
zB|fnr6B4r^TMF_Eg4h`t7=l2N1&M38qrpidK0Y%qvm`zqq6HN3#i==I;1rOTn44Mx
z(p;QhT9lkx3>Hi*N-r(}*_&Msj%zS601+Mp^0hK3>_Bd2U>0Re21O!>1H#};SqRF`
z3=GW-3`M-4m<+CAV8~)*D3AojW-TK_4I@Jq6G%FRnIW5rp~wVO)Z{TUq_8s7!h*hp
zl_84_RH)Q2F*GwX)G{-aurri!fMbGzA&V0fRn3f`7>efv+o1stu{*Gw49U%qWB?6E
zh4Rdj3<XenP=F`lVug}?1r+&`j8uh^#G>@n5^y#LnUj;4mtLBfo{G?>rx22nS*(zo
znw*iCmsy;vkeHK`UtX*LSD9E^l968oF}<{)Ag2;;SV2*$ZgPHJSt_U~fm@waS^{!O
zK~ZX2YLNoS4PbXdT?Q#}Ku+;10cD$FP!dbl)-DDGxn6QXK`|(0=p`3}5;sVr3b=F)
z;siwms33y53tW`s<d>%wfiq-UX<jlodxMi(L1Ix!W?~LFl@+Ce%j4qGByj2j6=Fdk
zn}Y-y7#P5XW)MHfaF7E)hJ%whB-lWuUl6Ep1Se52F#zebL<UqaK?6Fzpt2$!8kX@T
z`SBnZYl6}+56Dk!oJ=f?{ETvp5{!`C2nw<Icu+Qsj|Y1!K0Y@;r8FlsJ{}xU@$o77
z$?@^vtPmsz3J{PnV4s4C0q|}R7Xt$Ws1Pj%m2GT{Y)qVNV7K~YCKV+XRbrO7pnQy6
z;synSYnNhM1_lPN(&7?@oXqT0g+zs-)b!Gv#3BWF@ui~xO01yTtVAKPSRqj%2V#W+
zsPafnOaT|uLGqx&59FXA#laCkN(>AP7N9r>Wfe9?4FQk?B|(HZC?SJ_BL!ZKC+8QX
zf^!I5s05@Q&eKaRD#|Y^E)fPbKj6CHrAmo3$Rc><sRxoM%F`>(tkBENFH0>3XQdKQ
zOy%b1Wv5mKfr?N_ZUx07xH>JUEK02aXFiZ)!0{UdY7hm1JOWN;2x0&d9Jms*fn*Ci
ckn@Yh7#J9M7@?3!fJuOvlb?-Ah*?Ym07;mm<p2Nx

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/extern/__init__.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/extern/__init__.py
new file mode 100644
index 0000000..cb2fa32
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/extern/__init__.py
@@ -0,0 +1,73 @@
+import sys
+
+
+class VendorImporter:
+    """
+    A PEP 302 meta path importer for finding optionally-vendored
+    or otherwise naturally-installed packages from root_name.
+    """
+
+    def __init__(self, root_name, vendored_names=(), vendor_pkg=None):
+        self.root_name = root_name
+        self.vendored_names = set(vendored_names)
+        self.vendor_pkg = vendor_pkg or root_name.replace('extern', '_vendor')
+
+    @property
+    def search_path(self):
+        """
+        Search first the vendor package then as a natural package.
+        """
+        yield self.vendor_pkg + '.'
+        yield ''
+
+    def find_module(self, fullname, path=None):
+        """
+        Return self when fullname starts with root_name and the
+        target module is one vendored through this importer.
+        """
+        root, base, target = fullname.partition(self.root_name + '.')
+        if root:
+            return
+        if not any(map(target.startswith, self.vendored_names)):
+            return
+        return self
+
+    def load_module(self, fullname):
+        """
+        Iterate over the search path to locate and load fullname.
+        """
+        root, base, target = fullname.partition(self.root_name + '.')
+        for prefix in self.search_path:
+            try:
+                extant = prefix + target
+                __import__(extant)
+                mod = sys.modules[extant]
+                sys.modules[fullname] = mod
+                # mysterious hack:
+                # Remove the reference to the extant package/module
+                # on later Python versions to cause relative imports
+                # in the vendor package to resolve the same modules
+                # as those going through this importer.
+                if sys.version_info >= (3, ):
+                    del sys.modules[extant]
+                return mod
+            except ImportError:
+                pass
+        else:
+            raise ImportError(
+                "The '{target}' package is required; "
+                "normally this is bundled with this package so if you get "
+                "this warning, consult the packager of your "
+                "distribution.".format(**locals())
+            )
+
+    def install(self):
+        """
+        Install this importer into sys.meta_path if not already present.
+        """
+        if self not in sys.meta_path:
+            sys.meta_path.append(self)
+
+
+names = 'six', 'packaging', 'pyparsing',
+VendorImporter(__name__, names, 'setuptools._vendor').install()
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/extern/__init__.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/extern/__init__.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..9a1e27d311b54d9fb9a0740dd44a9e03009e4bd1
GIT binary patch
literal 3323
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

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/glibc.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/glibc.py
new file mode 100644
index 0000000..a134591
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/glibc.py
@@ -0,0 +1,86 @@
+# This file originally from pip:
+# https://github.com/pypa/pip/blob/8f4f15a5a95d7d5b511ceaee9ed261176c181970/src/pip/_internal/utils/glibc.py
+from __future__ import absolute_import
+
+import ctypes
+import re
+import warnings
+
+
+def glibc_version_string():
+    "Returns glibc version string, or None if not using glibc."
+
+    # ctypes.CDLL(None) internally calls dlopen(NULL), and as the dlopen
+    # manpage says, "If filename is NULL, then the returned handle is for the
+    # main program". This way we can let the linker do the work to figure out
+    # which libc our process is actually using.
+    process_namespace = ctypes.CDLL(None)
+    try:
+        gnu_get_libc_version = process_namespace.gnu_get_libc_version
+    except AttributeError:
+        # Symbol doesn't exist -> therefore, we are not linked to
+        # glibc.
+        return None
+
+    # Call gnu_get_libc_version, which returns a string like "2.5"
+    gnu_get_libc_version.restype = ctypes.c_char_p
+    version_str = gnu_get_libc_version()
+    # py2 / py3 compatibility:
+    if not isinstance(version_str, str):
+        version_str = version_str.decode("ascii")
+
+    return version_str
+
+
+# Separated out from have_compatible_glibc for easier unit testing
+def check_glibc_version(version_str, required_major, minimum_minor):
+    # Parse string and check against requested version.
+    #
+    # We use a regexp instead of str.split because we want to discard any
+    # random junk that might come after the minor version -- this might happen
+    # in patched/forked versions of glibc (e.g. Linaro's version of glibc
+    # uses version strings like "2.20-2014.11"). See gh-3588.
+    m = re.match(r"(?P<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 False
+    return (int(m.group("major")) == required_major and
+            int(m.group("minor")) >= minimum_minor)
+
+
+def have_compatible_glibc(required_major, minimum_minor):
+    version_str = glibc_version_string()
+    if version_str is None:
+        return False
+    return check_glibc_version(version_str, required_major, minimum_minor)
+
+
+# platform.libc_ver regularly returns completely nonsensical glibc
+# versions. E.g. on my computer, platform says:
+#
+#   ~$ python2.7 -c 'import platform; print(platform.libc_ver())'
+#   ('glibc', '2.7')
+#   ~$ python3.5 -c 'import platform; print(platform.libc_ver())'
+#   ('glibc', '2.9')
+#
+# But the truth is:
+#
+#   ~$ ldd --version
+#   ldd (Debian GLIBC 2.22-11) 2.22
+#
+# This is unfortunate, because it means that the linehaul data on libc
+# versions that was generated by pip 8.1.2 and earlier is useless and
+# misleading. Solution: instead of using platform, use our code that actually
+# works.
+def libc_ver():
+    """Try to determine the glibc version
+
+    Returns a tuple of strings (lib, version) which default to empty strings
+    in case the lookup fails.
+    """
+    glibc_version = glibc_version_string()
+    if glibc_version is None:
+        return ("", "")
+    else:
+        return ("glibc", glibc_version)
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/glibc.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/glibc.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..b524cf1b6380eb23032257dcb952abc9b4e8b346
GIT binary patch
literal 2230
zcmZSn%**AGdLky70ScHH7#JKJ7#NCU7#J8*7#LC*8FCmHav2$-7#SErd?tn*CWa^`
zupARZ4l_d(GmOo`5XHif!pzXZz!1gCkir6HurZ{tf*I@#DQsW{2SW-IL$C%r0|P@Q
z$W{$T1_p)_eg+1H#H8Z<oYIoi_{`jb{Gt*+u&bCE7#LU?7#N&EuF3`}Wnjo+1ewvy
z$WY6`P|3?s!@!Wm%uvh75S}N*z*54(kj=$VWWd14$Oy72qJ)7Vi<O~<ks+Q9L^d-p
z)G{%Yurt&!F_dsHG&3<2r-Rs8oFLzV3}s@-V*rT+Yk({-wq#&n2udv}Ey^oaNYBYk
zN>(UKEh^5;&r>KaDay=C*HOqXQt->qOI65BQ^?CNQ7A3W%u9zT)hhwHJ+U}BGt*Cl
z3*>q>1_p-YlFEYA;u02+w_JRDzzmQ9B_a$A4C#5L@#(20@gSSxp*EH9F)%PVmXs7_
zCY6??x)v4X7nN{;42n<ANGyskC;^3LQED;B+!ByAnZ=oT#U+V($*Cn^Ka>=efGkc)
zP0mkA1$(PRkb!}rpeR2%wYWGwFEKZ@xF9h(H3;O~5^e?t2B^*P#U(`=;AjF7#aRpt
z4EhB{nPrJ3srqG!Mfz#^IVq_{#rjDp`sGPUdAX*!#YTon=IK@G7N!>EIayU^1|X20
zryrtUkXfJ$c2-V~u3MRhr*VLOacW6vK}mjoPBAhQ9LjnHm5}g24hWEQGV{_wUMvO$
z76Us!BQql}BQG;6GY=yt6F;L6Q!>cMps)qe;AE2m3V2AeVFaa?W+sMOW`-JOhGGMT
z5++dMNnrwsi<Pi|(gR}&D?@Mz8%RMGJ19jrGcq(Yg3?Yl6GMJ7144=gBo2~dV#sD?
z2-X0Fo?o#F0|SGGeSl4FVpe{UU9^F&WvsSlj2>7hGY=tDY|FsF;960Tnp~2a0!c6M
zq*b0-lA&Ovker`eke`>DS5mA1Hcc-VWPpxBdVYzOf@(21b%7-yERduIC}EU<GICKW
zL^QD^IRl(r$`gz7GV{_QDG$T}r>mgSypqh^)NqI-Sc_X?PBA3qWagECMbeA%OA9nW
zp&G;s3QbUgEJ`gb%`8eyiHEoVB%Yg@mzi6d8xMA72`Fdh4qWOH2IY{9)a2}VaDswm
zCQ$SggWS)+F2u;j$jQjf$igVim<$RsP?7<85}a%_K^|pbfD{-t;4&|pgP}+glxBiU
zm_bEE4Ff1yG&3^<gNrdgNC<%p4+0qzBnB!wWI*WwWO9%sh${smK!G)IAtTDbz>twx
zmKqOAUx_7|Nja&IFfw6aU?>J9AO=QGMjl2MMsOJnibqiBfI~$c5h@IzOq0UQ011^8
z7KUI*K1yR^2u=Zo2`E1lPiA0X2q~&mD9KkyNi9h&%FWD6RVc|wMNRQsTnY*b3b1lE
zQK6)?ASYEJKMh*Q7At7vWG3mr@`t8Ec}8Y(hC)heT4HHV3CQf!+=7xym};<LnRyDy
ziNz4Ra`N-DOA8dz5;Jp(^}w<vpaKn&wm~I~p9aW>L2{tT0TB=`JSM@>TLOwTl(aN(
zQ3#48kh?*t+6NwMY~Wa9(%=L|5*GslLwtN%X-R2OYJ7YU$iG2gPlAg6AW-fI0{ah?
tK7(XI9#;gVRFJxX^_NX<eoARhsvRiLfODz<6AvQ~BM&pD6sG{E1OR8S9P|JH

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/glob.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/glob.py
new file mode 100644
index 0000000..9d7cbc5
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/glob.py
@@ -0,0 +1,174 @@
+"""
+Filename globbing utility. Mostly a copy of `glob` from Python 3.5.
+
+Changes include:
+ * `yield from` and PEP3102 `*` removed.
+ * Hidden files are not ignored.
+"""
+
+import os
+import re
+import fnmatch
+
+__all__ = ["glob", "iglob", "escape"]
+
+
+def glob(pathname, recursive=False):
+    """Return a list of paths matching a pathname pattern.
+
+    The pattern may contain simple shell-style wildcards a la
+    fnmatch. However, unlike fnmatch, filenames starting with a
+    dot are special cases that are not matched by '*' and '?'
+    patterns.
+
+    If recursive is true, the pattern '**' will match any files and
+    zero or more directories and subdirectories.
+    """
+    return list(iglob(pathname, recursive=recursive))
+
+
+def iglob(pathname, recursive=False):
+    """Return an iterator which yields the paths matching a pathname pattern.
+
+    The pattern may contain simple shell-style wildcards a la
+    fnmatch. However, unlike fnmatch, filenames starting with a
+    dot are special cases that are not matched by '*' and '?'
+    patterns.
+
+    If recursive is true, the pattern '**' will match any files and
+    zero or more directories and subdirectories.
+    """
+    it = _iglob(pathname, recursive)
+    if recursive and _isrecursive(pathname):
+        s = next(it)  # skip empty string
+        assert not s
+    return it
+
+
+def _iglob(pathname, recursive):
+    dirname, basename = os.path.split(pathname)
+    if not has_magic(pathname):
+        if basename:
+            if os.path.lexists(pathname):
+                yield pathname
+        else:
+            # Patterns ending with a slash should match only directories
+            if os.path.isdir(dirname):
+                yield pathname
+        return
+    if not dirname:
+        if recursive and _isrecursive(basename):
+            for x in glob2(dirname, basename):
+                yield x
+        else:
+            for x in glob1(dirname, basename):
+                yield x
+        return
+    # `os.path.split()` returns the argument itself as a dirname if it is a
+    # drive or UNC path.  Prevent an infinite recursion if a drive or UNC path
+    # contains magic characters (i.e. r'\\?\C:').
+    if dirname != pathname and has_magic(dirname):
+        dirs = _iglob(dirname, recursive)
+    else:
+        dirs = [dirname]
+    if has_magic(basename):
+        if recursive and _isrecursive(basename):
+            glob_in_dir = glob2
+        else:
+            glob_in_dir = glob1
+    else:
+        glob_in_dir = glob0
+    for dirname in dirs:
+        for name in glob_in_dir(dirname, basename):
+            yield os.path.join(dirname, name)
+
+
+# These 2 helper functions non-recursively glob inside a literal directory.
+# They return a list of basenames. `glob1` accepts a pattern while `glob0`
+# takes a literal basename (so it only has to check for its existence).
+
+
+def glob1(dirname, pattern):
+    if not dirname:
+        if isinstance(pattern, bytes):
+            dirname = os.curdir.encode('ASCII')
+        else:
+            dirname = os.curdir
+    try:
+        names = os.listdir(dirname)
+    except OSError:
+        return []
+    return fnmatch.filter(names, pattern)
+
+
+def glob0(dirname, basename):
+    if not basename:
+        # `os.path.split()` returns an empty basename for paths ending with a
+        # directory separator.  'q*x/' should match only directories.
+        if os.path.isdir(dirname):
+            return [basename]
+    else:
+        if os.path.lexists(os.path.join(dirname, basename)):
+            return [basename]
+    return []
+
+
+# This helper function recursively yields relative pathnames inside a literal
+# directory.
+
+
+def glob2(dirname, pattern):
+    assert _isrecursive(pattern)
+    yield pattern[:0]
+    for x in _rlistdir(dirname):
+        yield x
+
+
+# Recursively yields relative pathnames inside a literal directory.
+def _rlistdir(dirname):
+    if not dirname:
+        if isinstance(dirname, bytes):
+            dirname = os.curdir.encode('ASCII')
+        else:
+            dirname = os.curdir
+    try:
+        names = os.listdir(dirname)
+    except os.error:
+        return
+    for x in names:
+        yield x
+        path = os.path.join(dirname, x) if dirname else x
+        for y in _rlistdir(path):
+            yield os.path.join(x, y)
+
+
+magic_check = re.compile('([*?[])')
+magic_check_bytes = re.compile(b'([*?[])')
+
+
+def has_magic(s):
+    if isinstance(s, bytes):
+        match = magic_check_bytes.search(s)
+    else:
+        match = magic_check.search(s)
+    return match is not None
+
+
+def _isrecursive(pattern):
+    if isinstance(pattern, bytes):
+        return pattern == b'**'
+    else:
+        return pattern == '**'
+
+
+def escape(pathname):
+    """Escape all special characters.
+    """
+    # Escaping is done by wrapping any of "*?[" between square brackets.
+    # Metacharacters do not work in the drive part and shouldn't be escaped.
+    drive, pathname = os.path.splitdrive(pathname)
+    if isinstance(pathname, bytes):
+        pathname = magic_check_bytes.sub(br'[\1]', pathname)
+    else:
+        pathname = magic_check.sub(r'[\1]', pathname)
+    return drive + pathname
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/glob.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/glob.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..b535adfb404f962fff2df03ab453c080b1eb716d
GIT binary patch
literal 5311
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
D6>7+9

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/gui-32.exe b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/gui-32.exe
new file mode 100644
index 0000000000000000000000000000000000000000..f8d3509653ba8f80ca7f3aa7f95616142ba83a94
GIT binary patch
literal 65536
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

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/gui-64.exe b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/gui-64.exe
new file mode 100644
index 0000000000000000000000000000000000000000..330c51a5dde15a0bb610a48cd0ca11770c914dae
GIT binary patch
literal 75264
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
V{_})^Apq177}AZ{QOA=T0ss*!rV{`F

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/gui.exe b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/gui.exe
new file mode 100644
index 0000000000000000000000000000000000000000..f8d3509653ba8f80ca7f3aa7f95616142ba83a94
GIT binary patch
literal 65536
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

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/launch.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/launch.py
new file mode 100644
index 0000000..308283e
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/launch.py
@@ -0,0 +1,35 @@
+"""
+Launch the Python script on the command line after
+setuptools is bootstrapped via import.
+"""
+
+# Note that setuptools gets imported implicitly by the
+# invocation of this script using python -m setuptools.launch
+
+import tokenize
+import sys
+
+
+def run():
+    """
+    Run the script in sys.argv[1] as if it had
+    been invoked naturally.
+    """
+    __builtins__
+    script_name = sys.argv[1]
+    namespace = dict(
+        __file__=script_name,
+        __name__='__main__',
+        __doc__=None,
+    )
+    sys.argv[:] = sys.argv[1:]
+
+    open_ = getattr(tokenize, 'open', open)
+    script = open_(script_name).read()
+    norm_script = script.replace('\\r\\n', '\\n')
+    code = compile(norm_script, script_name, 'exec')
+    exec(code, namespace)
+
+
+if __name__ == '__main__':
+    run()
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/launch.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/launch.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..e6651d722e8323e06dc6735b4bb6613c28ecd117
GIT binary patch
literal 1108
zcmZSn%**AGdLky70ScHH7#JKF7#NBj85kH+7#N}$7*ZG+QkWQW7#X4%VQeObC?<v!
zW`-69hA3u+R2GI57KUslh9X;rRAz=|1_s7F29Ta$4OWm*(F_a>Tt11VdC3_HB^jv-
z0hJ{g`FRS($wiq3B?|d@V8P`4+}y;x6os73yi|q6w35^!uHw{^(t?uw{G4Ki%wmP4
z{QQ#QlA^?dg47g+vdlz<%-n+fq7pr>%>V!Y|Mvs?fQ^BHft`VY!3kvTL<R<iR0amd
zR7Qp@CXmY|YZ*Z9OJQQDVF0;4g@qx7l_7<Tp_zfXmXQIjP9DP2NM&V6Wn)NTV@PFZ
zXl7=pWn!oSYi(v^$l?HbvzD2mhM6IYlOctjA%%mXnTes6g&~!Tp@s!)11DG)D?<${
zLk%MXOK1ugL$C%n$Y}wf5K&N2PzWl8_#PS-nRyDumBo6AMd@YHhOr8X#R{2e3YjGe
z8Hp)eAmvG^sd);Sd1d+8sVNG1i6x~)i8(oydSJOsMg|6k5)K9ihWPlj%$(Htcqk_?
zF&DwfP0Y-Tk1qiQQha<$esX+#2@3-QLw-SOUNMLfQxua|3`ztsd0>guiqvF3u%k<O
zz(yyPX6BS+<`u`smoS68QdtaE2XZo)k&>BQ0%rK-=cR(}Nlz_FEGa1hyQU;RJ2fw}
zDm4gX7g$+QYGMjlSy5_1PGT}dOLBg0L1s>>1}HvDz##@sEAb$&lyEXIFn}1v1t8_1
z6b5pAd<jS~Bpkt7^74yv<Dq<zZOQp5sT!bE4kn7T85kJ!3yLz!5=&C`%My$9)ADmt
zQj3c9lT!4{lalgsO>>Kl43o^$tI{n@Ey{DUs>}>PAU#h%M86=jKsPh5xFj(rN7t>)
z!_zoGACXv*nK|H8uUAkB4y>ZmJYG<kNr0Te%EHLY$OeX-OoB{8j1U+E3Vd+B2?B+0
z5Gd4xK+zQ>#=yW31d3#^2M`3^y#h*OHo5sJr8%i~ppY%*VqjokW94DwVdfO&VFUoX
CZ3>S7

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/lib2to3_ex.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/lib2to3_ex.py
new file mode 100644
index 0000000..4b1a73f
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/lib2to3_ex.py
@@ -0,0 +1,62 @@
+"""
+Customized Mixin2to3 support:
+
+ - adds support for converting doctests
+
+
+This module raises an ImportError on Python 2.
+"""
+
+from distutils.util import Mixin2to3 as _Mixin2to3
+from distutils import log
+from lib2to3.refactor import RefactoringTool, get_fixers_from_package
+
+import setuptools
+
+
+class DistutilsRefactoringTool(RefactoringTool):
+    def log_error(self, msg, *args, **kw):
+        log.error(msg, *args)
+
+    def log_message(self, msg, *args):
+        log.info(msg, *args)
+
+    def log_debug(self, msg, *args):
+        log.debug(msg, *args)
+
+
+class Mixin2to3(_Mixin2to3):
+    def run_2to3(self, files, doctests=False):
+        # See of the distribution option has been set, otherwise check the
+        # setuptools default.
+        if self.distribution.use_2to3 is not True:
+            return
+        if not files:
+            return
+        log.info("Fixing " + " ".join(files))
+        self.__build_fixer_names()
+        self.__exclude_fixers()
+        if doctests:
+            if setuptools.run_2to3_on_doctests:
+                r = DistutilsRefactoringTool(self.fixer_names)
+                r.refactor(files, write=True, doctests_only=True)
+        else:
+            _Mixin2to3.run_2to3(self, files)
+
+    def __build_fixer_names(self):
+        if self.fixer_names:
+            return
+        self.fixer_names = []
+        for p in setuptools.lib2to3_fixer_packages:
+            self.fixer_names.extend(get_fixers_from_package(p))
+        if self.distribution.use_2to3_fixers is not None:
+            for p in self.distribution.use_2to3_fixers:
+                self.fixer_names.extend(get_fixers_from_package(p))
+
+    def __exclude_fixers(self):
+        excluded_fixers = getattr(self, 'exclude_fixers', [])
+        if self.distribution.use_2to3_exclude_fixers is not None:
+            excluded_fixers.extend(self.distribution.use_2to3_exclude_fixers)
+        for fixer_name in excluded_fixers:
+            if fixer_name in self.fixer_names:
+                self.fixer_names.remove(fixer_name)
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/lib2to3_ex.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/lib2to3_ex.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..55a59784bc5c09986c4026355ef4b28d3f3f952c
GIT binary patch
literal 3490
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
W4#X}7#U>k*0HXk-7!wb(7&idtfiv|0

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/monkey.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/monkey.py
new file mode 100644
index 0000000..3c77f8c
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/monkey.py
@@ -0,0 +1,179 @@
+"""
+Monkey patching of distutils.
+"""
+
+import sys
+import distutils.filelist
+import platform
+import types
+import functools
+from importlib import import_module
+import inspect
+
+from setuptools.extern import six
+
+import setuptools
+
+__all__ = []
+"""
+Everything is private. Contact the project team
+if you think you need this functionality.
+"""
+
+
+def _get_mro(cls):
+    """
+    Returns the bases classes for cls sorted by the MRO.
+
+    Works around an issue on Jython where inspect.getmro will not return all
+    base classes if multiple classes share the same name. Instead, this
+    function will return a tuple containing the class itself, and the contents
+    of cls.__bases__. See https://github.com/pypa/setuptools/issues/1024.
+    """
+    if platform.python_implementation() == "Jython":
+        return (cls,) + cls.__bases__
+    return inspect.getmro(cls)
+
+
+def get_unpatched(item):
+    lookup = (
+        get_unpatched_class if isinstance(item, six.class_types) else
+        get_unpatched_function if isinstance(item, types.FunctionType) else
+        lambda item: None
+    )
+    return lookup(item)
+
+
+def get_unpatched_class(cls):
+    """Protect against re-patching the distutils if reloaded
+
+    Also ensures that no other distutils extension monkeypatched the distutils
+    first.
+    """
+    external_bases = (
+        cls
+        for cls in _get_mro(cls)
+        if not cls.__module__.startswith('setuptools')
+    )
+    base = next(external_bases)
+    if not base.__module__.startswith('distutils'):
+        msg = "distutils has already been patched by %r" % cls
+        raise AssertionError(msg)
+    return base
+
+
+def patch_all():
+    # we can't patch distutils.cmd, alas
+    distutils.core.Command = setuptools.Command
+
+    has_issue_12885 = sys.version_info <= (3, 5, 3)
+
+    if has_issue_12885:
+        # fix findall bug in distutils (http://bugs.python.org/issue12885)
+        distutils.filelist.findall = setuptools.findall
+
+    needs_warehouse = (
+        sys.version_info < (2, 7, 13)
+        or
+        (3, 4) < sys.version_info < (3, 4, 6)
+        or
+        (3, 5) < sys.version_info <= (3, 5, 3)
+    )
+
+    if needs_warehouse:
+        warehouse = 'https://upload.pypi.org/legacy/'
+        distutils.config.PyPIRCCommand.DEFAULT_REPOSITORY = warehouse
+
+    _patch_distribution_metadata()
+
+    # Install Distribution throughout the distutils
+    for module in distutils.dist, distutils.core, distutils.cmd:
+        module.Distribution = setuptools.dist.Distribution
+
+    # Install the patched Extension
+    distutils.core.Extension = setuptools.extension.Extension
+    distutils.extension.Extension = setuptools.extension.Extension
+    if 'distutils.command.build_ext' in sys.modules:
+        sys.modules['distutils.command.build_ext'].Extension = (
+            setuptools.extension.Extension
+        )
+
+    patch_for_msvc_specialized_compiler()
+
+
+def _patch_distribution_metadata():
+    """Patch write_pkg_file and read_pkg_file for higher metadata standards"""
+    for attr in ('write_pkg_file', 'read_pkg_file', 'get_metadata_version'):
+        new_val = getattr(setuptools.dist, attr)
+        setattr(distutils.dist.DistributionMetadata, attr, new_val)
+
+
+def patch_func(replacement, target_mod, func_name):
+    """
+    Patch func_name in target_mod with replacement
+
+    Important - original must be resolved by name to avoid
+    patching an already patched function.
+    """
+    original = getattr(target_mod, func_name)
+
+    # set the 'unpatched' attribute on the replacement to
+    # point to the original.
+    vars(replacement).setdefault('unpatched', original)
+
+    # replace the function in the original module
+    setattr(target_mod, func_name, replacement)
+
+
+def get_unpatched_function(candidate):
+    return getattr(candidate, 'unpatched')
+
+
+def patch_for_msvc_specialized_compiler():
+    """
+    Patch functions in distutils to use standalone Microsoft Visual C++
+    compilers.
+    """
+    # import late to avoid circular imports on Python < 3.5
+    msvc = import_module('setuptools.msvc')
+
+    if platform.system() != 'Windows':
+        # Compilers only availables on Microsoft Windows
+        return
+
+    def patch_params(mod_name, func_name):
+        """
+        Prepare the parameters for patch_func to patch indicated function.
+        """
+        repl_prefix = 'msvc9_' if 'msvc9' in mod_name else 'msvc14_'
+        repl_name = repl_prefix + func_name.lstrip('_')
+        repl = getattr(msvc, repl_name)
+        mod = import_module(mod_name)
+        if not hasattr(mod, func_name):
+            raise ImportError(func_name)
+        return repl, mod, func_name
+
+    # Python 2.7 to 3.4
+    msvc9 = functools.partial(patch_params, 'distutils.msvc9compiler')
+
+    # Python 3.5+
+    msvc14 = functools.partial(patch_params, 'distutils._msvccompiler')
+
+    try:
+        # Patch distutils.msvc9compiler
+        patch_func(*msvc9('find_vcvarsall'))
+        patch_func(*msvc9('query_vcvarsall'))
+    except ImportError:
+        pass
+
+    try:
+        # Patch distutils._msvccompiler._get_vc_env
+        patch_func(*msvc14('_get_vc_env'))
+    except ImportError:
+        pass
+
+    try:
+        # Patch distutils._msvccompiler.gen_lib_options for Numpy
+        patch_func(*msvc14('gen_lib_options'))
+    except ImportError:
+        pass
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/monkey.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/monkey.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..ebf119892a9d5ccd1be8cba39cddc128edfa0eb3
GIT binary patch
literal 6478
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
Wc$nDOIr%s_IfXdYIoUY{IavUs8bBBT

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/msvc.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/msvc.py
new file mode 100644
index 0000000..b9c472f
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/msvc.py
@@ -0,0 +1,1301 @@
+"""
+Improved support for Microsoft Visual C++ compilers.
+
+Known supported compilers:
+--------------------------
+Microsoft Visual C++ 9.0:
+    Microsoft Visual C++ Compiler for Python 2.7 (x86, amd64)
+    Microsoft Windows SDK 6.1 (x86, x64, ia64)
+    Microsoft Windows SDK 7.0 (x86, x64, ia64)
+
+Microsoft Visual C++ 10.0:
+    Microsoft Windows SDK 7.1 (x86, x64, ia64)
+
+Microsoft Visual C++ 14.0:
+    Microsoft Visual C++ Build Tools 2015 (x86, x64, arm)
+    Microsoft Visual Studio 2017 (x86, x64, arm, arm64)
+    Microsoft Visual Studio Build Tools 2017 (x86, x64, arm, arm64)
+"""
+
+import os
+import sys
+import platform
+import itertools
+import distutils.errors
+from setuptools.extern.packaging.version import LegacyVersion
+
+from setuptools.extern.six.moves import filterfalse
+
+from .monkey import get_unpatched
+
+if platform.system() == 'Windows':
+    from setuptools.extern.six.moves import winreg
+    safe_env = os.environ
+else:
+    """
+    Mock winreg and environ so the module can be imported
+    on this platform.
+    """
+
+    class winreg:
+        HKEY_USERS = None
+        HKEY_CURRENT_USER = None
+        HKEY_LOCAL_MACHINE = None
+        HKEY_CLASSES_ROOT = None
+
+    safe_env = dict()
+
+_msvc9_suppress_errors = (
+    # msvc9compiler isn't available on some platforms
+    ImportError,
+
+    # msvc9compiler raises DistutilsPlatformError in some
+    # environments. See #1118.
+    distutils.errors.DistutilsPlatformError,
+)
+
+try:
+    from distutils.msvc9compiler import Reg
+except _msvc9_suppress_errors:
+    pass
+
+
+def msvc9_find_vcvarsall(version):
+    """
+    Patched "distutils.msvc9compiler.find_vcvarsall" to use the standalone
+    compiler build for Python (VCForPython). Fall back to original behavior
+    when the standalone compiler is not available.
+
+    Redirect the path of "vcvarsall.bat".
+
+    Known supported compilers
+    -------------------------
+    Microsoft Visual C++ 9.0:
+        Microsoft Visual C++ Compiler for Python 2.7 (x86, amd64)
+
+    Parameters
+    ----------
+    version: float
+        Required Microsoft Visual C++ version.
+
+    Return
+    ------
+    vcvarsall.bat path: str
+    """
+    VC_BASE = r'Software\%sMicrosoft\DevDiv\VCForPython\%0.1f'
+    key = VC_BASE % ('', version)
+    try:
+        # Per-user installs register the compiler path here
+        productdir = Reg.get_value(key, "installdir")
+    except KeyError:
+        try:
+            # All-user installs on a 64-bit system register here
+            key = VC_BASE % ('Wow6432Node\\', version)
+            productdir = Reg.get_value(key, "installdir")
+        except KeyError:
+            productdir = None
+
+    if productdir:
+        vcvarsall = os.path.os.path.join(productdir, "vcvarsall.bat")
+        if os.path.isfile(vcvarsall):
+            return vcvarsall
+
+    return get_unpatched(msvc9_find_vcvarsall)(version)
+
+
+def msvc9_query_vcvarsall(ver, arch='x86', *args, **kwargs):
+    """
+    Patched "distutils.msvc9compiler.query_vcvarsall" for support extra
+    compilers.
+
+    Set environment without use of "vcvarsall.bat".
+
+    Known supported compilers
+    -------------------------
+    Microsoft Visual C++ 9.0:
+        Microsoft Visual C++ Compiler for Python 2.7 (x86, amd64)
+        Microsoft Windows SDK 6.1 (x86, x64, ia64)
+        Microsoft Windows SDK 7.0 (x86, x64, ia64)
+
+    Microsoft Visual C++ 10.0:
+        Microsoft Windows SDK 7.1 (x86, x64, ia64)
+
+    Parameters
+    ----------
+    ver: float
+        Required Microsoft Visual C++ version.
+    arch: str
+        Target architecture.
+
+    Return
+    ------
+    environment: dict
+    """
+    # Try to get environement from vcvarsall.bat (Classical way)
+    try:
+        orig = get_unpatched(msvc9_query_vcvarsall)
+        return orig(ver, arch, *args, **kwargs)
+    except distutils.errors.DistutilsPlatformError:
+        # Pass error if Vcvarsall.bat is missing
+        pass
+    except ValueError:
+        # Pass error if environment not set after executing vcvarsall.bat
+        pass
+
+    # If error, try to set environment directly
+    try:
+        return EnvironmentInfo(arch, ver).return_env()
+    except distutils.errors.DistutilsPlatformError as exc:
+        _augment_exception(exc, ver, arch)
+        raise
+
+
+def msvc14_get_vc_env(plat_spec):
+    """
+    Patched "distutils._msvccompiler._get_vc_env" for support extra
+    compilers.
+
+    Set environment without use of "vcvarsall.bat".
+
+    Known supported compilers
+    -------------------------
+    Microsoft Visual C++ 14.0:
+        Microsoft Visual C++ Build Tools 2015 (x86, x64, arm)
+        Microsoft Visual Studio 2017 (x86, x64, arm, arm64)
+        Microsoft Visual Studio Build Tools 2017 (x86, x64, arm, arm64)
+
+    Parameters
+    ----------
+    plat_spec: str
+        Target architecture.
+
+    Return
+    ------
+    environment: dict
+    """
+    # Try to get environment from vcvarsall.bat (Classical way)
+    try:
+        return get_unpatched(msvc14_get_vc_env)(plat_spec)
+    except distutils.errors.DistutilsPlatformError:
+        # Pass error Vcvarsall.bat is missing
+        pass
+
+    # If error, try to set environment directly
+    try:
+        return EnvironmentInfo(plat_spec, vc_min_ver=14.0).return_env()
+    except distutils.errors.DistutilsPlatformError as exc:
+        _augment_exception(exc, 14.0)
+        raise
+
+
+def msvc14_gen_lib_options(*args, **kwargs):
+    """
+    Patched "distutils._msvccompiler.gen_lib_options" for fix
+    compatibility between "numpy.distutils" and "distutils._msvccompiler"
+    (for Numpy < 1.11.2)
+    """
+    if "numpy.distutils" in sys.modules:
+        import numpy as np
+        if LegacyVersion(np.__version__) < LegacyVersion('1.11.2'):
+            return np.distutils.ccompiler.gen_lib_options(*args, **kwargs)
+    return get_unpatched(msvc14_gen_lib_options)(*args, **kwargs)
+
+
+def _augment_exception(exc, version, arch=''):
+    """
+    Add details to the exception message to help guide the user
+    as to what action will resolve it.
+    """
+    # Error if MSVC++ directory not found or environment not set
+    message = exc.args[0]
+
+    if "vcvarsall" in message.lower() or "visual c" in message.lower():
+        # Special error message if MSVC++ not installed
+        tmpl = 'Microsoft Visual C++ {version:0.1f} is required.'
+        message = tmpl.format(**locals())
+        msdownload = 'www.microsoft.com/download/details.aspx?id=%d'
+        if version == 9.0:
+            if arch.lower().find('ia64') > -1:
+                # For VC++ 9.0, if IA64 support is needed, redirect user
+                # to Windows SDK 7.0
+                message += ' Get it with "Microsoft Windows SDK 7.0": '
+                message += msdownload % 3138
+            else:
+                # For VC++ 9.0 redirect user to Vc++ for Python 2.7 :
+                # This redirection link is maintained by Microsoft.
+                # Contact vspython@microsoft.com if it needs updating.
+                message += ' Get it from http://aka.ms/vcpython27'
+        elif version == 10.0:
+            # For VC++ 10.0 Redirect user to Windows SDK 7.1
+            message += ' Get it with "Microsoft Windows SDK 7.1": '
+            message += msdownload % 8279
+        elif version >= 14.0:
+            # For VC++ 14.0 Redirect user to Visual C++ Build Tools
+            message += (' Get it with "Microsoft Visual C++ Build Tools": '
+                        r'https://visualstudio.microsoft.com/downloads/')
+
+    exc.args = (message, )
+
+
+class PlatformInfo:
+    """
+    Current and Target Architectures informations.
+
+    Parameters
+    ----------
+    arch: str
+        Target architecture.
+    """
+    current_cpu = safe_env.get('processor_architecture', '').lower()
+
+    def __init__(self, arch):
+        self.arch = arch.lower().replace('x64', 'amd64')
+
+    @property
+    def target_cpu(self):
+        return self.arch[self.arch.find('_') + 1:]
+
+    def target_is_x86(self):
+        return self.target_cpu == 'x86'
+
+    def current_is_x86(self):
+        return self.current_cpu == 'x86'
+
+    def current_dir(self, hidex86=False, x64=False):
+        """
+        Current platform specific subfolder.
+
+        Parameters
+        ----------
+        hidex86: bool
+            return '' and not '\x86' if architecture is x86.
+        x64: bool
+            return '\x64' and not '\amd64' if architecture is amd64.
+
+        Return
+        ------
+        subfolder: str
+            '\target', or '' (see hidex86 parameter)
+        """
+        return (
+            '' if (self.current_cpu == 'x86' and hidex86) else
+            r'\x64' if (self.current_cpu == 'amd64' and x64) else
+            r'\%s' % self.current_cpu
+        )
+
+    def target_dir(self, hidex86=False, x64=False):
+        r"""
+        Target platform specific subfolder.
+
+        Parameters
+        ----------
+        hidex86: bool
+            return '' and not '\x86' if architecture is x86.
+        x64: bool
+            return '\x64' and not '\amd64' if architecture is amd64.
+
+        Return
+        ------
+        subfolder: str
+            '\current', or '' (see hidex86 parameter)
+        """
+        return (
+            '' if (self.target_cpu == 'x86' and hidex86) else
+            r'\x64' if (self.target_cpu == 'amd64' and x64) else
+            r'\%s' % self.target_cpu
+        )
+
+    def cross_dir(self, forcex86=False):
+        r"""
+        Cross platform specific subfolder.
+
+        Parameters
+        ----------
+        forcex86: bool
+            Use 'x86' as current architecture even if current acritecture is
+            not x86.
+
+        Return
+        ------
+        subfolder: str
+            '' if target architecture is current architecture,
+            '\current_target' if not.
+        """
+        current = 'x86' if forcex86 else self.current_cpu
+        return (
+            '' if self.target_cpu == current else
+            self.target_dir().replace('\\', '\\%s_' % current)
+        )
+
+
+class RegistryInfo:
+    """
+    Microsoft Visual Studio related registry informations.
+
+    Parameters
+    ----------
+    platform_info: PlatformInfo
+        "PlatformInfo" instance.
+    """
+    HKEYS = (winreg.HKEY_USERS,
+             winreg.HKEY_CURRENT_USER,
+             winreg.HKEY_LOCAL_MACHINE,
+             winreg.HKEY_CLASSES_ROOT)
+
+    def __init__(self, platform_info):
+        self.pi = platform_info
+
+    @property
+    def visualstudio(self):
+        """
+        Microsoft Visual Studio root registry key.
+        """
+        return 'VisualStudio'
+
+    @property
+    def sxs(self):
+        """
+        Microsoft Visual Studio SxS registry key.
+        """
+        return os.path.join(self.visualstudio, 'SxS')
+
+    @property
+    def vc(self):
+        """
+        Microsoft Visual C++ VC7 registry key.
+        """
+        return os.path.join(self.sxs, 'VC7')
+
+    @property
+    def vs(self):
+        """
+        Microsoft Visual Studio VS7 registry key.
+        """
+        return os.path.join(self.sxs, 'VS7')
+
+    @property
+    def vc_for_python(self):
+        """
+        Microsoft Visual C++ for Python registry key.
+        """
+        return r'DevDiv\VCForPython'
+
+    @property
+    def microsoft_sdk(self):
+        """
+        Microsoft SDK registry key.
+        """
+        return 'Microsoft SDKs'
+
+    @property
+    def windows_sdk(self):
+        """
+        Microsoft Windows/Platform SDK registry key.
+        """
+        return os.path.join(self.microsoft_sdk, 'Windows')
+
+    @property
+    def netfx_sdk(self):
+        """
+        Microsoft .NET Framework SDK registry key.
+        """
+        return os.path.join(self.microsoft_sdk, 'NETFXSDK')
+
+    @property
+    def windows_kits_roots(self):
+        """
+        Microsoft Windows Kits Roots registry key.
+        """
+        return r'Windows Kits\Installed Roots'
+
+    def microsoft(self, key, x86=False):
+        """
+        Return key in Microsoft software registry.
+
+        Parameters
+        ----------
+        key: str
+            Registry key path where look.
+        x86: str
+            Force x86 software registry.
+
+        Return
+        ------
+        str: value
+        """
+        node64 = '' if self.pi.current_is_x86() or x86 else 'Wow6432Node'
+        return os.path.join('Software', node64, 'Microsoft', key)
+
+    def lookup(self, key, name):
+        """
+        Look for values in registry in Microsoft software registry.
+
+        Parameters
+        ----------
+        key: str
+            Registry key path where look.
+        name: str
+            Value name to find.
+
+        Return
+        ------
+        str: value
+        """
+        KEY_READ = winreg.KEY_READ
+        openkey = winreg.OpenKey
+        ms = self.microsoft
+        for hkey in self.HKEYS:
+            try:
+                bkey = openkey(hkey, ms(key), 0, KEY_READ)
+            except (OSError, IOError):
+                if not self.pi.current_is_x86():
+                    try:
+                        bkey = openkey(hkey, ms(key, True), 0, KEY_READ)
+                    except (OSError, IOError):
+                        continue
+                else:
+                    continue
+            try:
+                return winreg.QueryValueEx(bkey, name)[0]
+            except (OSError, IOError):
+                pass
+
+
+class SystemInfo:
+    """
+    Microsoft Windows and Visual Studio related system inormations.
+
+    Parameters
+    ----------
+    registry_info: RegistryInfo
+        "RegistryInfo" instance.
+    vc_ver: float
+        Required Microsoft Visual C++ version.
+    """
+
+    # Variables and properties in this class use originals CamelCase variables
+    # names from Microsoft source files for more easy comparaison.
+    WinDir = safe_env.get('WinDir', '')
+    ProgramFiles = safe_env.get('ProgramFiles', '')
+    ProgramFilesx86 = safe_env.get('ProgramFiles(x86)', ProgramFiles)
+
+    def __init__(self, registry_info, vc_ver=None):
+        self.ri = registry_info
+        self.pi = self.ri.pi
+        self.vc_ver = vc_ver or self._find_latest_available_vc_ver()
+
+    def _find_latest_available_vc_ver(self):
+        try:
+            return self.find_available_vc_vers()[-1]
+        except IndexError:
+            err = 'No Microsoft Visual C++ version found'
+            raise distutils.errors.DistutilsPlatformError(err)
+
+    def find_available_vc_vers(self):
+        """
+        Find all available Microsoft Visual C++ versions.
+        """
+        ms = self.ri.microsoft
+        vckeys = (self.ri.vc, self.ri.vc_for_python, self.ri.vs)
+        vc_vers = []
+        for hkey in self.ri.HKEYS:
+            for key in vckeys:
+                try:
+                    bkey = winreg.OpenKey(hkey, ms(key), 0, winreg.KEY_READ)
+                except (OSError, IOError):
+                    continue
+                subkeys, values, _ = winreg.QueryInfoKey(bkey)
+                for i in range(values):
+                    try:
+                        ver = float(winreg.EnumValue(bkey, i)[0])
+                        if ver not in vc_vers:
+                            vc_vers.append(ver)
+                    except ValueError:
+                        pass
+                for i in range(subkeys):
+                    try:
+                        ver = float(winreg.EnumKey(bkey, i))
+                        if ver not in vc_vers:
+                            vc_vers.append(ver)
+                    except ValueError:
+                        pass
+        return sorted(vc_vers)
+
+    @property
+    def VSInstallDir(self):
+        """
+        Microsoft Visual Studio directory.
+        """
+        # Default path
+        name = 'Microsoft Visual Studio %0.1f' % self.vc_ver
+        default = os.path.join(self.ProgramFilesx86, name)
+
+        # Try to get path from registry, if fail use default path
+        return self.ri.lookup(self.ri.vs, '%0.1f' % self.vc_ver) or default
+
+    @property
+    def VCInstallDir(self):
+        """
+        Microsoft Visual C++ directory.
+        """
+        self.VSInstallDir
+
+        guess_vc = self._guess_vc() or self._guess_vc_legacy()
+
+        # Try to get "VC++ for Python" path from registry as default path
+        reg_path = os.path.join(self.ri.vc_for_python, '%0.1f' % self.vc_ver)
+        python_vc = self.ri.lookup(reg_path, 'installdir')
+        default_vc = os.path.join(python_vc, 'VC') if python_vc else guess_vc
+
+        # Try to get path from registry, if fail use default path
+        path = self.ri.lookup(self.ri.vc, '%0.1f' % self.vc_ver) or default_vc
+
+        if not os.path.isdir(path):
+            msg = 'Microsoft Visual C++ directory not found'
+            raise distutils.errors.DistutilsPlatformError(msg)
+
+        return path
+
+    def _guess_vc(self):
+        """
+        Locate Visual C for 2017
+        """
+        if self.vc_ver <= 14.0:
+            return
+
+        default = r'VC\Tools\MSVC'
+        guess_vc = os.path.join(self.VSInstallDir, default)
+        # Subdir with VC exact version as name
+        try:
+            vc_exact_ver = os.listdir(guess_vc)[-1]
+            return os.path.join(guess_vc, vc_exact_ver)
+        except (OSError, IOError, IndexError):
+            pass
+
+    def _guess_vc_legacy(self):
+        """
+        Locate Visual C for versions prior to 2017
+        """
+        default = r'Microsoft Visual Studio %0.1f\VC' % self.vc_ver
+        return os.path.join(self.ProgramFilesx86, default)
+
+    @property
+    def WindowsSdkVersion(self):
+        """
+        Microsoft Windows SDK versions for specified MSVC++ version.
+        """
+        if self.vc_ver <= 9.0:
+            return ('7.0', '6.1', '6.0a')
+        elif self.vc_ver == 10.0:
+            return ('7.1', '7.0a')
+        elif self.vc_ver == 11.0:
+            return ('8.0', '8.0a')
+        elif self.vc_ver == 12.0:
+            return ('8.1', '8.1a')
+        elif self.vc_ver >= 14.0:
+            return ('10.0', '8.1')
+
+    @property
+    def WindowsSdkLastVersion(self):
+        """
+        Microsoft Windows SDK last version
+        """
+        return self._use_last_dir_name(os.path.join(
+            self.WindowsSdkDir, 'lib'))
+
+    @property
+    def WindowsSdkDir(self):
+        """
+        Microsoft Windows SDK directory.
+        """
+        sdkdir = ''
+        for ver in self.WindowsSdkVersion:
+            # Try to get it from registry
+            loc = os.path.join(self.ri.windows_sdk, 'v%s' % ver)
+            sdkdir = self.ri.lookup(loc, 'installationfolder')
+            if sdkdir:
+                break
+        if not sdkdir or not os.path.isdir(sdkdir):
+            # Try to get "VC++ for Python" version from registry
+            path = os.path.join(self.ri.vc_for_python, '%0.1f' % self.vc_ver)
+            install_base = self.ri.lookup(path, 'installdir')
+            if install_base:
+                sdkdir = os.path.join(install_base, 'WinSDK')
+        if not sdkdir or not os.path.isdir(sdkdir):
+            # If fail, use default new path
+            for ver in self.WindowsSdkVersion:
+                intver = ver[:ver.rfind('.')]
+                path = r'Microsoft SDKs\Windows Kits\%s' % (intver)
+                d = os.path.join(self.ProgramFiles, path)
+                if os.path.isdir(d):
+                    sdkdir = d
+        if not sdkdir or not os.path.isdir(sdkdir):
+            # If fail, use default old path
+            for ver in self.WindowsSdkVersion:
+                path = r'Microsoft SDKs\Windows\v%s' % ver
+                d = os.path.join(self.ProgramFiles, path)
+                if os.path.isdir(d):
+                    sdkdir = d
+        if not sdkdir:
+            # If fail, use Platform SDK
+            sdkdir = os.path.join(self.VCInstallDir, 'PlatformSDK')
+        return sdkdir
+
+    @property
+    def WindowsSDKExecutablePath(self):
+        """
+        Microsoft Windows SDK executable directory.
+        """
+        # Find WinSDK NetFx Tools registry dir name
+        if self.vc_ver <= 11.0:
+            netfxver = 35
+            arch = ''
+        else:
+            netfxver = 40
+            hidex86 = True if self.vc_ver <= 12.0 else False
+            arch = self.pi.current_dir(x64=True, hidex86=hidex86)
+        fx = 'WinSDK-NetFx%dTools%s' % (netfxver, arch.replace('\\', '-'))
+
+        # liste all possibles registry paths
+        regpaths = []
+        if self.vc_ver >= 14.0:
+            for ver in self.NetFxSdkVersion:
+                regpaths += [os.path.join(self.ri.netfx_sdk, ver, fx)]
+
+        for ver in self.WindowsSdkVersion:
+            regpaths += [os.path.join(self.ri.windows_sdk, 'v%sA' % ver, fx)]
+
+        # Return installation folder from the more recent path
+        for path in regpaths:
+            execpath = self.ri.lookup(path, 'installationfolder')
+            if execpath:
+                break
+        return execpath
+
+    @property
+    def FSharpInstallDir(self):
+        """
+        Microsoft Visual F# directory.
+        """
+        path = r'%0.1f\Setup\F#' % self.vc_ver
+        path = os.path.join(self.ri.visualstudio, path)
+        return self.ri.lookup(path, 'productdir') or ''
+
+    @property
+    def UniversalCRTSdkDir(self):
+        """
+        Microsoft Universal CRT SDK directory.
+        """
+        # Set Kit Roots versions for specified MSVC++ version
+        if self.vc_ver >= 14.0:
+            vers = ('10', '81')
+        else:
+            vers = ()
+
+        # Find path of the more recent Kit
+        for ver in vers:
+            sdkdir = self.ri.lookup(self.ri.windows_kits_roots,
+                                    'kitsroot%s' % ver)
+            if sdkdir:
+                break
+        return sdkdir or ''
+
+    @property
+    def UniversalCRTSdkLastVersion(self):
+        """
+        Microsoft Universal C Runtime SDK last version
+        """
+        return self._use_last_dir_name(os.path.join(
+            self.UniversalCRTSdkDir, 'lib'))
+
+    @property
+    def NetFxSdkVersion(self):
+        """
+        Microsoft .NET Framework SDK versions.
+        """
+        # Set FxSdk versions for specified MSVC++ version
+        if self.vc_ver >= 14.0:
+            return ('4.6.1', '4.6')
+        else:
+            return ()
+
+    @property
+    def NetFxSdkDir(self):
+        """
+        Microsoft .NET Framework SDK directory.
+        """
+        for ver in self.NetFxSdkVersion:
+            loc = os.path.join(self.ri.netfx_sdk, ver)
+            sdkdir = self.ri.lookup(loc, 'kitsinstallationfolder')
+            if sdkdir:
+                break
+        return sdkdir or ''
+
+    @property
+    def FrameworkDir32(self):
+        """
+        Microsoft .NET Framework 32bit directory.
+        """
+        # Default path
+        guess_fw = os.path.join(self.WinDir, r'Microsoft.NET\Framework')
+
+        # Try to get path from registry, if fail use default path
+        return self.ri.lookup(self.ri.vc, 'frameworkdir32') or guess_fw
+
+    @property
+    def FrameworkDir64(self):
+        """
+        Microsoft .NET Framework 64bit directory.
+        """
+        # Default path
+        guess_fw = os.path.join(self.WinDir, r'Microsoft.NET\Framework64')
+
+        # Try to get path from registry, if fail use default path
+        return self.ri.lookup(self.ri.vc, 'frameworkdir64') or guess_fw
+
+    @property
+    def FrameworkVersion32(self):
+        """
+        Microsoft .NET Framework 32bit versions.
+        """
+        return self._find_dot_net_versions(32)
+
+    @property
+    def FrameworkVersion64(self):
+        """
+        Microsoft .NET Framework 64bit versions.
+        """
+        return self._find_dot_net_versions(64)
+
+    def _find_dot_net_versions(self, bits):
+        """
+        Find Microsoft .NET Framework versions.
+
+        Parameters
+        ----------
+        bits: int
+            Platform number of bits: 32 or 64.
+        """
+        # Find actual .NET version in registry
+        reg_ver = self.ri.lookup(self.ri.vc, 'frameworkver%d' % bits)
+        dot_net_dir = getattr(self, 'FrameworkDir%d' % bits)
+        ver = reg_ver or self._use_last_dir_name(dot_net_dir, 'v') or ''
+
+        # Set .NET versions for specified MSVC++ version
+        if self.vc_ver >= 12.0:
+            frameworkver = (ver, 'v4.0')
+        elif self.vc_ver >= 10.0:
+            frameworkver = ('v4.0.30319' if ver.lower()[:2] != 'v4' else ver,
+                            'v3.5')
+        elif self.vc_ver == 9.0:
+            frameworkver = ('v3.5', 'v2.0.50727')
+        if self.vc_ver == 8.0:
+            frameworkver = ('v3.0', 'v2.0.50727')
+        return frameworkver
+
+    def _use_last_dir_name(self, path, prefix=''):
+        """
+        Return name of the last dir in path or '' if no dir found.
+
+        Parameters
+        ----------
+        path: str
+            Use dirs in this path
+        prefix: str
+            Use only dirs startings by this prefix
+        """
+        matching_dirs = (
+            dir_name
+            for dir_name in reversed(os.listdir(path))
+            if os.path.isdir(os.path.join(path, dir_name)) and
+            dir_name.startswith(prefix)
+        )
+        return next(matching_dirs, None) or ''
+
+
+class EnvironmentInfo:
+    """
+    Return environment variables for specified Microsoft Visual C++ version
+    and platform : Lib, Include, Path and libpath.
+
+    This function is compatible with Microsoft Visual C++ 9.0 to 14.0.
+
+    Script created by analysing Microsoft environment configuration files like
+    "vcvars[...].bat", "SetEnv.Cmd", "vcbuildtools.bat", ...
+
+    Parameters
+    ----------
+    arch: str
+        Target architecture.
+    vc_ver: float
+        Required Microsoft Visual C++ version. If not set, autodetect the last
+        version.
+    vc_min_ver: float
+        Minimum Microsoft Visual C++ version.
+    """
+
+    # Variables and properties in this class use originals CamelCase variables
+    # names from Microsoft source files for more easy comparaison.
+
+    def __init__(self, arch, vc_ver=None, vc_min_ver=0):
+        self.pi = PlatformInfo(arch)
+        self.ri = RegistryInfo(self.pi)
+        self.si = SystemInfo(self.ri, vc_ver)
+
+        if self.vc_ver < vc_min_ver:
+            err = 'No suitable Microsoft Visual C++ version found'
+            raise distutils.errors.DistutilsPlatformError(err)
+
+    @property
+    def vc_ver(self):
+        """
+        Microsoft Visual C++ version.
+        """
+        return self.si.vc_ver
+
+    @property
+    def VSTools(self):
+        """
+        Microsoft Visual Studio Tools
+        """
+        paths = [r'Common7\IDE', r'Common7\Tools']
+
+        if self.vc_ver >= 14.0:
+            arch_subdir = self.pi.current_dir(hidex86=True, x64=True)
+            paths += [r'Common7\IDE\CommonExtensions\Microsoft\TestWindow']
+            paths += [r'Team Tools\Performance Tools']
+            paths += [r'Team Tools\Performance Tools%s' % arch_subdir]
+
+        return [os.path.join(self.si.VSInstallDir, path) for path in paths]
+
+    @property
+    def VCIncludes(self):
+        """
+        Microsoft Visual C++ & Microsoft Foundation Class Includes
+        """
+        return [os.path.join(self.si.VCInstallDir, 'Include'),
+                os.path.join(self.si.VCInstallDir, r'ATLMFC\Include')]
+
+    @property
+    def VCLibraries(self):
+        """
+        Microsoft Visual C++ & Microsoft Foundation Class Libraries
+        """
+        if self.vc_ver >= 15.0:
+            arch_subdir = self.pi.target_dir(x64=True)
+        else:
+            arch_subdir = self.pi.target_dir(hidex86=True)
+        paths = ['Lib%s' % arch_subdir, r'ATLMFC\Lib%s' % arch_subdir]
+
+        if self.vc_ver >= 14.0:
+            paths += [r'Lib\store%s' % arch_subdir]
+
+        return [os.path.join(self.si.VCInstallDir, path) for path in paths]
+
+    @property
+    def VCStoreRefs(self):
+        """
+        Microsoft Visual C++ store references Libraries
+        """
+        if self.vc_ver < 14.0:
+            return []
+        return [os.path.join(self.si.VCInstallDir, r'Lib\store\references')]
+
+    @property
+    def VCTools(self):
+        """
+        Microsoft Visual C++ Tools
+        """
+        si = self.si
+        tools = [os.path.join(si.VCInstallDir, 'VCPackages')]
+
+        forcex86 = True if self.vc_ver <= 10.0 else False
+        arch_subdir = self.pi.cross_dir(forcex86)
+        if arch_subdir:
+            tools += [os.path.join(si.VCInstallDir, 'Bin%s' % arch_subdir)]
+
+        if self.vc_ver == 14.0:
+            path = 'Bin%s' % self.pi.current_dir(hidex86=True)
+            tools += [os.path.join(si.VCInstallDir, path)]
+
+        elif self.vc_ver >= 15.0:
+            host_dir = (r'bin\HostX86%s' if self.pi.current_is_x86() else
+                        r'bin\HostX64%s')
+            tools += [os.path.join(
+                si.VCInstallDir, host_dir % self.pi.target_dir(x64=True))]
+
+            if self.pi.current_cpu != self.pi.target_cpu:
+                tools += [os.path.join(
+                    si.VCInstallDir, host_dir % self.pi.current_dir(x64=True))]
+
+        else:
+            tools += [os.path.join(si.VCInstallDir, 'Bin')]
+
+        return tools
+
+    @property
+    def OSLibraries(self):
+        """
+        Microsoft Windows SDK Libraries
+        """
+        if self.vc_ver <= 10.0:
+            arch_subdir = self.pi.target_dir(hidex86=True, x64=True)
+            return [os.path.join(self.si.WindowsSdkDir, 'Lib%s' % arch_subdir)]
+
+        else:
+            arch_subdir = self.pi.target_dir(x64=True)
+            lib = os.path.join(self.si.WindowsSdkDir, 'lib')
+            libver = self._sdk_subdir
+            return [os.path.join(lib, '%sum%s' % (libver , arch_subdir))]
+
+    @property
+    def OSIncludes(self):
+        """
+        Microsoft Windows SDK Include
+        """
+        include = os.path.join(self.si.WindowsSdkDir, 'include')
+
+        if self.vc_ver <= 10.0:
+            return [include, os.path.join(include, 'gl')]
+
+        else:
+            if self.vc_ver >= 14.0:
+                sdkver = self._sdk_subdir
+            else:
+                sdkver = ''
+            return [os.path.join(include, '%sshared' % sdkver),
+                    os.path.join(include, '%sum' % sdkver),
+                    os.path.join(include, '%swinrt' % sdkver)]
+
+    @property
+    def OSLibpath(self):
+        """
+        Microsoft Windows SDK Libraries Paths
+        """
+        ref = os.path.join(self.si.WindowsSdkDir, 'References')
+        libpath = []
+
+        if self.vc_ver <= 9.0:
+            libpath += self.OSLibraries
+
+        if self.vc_ver >= 11.0:
+            libpath += [os.path.join(ref, r'CommonConfiguration\Neutral')]
+
+        if self.vc_ver >= 14.0:
+            libpath += [
+                ref,
+                os.path.join(self.si.WindowsSdkDir, 'UnionMetadata'),
+                os.path.join(
+                    ref,
+                    'Windows.Foundation.UniversalApiContract',
+                    '1.0.0.0',
+                ),
+                os.path.join(
+                    ref,
+                    'Windows.Foundation.FoundationContract',
+                    '1.0.0.0',
+                ),
+                os.path.join(
+                    ref,
+                    'Windows.Networking.Connectivity.WwanContract',
+                    '1.0.0.0',
+                ),
+                os.path.join(
+                    self.si.WindowsSdkDir,
+                    'ExtensionSDKs',
+                    'Microsoft.VCLibs',
+                    '%0.1f' % self.vc_ver,
+                    'References',
+                    'CommonConfiguration',
+                    'neutral',
+                ),
+            ]
+        return libpath
+
+    @property
+    def SdkTools(self):
+        """
+        Microsoft Windows SDK Tools
+        """
+        return list(self._sdk_tools())
+
+    def _sdk_tools(self):
+        """
+        Microsoft Windows SDK Tools paths generator
+        """
+        if self.vc_ver < 15.0:
+            bin_dir = 'Bin' if self.vc_ver <= 11.0 else r'Bin\x86'
+            yield os.path.join(self.si.WindowsSdkDir, bin_dir)
+
+        if not self.pi.current_is_x86():
+            arch_subdir = self.pi.current_dir(x64=True)
+            path = 'Bin%s' % arch_subdir
+            yield os.path.join(self.si.WindowsSdkDir, path)
+
+        if self.vc_ver == 10.0 or self.vc_ver == 11.0:
+            if self.pi.target_is_x86():
+                arch_subdir = ''
+            else:
+                arch_subdir = self.pi.current_dir(hidex86=True, x64=True)
+            path = r'Bin\NETFX 4.0 Tools%s' % arch_subdir
+            yield os.path.join(self.si.WindowsSdkDir, path)
+
+        elif self.vc_ver >= 15.0:
+            path = os.path.join(self.si.WindowsSdkDir, 'Bin')
+            arch_subdir = self.pi.current_dir(x64=True)
+            sdkver = self.si.WindowsSdkLastVersion
+            yield os.path.join(path, '%s%s' % (sdkver, arch_subdir))
+
+        if self.si.WindowsSDKExecutablePath:
+            yield self.si.WindowsSDKExecutablePath
+
+    @property
+    def _sdk_subdir(self):
+        """
+        Microsoft Windows SDK version subdir
+        """
+        ucrtver = self.si.WindowsSdkLastVersion
+        return ('%s\\' % ucrtver) if ucrtver else ''
+
+    @property
+    def SdkSetup(self):
+        """
+        Microsoft Windows SDK Setup
+        """
+        if self.vc_ver > 9.0:
+            return []
+
+        return [os.path.join(self.si.WindowsSdkDir, 'Setup')]
+
+    @property
+    def FxTools(self):
+        """
+        Microsoft .NET Framework Tools
+        """
+        pi = self.pi
+        si = self.si
+
+        if self.vc_ver <= 10.0:
+            include32 = True
+            include64 = not pi.target_is_x86() and not pi.current_is_x86()
+        else:
+            include32 = pi.target_is_x86() or pi.current_is_x86()
+            include64 = pi.current_cpu == 'amd64' or pi.target_cpu == 'amd64'
+
+        tools = []
+        if include32:
+            tools += [os.path.join(si.FrameworkDir32, ver)
+                      for ver in si.FrameworkVersion32]
+        if include64:
+            tools += [os.path.join(si.FrameworkDir64, ver)
+                      for ver in si.FrameworkVersion64]
+        return tools
+
+    @property
+    def NetFxSDKLibraries(self):
+        """
+        Microsoft .Net Framework SDK Libraries
+        """
+        if self.vc_ver < 14.0 or not self.si.NetFxSdkDir:
+            return []
+
+        arch_subdir = self.pi.target_dir(x64=True)
+        return [os.path.join(self.si.NetFxSdkDir, r'lib\um%s' % arch_subdir)]
+
+    @property
+    def NetFxSDKIncludes(self):
+        """
+        Microsoft .Net Framework SDK Includes
+        """
+        if self.vc_ver < 14.0 or not self.si.NetFxSdkDir:
+            return []
+
+        return [os.path.join(self.si.NetFxSdkDir, r'include\um')]
+
+    @property
+    def VsTDb(self):
+        """
+        Microsoft Visual Studio Team System Database
+        """
+        return [os.path.join(self.si.VSInstallDir, r'VSTSDB\Deploy')]
+
+    @property
+    def MSBuild(self):
+        """
+        Microsoft Build Engine
+        """
+        if self.vc_ver < 12.0:
+            return []
+        elif self.vc_ver < 15.0:
+            base_path = self.si.ProgramFilesx86
+            arch_subdir = self.pi.current_dir(hidex86=True)
+        else:
+            base_path = self.si.VSInstallDir
+            arch_subdir = ''
+
+        path = r'MSBuild\%0.1f\bin%s' % (self.vc_ver, arch_subdir)
+        build = [os.path.join(base_path, path)]
+
+        if self.vc_ver >= 15.0:
+            # Add Roslyn C# & Visual Basic Compiler
+            build += [os.path.join(base_path, path, 'Roslyn')]
+
+        return build
+
+    @property
+    def HTMLHelpWorkshop(self):
+        """
+        Microsoft HTML Help Workshop
+        """
+        if self.vc_ver < 11.0:
+            return []
+
+        return [os.path.join(self.si.ProgramFilesx86, 'HTML Help Workshop')]
+
+    @property
+    def UCRTLibraries(self):
+        """
+        Microsoft Universal C Runtime SDK Libraries
+        """
+        if self.vc_ver < 14.0:
+            return []
+
+        arch_subdir = self.pi.target_dir(x64=True)
+        lib = os.path.join(self.si.UniversalCRTSdkDir, 'lib')
+        ucrtver = self._ucrt_subdir
+        return [os.path.join(lib, '%sucrt%s' % (ucrtver, arch_subdir))]
+
+    @property
+    def UCRTIncludes(self):
+        """
+        Microsoft Universal C Runtime SDK Include
+        """
+        if self.vc_ver < 14.0:
+            return []
+
+        include = os.path.join(self.si.UniversalCRTSdkDir, 'include')
+        return [os.path.join(include, '%sucrt' % self._ucrt_subdir)]
+
+    @property
+    def _ucrt_subdir(self):
+        """
+        Microsoft Universal C Runtime SDK version subdir
+        """
+        ucrtver = self.si.UniversalCRTSdkLastVersion
+        return ('%s\\' % ucrtver) if ucrtver else ''
+
+    @property
+    def FSharp(self):
+        """
+        Microsoft Visual F#
+        """
+        if self.vc_ver < 11.0 and self.vc_ver > 12.0:
+            return []
+
+        return self.si.FSharpInstallDir
+
+    @property
+    def VCRuntimeRedist(self):
+        """
+        Microsoft Visual C++ runtime redistribuable dll
+        """
+        arch_subdir = self.pi.target_dir(x64=True)
+        if self.vc_ver < 15:
+            redist_path = self.si.VCInstallDir
+            vcruntime = 'redist%s\\Microsoft.VC%d0.CRT\\vcruntime%d0.dll'
+        else:
+            redist_path = self.si.VCInstallDir.replace('\\Tools', '\\Redist')
+            vcruntime = 'onecore%s\\Microsoft.VC%d0.CRT\\vcruntime%d0.dll'
+
+        # Visual Studio 2017  is still Visual C++ 14.0
+        dll_ver = 14.0 if self.vc_ver == 15 else self.vc_ver
+
+        vcruntime = vcruntime % (arch_subdir, self.vc_ver, dll_ver)
+        return os.path.join(redist_path, vcruntime)
+
+    def return_env(self, exists=True):
+        """
+        Return environment dict.
+
+        Parameters
+        ----------
+        exists: bool
+            It True, only return existing paths.
+        """
+        env = dict(
+            include=self._build_paths('include',
+                                      [self.VCIncludes,
+                                       self.OSIncludes,
+                                       self.UCRTIncludes,
+                                       self.NetFxSDKIncludes],
+                                      exists),
+            lib=self._build_paths('lib',
+                                  [self.VCLibraries,
+                                   self.OSLibraries,
+                                   self.FxTools,
+                                   self.UCRTLibraries,
+                                   self.NetFxSDKLibraries],
+                                  exists),
+            libpath=self._build_paths('libpath',
+                                      [self.VCLibraries,
+                                       self.FxTools,
+                                       self.VCStoreRefs,
+                                       self.OSLibpath],
+                                      exists),
+            path=self._build_paths('path',
+                                   [self.VCTools,
+                                    self.VSTools,
+                                    self.VsTDb,
+                                    self.SdkTools,
+                                    self.SdkSetup,
+                                    self.FxTools,
+                                    self.MSBuild,
+                                    self.HTMLHelpWorkshop,
+                                    self.FSharp],
+                                   exists),
+        )
+        if self.vc_ver >= 14 and os.path.isfile(self.VCRuntimeRedist):
+            env['py_vcruntime_redist'] = self.VCRuntimeRedist
+        return env
+
+    def _build_paths(self, name, spec_path_lists, exists):
+        """
+        Given an environment variable name and specified paths,
+        return a pathsep-separated string of paths containing
+        unique, extant, directories from those paths and from
+        the environment variable. Raise an error if no paths
+        are resolved.
+        """
+        # flatten spec_path_lists
+        spec_paths = itertools.chain.from_iterable(spec_path_lists)
+        env_paths = safe_env.get(name, '').split(os.pathsep)
+        paths = itertools.chain(spec_paths, env_paths)
+        extant_paths = list(filter(os.path.isdir, paths)) if exists else paths
+        if not extant_paths:
+            msg = "%s environment variable is empty" % name.upper()
+            raise distutils.errors.DistutilsPlatformError(msg)
+        unique_paths = self._unique_everseen(extant_paths)
+        return os.pathsep.join(unique_paths)
+
+    # from Python docs
+    def _unique_everseen(self, iterable, key=None):
+        """
+        List unique elements, preserving order.
+        Remember all elements ever seen.
+
+        _unique_everseen('AAAABBBCCDAABBB') --> A B C D
+
+        _unique_everseen('ABBCcAD', str.lower) --> A B C D
+        """
+        seen = set()
+        seen_add = seen.add
+        if key is None:
+            for element in filterfalse(seen.__contains__, iterable):
+                seen_add(element)
+                yield element
+        else:
+            for element in iterable:
+                k = key(element)
+                if k not in seen:
+                    seen_add(k)
+                    yield element
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/msvc.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/msvc.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..a485375303745bb20cff5e8435568a83782ebf70
GIT binary patch
literal 44716
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
LE!-;npCJ(dS4-)%

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/namespaces.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/namespaces.py
new file mode 100644
index 0000000..dc16106
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/namespaces.py
@@ -0,0 +1,107 @@
+import os
+from distutils import log
+import itertools
+
+from setuptools.extern.six.moves import map
+
+
+flatten = itertools.chain.from_iterable
+
+
+class Installer:
+
+    nspkg_ext = '-nspkg.pth'
+
+    def install_namespaces(self):
+        nsp = self._get_all_ns_packages()
+        if not nsp:
+            return
+        filename, ext = os.path.splitext(self._get_target())
+        filename += self.nspkg_ext
+        self.outputs.append(filename)
+        log.info("Installing %s", filename)
+        lines = map(self._gen_nspkg_line, nsp)
+
+        if self.dry_run:
+            # always generate the lines, even in dry run
+            list(lines)
+            return
+
+        with open(filename, 'wt') as f:
+            f.writelines(lines)
+
+    def uninstall_namespaces(self):
+        filename, ext = os.path.splitext(self._get_target())
+        filename += self.nspkg_ext
+        if not os.path.exists(filename):
+            return
+        log.info("Removing %s", filename)
+        os.remove(filename)
+
+    def _get_target(self):
+        return self.target
+
+    _nspkg_tmpl = (
+        "import sys, types, os",
+        "has_mfs = sys.version_info > (3, 5)",
+        "p = os.path.join(%(root)s, *%(pth)r)",
+        "importlib = has_mfs and __import__('importlib.util')",
+        "has_mfs and __import__('importlib.machinery')",
+        "m = has_mfs and "
+            "sys.modules.setdefault(%(pkg)r, "
+                "importlib.util.module_from_spec("
+                    "importlib.machinery.PathFinder.find_spec(%(pkg)r, "
+                        "[os.path.dirname(p)])))",
+        "m = m or "
+            "sys.modules.setdefault(%(pkg)r, types.ModuleType(%(pkg)r))",
+        "mp = (m or []) and m.__dict__.setdefault('__path__',[])",
+        "(p not in mp) and mp.append(p)",
+    )
+    "lines for the namespace installer"
+
+    _nspkg_tmpl_multi = (
+        'm and setattr(sys.modules[%(parent)r], %(child)r, m)',
+    )
+    "additional line(s) when a parent package is indicated"
+
+    def _get_root(self):
+        return "sys._getframe(1).f_locals['sitedir']"
+
+    def _gen_nspkg_line(self, pkg):
+        # ensure pkg is not a unicode string under Python 2.7
+        pkg = str(pkg)
+        pth = tuple(pkg.split('.'))
+        root = self._get_root()
+        tmpl_lines = self._nspkg_tmpl
+        parent, sep, child = pkg.rpartition('.')
+        if parent:
+            tmpl_lines += self._nspkg_tmpl_multi
+        return ';'.join(tmpl_lines) % locals() + '\n'
+
+    def _get_all_ns_packages(self):
+        """Return sorted list of all package namespaces"""
+        pkgs = self.distribution.namespace_packages or []
+        return sorted(flatten(map(self._pkg_names, pkgs)))
+
+    @staticmethod
+    def _pkg_names(pkg):
+        """
+        Given a namespace package, yield the components of that
+        package.
+
+        >>> names = Installer._pkg_names('a.b.c')
+        >>> set(names) == set(['a', 'a.b', 'a.b.c'])
+        True
+        """
+        parts = pkg.split('.')
+        while parts:
+            yield '.'.join(parts)
+            parts.pop()
+
+
+class DevelopInstaller(Installer):
+    def _get_root(self):
+        return repr(str(self.egg_path))
+
+    def _get_target(self):
+        return self.egg_link
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/namespaces.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/namespaces.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..21b3064765460b78668af480e1bbdd286b9d080f
GIT binary patch
literal 5681
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
MVG>~GVHS=C0B_8h3IG5A

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/package_index.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/package_index.py
new file mode 100644
index 0000000..6b06f2c
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/package_index.py
@@ -0,0 +1,1136 @@
+"""PyPI and direct package downloading"""
+import sys
+import os
+import re
+import shutil
+import socket
+import base64
+import hashlib
+import itertools
+import warnings
+from functools import wraps
+
+from setuptools.extern import six
+from setuptools.extern.six.moves import urllib, http_client, configparser, map
+
+import setuptools
+from pkg_resources import (
+    CHECKOUT_DIST, Distribution, BINARY_DIST, normalize_path, SOURCE_DIST,
+    Environment, find_distributions, safe_name, safe_version,
+    to_filename, Requirement, DEVELOP_DIST, EGG_DIST,
+)
+from setuptools import ssl_support
+from distutils import log
+from distutils.errors import DistutilsError
+from fnmatch import translate
+from setuptools.py27compat import get_all_headers
+from setuptools.py33compat import unescape
+from setuptools.wheel import Wheel
+
+__metaclass__ = type
+
+EGG_FRAGMENT = re.compile(r'^egg=([-A-Za-z0-9_.+!]+)$')
+HREF = re.compile(r"""href\s*=\s*['"]?([^'"> ]+)""", re.I)
+PYPI_MD5 = re.compile(
+    r'<a href="([^"#]+)">([^<]+)</a>\n\s+\(<a (?:title="MD5 hash"\n\s+)'
+    r'href="[^?]+\?:action=show_md5&amp;digest=([0-9a-f]{32})">md5</a>\)'
+)
+URL_SCHEME = re.compile('([-+.a-z0-9]{2,}):', re.I).match
+EXTENSIONS = ".tar.gz .tar.bz2 .tar .zip .tgz".split()
+
+__all__ = [
+    'PackageIndex', 'distros_for_url', 'parse_bdist_wininst',
+    'interpret_distro_name',
+]
+
+_SOCKET_TIMEOUT = 15
+
+_tmpl = "setuptools/{setuptools.__version__} Python-urllib/{py_major}"
+user_agent = _tmpl.format(py_major=sys.version[:3], setuptools=setuptools)
+
+
+def parse_requirement_arg(spec):
+    try:
+        return Requirement.parse(spec)
+    except ValueError:
+        raise DistutilsError(
+            "Not a URL, existing file, or requirement spec: %r" % (spec,)
+        )
+
+
+def parse_bdist_wininst(name):
+    """Return (base,pyversion) or (None,None) for possible .exe name"""
+
+    lower = name.lower()
+    base, py_ver, plat = None, None, None
+
+    if lower.endswith('.exe'):
+        if lower.endswith('.win32.exe'):
+            base = name[:-10]
+            plat = 'win32'
+        elif lower.startswith('.win32-py', -16):
+            py_ver = name[-7:-4]
+            base = name[:-16]
+            plat = 'win32'
+        elif lower.endswith('.win-amd64.exe'):
+            base = name[:-14]
+            plat = 'win-amd64'
+        elif lower.startswith('.win-amd64-py', -20):
+            py_ver = name[-7:-4]
+            base = name[:-20]
+            plat = 'win-amd64'
+    return base, py_ver, plat
+
+
+def egg_info_for_url(url):
+    parts = urllib.parse.urlparse(url)
+    scheme, server, path, parameters, query, fragment = parts
+    base = urllib.parse.unquote(path.split('/')[-1])
+    if server == 'sourceforge.net' and base == 'download':  # XXX Yuck
+        base = urllib.parse.unquote(path.split('/')[-2])
+    if '#' in base:
+        base, fragment = base.split('#', 1)
+    return base, fragment
+
+
+def distros_for_url(url, metadata=None):
+    """Yield egg or source distribution objects that might be found at a URL"""
+    base, fragment = egg_info_for_url(url)
+    for dist in distros_for_location(url, base, metadata):
+        yield dist
+    if fragment:
+        match = EGG_FRAGMENT.match(fragment)
+        if match:
+            for dist in interpret_distro_name(
+                url, match.group(1), metadata, precedence=CHECKOUT_DIST
+            ):
+                yield dist
+
+
+def distros_for_location(location, basename, metadata=None):
+    """Yield egg or source distribution objects based on basename"""
+    if basename.endswith('.egg.zip'):
+        basename = basename[:-4]  # strip the .zip
+    if basename.endswith('.egg') and '-' in basename:
+        # only one, unambiguous interpretation
+        return [Distribution.from_location(location, basename, metadata)]
+    if basename.endswith('.whl') and '-' in basename:
+        wheel = Wheel(basename)
+        if not wheel.is_compatible():
+            return []
+        return [Distribution(
+            location=location,
+            project_name=wheel.project_name,
+            version=wheel.version,
+            # Increase priority over eggs.
+            precedence=EGG_DIST + 1,
+        )]
+    if basename.endswith('.exe'):
+        win_base, py_ver, platform = parse_bdist_wininst(basename)
+        if win_base is not None:
+            return interpret_distro_name(
+                location, win_base, metadata, py_ver, BINARY_DIST, platform
+            )
+    # Try source distro extensions (.zip, .tgz, etc.)
+    #
+    for ext in EXTENSIONS:
+        if basename.endswith(ext):
+            basename = basename[:-len(ext)]
+            return interpret_distro_name(location, basename, metadata)
+    return []  # no extension matched
+
+
+def distros_for_filename(filename, metadata=None):
+    """Yield possible egg or source distribution objects based on a filename"""
+    return distros_for_location(
+        normalize_path(filename), os.path.basename(filename), metadata
+    )
+
+
+def interpret_distro_name(
+        location, basename, metadata, py_version=None, precedence=SOURCE_DIST,
+        platform=None
+):
+    """Generate alternative interpretations of a source distro name
+
+    Note: if `location` is a filesystem filename, you should call
+    ``pkg_resources.normalize_path()`` on it before passing it to this
+    routine!
+    """
+    # Generate alternative interpretations of a source distro name
+    # Because some packages are ambiguous as to name/versions split
+    # e.g. "adns-python-1.1.0", "egenix-mx-commercial", etc.
+    # So, we generate each possible interepretation (e.g. "adns, python-1.1.0"
+    # "adns-python, 1.1.0", and "adns-python-1.1.0, no version").  In practice,
+    # the spurious interpretations should be ignored, because in the event
+    # there's also an "adns" package, the spurious "python-1.1.0" version will
+    # compare lower than any numeric version number, and is therefore unlikely
+    # to match a request for it.  It's still a potential problem, though, and
+    # in the long run PyPI and the distutils should go for "safe" names and
+    # versions in distribution archive names (sdist and bdist).
+
+    parts = basename.split('-')
+    if not py_version and any(re.match(r'py\d\.\d$', p) for p in parts[2:]):
+        # it is a bdist_dumb, not an sdist -- bail out
+        return
+
+    for p in range(1, len(parts) + 1):
+        yield Distribution(
+            location, metadata, '-'.join(parts[:p]), '-'.join(parts[p:]),
+            py_version=py_version, precedence=precedence,
+            platform=platform
+        )
+
+
+# From Python 2.7 docs
+def unique_everseen(iterable, key=None):
+    "List unique elements, preserving order. Remember all elements ever seen."
+    # unique_everseen('AAAABBBCCDAABBB') --> A B C D
+    # unique_everseen('ABBCcAD', str.lower) --> A B C D
+    seen = set()
+    seen_add = seen.add
+    if key is None:
+        for element in six.moves.filterfalse(seen.__contains__, iterable):
+            seen_add(element)
+            yield element
+    else:
+        for element in iterable:
+            k = key(element)
+            if k not in seen:
+                seen_add(k)
+                yield element
+
+
+def unique_values(func):
+    """
+    Wrap a function returning an iterable such that the resulting iterable
+    only ever yields unique items.
+    """
+
+    @wraps(func)
+    def wrapper(*args, **kwargs):
+        return unique_everseen(func(*args, **kwargs))
+
+    return wrapper
+
+
+REL = re.compile(r"""<([^>]*\srel\s*=\s*['"]?([^'">]+)[^>]*)>""", re.I)
+# this line is here to fix emacs' cruddy broken syntax highlighting
+
+
+@unique_values
+def find_external_links(url, page):
+    """Find rel="homepage" and rel="download" links in `page`, yielding URLs"""
+
+    for match in REL.finditer(page):
+        tag, rel = match.groups()
+        rels = set(map(str.strip, rel.lower().split(',')))
+        if 'homepage' in rels or 'download' in rels:
+            for match in HREF.finditer(tag):
+                yield urllib.parse.urljoin(url, htmldecode(match.group(1)))
+
+    for tag in ("<th>Home Page", "<th>Download URL"):
+        pos = page.find(tag)
+        if pos != -1:
+            match = HREF.search(page, pos)
+            if match:
+                yield urllib.parse.urljoin(url, htmldecode(match.group(1)))
+
+
+class ContentChecker:
+    """
+    A null content checker that defines the interface for checking content
+    """
+
+    def feed(self, block):
+        """
+        Feed a block of data to the hash.
+        """
+        return
+
+    def is_valid(self):
+        """
+        Check the hash. Return False if validation fails.
+        """
+        return True
+
+    def report(self, reporter, template):
+        """
+        Call reporter with information about the checker (hash name)
+        substituted into the template.
+        """
+        return
+
+
+class HashChecker(ContentChecker):
+    pattern = re.compile(
+        r'(?P<hash_name>sha1|sha224|sha384|sha256|sha512|md5)='
+        r'(?P<expected>[a-f0-9]+)'
+    )
+
+    def __init__(self, hash_name, expected):
+        self.hash_name = hash_name
+        self.hash = hashlib.new(hash_name)
+        self.expected = expected
+
+    @classmethod
+    def from_url(cls, url):
+        "Construct a (possibly null) ContentChecker from a URL"
+        fragment = urllib.parse.urlparse(url)[-1]
+        if not fragment:
+            return ContentChecker()
+        match = cls.pattern.search(fragment)
+        if not match:
+            return ContentChecker()
+        return cls(**match.groupdict())
+
+    def feed(self, block):
+        self.hash.update(block)
+
+    def is_valid(self):
+        return self.hash.hexdigest() == self.expected
+
+    def report(self, reporter, template):
+        msg = template % self.hash_name
+        return reporter(msg)
+
+
+class PackageIndex(Environment):
+    """A distribution index that scans web pages for download URLs"""
+
+    def __init__(
+            self, index_url="https://pypi.org/simple/", hosts=('*',),
+            ca_bundle=None, verify_ssl=True, *args, **kw
+    ):
+        Environment.__init__(self, *args, **kw)
+        self.index_url = index_url + "/" [:not index_url.endswith('/')]
+        self.scanned_urls = {}
+        self.fetched_urls = {}
+        self.package_pages = {}
+        self.allows = re.compile('|'.join(map(translate, hosts))).match
+        self.to_scan = []
+        use_ssl = (
+            verify_ssl
+            and ssl_support.is_available
+            and (ca_bundle or ssl_support.find_ca_bundle())
+        )
+        if use_ssl:
+            self.opener = ssl_support.opener_for(ca_bundle)
+        else:
+            self.opener = urllib.request.urlopen
+
+    def process_url(self, url, retrieve=False):
+        """Evaluate a URL as a possible download, and maybe retrieve it"""
+        if url in self.scanned_urls and not retrieve:
+            return
+        self.scanned_urls[url] = True
+        if not URL_SCHEME(url):
+            self.process_filename(url)
+            return
+        else:
+            dists = list(distros_for_url(url))
+            if dists:
+                if not self.url_ok(url):
+                    return
+                self.debug("Found link: %s", url)
+
+        if dists or not retrieve or url in self.fetched_urls:
+            list(map(self.add, dists))
+            return  # don't need the actual page
+
+        if not self.url_ok(url):
+            self.fetched_urls[url] = True
+            return
+
+        self.info("Reading %s", url)
+        self.fetched_urls[url] = True  # prevent multiple fetch attempts
+        tmpl = "Download error on %s: %%s -- Some packages may not be found!"
+        f = self.open_url(url, tmpl % url)
+        if f is None:
+            return
+        self.fetched_urls[f.url] = True
+        if 'html' not in f.headers.get('content-type', '').lower():
+            f.close()  # not html, we can't process it
+            return
+
+        base = f.url  # handle redirects
+        page = f.read()
+        if not isinstance(page, str):
+            # In Python 3 and got bytes but want str.
+            if isinstance(f, urllib.error.HTTPError):
+                # Errors have no charset, assume latin1:
+                charset = 'latin-1'
+            else:
+                charset = f.headers.get_param('charset') or 'latin-1'
+            page = page.decode(charset, "ignore")
+        f.close()
+        for match in HREF.finditer(page):
+            link = urllib.parse.urljoin(base, htmldecode(match.group(1)))
+            self.process_url(link)
+        if url.startswith(self.index_url) and getattr(f, 'code', None) != 404:
+            page = self.process_index(url, page)
+
+    def process_filename(self, fn, nested=False):
+        # process filenames or directories
+        if not os.path.exists(fn):
+            self.warn("Not found: %s", fn)
+            return
+
+        if os.path.isdir(fn) and not nested:
+            path = os.path.realpath(fn)
+            for item in os.listdir(path):
+                self.process_filename(os.path.join(path, item), True)
+
+        dists = distros_for_filename(fn)
+        if dists:
+            self.debug("Found: %s", fn)
+            list(map(self.add, dists))
+
+    def url_ok(self, url, fatal=False):
+        s = URL_SCHEME(url)
+        is_file = s and s.group(1).lower() == 'file'
+        if is_file or self.allows(urllib.parse.urlparse(url)[1]):
+            return True
+        msg = (
+            "\nNote: Bypassing %s (disallowed host; see "
+            "http://bit.ly/2hrImnY for details).\n")
+        if fatal:
+            raise DistutilsError(msg % url)
+        else:
+            self.warn(msg, url)
+
+    def scan_egg_links(self, search_path):
+        dirs = filter(os.path.isdir, search_path)
+        egg_links = (
+            (path, entry)
+            for path in dirs
+            for entry in os.listdir(path)
+            if entry.endswith('.egg-link')
+        )
+        list(itertools.starmap(self.scan_egg_link, egg_links))
+
+    def scan_egg_link(self, path, entry):
+        with open(os.path.join(path, entry)) as raw_lines:
+            # filter non-empty lines
+            lines = list(filter(None, map(str.strip, raw_lines)))
+
+        if len(lines) != 2:
+            # format is not recognized; punt
+            return
+
+        egg_path, setup_path = lines
+
+        for dist in find_distributions(os.path.join(path, egg_path)):
+            dist.location = os.path.join(path, *lines)
+            dist.precedence = SOURCE_DIST
+            self.add(dist)
+
+    def process_index(self, url, page):
+        """Process the contents of a PyPI page"""
+
+        def scan(link):
+            # Process a URL to see if it's for a package page
+            if link.startswith(self.index_url):
+                parts = list(map(
+                    urllib.parse.unquote, link[len(self.index_url):].split('/')
+                ))
+                if len(parts) == 2 and '#' not in parts[1]:
+                    # it's a package page, sanitize and index it
+                    pkg = safe_name(parts[0])
+                    ver = safe_version(parts[1])
+                    self.package_pages.setdefault(pkg.lower(), {})[link] = True
+                    return to_filename(pkg), to_filename(ver)
+            return None, None
+
+        # process an index page into the package-page index
+        for match in HREF.finditer(page):
+            try:
+                scan(urllib.parse.urljoin(url, htmldecode(match.group(1))))
+            except ValueError:
+                pass
+
+        pkg, ver = scan(url)  # ensure this page is in the page index
+        if pkg:
+            # process individual package page
+            for new_url in find_external_links(url, page):
+                # Process the found URL
+                base, frag = egg_info_for_url(new_url)
+                if base.endswith('.py') and not frag:
+                    if ver:
+                        new_url += '#egg=%s-%s' % (pkg, ver)
+                    else:
+                        self.need_version_info(url)
+                self.scan_url(new_url)
+
+            return PYPI_MD5.sub(
+                lambda m: '<a href="%s#md5=%s">%s</a>' % m.group(1, 3, 2), page
+            )
+        else:
+            return ""  # no sense double-scanning non-package pages
+
+    def need_version_info(self, url):
+        self.scan_all(
+            "Page at %s links to .py file(s) without version info; an index "
+            "scan is required.", url
+        )
+
+    def scan_all(self, msg=None, *args):
+        if self.index_url not in self.fetched_urls:
+            if msg:
+                self.warn(msg, *args)
+            self.info(
+                "Scanning index of all packages (this may take a while)"
+            )
+        self.scan_url(self.index_url)
+
+    def find_packages(self, requirement):
+        self.scan_url(self.index_url + requirement.unsafe_name + '/')
+
+        if not self.package_pages.get(requirement.key):
+            # Fall back to safe version of the name
+            self.scan_url(self.index_url + requirement.project_name + '/')
+
+        if not self.package_pages.get(requirement.key):
+            # We couldn't find the target package, so search the index page too
+            self.not_found_in_index(requirement)
+
+        for url in list(self.package_pages.get(requirement.key, ())):
+            # scan each page that might be related to the desired package
+            self.scan_url(url)
+
+    def obtain(self, requirement, installer=None):
+        self.prescan()
+        self.find_packages(requirement)
+        for dist in self[requirement.key]:
+            if dist in requirement:
+                return dist
+            self.debug("%s does not match %s", requirement, dist)
+        return super(PackageIndex, self).obtain(requirement, installer)
+
+    def check_hash(self, checker, filename, tfp):
+        """
+        checker is a ContentChecker
+        """
+        checker.report(
+            self.debug,
+            "Validating %%s checksum for %s" % filename)
+        if not checker.is_valid():
+            tfp.close()
+            os.unlink(filename)
+            raise DistutilsError(
+                "%s validation failed for %s; "
+                "possible download problem?"
+                % (checker.hash.name, os.path.basename(filename))
+            )
+
+    def add_find_links(self, urls):
+        """Add `urls` to the list that will be prescanned for searches"""
+        for url in urls:
+            if (
+                self.to_scan is None  # if we have already "gone online"
+                or not URL_SCHEME(url)  # or it's a local file/directory
+                or url.startswith('file:')
+                or list(distros_for_url(url))  # or a direct package link
+            ):
+                # then go ahead and process it now
+                self.scan_url(url)
+            else:
+                # otherwise, defer retrieval till later
+                self.to_scan.append(url)
+
+    def prescan(self):
+        """Scan urls scheduled for prescanning (e.g. --find-links)"""
+        if self.to_scan:
+            list(map(self.scan_url, self.to_scan))
+        self.to_scan = None  # from now on, go ahead and process immediately
+
+    def not_found_in_index(self, requirement):
+        if self[requirement.key]:  # we've seen at least one distro
+            meth, msg = self.info, "Couldn't retrieve index page for %r"
+        else:  # no distros seen for this name, might be misspelled
+            meth, msg = (
+                self.warn,
+                "Couldn't find index page for %r (maybe misspelled?)")
+        meth(msg, requirement.unsafe_name)
+        self.scan_all()
+
+    def download(self, spec, tmpdir):
+        """Locate and/or download `spec` to `tmpdir`, returning a local path
+
+        `spec` may be a ``Requirement`` object, or a string containing a URL,
+        an existing local filename, or a project/version requirement spec
+        (i.e. the string form of a ``Requirement`` object).  If it is the URL
+        of a .py file with an unambiguous ``#egg=name-version`` tag (i.e., one
+        that escapes ``-`` as ``_`` throughout), a trivial ``setup.py`` is
+        automatically created alongside the downloaded file.
+
+        If `spec` is a ``Requirement`` object or a string containing a
+        project/version requirement spec, this method returns the location of
+        a matching distribution (possibly after downloading it to `tmpdir`).
+        If `spec` is a locally existing file or directory name, it is simply
+        returned unchanged.  If `spec` is a URL, it is downloaded to a subpath
+        of `tmpdir`, and the local filename is returned.  Various errors may be
+        raised if a problem occurs during downloading.
+        """
+        if not isinstance(spec, Requirement):
+            scheme = URL_SCHEME(spec)
+            if scheme:
+                # It's a url, download it to tmpdir
+                found = self._download_url(scheme.group(1), spec, tmpdir)
+                base, fragment = egg_info_for_url(spec)
+                if base.endswith('.py'):
+                    found = self.gen_setup(found, fragment, tmpdir)
+                return found
+            elif os.path.exists(spec):
+                # Existing file or directory, just return it
+                return spec
+            else:
+                spec = parse_requirement_arg(spec)
+        return getattr(self.fetch_distribution(spec, tmpdir), 'location', None)
+
+    def fetch_distribution(
+            self, requirement, tmpdir, force_scan=False, source=False,
+            develop_ok=False, local_index=None):
+        """Obtain a distribution suitable for fulfilling `requirement`
+
+        `requirement` must be a ``pkg_resources.Requirement`` instance.
+        If necessary, or if the `force_scan` flag is set, the requirement is
+        searched for in the (online) package index as well as the locally
+        installed packages.  If a distribution matching `requirement` is found,
+        the returned distribution's ``location`` is the value you would have
+        gotten from calling the ``download()`` method with the matching
+        distribution's URL or filename.  If no matching distribution is found,
+        ``None`` is returned.
+
+        If the `source` flag is set, only source distributions and source
+        checkout links will be considered.  Unless the `develop_ok` flag is
+        set, development and system eggs (i.e., those using the ``.egg-info``
+        format) will be ignored.
+        """
+        # process a Requirement
+        self.info("Searching for %s", requirement)
+        skipped = {}
+        dist = None
+
+        def find(req, env=None):
+            if env is None:
+                env = self
+            # Find a matching distribution; may be called more than once
+
+            for dist in env[req.key]:
+
+                if dist.precedence == DEVELOP_DIST and not develop_ok:
+                    if dist not in skipped:
+                        self.warn(
+                            "Skipping development or system egg: %s", dist,
+                        )
+                        skipped[dist] = 1
+                    continue
+
+                test = (
+                    dist in req
+                    and (dist.precedence <= SOURCE_DIST or not source)
+                )
+                if test:
+                    loc = self.download(dist.location, tmpdir)
+                    dist.download_location = loc
+                    if os.path.exists(dist.download_location):
+                        return dist
+
+        if force_scan:
+            self.prescan()
+            self.find_packages(requirement)
+            dist = find(requirement)
+
+        if not dist and local_index is not None:
+            dist = find(requirement, local_index)
+
+        if dist is None:
+            if self.to_scan is not None:
+                self.prescan()
+            dist = find(requirement)
+
+        if dist is None and not force_scan:
+            self.find_packages(requirement)
+            dist = find(requirement)
+
+        if dist is None:
+            self.warn(
+                "No local packages or working download links found for %s%s",
+                (source and "a source distribution of " or ""),
+                requirement,
+            )
+        else:
+            self.info("Best match: %s", dist)
+            return dist.clone(location=dist.download_location)
+
+    def fetch(self, requirement, tmpdir, force_scan=False, source=False):
+        """Obtain a file suitable for fulfilling `requirement`
+
+        DEPRECATED; use the ``fetch_distribution()`` method now instead.  For
+        backward compatibility, this routine is identical but returns the
+        ``location`` of the downloaded distribution instead of a distribution
+        object.
+        """
+        dist = self.fetch_distribution(requirement, tmpdir, force_scan, source)
+        if dist is not None:
+            return dist.location
+        return None
+
+    def gen_setup(self, filename, fragment, tmpdir):
+        match = EGG_FRAGMENT.match(fragment)
+        dists = match and [
+            d for d in
+            interpret_distro_name(filename, match.group(1), None) if d.version
+        ] or []
+
+        if len(dists) == 1:  # unambiguous ``#egg`` fragment
+            basename = os.path.basename(filename)
+
+            # Make sure the file has been downloaded to the temp dir.
+            if os.path.dirname(filename) != tmpdir:
+                dst = os.path.join(tmpdir, basename)
+                from setuptools.command.easy_install import samefile
+                if not samefile(filename, dst):
+                    shutil.copy2(filename, dst)
+                    filename = dst
+
+            with open(os.path.join(tmpdir, 'setup.py'), 'w') as file:
+                file.write(
+                    "from setuptools import setup\n"
+                    "setup(name=%r, version=%r, py_modules=[%r])\n"
+                    % (
+                        dists[0].project_name, dists[0].version,
+                        os.path.splitext(basename)[0]
+                    )
+                )
+            return filename
+
+        elif match:
+            raise DistutilsError(
+                "Can't unambiguously interpret project/version identifier %r; "
+                "any dashes in the name or version should be escaped using "
+                "underscores. %r" % (fragment, dists)
+            )
+        else:
+            raise DistutilsError(
+                "Can't process plain .py files without an '#egg=name-version'"
+                " suffix to enable automatic setup script generation."
+            )
+
+    dl_blocksize = 8192
+
+    def _download_to(self, url, filename):
+        self.info("Downloading %s", url)
+        # Download the file
+        fp = None
+        try:
+            checker = HashChecker.from_url(url)
+            fp = self.open_url(url)
+            if isinstance(fp, urllib.error.HTTPError):
+                raise DistutilsError(
+                    "Can't download %s: %s %s" % (url, fp.code, fp.msg)
+                )
+            headers = fp.info()
+            blocknum = 0
+            bs = self.dl_blocksize
+            size = -1
+            if "content-length" in headers:
+                # Some servers return multiple Content-Length headers :(
+                sizes = get_all_headers(headers, 'Content-Length')
+                size = max(map(int, sizes))
+                self.reporthook(url, filename, blocknum, bs, size)
+            with open(filename, 'wb') as tfp:
+                while True:
+                    block = fp.read(bs)
+                    if block:
+                        checker.feed(block)
+                        tfp.write(block)
+                        blocknum += 1
+                        self.reporthook(url, filename, blocknum, bs, size)
+                    else:
+                        break
+                self.check_hash(checker, filename, tfp)
+            return headers
+        finally:
+            if fp:
+                fp.close()
+
+    def reporthook(self, url, filename, blocknum, blksize, size):
+        pass  # no-op
+
+    def open_url(self, url, warning=None):
+        if url.startswith('file:'):
+            return local_open(url)
+        try:
+            return open_with_auth(url, self.opener)
+        except (ValueError, http_client.InvalidURL) as v:
+            msg = ' '.join([str(arg) for arg in v.args])
+            if warning:
+                self.warn(warning, msg)
+            else:
+                raise DistutilsError('%s %s' % (url, msg))
+        except urllib.error.HTTPError as v:
+            return v
+        except urllib.error.URLError as v:
+            if warning:
+                self.warn(warning, v.reason)
+            else:
+                raise DistutilsError("Download error for %s: %s"
+                                     % (url, v.reason))
+        except http_client.BadStatusLine as v:
+            if warning:
+                self.warn(warning, v.line)
+            else:
+                raise DistutilsError(
+                    '%s returned a bad status line. The server might be '
+                    'down, %s' %
+                    (url, v.line)
+                )
+        except (http_client.HTTPException, socket.error) as v:
+            if warning:
+                self.warn(warning, v)
+            else:
+                raise DistutilsError("Download error for %s: %s"
+                                     % (url, v))
+
+    def _download_url(self, scheme, url, tmpdir):
+        # Determine download filename
+        #
+        name, fragment = egg_info_for_url(url)
+        if name:
+            while '..' in name:
+                name = name.replace('..', '.').replace('\\', '_')
+        else:
+            name = "__downloaded__"  # default if URL has no path contents
+
+        if name.endswith('.egg.zip'):
+            name = name[:-4]  # strip the extra .zip before download
+
+        filename = os.path.join(tmpdir, name)
+
+        # Download the file
+        #
+        if scheme == 'svn' or scheme.startswith('svn+'):
+            return self._download_svn(url, filename)
+        elif scheme == 'git' or scheme.startswith('git+'):
+            return self._download_git(url, filename)
+        elif scheme.startswith('hg+'):
+            return self._download_hg(url, filename)
+        elif scheme == 'file':
+            return urllib.request.url2pathname(urllib.parse.urlparse(url)[2])
+        else:
+            self.url_ok(url, True)  # raises error if not allowed
+            return self._attempt_download(url, filename)
+
+    def scan_url(self, url):
+        self.process_url(url, True)
+
+    def _attempt_download(self, url, filename):
+        headers = self._download_to(url, filename)
+        if 'html' in headers.get('content-type', '').lower():
+            return self._download_html(url, headers, filename)
+        else:
+            return filename
+
+    def _download_html(self, url, headers, filename):
+        file = open(filename)
+        for line in file:
+            if line.strip():
+                # Check for a subversion index page
+                if re.search(r'<title>([^- ]+ - )?Revision \d+:', line):
+                    # it's a subversion index page:
+                    file.close()
+                    os.unlink(filename)
+                    return self._download_svn(url, filename)
+                break  # not an index page
+        file.close()
+        os.unlink(filename)
+        raise DistutilsError("Unexpected HTML page found at " + url)
+
+    def _download_svn(self, url, filename):
+        warnings.warn("SVN download support is deprecated", UserWarning)
+        url = url.split('#', 1)[0]  # remove any fragment for svn's sake
+        creds = ''
+        if url.lower().startswith('svn:') and '@' in url:
+            scheme, netloc, path, p, q, f = urllib.parse.urlparse(url)
+            if not netloc and path.startswith('//') and '/' in path[2:]:
+                netloc, path = path[2:].split('/', 1)
+                auth, host = _splituser(netloc)
+                if auth:
+                    if ':' in auth:
+                        user, pw = auth.split(':', 1)
+                        creds = " --username=%s --password=%s" % (user, pw)
+                    else:
+                        creds = " --username=" + auth
+                    netloc = host
+                    parts = scheme, netloc, url, p, q, f
+                    url = urllib.parse.urlunparse(parts)
+        self.info("Doing subversion checkout from %s to %s", url, filename)
+        os.system("svn checkout%s -q %s %s" % (creds, url, filename))
+        return filename
+
+    @staticmethod
+    def _vcs_split_rev_from_url(url, pop_prefix=False):
+        scheme, netloc, path, query, frag = urllib.parse.urlsplit(url)
+
+        scheme = scheme.split('+', 1)[-1]
+
+        # Some fragment identification fails
+        path = path.split('#', 1)[0]
+
+        rev = None
+        if '@' in path:
+            path, rev = path.rsplit('@', 1)
+
+        # Also, discard fragment
+        url = urllib.parse.urlunsplit((scheme, netloc, path, query, ''))
+
+        return url, rev
+
+    def _download_git(self, url, filename):
+        filename = filename.split('#', 1)[0]
+        url, rev = self._vcs_split_rev_from_url(url, pop_prefix=True)
+
+        self.info("Doing git clone from %s to %s", url, filename)
+        os.system("git clone --quiet %s %s" % (url, filename))
+
+        if rev is not None:
+            self.info("Checking out %s", rev)
+            os.system("git -C %s checkout --quiet %s" % (
+                filename,
+                rev,
+            ))
+
+        return filename
+
+    def _download_hg(self, url, filename):
+        filename = filename.split('#', 1)[0]
+        url, rev = self._vcs_split_rev_from_url(url, pop_prefix=True)
+
+        self.info("Doing hg clone from %s to %s", url, filename)
+        os.system("hg clone --quiet %s %s" % (url, filename))
+
+        if rev is not None:
+            self.info("Updating to %s", rev)
+            os.system("hg --cwd %s up -C -r %s -q" % (
+                filename,
+                rev,
+            ))
+
+        return filename
+
+    def debug(self, msg, *args):
+        log.debug(msg, *args)
+
+    def info(self, msg, *args):
+        log.info(msg, *args)
+
+    def warn(self, msg, *args):
+        log.warn(msg, *args)
+
+
+# This pattern matches a character entity reference (a decimal numeric
+# references, a hexadecimal numeric reference, or a named reference).
+entity_sub = re.compile(r'&(#(\d+|x[\da-fA-F]+)|[\w.:-]+);?').sub
+
+
+def decode_entity(match):
+    what = match.group(0)
+    return unescape(what)
+
+
+def htmldecode(text):
+    """
+    Decode HTML entities in the given text.
+
+    >>> htmldecode(
+    ...     'https://../package_name-0.1.2.tar.gz'
+    ...     '?tokena=A&amp;tokenb=B">package_name-0.1.2.tar.gz')
+    'https://../package_name-0.1.2.tar.gz?tokena=A&tokenb=B">package_name-0.1.2.tar.gz'
+    """
+    return entity_sub(decode_entity, text)
+
+
+def socket_timeout(timeout=15):
+    def _socket_timeout(func):
+        def _socket_timeout(*args, **kwargs):
+            old_timeout = socket.getdefaulttimeout()
+            socket.setdefaulttimeout(timeout)
+            try:
+                return func(*args, **kwargs)
+            finally:
+                socket.setdefaulttimeout(old_timeout)
+
+        return _socket_timeout
+
+    return _socket_timeout
+
+
+def _encode_auth(auth):
+    """
+    A function compatible with Python 2.3-3.3 that will encode
+    auth from a URL suitable for an HTTP header.
+    >>> str(_encode_auth('username%3Apassword'))
+    'dXNlcm5hbWU6cGFzc3dvcmQ='
+
+    Long auth strings should not cause a newline to be inserted.
+    >>> long_auth = 'username:' + 'password'*10
+    >>> chr(10) in str(_encode_auth(long_auth))
+    False
+    """
+    auth_s = urllib.parse.unquote(auth)
+    # convert to bytes
+    auth_bytes = auth_s.encode()
+    encoded_bytes = base64.b64encode(auth_bytes)
+    # convert back to a string
+    encoded = encoded_bytes.decode()
+    # strip the trailing carriage return
+    return encoded.replace('\n', '')
+
+
+class Credential:
+    """
+    A username/password pair. Use like a namedtuple.
+    """
+
+    def __init__(self, username, password):
+        self.username = username
+        self.password = password
+
+    def __iter__(self):
+        yield self.username
+        yield self.password
+
+    def __str__(self):
+        return '%(username)s:%(password)s' % vars(self)
+
+
+class PyPIConfig(configparser.RawConfigParser):
+    def __init__(self):
+        """
+        Load from ~/.pypirc
+        """
+        defaults = dict.fromkeys(['username', 'password', 'repository'], '')
+        configparser.RawConfigParser.__init__(self, defaults)
+
+        rc = os.path.join(os.path.expanduser('~'), '.pypirc')
+        if os.path.exists(rc):
+            self.read(rc)
+
+    @property
+    def creds_by_repository(self):
+        sections_with_repositories = [
+            section for section in self.sections()
+            if self.get(section, 'repository').strip()
+        ]
+
+        return dict(map(self._get_repo_cred, sections_with_repositories))
+
+    def _get_repo_cred(self, section):
+        repo = self.get(section, 'repository').strip()
+        return repo, Credential(
+            self.get(section, 'username').strip(),
+            self.get(section, 'password').strip(),
+        )
+
+    def find_credential(self, url):
+        """
+        If the URL indicated appears to be a repository defined in this
+        config, return the credential for that repository.
+        """
+        for repository, cred in self.creds_by_repository.items():
+            if url.startswith(repository):
+                return cred
+
+
+def open_with_auth(url, opener=urllib.request.urlopen):
+    """Open a urllib2 request, handling HTTP authentication"""
+
+    parsed = urllib.parse.urlparse(url)
+    scheme, netloc, path, params, query, frag = parsed
+
+    # Double scheme does not raise on Mac OS X as revealed by a
+    # failing test. We would expect "nonnumeric port". Refs #20.
+    if netloc.endswith(':'):
+        raise http_client.InvalidURL("nonnumeric port: ''")
+
+    if scheme in ('http', 'https'):
+        auth, address = _splituser(netloc)
+    else:
+        auth = None
+
+    if not auth:
+        cred = PyPIConfig().find_credential(url)
+        if cred:
+            auth = str(cred)
+            info = cred.username, url
+            log.info('Authenticating as %s for %s (from .pypirc)', *info)
+
+    if auth:
+        auth = "Basic " + _encode_auth(auth)
+        parts = scheme, address, path, params, query, frag
+        new_url = urllib.parse.urlunparse(parts)
+        request = urllib.request.Request(new_url)
+        request.add_header("Authorization", auth)
+    else:
+        request = urllib.request.Request(url)
+
+    request.add_header('User-Agent', user_agent)
+    fp = opener(request)
+
+    if auth:
+        # Put authentication info back into request URL if same host,
+        # so that links found on the page will work
+        s2, h2, path2, param2, query2, frag2 = urllib.parse.urlparse(fp.url)
+        if s2 == scheme and h2 == address:
+            parts = s2, netloc, path2, param2, query2, frag2
+            fp.url = urllib.parse.urlunparse(parts)
+
+    return fp
+
+
+# copy of urllib.parse._splituser from Python 3.8
+def _splituser(host):
+    """splituser('user[:passwd]@host[:port]') --> 'user[:passwd]', 'host[:port]'."""
+    user, delim, host = host.rpartition('@')
+    return (user if delim else None), host
+
+
+# adding a timeout to avoid freezing package_index
+open_with_auth = socket_timeout(_SOCKET_TIMEOUT)(open_with_auth)
+
+
+def fix_sf_url(url):
+    return url  # backward compatibility
+
+
+def local_open(url):
+    """Read a local path, with special support for directories"""
+    scheme, server, path, param, query, frag = urllib.parse.urlparse(url)
+    filename = urllib.request.url2pathname(path)
+    if os.path.isfile(filename):
+        return urllib.request.urlopen(url)
+    elif path.endswith('/') and os.path.isdir(filename):
+        files = []
+        for f in os.listdir(filename):
+            filepath = os.path.join(filename, f)
+            if f == 'index.html':
+                with open(filepath, 'r') as fp:
+                    body = fp.read()
+                break
+            elif os.path.isdir(filepath):
+                f += '/'
+            files.append('<a href="{name}">{name}</a>'.format(name=f))
+        else:
+            tmpl = (
+                "<html><head><title>{url}</title>"
+                "</head><body>{files}</body></html>")
+            body = tmpl.format(url=url, files='\n'.join(files))
+        status, message = 200, "OK"
+    else:
+        status, message, body = 404, "Path not found", "Not found"
+
+    headers = {'content-type': 'text/html'}
+    body_stream = six.StringIO(body)
+    return urllib.error.HTTPError(url, status, message, headers, body_stream)
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/package_index.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/package_index.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..62e4f1fe9d5ee0cb979f151b36a6daa628fe5ffc
GIT binary patch
literal 44744
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
Zm^oQFd3g9a#e@YV)r9mp*@c)nSpY?)z)k=F

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/pep425tags.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/pep425tags.py
new file mode 100644
index 0000000..48745a2
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/pep425tags.py
@@ -0,0 +1,319 @@
+# This file originally from pip:
+# https://github.com/pypa/pip/blob/8f4f15a5a95d7d5b511ceaee9ed261176c181970/src/pip/_internal/pep425tags.py
+"""Generate and work with PEP 425 Compatibility Tags."""
+from __future__ import absolute_import
+
+import distutils.util
+from distutils import log
+import platform
+import re
+import sys
+import sysconfig
+import warnings
+from collections import OrderedDict
+
+from .extern import six
+
+from . import glibc
+
+_osx_arch_pat = re.compile(r'(.+)_(\d+)_(\d+)_(.+)')
+
+
+def get_config_var(var):
+    try:
+        return sysconfig.get_config_var(var)
+    except IOError as e:  # Issue #1074
+        warnings.warn("{}".format(e), RuntimeWarning)
+        return None
+
+
+def get_abbr_impl():
+    """Return abbreviated implementation name."""
+    if hasattr(sys, 'pypy_version_info'):
+        pyimpl = 'pp'
+    elif sys.platform.startswith('java'):
+        pyimpl = 'jy'
+    elif sys.platform == 'cli':
+        pyimpl = 'ip'
+    else:
+        pyimpl = 'cp'
+    return pyimpl
+
+
+def get_impl_ver():
+    """Return implementation version."""
+    impl_ver = get_config_var("py_version_nodot")
+    if not impl_ver or get_abbr_impl() == 'pp':
+        impl_ver = ''.join(map(str, get_impl_version_info()))
+    return impl_ver
+
+
+def get_impl_version_info():
+    """Return sys.version_info-like tuple for use in decrementing the minor
+    version."""
+    if get_abbr_impl() == 'pp':
+        # as per https://github.com/pypa/pip/issues/2882
+        return (sys.version_info[0], sys.pypy_version_info.major,
+                sys.pypy_version_info.minor)
+    else:
+        return sys.version_info[0], sys.version_info[1]
+
+
+def get_impl_tag():
+    """
+    Returns the Tag for this specific implementation.
+    """
+    return "{}{}".format(get_abbr_impl(), get_impl_ver())
+
+
+def get_flag(var, fallback, expected=True, warn=True):
+    """Use a fallback method for determining SOABI flags if the needed config
+    var is unset or unavailable."""
+    val = get_config_var(var)
+    if val is None:
+        if warn:
+            log.debug("Config variable '%s' is unset, Python ABI tag may "
+                      "be incorrect", var)
+        return fallback()
+    return val == expected
+
+
+def get_abi_tag():
+    """Return the ABI tag based on SOABI (if available) or emulate SOABI
+    (CPython 2, PyPy)."""
+    soabi = get_config_var('SOABI')
+    impl = get_abbr_impl()
+    if not soabi and impl in {'cp', 'pp'} and hasattr(sys, 'maxunicode'):
+        d = ''
+        m = ''
+        u = ''
+        if get_flag('Py_DEBUG',
+                    lambda: hasattr(sys, 'gettotalrefcount'),
+                    warn=(impl == 'cp')):
+            d = 'd'
+        if get_flag('WITH_PYMALLOC',
+                    lambda: impl == 'cp',
+                    warn=(impl == 'cp')):
+            m = 'm'
+        if get_flag('Py_UNICODE_SIZE',
+                    lambda: sys.maxunicode == 0x10ffff,
+                    expected=4,
+                    warn=(impl == 'cp' and
+                          six.PY2)) \
+                and six.PY2:
+            u = 'u'
+        abi = '%s%s%s%s%s' % (impl, get_impl_ver(), d, m, u)
+    elif soabi and soabi.startswith('cpython-'):
+        abi = 'cp' + soabi.split('-')[1]
+    elif soabi:
+        abi = soabi.replace('.', '_').replace('-', '_')
+    else:
+        abi = None
+    return abi
+
+
+def _is_running_32bit():
+    return sys.maxsize == 2147483647
+
+
+def get_platform():
+    """Return our platform name 'win32', 'linux_x86_64'"""
+    if sys.platform == 'darwin':
+        # distutils.util.get_platform() returns the release based on the value
+        # of MACOSX_DEPLOYMENT_TARGET on which Python was built, which may
+        # be significantly older than the user's current machine.
+        release, _, machine = platform.mac_ver()
+        split_ver = release.split('.')
+
+        if machine == "x86_64" and _is_running_32bit():
+            machine = "i386"
+        elif machine == "ppc64" and _is_running_32bit():
+            machine = "ppc"
+
+        return 'macosx_{}_{}_{}'.format(split_ver[0], split_ver[1], machine)
+
+    # XXX remove distutils dependency
+    result = distutils.util.get_platform().replace('.', '_').replace('-', '_')
+    if result == "linux_x86_64" and _is_running_32bit():
+        # 32 bit Python program (running on a 64 bit Linux): pip should only
+        # install and run 32 bit compiled extensions in that case.
+        result = "linux_i686"
+
+    return result
+
+
+def is_manylinux1_compatible():
+    # Only Linux, and only x86-64 / i686
+    if get_platform() not in {"linux_x86_64", "linux_i686"}:
+        return False
+
+    # Check for presence of _manylinux module
+    try:
+        import _manylinux
+        return bool(_manylinux.manylinux1_compatible)
+    except (ImportError, AttributeError):
+        # Fall through to heuristic check below
+        pass
+
+    # Check glibc version. CentOS 5 uses glibc 2.5.
+    return glibc.have_compatible_glibc(2, 5)
+
+
+def get_darwin_arches(major, minor, machine):
+    """Return a list of supported arches (including group arches) for
+    the given major, minor and machine architecture of a macOS machine.
+    """
+    arches = []
+
+    def _supports_arch(major, minor, arch):
+        # Looking at the application support for macOS versions in the chart
+        # provided by https://en.wikipedia.org/wiki/OS_X#Versions it appears
+        # our timeline looks roughly like:
+        #
+        # 10.0 - Introduces ppc support.
+        # 10.4 - Introduces ppc64, i386, and x86_64 support, however the ppc64
+        #        and x86_64 support is CLI only, and cannot be used for GUI
+        #        applications.
+        # 10.5 - Extends ppc64 and x86_64 support to cover GUI applications.
+        # 10.6 - Drops support for ppc64
+        # 10.7 - Drops support for ppc
+        #
+        # Given that we do not know if we're installing a CLI or a GUI
+        # application, we must be conservative and assume it might be a GUI
+        # application and behave as if ppc64 and x86_64 support did not occur
+        # until 10.5.
+        #
+        # Note: The above information is taken from the "Application support"
+        #       column in the chart not the "Processor support" since I believe
+        #       that we care about what instruction sets an application can use
+        #       not which processors the OS supports.
+        if arch == 'ppc':
+            return (major, minor) <= (10, 5)
+        if arch == 'ppc64':
+            return (major, minor) == (10, 5)
+        if arch == 'i386':
+            return (major, minor) >= (10, 4)
+        if arch == 'x86_64':
+            return (major, minor) >= (10, 5)
+        if arch in groups:
+            for garch in groups[arch]:
+                if _supports_arch(major, minor, garch):
+                    return True
+        return False
+
+    groups = OrderedDict([
+        ("fat", ("i386", "ppc")),
+        ("intel", ("x86_64", "i386")),
+        ("fat64", ("x86_64", "ppc64")),
+        ("fat32", ("x86_64", "i386", "ppc")),
+    ])
+
+    if _supports_arch(major, minor, machine):
+        arches.append(machine)
+
+    for garch in groups:
+        if machine in groups[garch] and _supports_arch(major, minor, garch):
+            arches.append(garch)
+
+    arches.append('universal')
+
+    return arches
+
+
+def get_supported(versions=None, noarch=False, platform=None,
+                  impl=None, abi=None):
+    """Return a list of supported tags for each version specified in
+    `versions`.
+
+    :param versions: a list of string versions, of the form ["33", "32"],
+        or None. The first version will be assumed to support our ABI.
+    :param platform: specify the exact platform you want valid
+        tags for, or None. If None, use the local system platform.
+    :param impl: specify the exact implementation you want valid
+        tags for, or None. If None, use the local interpreter impl.
+    :param abi: specify the exact abi you want valid
+        tags for, or None. If None, use the local interpreter abi.
+    """
+    supported = []
+
+    # Versions must be given with respect to the preference
+    if versions is None:
+        versions = []
+        version_info = get_impl_version_info()
+        major = version_info[:-1]
+        # Support all previous minor Python versions.
+        for minor in range(version_info[-1], -1, -1):
+            versions.append(''.join(map(str, major + (minor,))))
+
+    impl = impl or get_abbr_impl()
+
+    abis = []
+
+    abi = abi or get_abi_tag()
+    if abi:
+        abis[0:0] = [abi]
+
+    abi3s = set()
+    import imp
+    for suffix in imp.get_suffixes():
+        if suffix[0].startswith('.abi'):
+            abi3s.add(suffix[0].split('.', 2)[1])
+
+    abis.extend(sorted(list(abi3s)))
+
+    abis.append('none')
+
+    if not noarch:
+        arch = platform or get_platform()
+        if arch.startswith('macosx'):
+            # support macosx-10.6-intel on macosx-10.9-x86_64
+            match = _osx_arch_pat.match(arch)
+            if match:
+                name, major, minor, actual_arch = match.groups()
+                tpl = '{}_{}_%i_%s'.format(name, major)
+                arches = []
+                for m in reversed(range(int(minor) + 1)):
+                    for a in get_darwin_arches(int(major), m, actual_arch):
+                        arches.append(tpl % (m, a))
+            else:
+                # arch pattern didn't match (?!)
+                arches = [arch]
+        elif platform is None and is_manylinux1_compatible():
+            arches = [arch.replace('linux', 'manylinux1'), arch]
+        else:
+            arches = [arch]
+
+        # Current version, current API (built specifically for our Python):
+        for abi in abis:
+            for arch in arches:
+                supported.append(('%s%s' % (impl, versions[0]), abi, arch))
+
+        # abi3 modules compatible with older version of Python
+        for version in versions[1:]:
+            # abi3 was introduced in Python 3.2
+            if version in {'31', '30'}:
+                break
+            for abi in abi3s:   # empty set if not Python 3
+                for arch in arches:
+                    supported.append(("%s%s" % (impl, version), abi, arch))
+
+        # Has binaries, does not use the Python API:
+        for arch in arches:
+            supported.append(('py%s' % (versions[0][0]), 'none', arch))
+
+    # No abi / arch, but requires our implementation:
+    supported.append(('%s%s' % (impl, versions[0]), 'none', 'any'))
+    # Tagged specifically as being cross-version compatible
+    # (with just the major version specified)
+    supported.append(('%s%s' % (impl, versions[0][0]), 'none', 'any'))
+
+    # No abi / arch, generic Python
+    for i, version in enumerate(versions):
+        supported.append(('py%s' % (version,), 'none', 'any'))
+        if i == 0:
+            supported.append(('py%s' % (version[0]), 'none', 'any'))
+
+    return supported
+
+
+implementation_tag = get_impl_tag()
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/pep425tags.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/pep425tags.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..3d06276494369b719e122eb20a2e8a22671c6539
GIT binary patch
literal 10313
zcmZSn%**AGdLky70Sed{7#JKJ7#NDJ85tN-7#N}$7*ZG+QkWQW7#VVz7^0XM7(sky
zh8$*wC>F3B3quYILoO>r6f0bgjUkE+EXT}{!_E-J4r6mLL~+2_oD5N%Fg6!M6c?Dy
z%8<j&kjujm#lygu!p4xo&XB{)kjuvq#RuVYFy!zv<O(oE2{16GvNL1}GNf=aG&3?p
z2{EK_F|;r+L<uvbaDy2l3@JQdhA2Y{FPI_5kirLMh%=;0fKUoQLkkl_lq5rn09ag#
zAw>|(kY-2`0yAV7QiQ<_S%wr5Fhh<Zg_$8$0Ys)SgGo__7FLERMTS&yhGqtaC?$|!
zu!a}|14FS90|SG5YF=tlVo9n(VqS_ud45s0LV0FMhC+aAfP#sUse*HUZb4#6W>RKO
zW=W+&NMd@iUM46mG#D8e7)tmV7#I?hit}?yOH$)Aa|`l|O8g))%nS?+Ir-@j4mSe>
zgMU#<YEf#6OJ;IOCP*(t2BfSwvjW0lWnf@P&&f<mE*52AV9?Oh){NJPNkNc$+M3BA
ztxOCI3?Q}6poHMcz`#%`$WX$-kj2PQ!vG5H;P5<M29^>ghHNf|A_oS>T1E!O5@v=h
zaC*pMWvF2UsVZS(Xa*%028Q5>6b6Q14Un;Z#UQe}R)YiNJx)*{RTd}b=cQ$)m+*m{
zms%1J;l`IG7L~9wFfe%fyA~DY7nOi?lqVMDW#*+9m#{D}Fn~BEpah$iUzD3z0@fc?
znpcvUn;H&L2Ug~npO*@@y95*%AX7npOw|B~GKeV7XJBB^FDS|^ODsv%FH0=aPs`6q
zNi8bYPfF1*PfE(mHO(zHGE6d0uS&NtwJ6WYsxmVGf%H865dDJ80^Q8K;*!Li99_3E
z4^QI&{o>S;(t?uw{G4KBW<hF!iIHguD259vgFx;Erx7lY6BwBp1sVAnB^kjP5#&CQ
zTfyNU3JNF&h7v|l25DwuD3SnW$65x4JWG&Z7864jI2|@KG87pzq_8l6q~xGdDXa|H
zObkWd3@L12ad4KZWdOxvFgOZ|)fpHVf>KLLi}Dl_lah*3%Q6#7Qd1N%a|?1(b5rw5
z5=%1k^Az$Db5r$71Q{3@3MvaK<I7TuiZk=`;xqHo@=HJwT2KHE>a4`FL@+<A5**mc
zIhkN?W&xN=F3<qQ8#q=o5{nZ{N{YbBiYtr3v0IRnSOSX65>S{Fmn0UI6oc{#B=Ld*
zte_I)u7QoY5?*LB1qBx<Pv*#hQn3Ii8kzVRIT?i*IT`sGIhoiHkqPoOI5J%zk(mO{
zAdq<ADOLhSRx<-AT0xQJ04hMTm>5c!8A@0fN?1XqN;4BEM}cA%8h0QQi$NAc;|>%q
zNbv=YAiWZhvydVzFFz%}BnTu}0&=egC{V#kF-RKZGLWfR`I&j(SjkN+0Mo@KMJ1r}
zB0aSP>|K=Dhr|siYl2(=k{aOH;eo~u%sJYi$N{;Jfr*Dvj8P5}DIm|obC@^C>kOb^
zPGJOR7kyBKWHEsvM6!etl)tiAz(ULnS*#3c%nZRGQG`4bD8?kym>7anSQvseKt*S9
zAR=ECR~G9*BLtjdbaOJZQx!@|3vyBw((;QGN{dq!GV>HtQj?3oQJ9&Ru27PZs*szR
zmtVxCprD`t)vX7PIdJs=F5>+l@dt{!AaRf<K%R%H1=|z^sy|9V?#WHe$}fVjK&B!h
z3CtRh5>SzWfx#FaJIwq{!i>C3;PMY8c0h$>3L`@nxCm@!U?^b%#Z)sBv_dJiW?*0d
z2NEPF6oZ2<BrzQvv?Upt#R|m*smYmXnaOB{njTnJF(}Pf*H+hRfYL({sN@0Xg&<{6
z6$x?)IE28&Km=0>C{E#7uOu<u4isddGM9lR8RT|Q?1G#QE?=BLsQ_F=G&3^PvM|)J
zfD&;w2SbqsLk%-Sks&DfK=lP9s0sj8&v^{s>Y9NexQ2zHh6$AZgTX;joX)_&5L%q7
zkf@NBn3I!~n4GPUn_7~Qp8^iql+=>cqTEbSZLARN@95;Ikd~8}UaXLr29AKd)YO#J
z6a`3C4i4zD#3F^vVujMY;?xoaP^!;MEKAJHNleN~)hh;h${E}WP$)|*$^;22sH+yM
z!*%E=1XPw}<mV}XY${1iSIAAQR7e8lo8<hWqSWLPKXBCoDa$}X76ht9!3jPkHK{Zm
zoGF7qMK`#nf%yo`Nv$YIO)g1I3E~8W9w;o!5_7;24kiX9)<Go}DAqxN3TlBBgBnK+
z%sh-djBJdYj9iTDkb(>p`yjQ<pr%?PBLk?N2CrR87(rR36PzA+iWnI?z;#RtGeZUw
zLpB>j5hG&>xSB~}0kzbM7#UMo8EP3BKqM2G1lK^2c6bW|Lkb52#Dr`nhGr(lqB2n9
zyOxn5j{#IsrEoE{Gccqvg4*A0n2HyJn&Y)hFvYykws;CZsPT<#a{eh$otFh_JTetM
zg0hPqftu#E%pmP4LLg_9u!H<o!w5>VHOvfYtPEncEDU)upmbeiz*xh;ki`LNyn~uW
z28=08An`0tP%FNfks(EtK~fx~To)u<6b@F-#gHP#kRlEWiYzXWLI@kAjEx~h0-BwI
zH6%e9FalA$gNkZcs!U2OPEAqB&x2+Ojm$I!cq-QfrTWy|(i~7{0GwsO`9i}PnzD^R
zX*{4(QxBYK!3u&v^)9&32RDgw6DvydGL!RDQiEhcNfi|F0hRGCu1=xuC<SLQC^di+
zJGj&YB?wq~=?88Sq^FjY<d-Do6s4vm=a=S{fZNAGprRIBk$}@Zf*7zIV3U)Wo0O7h
z7Yzz>P+1JgqM)pu0&a(edxm(#2SoZh`uO-e!-D`+Itqh=fQx|vlvW_sI<x}<4pW5R
zAPpE$K?-UyfW-&GyFrEw3=HuwZ<c_3m<#Ux1ysg|`guD0yST;&dq%mU_z^jpv%vj>
zY<M(h{{Jt)0Et#m(;!H1a8zete}X(w4317M1_p*qP~d}oTv`l@Fx6rhECwa;<N|QP
zuM1Y83vTy-nR;L{-cJKu+JhUi;D!)95eMmj@+hb{2RCB_B8|XxdJri8g0on0K~81~
zxHD3eT9A{NoEii&3S3h_<nt4gGJ`;U_#jh|QRbjL2Qn`)DHEJfz-cGQ1Qcrn(1k1k
z_4+||L}F5Ad`V(DsKr@q0SZ=T9!5?^4MsL71b0Um*%<jj-4by1!Nv%xNH`fe8RZ#8
z8KoH67!_gN6_9>V{sA{9phXClwDrFpk+#4=n44HpoLPm`s|JVAKx8FwH#I)9IKHSf
z57az~H#SPjECHoA@Yn+bqT&Q4Jg`46gJKpuzyT>Lin_qfeQ--Nh8fgzu4QDXWdc<e
zpvDuVGsX<6dQzA{EvBMCPz~73z)%zj?twEg<jH|$A>HqMm~1|{9}cbrQ`kX$i5g~5
zttttkI2j~sm>8NtoeMUGEOt=!)y%*Es<N0sV_VHkU^X|D4Q<=;fNehyGygnjs0&nK
zF@Rcr!5W}OL$LuU?LvC^`K3h)uue9(Pp_a}o|$KCq^_f&o|BnZS`lAiVHR&@q7EKb
zNl7d!&&&(51O*N#e?jEH9sNvW3o~#YDJV!bGXdwXf`a5?P<JCYF*(1uBEGs7f)Krx
zAS;kVKnWDwrbV_7T)RO8GR-W^G`K)2!NryY$a2sqP;O!}sCOA;1CjzYbHPpZ5>S&Z
zC9}Asv?MbJGAaaOfh_=K4VY(xY(d2zsIdf2tVO9gsfop@U>AV}aubs?GV@Zw#(|3k
zkX_(FC`v6Z%_#vVW-u`jDLTj(G};9!W<bHgz{JlY%E-?o%E-wm%E-wi&8*HS%FGGr
zI)N$<P+WnNbpj~xU>(~OCUCQlouNn)l(>T{WkJ2x6b6PICQt$|VFsse7SK3DaCn|L
z14{`jLkSy08f28upMjB)F^`cUq6C~WQ&>RlLvSYyWSd`*2Pj%RL8UpU0LcWEAeo@x
z)&NBi*!|$-;+B|GoC=QZ_}s+2N^q2e6I4=uehzq)0WNG9p9~!u%}E6pb)MkiPsmsx
zC}BI6loVwqm6oJ}g@Qnt8EisEVp%GZ-gxkcC#0wj2BiX!0|zWBOF%K0S&Z;KvNtD!
zq8Kzd!@wlU$imFb$ipbeD9psdoD8aUK*0&B5Sc+On|+{R4hDu=W>BNMoe>mGDU1wl
z3=Ex+E&vm#8J-4i#i#IqW!XVx14x7u)bvhcVn_$abtfaJg;WFX1wzW7qAXBX5j5Bf
zF6S8Y7#J!X7&;gkTw*Q2jbJ7ar-p?=64Zw%MAFUzD!z&eVcNmwGZq#y6c#ds*D!;|
zk5jln>5H+3nITvMR9F;ugVGJ8a7t9j$t*5W$WK!!E-e6!bf=~$Bo-xSq!ue^WacI3
zl%{|NM$(J&OADalnxLL2xDgF%gQsVfrRFJs2Rd{hV<+GtcWBlIYsoB0O)e=dN(EVx
zsF0hO>>mswL0KO%8UPMxP)Y&?Hn<77j)4JOl0!y@WI&mu1`^yH4B3nf!8J^v5+5{f
zXMrTg2`ZPta*!Gz1WAsIA)6JVj~%3{r~pZh8z$Gm2=1Y+VyMsthc**~q)V&}D84(u
z-8oRlhZ!8)?Vv7SaA7+`IH(`S$Pf%}5cvhUgEAwiAO+{cAU9AzgL;zS=2j4BAQD`I
zXTp`>=7ItQn=Clzh7^^i1_gmK7D!o;D##u+P{9M@g5nRH@zX&puo>WC`gmv*7srFd
z!38ZiVv7eXV+O@CFfgnDWk4xV0U^f2D8Pt{1sR1Hxk2+B3=C<BB|)ID1P3zMf0=nD
zsX5?K1#{C9OUz8bVGiRO8-XjA(!5O209|4ZI4r<}PoTQA7?i;a3X&nBpduAg*}@fI
zNPrS3xblSz)?m?sVrCGiL<Wa*VnIP_UJAICi-@cse^88p3<1SQYH?5uC_+I20k#+%
zI6-ls&>4t^E@<8XRGUK@B;X{ITD%D48X1riS=g9_RG1k-%~?)HA!Z>)0VZBXB}Ne@
zUZ!MFFo7Bppe6*kPJGMEz>v<sP|FI+btx<ips}%1un4%T+|0mG%f?Uxp1oA4WoM{x
z2aT9P_>!QRPexFtbBWbqsO12e0BH__hKIqmWeqz+4F_ltL>w|=-^|FsSm*@Knl;P}
z1&s`lVT)R3u#KFcR$9R{h7u0YSO%m?SF{Nvn9j&h!wIgRnHjV}`I-}~f(tCf!jQwo
zP|M9w;muIP&5*?nl5&Z)WvJz0sNn&rkj&x%SI>+LMOPSVxEQi{;SzkH7HA4PXpkd?
zgFzDPzAFrcR~W);I2p3|8A=2gN(4cAn!!^PAbF4kGiay>%wc3GHe;?~Vkq!sED-|P
zT+7Q)!^;4&5nQ$xi7=H2Gh~T?1VLkvd<->w3`HDFHGB+Nq9FA#EDW{$47Kc_0IU@N
zRa04F3^n`=HDE{83W7sMh@m2jp+p=M_9YUaAO#KDa4?8NT;&q$z)&m9P+`tcBFO-f
zX9v|PHNp%v0+85|WvCTls1X8<+}8*)fFwjfb)Xo?2Zaw9!wU~Gh8OxW)$lT;Gcwc)
zfu_=+<v0gJkqc9a6v&}PE+7S2(x8E>6kbq>fz&gB)pLTp2hm&M42mk3SZh$-SYZUR
z)+JVp0Te8(AP1!If$GB=25`irF)@gN##wnmvj||<Br=5;hA@R!WPwss3I~I{OKcoN
zttdl{C<A0{ECVuDw~HwNR1w>Q;>IP`9Bi2$#4<Gu%S6GxMYZT0Q+VM)rtrdfOyL#A
z5RDp08U?}jGc!o0Ff&MsrGPz{#taHq#zJ;xP~B34-8(6qpviKmQY>mf=7GG8qOKx^
zp#)r)HiMcKVGJ=$47FllZ$m5*1o=OWkpbk86d_n()rf%t5meXqGed0xD+F1As<N=3
zxv-x(yoQw_SVI_8P$V-Ura7^+GeEPlpvHtkYGQH*Y`O(DaR8bQ%>y?x5<q2lW`16A
zf*u!Gz^WjzC@~kNq1Z|RsS#6B1ZuCqbm)NE9H3?jXo6EATFKa0Nk>7+*hnc>2W%2(
znkT<V0W?{yrx22ns*sjhR9pfxS)n{LCkHg%omgC4nwy%UP?8U8B`JV9b&gJ+kOmCY
zL9l+071R%v;6eG+ip1m+L<g`kzf_?-F|S0SEHNiD1?~!1Sm=PpD<SUjOanVi2Ru~;
z@<dL4a$=4GXx=t87j7Vm3qYf3*lY)hgJ-!Q6U!940aWo86%>JHBf#@JD2_->%Eab|
z#H36Gs#=_wlnJpn^Z)<<|G|T^;C`<kxc=4y4I_bi(U5KtsEY<}IpyW&rGl$uNSC>o
zn}LA=(rs4Fj8`oNw;UinBv2a-(J=xW3K}B=PpTUmLMQ{Ua6zSNF}ORPm{+L*8YBjf
zX$67i+Q8-&CFZ542Bm-+Y2evoc@RqhM1Tj+96-$gP+O!pwFGQTW^MtzGhJMomX=wO
zS_~OM1F1?(Ndb4r!M;eXC`rvr0W*v9i%L>cz@7xP=^_0;UeE|9XlMY`#E36QECD+x
zH?br+1KhNLbm&1noT5}vu1QUSxFD}2C=KMmNDu+)$AcSEsd=Tj;B_?`pz0kwj|0*K
z%A8;)<mH2`2?BMuf<Pm5LG~c8fqJ9Rre|tOkP65|v<7QZCM4h!lQNBqg9<>JK+PhE
z--AE{(Lv=PK~U=!v?>DJHBC$|DNW1)H%!28E-A<fN(C7X8aD)wQzn9k8K5o%i$I4E
zK@FIJ7*hZbpMx4z@Zh))Dkn2Q?%`u&hE6jv$ujCP@iVb8@iVe93Nvvs@-PZB3Nvaj
zNiy*=fkza<G7^kJjBJd`jPi_1%sh;ujM7Y;%)E@ej5^GMOhSw-j1V?2qb9Qovj(#y
zqbws2qbidIXo?jaF7fdx`N{F|kb!~tv{FzXEj}L9sbBzi7vLj2dZ5vrAkc(8czzEY
zz2M|ulnS1>2m-bDf<S2q952cFIXS7xpcO2|hz2kyofhQ<fzmHHr$R;!Kn+CDfJ0_Z
zYET&{>OirMm<a~wpdj#KnJADfcx)MzTY|u2QJ?{uAaDW&CsoimGPq9^)DB83LZGe~
z%7PlucrCcAgCGVZ5r9I<CO1E&G$+*#6d=W*tir}9zy#^~fJTWySbzxx`I$L6IC(ia
YIJr65`FS{%I9WKQI0ZRvIT`um0V1gpd;kCd

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/py27compat.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/py27compat.py
new file mode 100644
index 0000000..2985011
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/py27compat.py
@@ -0,0 +1,28 @@
+"""
+Compatibility Support for Python 2.7 and earlier
+"""
+
+import platform
+
+from setuptools.extern import six
+
+
+def get_all_headers(message, key):
+    """
+    Given an HTTPMessage, return all headers matching a given key.
+    """
+    return message.get_all(key)
+
+
+if six.PY2:
+    def get_all_headers(message, key):
+        return message.getheaders(key)
+
+
+linux_py2_ascii = (
+    platform.system() == 'Linux' and
+    six.PY2
+)
+
+rmtree_safe = str if linux_py2_ascii else lambda x: x
+"""Workaround for http://bugs.python.org/issue24672"""
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/py27compat.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/py27compat.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..145e44c9f448e02a04f47bfe851508a33740b482
GIT binary patch
literal 1261
zcmZSn%**AGdLky70ScHH7#JKF7#NC67#J8*7#N}$7*ZG+QkWQW7#X4%!E9!R943Zb
zW`-zc2F4T?h86~fC>DlPW`-<Qh9U=s6jrE69s@%vBSRJ&Lo)+I3L8T<6GMIkR9O@|
zLn=E%Q945^2SXkkLkc@s3n$2$U=0qC?M4g?3|!9nxdn+OnMs*BnI)A9!KDQS`9&oP
zY57G80hJ{g`FRRPdgcm=c_|91iA6b?sYP6w|NsC0@2A1Yz`#(#3^FFOA{pc%7<LAU
z@iH(l)G#n)F)-9HGBh(X1cTKVdw^_IP*6~C&n!#LQ%KBH@CXSB@J%f)PE1eLQ7B3+
zDJ{xVNX*Gm$Vg30Ni8Z?$W1Is&dAJ5S4dPy2kXgBt<>WJ838u2gq?wbAw9JuJ~1ap
z1LOj*KrX~Uu=BE0D>XpD4kn8885kJ!3yLz!5=&C`%My$9)ADmb_UI?2=$9uY<>i{@
z78@BRnWtB!TbNpu=VVox8Gt}~o_>gaL1uw&W?pegVor{(TbYNaae#htYDsB9Nq&A#
zF*38D(#Sj+9Iko=l_mTLC&oj)#RUo@kaHPWhz&bvh=X*dr<Op?0ed+JWKa+&D!_gO
z69eJVAQlD&1|hi57)w|g7#Msq^GYj{L5T&1!RZ5}w1xqiEd0PuhQudGRRx3(inW38
zM+qo%*yJSUCZ#0WNrU_Ya)|~g<iV*cK0YNsIX)h&tRN?`BrU%vw?q)64xSkFQY%VQ
zi}Hd%8o|K=PKp7MMkQ<@b(O^>skz{Ekpl{z_<~BK_{8Gm%uKMd;*z2gZUzR1qTG_A
x)YSOm#I#gIfPh&87b>~=DWy57cA&&o42o(tCLSgMW=?iaMjlonMowl?MgTLSImrM3

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/py31compat.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/py31compat.py
new file mode 100644
index 0000000..e1da7ee
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/py31compat.py
@@ -0,0 +1,32 @@
+__all__ = []
+
+__metaclass__ = type
+
+
+try:
+    # Python >=3.2
+    from tempfile import TemporaryDirectory
+except ImportError:
+    import shutil
+    import tempfile
+
+    class TemporaryDirectory:
+        """
+        Very simple temporary directory context manager.
+        Will try to delete afterward, but will also ignore OS and similar
+        errors on deletion.
+        """
+
+        def __init__(self, **kwargs):
+            self.name = None  # Handle mkdtemp raising an exception
+            self.name = tempfile.mkdtemp(**kwargs)
+
+        def __enter__(self):
+            return self.name
+
+        def __exit__(self, exctype, excvalue, exctrace):
+            try:
+                shutil.rmtree(self.name, True)
+            except OSError:  # removal errors are not the only possible
+                pass
+            self.name = None
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/py31compat.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/py31compat.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..38c8538959b8a20d3f18172801c4d02b8ee163fa
GIT binary patch
literal 1712
zcmZSn%**AGdLky70SZ_d7#JKF7#NB{BIyhaQ49>Jj0{ms43#1bDGUrLj0`!<47n@}
zQ7jCM;dwR;EUByv*<1`oaSV)%j35O}3^{BJQEXtvOd!Qk%nT{a3@NM(DJ%>v3=GW-
z43SYR40((U5h+Xz!5VA~3=En7|NsB5!N|bCP$I;@zz~v}TaaIrSXAkfS(KVwl3!Hm
z7X)%1$VniY0i@Ci<VZ~h28L7yhA2jmbx}+p=d~~}fNW#}*%ieCvKl19$`BN+!2;5<
zf`Ng7O92YPQj01TiZgQya#9saV74lxz^qkB&d)1Jtte5*P0UM7Pc71eYYflK$x$dN
zs#GY+S4c_CNi9iLNK7k9Eh<keO3_hBDlJhc2dPNRDb82OOwY?NN>%U=R!GcC0oj(B
zlUM{dDYd95zo=LtKM!I~W_}*RmSm7enHU%tK-e4PdU*y0kXLIM7~&ZjN|+e3m>Fsq
z8G0EQAR;LY48h=V^aFdg1mt7C{Jc~!BQG&GwS)r{$f>ynX_+~xCF~3g47u4UAfIc1
ztN<%3PR&Ux0mVvod16s|u?8r_!9;OB0|SG8K~ZK|Vo9ogSz?iXT7FJSYEiL%Qi^_g
zQc_;7X>PHRVUl@zRl0?#MR`tEm6-tur03~}=oe%b=w{{>mn7!o=(?48cp3-j7pIn#
z7L?@Y=M*C|3o4Bblk;;65=-<7D#7lJkI&4@EQya70fhj_OAL&hjNq^Vg%1cjgJeLy
zsbOHqLWBWGDhT8;aF_&v(l*#9U}8YL!^yzF5FekKSCU#3A1?uNHOP4kjL9HxfiTF8
zVBc6UFfde#Gn6neWHEwbH;aj(gqfk436$*w8CXhKz}Zd<l<mNI36cbuK&b<k1VE7p
zj>+PT(vr*^FtaGPq$o8N94O$}4k;>yqyzt8S5Qg}0)-hk@qmL1oJ3M9l1nNJAZaJH
zBDpLvrxea9DN0OE1&1e?7?3~(rRn(i)Cy1<kp_h+7bwj#GBb)Z@-nh8f{PevLIUN1
z`1lf#g82B{{FKt1)cAO?C*$K&@{{A^gFvY$2xMZA00RR9*i#5%AiM`I`glR!0=bHf
zm5qs$g_9ZLCXi#Hu20O#iH`?IDLAe`8sg(~Q%e$)a}tY-<Ku&v85kJAW|eR=Ffe$6
qir5lJlyeRakAkDf1`;WDpk!Fg$H2hA#>B?V%p}6d%gDpX!vp}!D4O{I

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/py33compat.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/py33compat.py
new file mode 100644
index 0000000..87cf539
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/py33compat.py
@@ -0,0 +1,55 @@
+import dis
+import array
+import collections
+
+try:
+    import html
+except ImportError:
+    html = None
+
+from setuptools.extern import six
+from setuptools.extern.six.moves import html_parser
+
+__metaclass__ = type
+
+OpArg = collections.namedtuple('OpArg', 'opcode arg')
+
+
+class Bytecode_compat:
+    def __init__(self, code):
+        self.code = code
+
+    def __iter__(self):
+        """Yield '(op,arg)' pair for each operation in code object 'code'"""
+
+        bytes = array.array('b', self.code.co_code)
+        eof = len(self.code.co_code)
+
+        ptr = 0
+        extended_arg = 0
+
+        while ptr < eof:
+
+            op = bytes[ptr]
+
+            if op >= dis.HAVE_ARGUMENT:
+
+                arg = bytes[ptr + 1] + bytes[ptr + 2] * 256 + extended_arg
+                ptr += 3
+
+                if op == dis.EXTENDED_ARG:
+                    long_type = six.integer_types[-1]
+                    extended_arg = arg * long_type(65536)
+                    continue
+
+            else:
+                arg = None
+                ptr += 1
+
+            yield OpArg(op, arg)
+
+
+Bytecode = getattr(dis, 'Bytecode', Bytecode_compat)
+
+
+unescape = getattr(html, 'unescape', html_parser.HTMLParser().unescape)
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/py33compat.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/py33compat.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..788acd7b57c353098bbc2b3e7c7d45de78250f51
GIT binary patch
literal 1962
zcmZSn%**AGdLky70SZ_d7#JKF7#NCAF)%QsFfgPrGUPBYM8VmN3{i|QaVCZ+CWcA@
z7?+tLikTriPn>}zm4zXji=oJufsv6hg%Kp2$H))?GL4BLhm9eZogs>yff2-KX2{`S
z$mL{+;$&b<<zk59W=LgX$l_s0VPQyNWoTw%h~i~PVPi<)Vn|_UXklPzW?+bn;$ukV
zXGmpWNa0{e<zr}OW{461i!d{!a5AKFGGqyY)MW{QrG!9U2-e_cU|`7n|NsAgKMh6(
z28I%5kRLNEARLfnMoDf?d_iJSacWTsC=mP$9E;M6xfmE2@(YslQ&JTYi_%N@85kIx
zDoav90`bZDxdn+O@Q?!;>jW}Yih%*-I!HLRFn|Ing%RZVC}xJBU=1b)28Lu10mIH9
zO}q>Y3^j}lH4F^#;IIw`yA0}B7Lb<wlvJ?Z5)iLAH76|y#Lxi68<;50XJBB^FDS|^
zODsv%FH0=aPs`6qNi8bYPfF1*PfE(mHO(zHGE6d0uS&NtwJ6WYsxmVGf%H865dDJ8
z0^Q8K;*!Li99_3E4^QI&{o>S;(t?uw{G4KBW<jN~F~sM31(hWn3=9nM@tJv<CGqjX
zAb)^7#lV;h3Jj1O$cdm3Dt-zIbOwejaEhv7V8~)*$YKITa4jP!G7ut+47E%QDNGEt
z%wUp*p<)F?4KqUx6GJuwL(v0pATcvY*0M6xurideFl4bZWV139?T1RFFf)itf&!8m
zl!nA5Q&<^9#A{d>#B13=#-y+@nAbAHw6ZZ|GcgpMXDDH3$l?H{Fv(hWh8i}88g@|H
zYGz~*sbyg(v}7ne&yXhoN?cGwn8AjWaDmLJVFURhjIq#?Av}eXAy@;HWQy$=7#Jcm
zQ*%-j)HU)8bP|iwHPsag5;Kbw((;QGQWKLi6!HsFixNvR^Yauk^Atb{N+CZfD>b=9
zK^??VF98K%QYI*RGeOKuP{?L7FfuS?g3>NHEoU+?Ff#ao(>6HGCKeSXR)Uj72|GB+
z#Dk0ir}doFJTRS-SzH22YaWhauJMjR?xDV}ejz113=9me5h1RAF0L*h(IAkuV0D>!
zC8_DDMe!w-1*yg0r018Pml_0ej0PxzgFtx&Y<W^;Noq0Jj@0}#FkMhm1U5Ofq9iph
zB{d};l!ZV#^9#W8ATB2Z14B-JUOLzUa5@GP1DTjhQj6l_#XyN!0Tc|(5{yDjY>aG7
z{7hU-{7g!WTul6oyo>^joXl*DTud6EBo567d5O8H@$n^~6c8Vuo1apelNui%#KyqD
z5G2mPzyS6cf*1%t27%I!5Xf&JXR|SKGJ~BCE7QQ7(!A8-<ivthh)Y4aItWxi27#ix
z1jI_t&&f$m1|?lciU1XzU<uFMg8ZTq*P^2Qq99OFSt1Cs30{ooff7Pd9wc!|W0TS=
z&aBYO%`ZzW4g#flaC!r!JaAHskIzjlNlea3EG~uyGAO)LN=gfIAPExeIdIBPPc2C-
zDJcp96~*A_@Cfns2>=)FK_H7EUIWE0m^BbF0S;;#NFuQVdA1njSRO_mMjj?+Mgc}%
TMlL1+Mgb-^CLv~FB_U=2(dE1M

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/sandbox.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/sandbox.py
new file mode 100644
index 0000000..685f3f7
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/sandbox.py
@@ -0,0 +1,491 @@
+import os
+import sys
+import tempfile
+import operator
+import functools
+import itertools
+import re
+import contextlib
+import pickle
+import textwrap
+
+from setuptools.extern import six
+from setuptools.extern.six.moves import builtins, map
+
+import pkg_resources.py31compat
+
+if sys.platform.startswith('java'):
+    import org.python.modules.posix.PosixModule as _os
+else:
+    _os = sys.modules[os.name]
+try:
+    _file = file
+except NameError:
+    _file = None
+_open = open
+from distutils.errors import DistutilsError
+from pkg_resources import working_set
+
+
+__all__ = [
+    "AbstractSandbox", "DirectorySandbox", "SandboxViolation", "run_setup",
+]
+
+
+def _execfile(filename, globals, locals=None):
+    """
+    Python 3 implementation of execfile.
+    """
+    mode = 'rb'
+    with open(filename, mode) as stream:
+        script = stream.read()
+    if locals is None:
+        locals = globals
+    code = compile(script, filename, 'exec')
+    exec(code, globals, locals)
+
+
+@contextlib.contextmanager
+def save_argv(repl=None):
+    saved = sys.argv[:]
+    if repl is not None:
+        sys.argv[:] = repl
+    try:
+        yield saved
+    finally:
+        sys.argv[:] = saved
+
+
+@contextlib.contextmanager
+def save_path():
+    saved = sys.path[:]
+    try:
+        yield saved
+    finally:
+        sys.path[:] = saved
+
+
+@contextlib.contextmanager
+def override_temp(replacement):
+    """
+    Monkey-patch tempfile.tempdir with replacement, ensuring it exists
+    """
+    pkg_resources.py31compat.makedirs(replacement, exist_ok=True)
+
+    saved = tempfile.tempdir
+
+    tempfile.tempdir = replacement
+
+    try:
+        yield
+    finally:
+        tempfile.tempdir = saved
+
+
+@contextlib.contextmanager
+def pushd(target):
+    saved = os.getcwd()
+    os.chdir(target)
+    try:
+        yield saved
+    finally:
+        os.chdir(saved)
+
+
+class UnpickleableException(Exception):
+    """
+    An exception representing another Exception that could not be pickled.
+    """
+
+    @staticmethod
+    def dump(type, exc):
+        """
+        Always return a dumped (pickled) type and exc. If exc can't be pickled,
+        wrap it in UnpickleableException first.
+        """
+        try:
+            return pickle.dumps(type), pickle.dumps(exc)
+        except Exception:
+            # get UnpickleableException inside the sandbox
+            from setuptools.sandbox import UnpickleableException as cls
+            return cls.dump(cls, cls(repr(exc)))
+
+
+class ExceptionSaver:
+    """
+    A Context Manager that will save an exception, serialized, and restore it
+    later.
+    """
+
+    def __enter__(self):
+        return self
+
+    def __exit__(self, type, exc, tb):
+        if not exc:
+            return
+
+        # dump the exception
+        self._saved = UnpickleableException.dump(type, exc)
+        self._tb = tb
+
+        # suppress the exception
+        return True
+
+    def resume(self):
+        "restore and re-raise any exception"
+
+        if '_saved' not in vars(self):
+            return
+
+        type, exc = map(pickle.loads, self._saved)
+        six.reraise(type, exc, self._tb)
+
+
+@contextlib.contextmanager
+def save_modules():
+    """
+    Context in which imported modules are saved.
+
+    Translates exceptions internal to the context into the equivalent exception
+    outside the context.
+    """
+    saved = sys.modules.copy()
+    with ExceptionSaver() as saved_exc:
+        yield saved
+
+    sys.modules.update(saved)
+    # remove any modules imported since
+    del_modules = (
+        mod_name for mod_name in sys.modules
+        if mod_name not in saved
+        # exclude any encodings modules. See #285
+        and not mod_name.startswith('encodings.')
+    )
+    _clear_modules(del_modules)
+
+    saved_exc.resume()
+
+
+def _clear_modules(module_names):
+    for mod_name in list(module_names):
+        del sys.modules[mod_name]
+
+
+@contextlib.contextmanager
+def save_pkg_resources_state():
+    saved = pkg_resources.__getstate__()
+    try:
+        yield saved
+    finally:
+        pkg_resources.__setstate__(saved)
+
+
+@contextlib.contextmanager
+def setup_context(setup_dir):
+    temp_dir = os.path.join(setup_dir, 'temp')
+    with save_pkg_resources_state():
+        with save_modules():
+            hide_setuptools()
+            with save_path():
+                with save_argv():
+                    with override_temp(temp_dir):
+                        with pushd(setup_dir):
+                            # ensure setuptools commands are available
+                            __import__('setuptools')
+                            yield
+
+
+def _needs_hiding(mod_name):
+    """
+    >>> _needs_hiding('setuptools')
+    True
+    >>> _needs_hiding('pkg_resources')
+    True
+    >>> _needs_hiding('setuptools_plugin')
+    False
+    >>> _needs_hiding('setuptools.__init__')
+    True
+    >>> _needs_hiding('distutils')
+    True
+    >>> _needs_hiding('os')
+    False
+    >>> _needs_hiding('Cython')
+    True
+    """
+    pattern = re.compile(r'(setuptools|pkg_resources|distutils|Cython)(\.|$)')
+    return bool(pattern.match(mod_name))
+
+
+def hide_setuptools():
+    """
+    Remove references to setuptools' modules from sys.modules to allow the
+    invocation to import the most appropriate setuptools. This technique is
+    necessary to avoid issues such as #315 where setuptools upgrading itself
+    would fail to find a function declared in the metadata.
+    """
+    modules = filter(_needs_hiding, sys.modules)
+    _clear_modules(modules)
+
+
+def run_setup(setup_script, args):
+    """Run a distutils setup script, sandboxed in its directory"""
+    setup_dir = os.path.abspath(os.path.dirname(setup_script))
+    with setup_context(setup_dir):
+        try:
+            sys.argv[:] = [setup_script] + list(args)
+            sys.path.insert(0, setup_dir)
+            # reset to include setup dir, w/clean callback list
+            working_set.__init__()
+            working_set.callbacks.append(lambda dist: dist.activate())
+
+            # __file__ should be a byte string on Python 2 (#712)
+            dunder_file = (
+                setup_script
+                if isinstance(setup_script, str) else
+                setup_script.encode(sys.getfilesystemencoding())
+            )
+
+            with DirectorySandbox(setup_dir):
+                ns = dict(__file__=dunder_file, __name__='__main__')
+                _execfile(setup_script, ns)
+        except SystemExit as v:
+            if v.args and v.args[0]:
+                raise
+            # Normal exit, just return
+
+
+class AbstractSandbox:
+    """Wrap 'os' module and 'open()' builtin for virtualizing setup scripts"""
+
+    _active = False
+
+    def __init__(self):
+        self._attrs = [
+            name for name in dir(_os)
+            if not name.startswith('_') and hasattr(self, name)
+        ]
+
+    def _copy(self, source):
+        for name in self._attrs:
+            setattr(os, name, getattr(source, name))
+
+    def __enter__(self):
+        self._copy(self)
+        if _file:
+            builtins.file = self._file
+        builtins.open = self._open
+        self._active = True
+
+    def __exit__(self, exc_type, exc_value, traceback):
+        self._active = False
+        if _file:
+            builtins.file = _file
+        builtins.open = _open
+        self._copy(_os)
+
+    def run(self, func):
+        """Run 'func' under os sandboxing"""
+        with self:
+            return func()
+
+    def _mk_dual_path_wrapper(name):
+        original = getattr(_os, name)
+
+        def wrap(self, src, dst, *args, **kw):
+            if self._active:
+                src, dst = self._remap_pair(name, src, dst, *args, **kw)
+            return original(src, dst, *args, **kw)
+
+        return wrap
+
+    for name in ["rename", "link", "symlink"]:
+        if hasattr(_os, name):
+            locals()[name] = _mk_dual_path_wrapper(name)
+
+    def _mk_single_path_wrapper(name, original=None):
+        original = original or getattr(_os, name)
+
+        def wrap(self, path, *args, **kw):
+            if self._active:
+                path = self._remap_input(name, path, *args, **kw)
+            return original(path, *args, **kw)
+
+        return wrap
+
+    if _file:
+        _file = _mk_single_path_wrapper('file', _file)
+    _open = _mk_single_path_wrapper('open', _open)
+    for name in [
+        "stat", "listdir", "chdir", "open", "chmod", "chown", "mkdir",
+        "remove", "unlink", "rmdir", "utime", "lchown", "chroot", "lstat",
+        "startfile", "mkfifo", "mknod", "pathconf", "access"
+    ]:
+        if hasattr(_os, name):
+            locals()[name] = _mk_single_path_wrapper(name)
+
+    def _mk_single_with_return(name):
+        original = getattr(_os, name)
+
+        def wrap(self, path, *args, **kw):
+            if self._active:
+                path = self._remap_input(name, path, *args, **kw)
+                return self._remap_output(name, original(path, *args, **kw))
+            return original(path, *args, **kw)
+
+        return wrap
+
+    for name in ['readlink', 'tempnam']:
+        if hasattr(_os, name):
+            locals()[name] = _mk_single_with_return(name)
+
+    def _mk_query(name):
+        original = getattr(_os, name)
+
+        def wrap(self, *args, **kw):
+            retval = original(*args, **kw)
+            if self._active:
+                return self._remap_output(name, retval)
+            return retval
+
+        return wrap
+
+    for name in ['getcwd', 'tmpnam']:
+        if hasattr(_os, name):
+            locals()[name] = _mk_query(name)
+
+    def _validate_path(self, path):
+        """Called to remap or validate any path, whether input or output"""
+        return path
+
+    def _remap_input(self, operation, path, *args, **kw):
+        """Called for path inputs"""
+        return self._validate_path(path)
+
+    def _remap_output(self, operation, path):
+        """Called for path outputs"""
+        return self._validate_path(path)
+
+    def _remap_pair(self, operation, src, dst, *args, **kw):
+        """Called for path pairs like rename, link, and symlink operations"""
+        return (
+            self._remap_input(operation + '-from', src, *args, **kw),
+            self._remap_input(operation + '-to', dst, *args, **kw)
+        )
+
+
+if hasattr(os, 'devnull'):
+    _EXCEPTIONS = [os.devnull,]
+else:
+    _EXCEPTIONS = []
+
+
+class DirectorySandbox(AbstractSandbox):
+    """Restrict operations to a single subdirectory - pseudo-chroot"""
+
+    write_ops = dict.fromkeys([
+        "open", "chmod", "chown", "mkdir", "remove", "unlink", "rmdir",
+        "utime", "lchown", "chroot", "mkfifo", "mknod", "tempnam",
+    ])
+
+    _exception_patterns = [
+        # Allow lib2to3 to attempt to save a pickled grammar object (#121)
+        r'.*lib2to3.*\.pickle$',
+    ]
+    "exempt writing to paths that match the pattern"
+
+    def __init__(self, sandbox, exceptions=_EXCEPTIONS):
+        self._sandbox = os.path.normcase(os.path.realpath(sandbox))
+        self._prefix = os.path.join(self._sandbox, '')
+        self._exceptions = [
+            os.path.normcase(os.path.realpath(path))
+            for path in exceptions
+        ]
+        AbstractSandbox.__init__(self)
+
+    def _violation(self, operation, *args, **kw):
+        from setuptools.sandbox import SandboxViolation
+        raise SandboxViolation(operation, args, kw)
+
+    if _file:
+
+        def _file(self, path, mode='r', *args, **kw):
+            if mode not in ('r', 'rt', 'rb', 'rU', 'U') and not self._ok(path):
+                self._violation("file", path, mode, *args, **kw)
+            return _file(path, mode, *args, **kw)
+
+    def _open(self, path, mode='r', *args, **kw):
+        if mode not in ('r', 'rt', 'rb', 'rU', 'U') and not self._ok(path):
+            self._violation("open", path, mode, *args, **kw)
+        return _open(path, mode, *args, **kw)
+
+    def tmpnam(self):
+        self._violation("tmpnam")
+
+    def _ok(self, path):
+        active = self._active
+        try:
+            self._active = False
+            realpath = os.path.normcase(os.path.realpath(path))
+            return (
+                self._exempted(realpath)
+                or realpath == self._sandbox
+                or realpath.startswith(self._prefix)
+            )
+        finally:
+            self._active = active
+
+    def _exempted(self, filepath):
+        start_matches = (
+            filepath.startswith(exception)
+            for exception in self._exceptions
+        )
+        pattern_matches = (
+            re.match(pattern, filepath)
+            for pattern in self._exception_patterns
+        )
+        candidates = itertools.chain(start_matches, pattern_matches)
+        return any(candidates)
+
+    def _remap_input(self, operation, path, *args, **kw):
+        """Called for path inputs"""
+        if operation in self.write_ops and not self._ok(path):
+            self._violation(operation, os.path.realpath(path), *args, **kw)
+        return path
+
+    def _remap_pair(self, operation, src, dst, *args, **kw):
+        """Called for path pairs like rename, link, and symlink operations"""
+        if not self._ok(src) or not self._ok(dst):
+            self._violation(operation, src, dst, *args, **kw)
+        return (src, dst)
+
+    def open(self, file, flags, mode=0o777, *args, **kw):
+        """Called for low-level os.open()"""
+        if flags & WRITE_FLAGS and not self._ok(file):
+            self._violation("os.open", file, flags, mode, *args, **kw)
+        return _os.open(file, flags, mode, *args, **kw)
+
+
+WRITE_FLAGS = functools.reduce(
+    operator.or_, [getattr(_os, a, 0) for a in
+        "O_WRONLY O_RDWR O_APPEND O_CREAT O_TRUNC O_TEMPORARY".split()]
+)
+
+
+class SandboxViolation(DistutilsError):
+    """A setup script attempted to modify the filesystem outside the sandbox"""
+
+    tmpl = textwrap.dedent("""
+        SandboxViolation: {cmd}{args!r} {kwargs}
+
+        The package setup script has attempted to modify files on your system
+        that are not within the EasyInstall build area, and has been aborted.
+
+        This package cannot be safely installed by EasyInstall, and may not
+        support alternate installation locations even if you run its setup
+        script by hand.  Please inform the package's author and the EasyInstall
+        maintainers to find out if a fix or workaround is available.
+        """).lstrip()
+
+    def __str__(self):
+        cmd, args, kwargs = self.args
+        return self.tmpl.format(**locals())
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/sandbox.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/sandbox.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..a41f52e8e5bfcb96152e3b201324873741cedc49
GIT binary patch
literal 21826
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
aoT8lEoYKPO{EYleY|LU|Y>b?Y+AIJukpbKQ

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/script (dev).tmpl b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/script (dev).tmpl
new file mode 100644
index 0000000..39a24b0
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/script (dev).tmpl	
@@ -0,0 +1,6 @@
+# EASY-INSTALL-DEV-SCRIPT: %(spec)r,%(script_name)r
+__requires__ = %(spec)r
+__import__('pkg_resources').require(%(spec)r)
+__file__ = %(dev_path)r
+with open(__file__) as f:
+    exec(compile(f.read(), __file__, 'exec'))
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/script.tmpl b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/script.tmpl
new file mode 100644
index 0000000..ff5efbc
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/script.tmpl
@@ -0,0 +1,3 @@
+# EASY-INSTALL-SCRIPT: %(spec)r,%(script_name)r
+__requires__ = %(spec)r
+__import__('pkg_resources').run_script(%(spec)r, %(script_name)r)
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/site-patch.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/site-patch.py
new file mode 100644
index 0000000..40b00de
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/site-patch.py
@@ -0,0 +1,74 @@
+def __boot():
+    import sys
+    import os
+    PYTHONPATH = os.environ.get('PYTHONPATH')
+    if PYTHONPATH is None or (sys.platform == 'win32' and not PYTHONPATH):
+        PYTHONPATH = []
+    else:
+        PYTHONPATH = PYTHONPATH.split(os.pathsep)
+
+    pic = getattr(sys, 'path_importer_cache', {})
+    stdpath = sys.path[len(PYTHONPATH):]
+    mydir = os.path.dirname(__file__)
+
+    for item in stdpath:
+        if item == mydir or not item:
+            continue  # skip if current dir. on Windows, or my own directory
+        importer = pic.get(item)
+        if importer is not None:
+            loader = importer.find_module('site')
+            if loader is not None:
+                # This should actually reload the current module
+                loader.load_module('site')
+                break
+        else:
+            try:
+                import imp  # Avoid import loop in Python 3
+                stream, path, descr = imp.find_module('site', [item])
+            except ImportError:
+                continue
+            if stream is None:
+                continue
+            try:
+                # This should actually reload the current module
+                imp.load_module('site', stream, path, descr)
+            finally:
+                stream.close()
+            break
+    else:
+        raise ImportError("Couldn't find the real 'site' module")
+
+    known_paths = dict([(makepath(item)[1], 1) for item in sys.path])  # 2.2 comp
+
+    oldpos = getattr(sys, '__egginsert', 0)  # save old insertion position
+    sys.__egginsert = 0  # and reset the current one
+
+    for item in PYTHONPATH:
+        addsitedir(item)
+
+    sys.__egginsert += oldpos  # restore effective old position
+
+    d, nd = makepath(stdpath[0])
+    insert_at = None
+    new_path = []
+
+    for item in sys.path:
+        p, np = makepath(item)
+
+        if np == nd and insert_at is None:
+            # We've hit the first 'system' path entry, so added entries go here
+            insert_at = len(new_path)
+
+        if np in known_paths or insert_at is None:
+            new_path.append(item)
+        else:
+            # new path after the insert point, back-insert it
+            new_path.insert(insert_at, item)
+            insert_at += 1
+
+    sys.path[:] = new_path
+
+
+if __name__ == 'site':
+    __boot()
+    del __boot
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/site-patch.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/site-patch.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..3b68b72b8d9dd6fce29c1d2f7bb8641a4cee616f
GIT binary patch
literal 1847
zcmZSn%**AGdLky70ScHH7#JKF7#NDx7#J8*7#La@7@`;$QW+Ui7#Xse7>bk_QW+SU
z85kI&85r^y7*d!Rf;E^K7#P3?h%zuRurV+&ID-th!o&d5l)}J}!@y7rXEQR?GBVUK
zGGs9^WHE#EH#0KSGBMOJfo#j>U?}!ss9|8pVr58S23r^klHw@}Wk_cLsml`r@w3>#
zMzAwLG?#FI^rWybWHK-`Gc(jOgSc6o3?*D3#m$Ti^0h2r4V(;F+zcf=U~Q}n6@M9O
zSQuPlUozCPG1Raz)UbkVEM5v?^AsInC|nBiVhuCMp*3t^P3#Oc>|lp-G8FMK*03{V
z@iL^af~7bZYB*q0eT+363|V|oDaL@pKE}eO43&DY0O4n-<z%SggzBzgV@PLYXl7!F
zVP>f1VyNY2sO4b@&l6!_DG^}E=3*!cVq|0l8IZ@w5K+SgwuFPBC>1Qkz)&RxHVSN8
z4HrWVH$x2%Lo*8lV|WS!Lk$;0mLNF7A_5ARGK7~1Fr<LJ(!|J6A_NLlP-t^9xWvkU
zLZL($<oRYsh7@)N$rN^mG$w{PCWgY*jG%z#Wq<}W2SW-cIH37Jj2Z@pcoBvQ2~b$O
z#0r3o5rrDVSon!CyoP~+B};^%hL6FVDPDvDWCsgKqhvE9Lktr`Ek8r80LW9df*|+Q
z3NcjlKqJs4wh?R`%vB)O!VI+{3^gJQH3Fd6Dr#V=5d>+@=3pplU;@Rs5I8yn!Eq<T
zP{YfR&BjnX14-EmrWzrJEHStf9l?BYh8jVz5EBC<$Vheu^IAcMLPw_X8X>52G*TEC
zf;G4p7#RFA|NsC0zXZe#hz#-Y_X}_g@hD+sU|=ZE%riDB5oTauC`c^Hh|kO|$S*2M
zEs9T0OwLFxVFBfg%#ze%6;L+GFU?8GQ!i0S%gjqrD9K1wC`wJtQBW_=EJ;;Y$jwhF
z%}LE<WME(@;bvf9h>uTAPtVLNPAw|Q1Z7qY36KmZ?-f@Tmw@tZesKvq0|P^9URh>Q
zeqISkDm}FXY^Ps-UTO&k$Wb|oC29FZxnQ>z7vyA?fc1dfTAW${W~Zl?B$kvEf%SpJ
z!3O1|=7A+sGK=yOb0KEM$ERiHq{hdCod@zmJjBgleolU33XBhONoH;VSlkmFAg)D4
z`9)wiB<JK8L&7B`Gr0up#@xj0RFK6%pwI$`abijeC{R)|i%LM{OJYGmYF-MM2?-Dl
zP{|Vn3jQFFd=Mynz|JnnOa?o<xFiK+BG|^<N{~4qvolLlbHO&kVhL;{$mOX;K_Z~w
z1({Y{Qk0sQ8^j0VgRDqNElw^1`z1RszdSD<WN<N9XMRpfL4I)wD9Td6F_M>3!pXqE
z0C8k|BE)-nspVijV08r$bp;wACxeONd<F&v{eq&*vc!^9{j$U&{j~g?l+>bP{iGEA
z@}#7^T+`fQBf})~^s00VQ;YJPtSU1D5J=C{5795kEYQu&D=taQ$<cKy^YAnd&@WCc
zDJ>|;&(A4FVP=-3>J}uHBxmRqRDxX}AD@(;4|Y^>0?0LtJd8YyLX1j`oJ>MYLX5(U
zLQK4j!i;Q;{ER#x%*4yc&cw{f!>Gi_%gD~i!^p<S%p}Fc&B)5c!(_xH#K_6S%gD#X
z&m_jk#>mDbz$nBd!Nkub!6?8iz{tlG1WFZt8lZ$5qyq|DQ1XnA2c@p~cyLG{hye)`
Xkb7((DcTMcrNyAc!0FDz$j%4=9}A57

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/ssl_support.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/ssl_support.py
new file mode 100644
index 0000000..226db69
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/ssl_support.py
@@ -0,0 +1,260 @@
+import os
+import socket
+import atexit
+import re
+import functools
+
+from setuptools.extern.six.moves import urllib, http_client, map, filter
+
+from pkg_resources import ResolutionError, ExtractionError
+
+try:
+    import ssl
+except ImportError:
+    ssl = None
+
+__all__ = [
+    'VerifyingHTTPSHandler', 'find_ca_bundle', 'is_available', 'cert_paths',
+    'opener_for'
+]
+
+cert_paths = """
+/etc/pki/tls/certs/ca-bundle.crt
+/etc/ssl/certs/ca-certificates.crt
+/usr/share/ssl/certs/ca-bundle.crt
+/usr/local/share/certs/ca-root.crt
+/etc/ssl/cert.pem
+/System/Library/OpenSSL/certs/cert.pem
+/usr/local/share/certs/ca-root-nss.crt
+/etc/ssl/ca-bundle.pem
+""".strip().split()
+
+try:
+    HTTPSHandler = urllib.request.HTTPSHandler
+    HTTPSConnection = http_client.HTTPSConnection
+except AttributeError:
+    HTTPSHandler = HTTPSConnection = object
+
+is_available = ssl is not None and object not in (HTTPSHandler, HTTPSConnection)
+
+
+try:
+    from ssl import CertificateError, match_hostname
+except ImportError:
+    try:
+        from backports.ssl_match_hostname import CertificateError
+        from backports.ssl_match_hostname import match_hostname
+    except ImportError:
+        CertificateError = None
+        match_hostname = None
+
+if not CertificateError:
+
+    class CertificateError(ValueError):
+        pass
+
+
+if not match_hostname:
+
+    def _dnsname_match(dn, hostname, max_wildcards=1):
+        """Matching according to RFC 6125, section 6.4.3
+
+        https://tools.ietf.org/html/rfc6125#section-6.4.3
+        """
+        pats = []
+        if not dn:
+            return False
+
+        # Ported from python3-syntax:
+        # leftmost, *remainder = dn.split(r'.')
+        parts = dn.split(r'.')
+        leftmost = parts[0]
+        remainder = parts[1:]
+
+        wildcards = leftmost.count('*')
+        if wildcards > max_wildcards:
+            # Issue #17980: avoid denials of service by refusing more
+            # than one wildcard per fragment.  A survey of established
+            # policy among SSL implementations showed it to be a
+            # reasonable choice.
+            raise CertificateError(
+                "too many wildcards in certificate DNS name: " + repr(dn))
+
+        # speed up common case w/o wildcards
+        if not wildcards:
+            return dn.lower() == hostname.lower()
+
+        # RFC 6125, section 6.4.3, subitem 1.
+        # The client SHOULD NOT attempt to match a presented identifier in which
+        # the wildcard character comprises a label other than the left-most label.
+        if leftmost == '*':
+            # When '*' is a fragment by itself, it matches a non-empty dotless
+            # fragment.
+            pats.append('[^.]+')
+        elif leftmost.startswith('xn--') or hostname.startswith('xn--'):
+            # RFC 6125, section 6.4.3, subitem 3.
+            # The client SHOULD NOT attempt to match a presented identifier
+            # where the wildcard character is embedded within an A-label or
+            # U-label of an internationalized domain name.
+            pats.append(re.escape(leftmost))
+        else:
+            # Otherwise, '*' matches any dotless string, e.g. www*
+            pats.append(re.escape(leftmost).replace(r'\*', '[^.]*'))
+
+        # add the remaining fragments, ignore any wildcards
+        for frag in remainder:
+            pats.append(re.escape(frag))
+
+        pat = re.compile(r'\A' + r'\.'.join(pats) + r'\Z', re.IGNORECASE)
+        return pat.match(hostname)
+
+    def match_hostname(cert, hostname):
+        """Verify that *cert* (in decoded format as returned by
+        SSLSocket.getpeercert()) matches the *hostname*.  RFC 2818 and RFC 6125
+        rules are followed, but IP addresses are not accepted for *hostname*.
+
+        CertificateError is raised on failure. On success, the function
+        returns nothing.
+        """
+        if not cert:
+            raise ValueError("empty or no certificate")
+        dnsnames = []
+        san = cert.get('subjectAltName', ())
+        for key, value in san:
+            if key == 'DNS':
+                if _dnsname_match(value, hostname):
+                    return
+                dnsnames.append(value)
+        if not dnsnames:
+            # The subject is only checked when there is no dNSName entry
+            # in subjectAltName
+            for sub in cert.get('subject', ()):
+                for key, value in sub:
+                    # XXX according to RFC 2818, the most specific Common Name
+                    # must be used.
+                    if key == 'commonName':
+                        if _dnsname_match(value, hostname):
+                            return
+                        dnsnames.append(value)
+        if len(dnsnames) > 1:
+            raise CertificateError("hostname %r "
+                "doesn't match either of %s"
+                % (hostname, ', '.join(map(repr, dnsnames))))
+        elif len(dnsnames) == 1:
+            raise CertificateError("hostname %r "
+                "doesn't match %r"
+                % (hostname, dnsnames[0]))
+        else:
+            raise CertificateError("no appropriate commonName or "
+                "subjectAltName fields were found")
+
+
+class VerifyingHTTPSHandler(HTTPSHandler):
+    """Simple verifying handler: no auth, subclasses, timeouts, etc."""
+
+    def __init__(self, ca_bundle):
+        self.ca_bundle = ca_bundle
+        HTTPSHandler.__init__(self)
+
+    def https_open(self, req):
+        return self.do_open(
+            lambda host, **kw: VerifyingHTTPSConn(host, self.ca_bundle, **kw), req
+        )
+
+
+class VerifyingHTTPSConn(HTTPSConnection):
+    """Simple verifying connection: no auth, subclasses, timeouts, etc."""
+
+    def __init__(self, host, ca_bundle, **kw):
+        HTTPSConnection.__init__(self, host, **kw)
+        self.ca_bundle = ca_bundle
+
+    def connect(self):
+        sock = socket.create_connection(
+            (self.host, self.port), getattr(self, 'source_address', None)
+        )
+
+        # Handle the socket if a (proxy) tunnel is present
+        if hasattr(self, '_tunnel') and getattr(self, '_tunnel_host', None):
+            self.sock = sock
+            self._tunnel()
+            # http://bugs.python.org/issue7776: Python>=3.4.1 and >=2.7.7
+            # change self.host to mean the proxy server host when tunneling is
+            # being used. Adapt, since we are interested in the destination
+            # host for the match_hostname() comparison.
+            actual_host = self._tunnel_host
+        else:
+            actual_host = self.host
+
+        if hasattr(ssl, 'create_default_context'):
+            ctx = ssl.create_default_context(cafile=self.ca_bundle)
+            self.sock = ctx.wrap_socket(sock, server_hostname=actual_host)
+        else:
+            # This is for python < 2.7.9 and < 3.4?
+            self.sock = ssl.wrap_socket(
+                sock, cert_reqs=ssl.CERT_REQUIRED, ca_certs=self.ca_bundle
+            )
+        try:
+            match_hostname(self.sock.getpeercert(), actual_host)
+        except CertificateError:
+            self.sock.shutdown(socket.SHUT_RDWR)
+            self.sock.close()
+            raise
+
+
+def opener_for(ca_bundle=None):
+    """Get a urlopen() replacement that uses ca_bundle for verification"""
+    return urllib.request.build_opener(
+        VerifyingHTTPSHandler(ca_bundle or find_ca_bundle())
+    ).open
+
+
+# from jaraco.functools
+def once(func):
+    @functools.wraps(func)
+    def wrapper(*args, **kwargs):
+        if not hasattr(func, 'always_returns'):
+            func.always_returns = func(*args, **kwargs)
+        return func.always_returns
+    return wrapper
+
+
+@once
+def get_win_certfile():
+    try:
+        import wincertstore
+    except ImportError:
+        return None
+
+    class CertFile(wincertstore.CertFile):
+        def __init__(self):
+            super(CertFile, self).__init__()
+            atexit.register(self.close)
+
+        def close(self):
+            try:
+                super(CertFile, self).close()
+            except OSError:
+                pass
+
+    _wincerts = CertFile()
+    _wincerts.addstore('CA')
+    _wincerts.addstore('ROOT')
+    return _wincerts.name
+
+
+def find_ca_bundle():
+    """Return an existing CA bundle path, or None"""
+    extant_cert_paths = filter(os.path.isfile, cert_paths)
+    return (
+        get_win_certfile()
+        or next(extant_cert_paths, None)
+        or _certifi_where()
+    )
+
+
+def _certifi_where():
+    try:
+        return __import__('certifi').where()
+    except (ImportError, ResolutionError, ExtractionError):
+        pass
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/ssl_support.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/ssl_support.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..aa1bc4c74e4c62905dff706651aad6b0ec9179f2
GIT binary patch
literal 9597
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
I`6W2H0Cs-SJOBUy

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/unicode_utils.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/unicode_utils.py
new file mode 100644
index 0000000..7c63efd
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/unicode_utils.py
@@ -0,0 +1,44 @@
+import unicodedata
+import sys
+
+from setuptools.extern import six
+
+
+# HFS Plus uses decomposed UTF-8
+def decompose(path):
+    if isinstance(path, six.text_type):
+        return unicodedata.normalize('NFD', path)
+    try:
+        path = path.decode('utf-8')
+        path = unicodedata.normalize('NFD', path)
+        path = path.encode('utf-8')
+    except UnicodeError:
+        pass  # Not UTF-8
+    return path
+
+
+def filesys_decode(path):
+    """
+    Ensure that the given path is decoded,
+    NONE when no expected encoding works
+    """
+
+    if isinstance(path, six.text_type):
+        return path
+
+    fs_enc = sys.getfilesystemencoding() or 'utf-8'
+    candidates = fs_enc, 'utf-8'
+
+    for enc in candidates:
+        try:
+            return path.decode(enc)
+        except UnicodeDecodeError:
+            continue
+
+
+def try_encode(string, enc):
+    "turn unicode encoding into a functional routine"
+    try:
+        return string.encode(enc)
+    except UnicodeEncodeError:
+        return None
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/unicode_utils.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/unicode_utils.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..84705a2cc4f6289c0126596082232c8bfe6e34b6
GIT binary patch
literal 1688
zcmZSn%**AGdLky70ScHH7#JKF7#ND(85kH+7#LC*8FCmHqTp;shA2j`I1@t-6GJXD
zLliRuV+u1v3j;$G3quMEn8C`B!U|@vf%FG!urV+&Wd8sE|G%FGBLf3N2{Xuo%!*_X
z2ZUJ}7#N&EVtF8028J32h7v}GEGC9#CWay<koqhZkV!QRAd%oo6Of85R)!QNhGs^F
zTCj=8Dr&(-WU(O>gy#t|u#~VfWOFeTWil`_GUhQdMAR@a1Z#lY;s<t-pPNfD$R(vE
zX}T5~93ZD~fgE0(nO9trn3tRy1PY@PPLM=uMM-=~WkG5QHv<DhX<lY>eoAUeVo4%c
zHZQ*@H!&x(DzyaU@sw1MB$%0+2WIjxFffEd^tcuk<rhH$g@u8Ep&+p&Ljz<Bm?$n{
zU|`TMD9S8LEJ@WbODxh)%g;$kEh^SeO3^P*O3KSM%`G-EOfpZeO1ChzD9_2NGBW^y
z^gR6#{esK_U9ih@a&+CwJUop9^ovtVN()Nz^K*)knNa7)mzHGa6zdgKg8cw;b#6g^
zaVjVriiJRKViaN&U}R?GXB1)-X5?jLVFbq?$k`xog5$3c6gJ?%N5r2PD6)b}m>IHI
z7@8Rv3RFQcS<A>!!w6!eF)`FKF;ti_)G#r)#Og8BGBZ>Pf^=lDGSo1GqBl6a(3*jz
zgbf^b8KAf;v}P!@W{4=XW(ZGVf<|F+Bm)Bjmx6+Vf@@xJX;G>|Nk(FcLP<udLV9Ld
zYMufpWEC=t6+r$<NlnoKEA{jDb5$tMNX=8o%U4LPC`e5%Nlj4z$5Liqx<Yw=QFbv{
zAtGJ)X|OXeFa&|J2{<_ffzl5+`4m?cmxwYjFr=rJq-Ex$g1D)<FtdU{K~w??Mrg#l
zfKvq|`awY$1Wr~URcXcXsd>pIprn_an3s~7l30>j47MRPFBzOJz{Ef$4n7732B`ny
zA%Q6Z%DEt~F|Y|SvM>oT@-Xo-GBXM?@-ila!U=>y`3jsuv=|s*5zGKe0?mvJ!QpvA
z3@jy#;0RU)MQ{ouLvRF$&;aQz)(54k(xN;CXi7!IP-b39zCxlxT4`Q#NoIatVva&l
zerZW&UaB8BUk8EW3OUqW!5I)7>Ls91_sh>q1=|76p2a0anR)3!0t^fc;2;JQ0~OAo
z_%A7{1f_-ilvH(47=yAR0}~`<A;}QrhagZ9R3Zpc0MFifsTC!uMR|}E3Nk4OBp(Dy
mo?uTQh=KAR$S*dz`6;D2sdk_$pcv#z9!4G}0TxakPGJB|6_q&v

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/version.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/version.py
new file mode 100644
index 0000000..95e1869
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/version.py
@@ -0,0 +1,6 @@
+import pkg_resources
+
+try:
+    __version__ = pkg_resources.get_distribution('setuptools').version
+except Exception:
+    __version__ = 'unknown'
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/version.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/version.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..3885564807ab73866564859e197d1a8335135591
GIT binary patch
literal 376
zcmZSn%**AGdLky70SZ_d7#JKF7#NB{L<$2#3L`@f149%8L!}r)Dg#3nBSQ)kLo*{o
z7864hGedZuI0H*63qv*+Ly<KDBO_x9Ge|g(ks%_5ks(-vg@J(~^Z)<<|NTn1K!&E4
zlopia=jRlcurn|)l;&mU<(KDafb1;cWnf?^$WD(hN-fSWElN%;E)ig0U`S6biBHKa
zE-A`PDlN&(&jaf#OD!q}vAG!-7~<ohy!iMMP6h@B*NWuS0+31#kcSXNaSj6mgML9#
zW?5oMs(x8wk$zf!PD*M~v3^pDetA+-Uao0wv5{etd3sg4g{eh(PF9tf0SKh$>4)eS
zWESXV<`tJD=H%$Qm3ep?2j~~W{esMdI!3RcvV?<yfx#v>KczG$)s7M5d5{1P6EmY2
HBQGNWTYX`>

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/wheel.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/wheel.py
new file mode 100644
index 0000000..e11f0a1
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/wheel.py
@@ -0,0 +1,211 @@
+"""Wheels support."""
+
+from distutils.util import get_platform
+import email
+import itertools
+import os
+import posixpath
+import re
+import zipfile
+
+import pkg_resources
+import setuptools
+from pkg_resources import parse_version
+from setuptools.extern.packaging.utils import canonicalize_name
+from setuptools.extern.six import PY3
+from setuptools import pep425tags
+from setuptools.command.egg_info import write_requirements
+
+
+__metaclass__ = type
+
+
+WHEEL_NAME = re.compile(
+    r"""^(?P<project_name>.+?)-(?P<version>\d.*?)
+    ((-(?P<build>\d.*?))?-(?P<py_version>.+?)-(?P<abi>.+?)-(?P<platform>.+?)
+    )\.whl$""",
+    re.VERBOSE).match
+
+NAMESPACE_PACKAGE_INIT = '''\
+try:
+    __import__('pkg_resources').declare_namespace(__name__)
+except ImportError:
+    __path__ = __import__('pkgutil').extend_path(__path__, __name__)
+'''
+
+
+def unpack(src_dir, dst_dir):
+    '''Move everything under `src_dir` to `dst_dir`, and delete the former.'''
+    for dirpath, dirnames, filenames in os.walk(src_dir):
+        subdir = os.path.relpath(dirpath, src_dir)
+        for f in filenames:
+            src = os.path.join(dirpath, f)
+            dst = os.path.join(dst_dir, subdir, f)
+            os.renames(src, dst)
+        for n, d in reversed(list(enumerate(dirnames))):
+            src = os.path.join(dirpath, d)
+            dst = os.path.join(dst_dir, subdir, d)
+            if not os.path.exists(dst):
+                # Directory does not exist in destination,
+                # rename it and prune it from os.walk list.
+                os.renames(src, dst)
+                del dirnames[n]
+    # Cleanup.
+    for dirpath, dirnames, filenames in os.walk(src_dir, topdown=True):
+        assert not filenames
+        os.rmdir(dirpath)
+
+
+class Wheel:
+
+    def __init__(self, filename):
+        match = WHEEL_NAME(os.path.basename(filename))
+        if match is None:
+            raise ValueError('invalid wheel name: %r' % filename)
+        self.filename = filename
+        for k, v in match.groupdict().items():
+            setattr(self, k, v)
+
+    def tags(self):
+        '''List tags (py_version, abi, platform) supported by this wheel.'''
+        return itertools.product(
+            self.py_version.split('.'),
+            self.abi.split('.'),
+            self.platform.split('.'),
+        )
+
+    def is_compatible(self):
+        '''Is the wheel is compatible with the current platform?'''
+        supported_tags = pep425tags.get_supported()
+        return next((True for t in self.tags() if t in supported_tags), False)
+
+    def egg_name(self):
+        return pkg_resources.Distribution(
+            project_name=self.project_name, version=self.version,
+            platform=(None if self.platform == 'any' else get_platform()),
+        ).egg_name() + '.egg'
+
+    def get_dist_info(self, zf):
+        # find the correct name of the .dist-info dir in the wheel file
+        for member in zf.namelist():
+            dirname = posixpath.dirname(member)
+            if (dirname.endswith('.dist-info') and
+                    canonicalize_name(dirname).startswith(
+                        canonicalize_name(self.project_name))):
+                return dirname
+        raise ValueError("unsupported wheel format. .dist-info not found")
+
+    def install_as_egg(self, destination_eggdir):
+        '''Install wheel as an egg directory.'''
+        with zipfile.ZipFile(self.filename) as zf:
+            self._install_as_egg(destination_eggdir, zf)
+
+    def _install_as_egg(self, destination_eggdir, zf):
+        dist_basename = '%s-%s' % (self.project_name, self.version)
+        dist_info = self.get_dist_info(zf)
+        dist_data = '%s.data' % dist_basename
+        egg_info = os.path.join(destination_eggdir, 'EGG-INFO')
+
+        self._convert_metadata(zf, destination_eggdir, dist_info, egg_info)
+        self._move_data_entries(destination_eggdir, dist_data)
+        self._fix_namespace_packages(egg_info, destination_eggdir)
+
+    @staticmethod
+    def _convert_metadata(zf, destination_eggdir, dist_info, egg_info):
+        def get_metadata(name):
+            with zf.open(posixpath.join(dist_info, name)) as fp:
+                value = fp.read().decode('utf-8') if PY3 else fp.read()
+                return email.parser.Parser().parsestr(value)
+
+        wheel_metadata = get_metadata('WHEEL')
+        # Check wheel format version is supported.
+        wheel_version = parse_version(wheel_metadata.get('Wheel-Version'))
+        wheel_v1 = (
+            parse_version('1.0') <= wheel_version < parse_version('2.0dev0')
+        )
+        if not wheel_v1:
+            raise ValueError(
+                'unsupported wheel format version: %s' % wheel_version)
+        # Extract to target directory.
+        os.mkdir(destination_eggdir)
+        zf.extractall(destination_eggdir)
+        # Convert metadata.
+        dist_info = os.path.join(destination_eggdir, dist_info)
+        dist = pkg_resources.Distribution.from_location(
+            destination_eggdir, dist_info,
+            metadata=pkg_resources.PathMetadata(destination_eggdir, dist_info),
+        )
+
+        # Note: Evaluate and strip markers now,
+        # as it's difficult to convert back from the syntax:
+        # foobar; "linux" in sys_platform and extra == 'test'
+        def raw_req(req):
+            req.marker = None
+            return str(req)
+        install_requires = list(sorted(map(raw_req, dist.requires())))
+        extras_require = {
+            extra: sorted(
+                req
+                for req in map(raw_req, dist.requires((extra,)))
+                if req not in install_requires
+            )
+            for extra in dist.extras
+        }
+        os.rename(dist_info, egg_info)
+        os.rename(
+            os.path.join(egg_info, 'METADATA'),
+            os.path.join(egg_info, 'PKG-INFO'),
+        )
+        setup_dist = setuptools.Distribution(
+            attrs=dict(
+                install_requires=install_requires,
+                extras_require=extras_require,
+            ),
+        )
+        write_requirements(
+            setup_dist.get_command_obj('egg_info'),
+            None,
+            os.path.join(egg_info, 'requires.txt'),
+        )
+
+    @staticmethod
+    def _move_data_entries(destination_eggdir, dist_data):
+        """Move data entries to their correct location."""
+        dist_data = os.path.join(destination_eggdir, dist_data)
+        dist_data_scripts = os.path.join(dist_data, 'scripts')
+        if os.path.exists(dist_data_scripts):
+            egg_info_scripts = os.path.join(
+                destination_eggdir, 'EGG-INFO', 'scripts')
+            os.mkdir(egg_info_scripts)
+            for entry in os.listdir(dist_data_scripts):
+                # Remove bytecode, as it's not properly handled
+                # during easy_install scripts install phase.
+                if entry.endswith('.pyc'):
+                    os.unlink(os.path.join(dist_data_scripts, entry))
+                else:
+                    os.rename(
+                        os.path.join(dist_data_scripts, entry),
+                        os.path.join(egg_info_scripts, entry),
+                    )
+            os.rmdir(dist_data_scripts)
+        for subdir in filter(os.path.exists, (
+            os.path.join(dist_data, d)
+            for d in ('data', 'headers', 'purelib', 'platlib')
+        )):
+            unpack(subdir, destination_eggdir)
+        if os.path.exists(dist_data):
+            os.rmdir(dist_data)
+
+    @staticmethod
+    def _fix_namespace_packages(egg_info, destination_eggdir):
+        namespace_packages = os.path.join(
+            egg_info, 'namespace_packages.txt')
+        if os.path.exists(namespace_packages):
+            with open(namespace_packages) as fp:
+                namespace_packages = fp.read().split()
+            for mod in namespace_packages:
+                mod_dir = os.path.join(destination_eggdir, *mod.split('.'))
+                mod_init = os.path.join(mod_dir, '__init__.py')
+                if os.path.exists(mod_dir) and not os.path.exists(mod_init):
+                    with open(mod_init, 'w') as fp:
+                        fp.write(NAMESPACE_PACKAGE_INIT)
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/wheel.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/wheel.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..5756aa8411cb78abc6bf7c24dd1423497b78c8ee
GIT binary patch
literal 9864
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

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/windows_support.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/windows_support.py
new file mode 100644
index 0000000..cb977cf
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/windows_support.py
@@ -0,0 +1,29 @@
+import platform
+import ctypes
+
+
+def windows_only(func):
+    if platform.system() != 'Windows':
+        return lambda *args, **kwargs: None
+    return func
+
+
+@windows_only
+def hide_file(path):
+    """
+    Set the hidden attribute on a file or directory.
+
+    From http://stackoverflow.com/questions/19622133/
+
+    `path` must be text.
+    """
+    __import__('ctypes.wintypes')
+    SetFileAttributes = ctypes.windll.kernel32.SetFileAttributesW
+    SetFileAttributes.argtypes = ctypes.wintypes.LPWSTR, ctypes.wintypes.DWORD
+    SetFileAttributes.restype = ctypes.wintypes.BOOL
+
+    FILE_ATTRIBUTE_HIDDEN = 0x02
+
+    ret = SetFileAttributes(path, FILE_ATTRIBUTE_HIDDEN)
+    if not ret:
+        raise ctypes.WinError()
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/windows_support.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/setuptools/windows_support.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..9d8ae09b370457423eede2266b25460ed40a580f
GIT binary patch
literal 1490
zcmZSn%**AGdLky70ScHH7#JKF7#NC87#J8*7#LC*8FCmHqTp;shA2jc6efli28Jjm
zhEyho6lM^+nUNui8KgK^gN1>CA@l$L|Ns4x85tNDKp14GGssX`1_p)_28Jv~hGwwQ
z*~|<@l2GG<YZw@UHJBL~82n1u85kJCGxJjN%ZtG-0~r7^C>~@8$buA*T9AmJ28b*H
ziTUN{rD}jwf_aHW>BS{%3=9m}<sha8$bVp>xP*a$LBF6Vvn;VBRlh8;NIxw<CndG0
zSU)L6zdR`^FV{4;*vK%+JiRL2!qlQXC#%ZL00h$W^h5LuG7EGw^NLFnb8>Xu$~-)c
z1N4hiOG*n$^7C_wk(uQX=f@Y978K+cmFN{zmT)jIFxccI<|d^i+JSsn40aRP#UQDI
zoWzo}{Gwd2tBWg(OHy+Yo=YpuO9ne1ObnbKco-NMU|!45%c*1q#Rw>v85o5a*%`r6
z4vGv=Jc6UV5EA7nj10|;42&g=3|UMJS<DPsEDW`b3?MEmLlzs1!OoDz#8AV?5YGV<
z;RJKJKxw2FELFq6P{YK~%*0U3%uvJ3P@D@^$qh<SO^ghA44?!FNrc7S3=9lh3JMAe
z!Koz*B^jv-8JQ_5sd);CB_&0fNu?#J3i){oi3(|%IjIWyMG7gIMXAXp`9+m_Twq;p
zMftf386_nJR{HwIC5g$|`DLj^X*v1jddc~@`h}&b#U+{fdBysMmS#pqhQ`MF5N!zs
zi6t2c3c01lB??KY3MHu(C3;}<iuoBB7?MjW3sQ^q$}{u8j7(7M`)PnewS<d-fgwIV
zGZ&Ox;^V=o0HPYq1O<9d4mb^ErxxX<<`^552r)1)1gDm`W#*(h!u(Vm4psxR0Ib(1
zAUrrEs00*OF5&(`E?^ajMd@HCfOCtJzrPPS*A=A}gG9k9!ZY(+i;D7#z*!os4CJ*E
zL2R~`h%zuRxOw`x#yf_D1bI4zhPcLic)GZ_`jvo^LQ!f7IN^ecflIxd3=9kznJKC9
zpg89SC0zkf9^~X=<Y$y-<Y!`I;%8)I1p7A#6k0)`I0*t}&LBw!1_rR}5yZgx1LPu`
X-29Z%oK!nd`Bx0efjo>n%$#fh+bDPc

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/wheel-0.33.1.dist-info/INSTALLER b/tests/python/assert_test01/venv/lib/python2.7/site-packages/wheel-0.33.1.dist-info/INSTALLER
new file mode 100644
index 0000000..a1b589e
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/wheel-0.33.1.dist-info/INSTALLER
@@ -0,0 +1 @@
+pip
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/wheel-0.33.1.dist-info/LICENSE.txt b/tests/python/assert_test01/venv/lib/python2.7/site-packages/wheel-0.33.1.dist-info/LICENSE.txt
new file mode 100644
index 0000000..c3441e6
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/wheel-0.33.1.dist-info/LICENSE.txt
@@ -0,0 +1,22 @@
+"wheel" copyright (c) 2012-2014 Daniel Holth <dholth@fastmail.fm> and
+contributors.
+
+The MIT License
+
+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/tests/python/assert_test01/venv/lib/python2.7/site-packages/wheel-0.33.1.dist-info/METADATA b/tests/python/assert_test01/venv/lib/python2.7/site-packages/wheel-0.33.1.dist-info/METADATA
new file mode 100644
index 0000000..2354dd4
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/wheel-0.33.1.dist-info/METADATA
@@ -0,0 +1,60 @@
+Metadata-Version: 2.1
+Name: wheel
+Version: 0.33.1
+Summary: A built-package format for Python.
+Home-page: https://github.com/pypa/wheel
+Author: Daniel Holth
+Author-email: dholth@fastmail.fm
+Maintainer: Alex Grönholm
+Maintainer-email: alex.gronholm@nextday.fi
+License: MIT
+Project-URL: Issue Tracker, https://github.com/pypa/wheel/issues
+Project-URL: Documentation, https://wheel.readthedocs.io/
+Project-URL: Changelog, https://wheel.readthedocs.io/en/stable/news.html
+Keywords: wheel,packaging
+Platform: UNKNOWN
+Classifier: Development Status :: 5 - Production/Stable
+Classifier: Intended Audience :: Developers
+Classifier: Topic :: System :: Archiving :: Packaging
+Classifier: License :: OSI Approved :: MIT License
+Classifier: Programming Language :: Python
+Classifier: Programming Language :: Python :: 2
+Classifier: Programming Language :: Python :: 2.7
+Classifier: Programming Language :: Python :: 3
+Classifier: Programming Language :: Python :: 3.4
+Classifier: Programming Language :: Python :: 3.5
+Classifier: Programming Language :: Python :: 3.6
+Classifier: Programming Language :: Python :: 3.7
+Requires-Python: >=2.7, !=3.0.*, !=3.1.*, !=3.2.*, !=3.3.*
+Provides-Extra: test
+Requires-Dist: pytest (>=3.0.0) ; extra == 'test'
+Requires-Dist: pytest-cov ; extra == 'test'
+
+wheel
+=====
+
+This library is the reference implementation of the Python wheel packaging
+standard, as defined in `PEP 427`_.
+
+It has two different roles:
+
+#. A setuptools_ extension for building wheels that provides the
+   ``bdist_wheel`` setuptools command
+#. A command line tool for working with wheel files
+
+It should be noted that wheel is **not** intended to be used as a library, and
+as such there is no stable, public API.
+
+.. _PEP 427: https://www.python.org/dev/peps/pep-0427/
+.. _setuptools: https://pypi.org/project/setuptools/
+
+
+Code of Conduct
+---------------
+
+Everyone interacting in the wheel project's codebases, issue trackers, chat
+rooms, and mailing lists is expected to follow the `PyPA Code of Conduct`_.
+
+.. _PyPA Code of Conduct: https://www.pypa.io/en/latest/code-of-conduct/
+
+
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/wheel-0.33.1.dist-info/RECORD b/tests/python/assert_test01/venv/lib/python2.7/site-packages/wheel-0.33.1.dist-info/RECORD
new file mode 100644
index 0000000..44a3242
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/wheel-0.33.1.dist-info/RECORD
@@ -0,0 +1,32 @@
+../../../bin/wheel,sha256=_pUQGTIuZu5unOqqoJ10EQNpjX_QUfJfqoF_oo0tU4w,269
+wheel-0.33.1.dist-info/INSTALLER,sha256=zuuue4knoyJ-UwPPXg8fezS7VCrXJQrAP7zeNuwvFQg,4
+wheel-0.33.1.dist-info/LICENSE.txt,sha256=zKniDGrx_Pv2lAjzd3aShsvuvN7TNhAMm0o_NfvmNeQ,1125
+wheel-0.33.1.dist-info/METADATA,sha256=ZKo4q8P_vXXg-OGjDZGlaIf4gafusgkeCd6jDxbrJLA,2082
+wheel-0.33.1.dist-info/RECORD,,
+wheel-0.33.1.dist-info/WHEEL,sha256=HX-v9-noUkyUoxyZ1PMSuS7auUxDAR4VBdoYLqD0xws,110
+wheel-0.33.1.dist-info/entry_points.txt,sha256=N8HbYFST3yrNQYeB2wXWBEPUhFsEtKNRPaCFGJPyqyc,108
+wheel-0.33.1.dist-info/top_level.txt,sha256=HxSBIbgEstMPe4eFawhA66Mq-QYHMopXVoAncfjb_1c,6
+wheel/__init__.py,sha256=OyOAcqlvJaBEASYRGijJyAkY_HL_5HR3alvjO5BEwKg,96
+wheel/__init__.pyc,,
+wheel/__main__.py,sha256=lF-YLO4hdQmoWuh4eWZd8YL1U95RSdm76sNLBXa0vjE,417
+wheel/__main__.pyc,,
+wheel/bdist_wheel.py,sha256=x2beC81u8AzTNVLwD36EPkVX5AxAYs2q70N09BxvMN0,14756
+wheel/bdist_wheel.pyc,,
+wheel/cli/__init__.py,sha256=GWSoGUpRabTf8bk3FsNTPrc5Fsr8YOv2dX55iY2W7eY,2572
+wheel/cli/__init__.pyc,,
+wheel/cli/convert.py,sha256=me0l6G4gSw-EBVhzjSr7yWYWBp9spMz7mnXlyJTiXso,9497
+wheel/cli/convert.pyc,,
+wheel/cli/pack.py,sha256=vkvZc4-rRZyWiwc6sHjpqIjzwDRMEF5u3JUNU9NY_jA,2263
+wheel/cli/pack.pyc,,
+wheel/cli/unpack.py,sha256=0VWzT7U_xyenTPwEVavxqvdee93GPvAFHnR3Uu91aRc,673
+wheel/cli/unpack.pyc,,
+wheel/metadata.py,sha256=uBv2aOz4U2sERF834C8DeNo235drcsp3ypTzT7MTWEA,4699
+wheel/metadata.pyc,,
+wheel/pep425tags.py,sha256=Jdjbnq17kqwPRKJCMb2E1VccNgnC3H6iQL7VGaxkPao,5908
+wheel/pep425tags.pyc,,
+wheel/pkginfo.py,sha256=GR76kupQzn1x9sKDaXuE6B6FsZ4OkfRtG7pndlXPvQ4,1257
+wheel/pkginfo.pyc,,
+wheel/util.py,sha256=zwVIk-9qWVQLRMgkgQTMp4TRE4HY03-tCUxLrtCpsfU,924
+wheel/util.pyc,,
+wheel/wheelfile.py,sha256=U_13q1XpVt02704XXkFRzmUbz_0R9-GgNxMOZFP3tOs,7168
+wheel/wheelfile.pyc,,
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/wheel-0.33.1.dist-info/WHEEL b/tests/python/assert_test01/venv/lib/python2.7/site-packages/wheel-0.33.1.dist-info/WHEEL
new file mode 100644
index 0000000..c8240f0
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/wheel-0.33.1.dist-info/WHEEL
@@ -0,0 +1,6 @@
+Wheel-Version: 1.0
+Generator: bdist_wheel (0.33.1)
+Root-Is-Purelib: true
+Tag: py2-none-any
+Tag: py3-none-any
+
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/wheel-0.33.1.dist-info/entry_points.txt b/tests/python/assert_test01/venv/lib/python2.7/site-packages/wheel-0.33.1.dist-info/entry_points.txt
new file mode 100644
index 0000000..b27acad
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/wheel-0.33.1.dist-info/entry_points.txt
@@ -0,0 +1,6 @@
+[console_scripts]
+wheel = wheel.cli:main
+
+[distutils.commands]
+bdist_wheel = wheel.bdist_wheel:bdist_wheel
+
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/wheel-0.33.1.dist-info/top_level.txt b/tests/python/assert_test01/venv/lib/python2.7/site-packages/wheel-0.33.1.dist-info/top_level.txt
new file mode 100644
index 0000000..2309722
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/wheel-0.33.1.dist-info/top_level.txt
@@ -0,0 +1 @@
+wheel
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/wheel/__init__.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/wheel/__init__.py
new file mode 100644
index 0000000..745cefc
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/wheel/__init__.py
@@ -0,0 +1,2 @@
+# __variables__ with double-quoted values will be available in setup.py:
+__version__ = "0.33.1"
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/wheel/__init__.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/wheel/__init__.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..d7c4b89a4bba388854ca5ec426313e4cb4b522f3
GIT binary patch
literal 219
zcmZSn%**AGdLky70SXuy7#JKF7#NDV7#J8*7#N}$7*ZG+f;E^xVr&cy3<i3}#(IW+
z8X$!w+zbp1@$qG;Ma7x<dGYZYAVUyDG00T?f}+f_#FA9~vcw|&wEUcu)S_bjq!j(~
zq@=uD)7)Ys!zA<cs&orei}IYTDl-ERNYB#`(J#m>(9O&%E=kPE(RC~H@H7t4FV9F#
k&4H5f@tJv<CGqik1(hWn3=9l5x%nxjIjMGFhl1Pz0A!{##{d8T

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/wheel/__main__.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/wheel/__main__.py
new file mode 100644
index 0000000..b3773a2
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/wheel/__main__.py
@@ -0,0 +1,19 @@
+"""
+Wheel command line tool (enable python -m wheel syntax)
+"""
+
+import sys
+
+
+def main():  # needed for console script
+    if __package__ == '':
+        # To be able to run 'python wheel-0.9.whl/wheel':
+        import os.path
+        path = os.path.dirname(os.path.dirname(__file__))
+        sys.path[0:0] = [path]
+    import wheel.cli
+    sys.exit(wheel.cli.main())
+
+
+if __name__ == "__main__":
+    sys.exit(main())
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/wheel/__main__.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/wheel/__main__.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..02edf07955863a3cd00f3a73cf1c40def3ec1f51
GIT binary patch
literal 811
zcmZSn%**AGdLky70ScHH7#JKF7#ND}7#J8*7#N}$7*ZG+QkWQW7#X4%8B&-TS{N9j
zm>5!-8B$mnvY8l)tQb-m8M0UyQkfW<85o)w85r{zKpKKISV87kGB7Z3g=eIu<|riR
z=jJBnr6}ZN=A|l><mcxoXr$&PCgr3m6jYXE<mV~q<|>qfRTfv~l_XYZa%KMi|Np-q
z*m2AZ3=Av`3=Ga7LyH&~7)rn{1G&HlWL*ja$ceQK3^fc4SxgLB%m_va3&>f`j10Am
z3^j}l>5L2|tROWh%pm`0L!1lJ&&E*81eRlGs9|Er;$X<)g!w6jfgxA}WWQetD5Ss+
z%LK7BxIk{<W?*25k1t3}&Q45EjgK#3XJBB+FV-taEXgPV=>juAf+?9rd5O8HB^+Q4
zX_+}7)gZqWR~DCWGB7ZJ13)i1CljnMwIZ{m1SAa;$W6@5(*OySfMP1YI0(!Jg)~^B
z2G~g;q8Jov`UORqWr-!J`elhl`f2$&DXB%p`bjDJ<w;3-xu&_rMuth|=~d|#rWWNn
zSyg5RAdsG?AEIB7S)iMlS6q^qlcVca=HY1^pbs`5O2)^7+z}tIS5O%Q@;}Ho#XKNu
z8F`p^808qn7<m|>euSt5CkAk^#K))PC&$MJu`w_(fHgzafr2GIJ_uwK!WUo`y}SZ;
bh)r&ON@-529VlFjL5^W#;$i0G;$Z{;pNqNL

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/wheel/bdist_wheel.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/wheel/bdist_wheel.py
new file mode 100644
index 0000000..4f06d36
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/wheel/bdist_wheel.py
@@ -0,0 +1,372 @@
+"""
+Create a wheel (.whl) distribution.
+
+A wheel is a built archive format.
+"""
+
+import os
+import shutil
+import sys
+import re
+from email.generator import Generator
+from distutils.core import Command
+from distutils.sysconfig import get_python_version
+from distutils import log as logger
+from glob import iglob
+from shutil import rmtree
+from warnings import warn
+
+import pkg_resources
+
+from .pep425tags import get_abbr_impl, get_impl_ver, get_abi_tag, get_platform
+from .pkginfo import write_pkg_info
+from .metadata import pkginfo_to_metadata
+from .wheelfile import WheelFile
+from . import pep425tags
+from . import __version__ as wheel_version
+
+
+safe_name = pkg_resources.safe_name
+safe_version = pkg_resources.safe_version
+
+PY_LIMITED_API_PATTERN = r'cp3\d'
+
+
+def safer_name(name):
+    return safe_name(name).replace('-', '_')
+
+
+def safer_version(version):
+    return safe_version(version).replace('-', '_')
+
+
+class bdist_wheel(Command):
+
+    description = 'create a wheel distribution'
+
+    user_options = [('bdist-dir=', 'b',
+                     "temporary directory for creating the distribution"),
+                    ('plat-name=', 'p',
+                     "platform name to embed in generated filenames "
+                     "(default: %s)" % get_platform()),
+                    ('keep-temp', 'k',
+                     "keep the pseudo-installation tree around after " +
+                     "creating the distribution archive"),
+                    ('dist-dir=', 'd',
+                     "directory to put final built distributions in"),
+                    ('skip-build', None,
+                     "skip rebuilding everything (for testing/debugging)"),
+                    ('relative', None,
+                     "build the archive using relative paths"
+                     "(default: false)"),
+                    ('owner=', 'u',
+                     "Owner name used when creating a tar file"
+                     " [default: current user]"),
+                    ('group=', 'g',
+                     "Group name used when creating a tar file"
+                     " [default: current group]"),
+                    ('universal', None,
+                     "make a universal wheel"
+                     " (default: false)"),
+                    ('python-tag=', None,
+                     "Python implementation compatibility tag"
+                     " (default: py%s)" % get_impl_ver()[0]),
+                    ('build-number=', None,
+                     "Build number for this particular version. "
+                     "As specified in PEP-0427, this must start with a digit. "
+                     "[default: None]"),
+                    ('py-limited-api=', None,
+                     "Python tag (cp32|cp33|cpNN) for abi3 wheel tag"
+                     " (default: false)"),
+                    ]
+
+    boolean_options = ['keep-temp', 'skip-build', 'relative', 'universal']
+
+    def initialize_options(self):
+        self.bdist_dir = None
+        self.data_dir = None
+        self.plat_name = None
+        self.plat_tag = None
+        self.format = 'zip'
+        self.keep_temp = False
+        self.dist_dir = None
+        self.egginfo_dir = None
+        self.root_is_pure = None
+        self.skip_build = None
+        self.relative = False
+        self.owner = None
+        self.group = None
+        self.universal = False
+        self.python_tag = 'py' + get_impl_ver()[0]
+        self.build_number = None
+        self.py_limited_api = False
+        self.plat_name_supplied = False
+
+    def finalize_options(self):
+        if self.bdist_dir is None:
+            bdist_base = self.get_finalized_command('bdist').bdist_base
+            self.bdist_dir = os.path.join(bdist_base, 'wheel')
+
+        self.data_dir = self.wheel_dist_name + '.data'
+        self.plat_name_supplied = self.plat_name is not None
+
+        need_options = ('dist_dir', 'plat_name', 'skip_build')
+
+        self.set_undefined_options('bdist',
+                                   *zip(need_options, need_options))
+
+        self.root_is_pure = not (self.distribution.has_ext_modules()
+                                 or self.distribution.has_c_libraries())
+
+        if self.py_limited_api and not re.match(PY_LIMITED_API_PATTERN, self.py_limited_api):
+            raise ValueError("py-limited-api must match '%s'" % PY_LIMITED_API_PATTERN)
+
+        # Support legacy [wheel] section for setting universal
+        wheel = self.distribution.get_option_dict('wheel')
+        if 'universal' in wheel:
+            # please don't define this in your global configs
+            logger.warn('The [wheel] section is deprecated. Use [bdist_wheel] instead.')
+            val = wheel['universal'][1].strip()
+            if val.lower() in ('1', 'true', 'yes'):
+                self.universal = True
+
+        if self.build_number is not None and not self.build_number[:1].isdigit():
+            raise ValueError("Build tag (build-number) must start with a digit.")
+
+    @property
+    def wheel_dist_name(self):
+        """Return distribution full name with - replaced with _"""
+        components = (safer_name(self.distribution.get_name()),
+                      safer_version(self.distribution.get_version()))
+        if self.build_number:
+            components += (self.build_number,)
+        return '-'.join(components)
+
+    def get_tag(self):
+        # bdist sets self.plat_name if unset, we should only use it for purepy
+        # wheels if the user supplied it.
+        if self.plat_name_supplied:
+            plat_name = self.plat_name
+        elif self.root_is_pure:
+            plat_name = 'any'
+        else:
+            plat_name = self.plat_name or get_platform()
+            if plat_name in ('linux-x86_64', 'linux_x86_64') and sys.maxsize == 2147483647:
+                plat_name = 'linux_i686'
+        plat_name = plat_name.replace('-', '_').replace('.', '_')
+
+        if self.root_is_pure:
+            if self.universal:
+                impl = 'py2.py3'
+            else:
+                impl = self.python_tag
+            tag = (impl, 'none', plat_name)
+        else:
+            impl_name = get_abbr_impl()
+            impl_ver = get_impl_ver()
+            impl = impl_name + impl_ver
+            # We don't work on CPython 3.1, 3.0.
+            if self.py_limited_api and (impl_name + impl_ver).startswith('cp3'):
+                impl = self.py_limited_api
+                abi_tag = 'abi3'
+            else:
+                abi_tag = str(get_abi_tag()).lower()
+            tag = (impl, abi_tag, plat_name)
+            supported_tags = pep425tags.get_supported(
+                supplied_platform=plat_name if self.plat_name_supplied else None)
+            # XXX switch to this alternate implementation for non-pure:
+            if not self.py_limited_api:
+                assert tag == supported_tags[0], "%s != %s" % (tag, supported_tags[0])
+            assert tag in supported_tags, "would build wheel with unsupported tag {}".format(tag)
+        return tag
+
+    def run(self):
+        build_scripts = self.reinitialize_command('build_scripts')
+        build_scripts.executable = 'python'
+        build_scripts.force = True
+
+        build_ext = self.reinitialize_command('build_ext')
+        build_ext.inplace = False
+
+        if not self.skip_build:
+            self.run_command('build')
+
+        install = self.reinitialize_command('install',
+                                            reinit_subcommands=True)
+        install.root = self.bdist_dir
+        install.compile = False
+        install.skip_build = self.skip_build
+        install.warn_dir = False
+
+        # A wheel without setuptools scripts is more cross-platform.
+        # Use the (undocumented) `no_ep` option to setuptools'
+        # install_scripts command to avoid creating entry point scripts.
+        install_scripts = self.reinitialize_command('install_scripts')
+        install_scripts.no_ep = True
+
+        # Use a custom scheme for the archive, because we have to decide
+        # at installation time which scheme to use.
+        for key in ('headers', 'scripts', 'data', 'purelib', 'platlib'):
+            setattr(install,
+                    'install_' + key,
+                    os.path.join(self.data_dir, key))
+
+        basedir_observed = ''
+
+        if os.name == 'nt':
+            # win32 barfs if any of these are ''; could be '.'?
+            # (distutils.command.install:change_roots bug)
+            basedir_observed = os.path.normpath(os.path.join(self.data_dir, '..'))
+            self.install_libbase = self.install_lib = basedir_observed
+
+        setattr(install,
+                'install_purelib' if self.root_is_pure else 'install_platlib',
+                basedir_observed)
+
+        logger.info("installing to %s", self.bdist_dir)
+
+        self.run_command('install')
+
+        impl_tag, abi_tag, plat_tag = self.get_tag()
+        archive_basename = "{}-{}-{}-{}".format(self.wheel_dist_name, impl_tag, abi_tag, plat_tag)
+        if not self.relative:
+            archive_root = self.bdist_dir
+        else:
+            archive_root = os.path.join(
+                self.bdist_dir,
+                self._ensure_relative(install.install_base))
+
+        self.set_undefined_options('install_egg_info', ('target', 'egginfo_dir'))
+        distinfo_dirname = '{}-{}.dist-info'.format(
+            safer_name(self.distribution.get_name()),
+            safer_version(self.distribution.get_version()))
+        distinfo_dir = os.path.join(self.bdist_dir, distinfo_dirname)
+        self.egg2dist(self.egginfo_dir, distinfo_dir)
+
+        self.write_wheelfile(distinfo_dir)
+
+        # Make the archive
+        if not os.path.exists(self.dist_dir):
+            os.makedirs(self.dist_dir)
+
+        wheel_path = os.path.join(self.dist_dir, archive_basename + '.whl')
+        with WheelFile(wheel_path, 'w') as wf:
+            wf.write_files(archive_root)
+
+        # Add to 'Distribution.dist_files' so that the "upload" command works
+        getattr(self.distribution, 'dist_files', []).append(
+            ('bdist_wheel', get_python_version(), wheel_path))
+
+        if not self.keep_temp:
+            logger.info('removing %s', self.bdist_dir)
+            if not self.dry_run:
+                rmtree(self.bdist_dir)
+
+    def write_wheelfile(self, wheelfile_base, generator='bdist_wheel (' + wheel_version + ')'):
+        from email.message import Message
+        msg = Message()
+        msg['Wheel-Version'] = '1.0'  # of the spec
+        msg['Generator'] = generator
+        msg['Root-Is-Purelib'] = str(self.root_is_pure).lower()
+        if self.build_number is not None:
+            msg['Build'] = self.build_number
+
+        # Doesn't work for bdist_wininst
+        impl_tag, abi_tag, plat_tag = self.get_tag()
+        for impl in impl_tag.split('.'):
+            for abi in abi_tag.split('.'):
+                for plat in plat_tag.split('.'):
+                    msg['Tag'] = '-'.join((impl, abi, plat))
+
+        wheelfile_path = os.path.join(wheelfile_base, 'WHEEL')
+        logger.info('creating %s', wheelfile_path)
+        with open(wheelfile_path, 'w') as f:
+            Generator(f, maxheaderlen=0).flatten(msg)
+
+    def _ensure_relative(self, path):
+        # copied from dir_util, deleted
+        drive, path = os.path.splitdrive(path)
+        if path[0:1] == os.sep:
+            path = drive + path[1:]
+        return path
+
+    @property
+    def license_paths(self):
+        metadata = self.distribution.get_option_dict('metadata')
+        files = set()
+        patterns = sorted({
+            option for option in metadata.get('license_files', ('', ''))[1].split()
+        })
+
+        if 'license_file' in metadata:
+            warn('The "license_file" option is deprecated. Use "license_files" instead.',
+                 DeprecationWarning)
+            files.add(metadata['license_file'][1])
+
+        if 'license_file' not in metadata and 'license_files' not in metadata:
+            patterns = ('LICEN[CS]E*', 'COPYING*', 'NOTICE*', 'AUTHORS*')
+
+        for pattern in patterns:
+            for path in iglob(pattern):
+                if path not in files and os.path.isfile(path):
+                    logger.info('adding license file "%s" (matched pattern "%s")', path, pattern)
+                    files.add(path)
+
+        return files
+
+    def egg2dist(self, egginfo_path, distinfo_path):
+        """Convert an .egg-info directory into a .dist-info directory"""
+        def adios(p):
+            """Appropriately delete directory, file or link."""
+            if os.path.exists(p) and not os.path.islink(p) and os.path.isdir(p):
+                shutil.rmtree(p)
+            elif os.path.exists(p):
+                os.unlink(p)
+
+        adios(distinfo_path)
+
+        if not os.path.exists(egginfo_path):
+            # There is no egg-info. This is probably because the egg-info
+            # file/directory is not named matching the distribution name used
+            # to name the archive file. Check for this case and report
+            # accordingly.
+            import glob
+            pat = os.path.join(os.path.dirname(egginfo_path), '*.egg-info')
+            possible = glob.glob(pat)
+            err = "Egg metadata expected at %s but not found" % (egginfo_path,)
+            if possible:
+                alt = os.path.basename(possible[0])
+                err += " (%s found - possible misnamed archive file?)" % (alt,)
+
+            raise ValueError(err)
+
+        if os.path.isfile(egginfo_path):
+            # .egg-info is a single file
+            pkginfo_path = egginfo_path
+            pkg_info = pkginfo_to_metadata(egginfo_path, egginfo_path)
+            os.mkdir(distinfo_path)
+        else:
+            # .egg-info is a directory
+            pkginfo_path = os.path.join(egginfo_path, 'PKG-INFO')
+            pkg_info = pkginfo_to_metadata(egginfo_path, pkginfo_path)
+
+            # ignore common egg metadata that is useless to wheel
+            shutil.copytree(egginfo_path, distinfo_path,
+                            ignore=lambda x, y: {'PKG-INFO', 'requires.txt', 'SOURCES.txt',
+                                                 'not-zip-safe'}
+                            )
+
+            # delete dependency_links if it is only whitespace
+            dependency_links_path = os.path.join(distinfo_path, 'dependency_links.txt')
+            with open(dependency_links_path, 'r') as dependency_links_file:
+                dependency_links = dependency_links_file.read().strip()
+            if not dependency_links:
+                adios(dependency_links_path)
+
+        write_pkg_info(os.path.join(distinfo_path, 'METADATA'), pkg_info)
+
+        for license_path in self.license_paths:
+            filename = os.path.basename(license_path)
+            shutil.copy(license_path, os.path.join(distinfo_path, filename))
+
+        adios(egginfo_path)
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/wheel/bdist_wheel.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/wheel/bdist_wheel.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..c265e6b7d05c97d7cd341f03eb5d97521a485a28
GIT binary patch
literal 14392
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
B9Wwv`

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/wheel/cli/__init__.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/wheel/cli/__init__.py
new file mode 100644
index 0000000..95740bf
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/wheel/cli/__init__.py
@@ -0,0 +1,88 @@
+"""
+Wheel command-line utility.
+"""
+
+from __future__ import print_function
+
+import argparse
+import os
+import sys
+
+
+def require_pkgresources(name):
+    try:
+        import pkg_resources  # noqa: F401
+    except ImportError:
+        raise RuntimeError("'{0}' needs pkg_resources (part of setuptools).".format(name))
+
+
+class WheelError(Exception):
+    pass
+
+
+def unpack_f(args):
+    from .unpack import unpack
+    unpack(args.wheelfile, args.dest)
+
+
+def pack_f(args):
+    from .pack import pack
+    pack(args.directory, args.dest_dir, args.build_number)
+
+
+def convert_f(args):
+    from .convert import convert
+    convert(args.files, args.dest_dir, args.verbose)
+
+
+def version_f(args):
+    from .. import __version__
+    print("wheel %s" % __version__)
+
+
+def parser():
+    p = argparse.ArgumentParser()
+    s = p.add_subparsers(help="commands")
+
+    unpack_parser = s.add_parser('unpack', help='Unpack wheel')
+    unpack_parser.add_argument('--dest', '-d', help='Destination directory',
+                               default='.')
+    unpack_parser.add_argument('wheelfile', help='Wheel file')
+    unpack_parser.set_defaults(func=unpack_f)
+
+    repack_parser = s.add_parser('pack', help='Repack wheel')
+    repack_parser.add_argument('directory', help='Root directory of the unpacked wheel')
+    repack_parser.add_argument('--dest-dir', '-d', default=os.path.curdir,
+                               help="Directory to store the wheel (default %(default)s)")
+    repack_parser.add_argument('--build-number', help="Build tag to use in the wheel name")
+    repack_parser.set_defaults(func=pack_f)
+
+    convert_parser = s.add_parser('convert', help='Convert egg or wininst to wheel')
+    convert_parser.add_argument('files', nargs='*', help='Files to convert')
+    convert_parser.add_argument('--dest-dir', '-d', default=os.path.curdir,
+                                help="Directory to store wheels (default %(default)s)")
+    convert_parser.add_argument('--verbose', '-v', action='store_true')
+    convert_parser.set_defaults(func=convert_f)
+
+    version_parser = s.add_parser('version', help='Print version and exit')
+    version_parser.set_defaults(func=version_f)
+
+    help_parser = s.add_parser('help', help='Show this help')
+    help_parser.set_defaults(func=lambda args: p.print_help())
+
+    return p
+
+
+def main():
+    p = parser()
+    args = p.parse_args()
+    if not hasattr(args, 'func'):
+        p.print_help()
+    else:
+        try:
+            args.func(args)
+            return 0
+        except WheelError as e:
+            print(e, file=sys.stderr)
+
+    return 1
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/wheel/cli/__init__.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/wheel/cli/__init__.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..2adcf47737bdf983ba70cf84d2f11d29297c36ea
GIT binary patch
literal 4405
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
GDgpp9`{%R(

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/wheel/cli/convert.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/wheel/cli/convert.py
new file mode 100644
index 0000000..f1a793a
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/wheel/cli/convert.py
@@ -0,0 +1,269 @@
+import os.path
+import re
+import shutil
+import sys
+import tempfile
+import zipfile
+from distutils import dist
+from glob import iglob
+
+from ..bdist_wheel import bdist_wheel
+from ..wheelfile import WheelFile
+from . import WheelError, require_pkgresources
+
+egg_info_re = re.compile(r'''
+    (?P<name>.+?)-(?P<ver>.+?)
+    (-(?P<pyver>py\d\.\d)
+     (-(?P<arch>.+?))?
+    )?.egg$''', re.VERBOSE)
+
+
+class _bdist_wheel_tag(bdist_wheel):
+    # allow the client to override the default generated wheel tag
+    # The default bdist_wheel implementation uses python and abi tags
+    # of the running python process. This is not suitable for
+    # generating/repackaging prebuild binaries.
+
+    full_tag_supplied = False
+    full_tag = None  # None or a (pytag, soabitag, plattag) triple
+
+    def get_tag(self):
+        if self.full_tag_supplied and self.full_tag is not None:
+            return self.full_tag
+        else:
+            return bdist_wheel.get_tag(self)
+
+
+def egg2wheel(egg_path, dest_dir):
+    filename = os.path.basename(egg_path)
+    match = egg_info_re.match(filename)
+    if not match:
+        raise WheelError('Invalid egg file name: {}'.format(filename))
+
+    egg_info = match.groupdict()
+    dir = tempfile.mkdtemp(suffix="_e2w")
+    if os.path.isfile(egg_path):
+        # assume we have a bdist_egg otherwise
+        with zipfile.ZipFile(egg_path) as egg:
+            egg.extractall(dir)
+    else:
+        # support buildout-style installed eggs directories
+        for pth in os.listdir(egg_path):
+            src = os.path.join(egg_path, pth)
+            if os.path.isfile(src):
+                shutil.copy2(src, dir)
+            else:
+                shutil.copytree(src, os.path.join(dir, pth))
+
+    pyver = egg_info['pyver']
+    if pyver:
+        pyver = egg_info['pyver'] = pyver.replace('.', '')
+
+    arch = (egg_info['arch'] or 'any').replace('.', '_').replace('-', '_')
+
+    # assume all binary eggs are for CPython
+    abi = 'cp' + pyver[2:] if arch != 'any' else 'none'
+
+    root_is_purelib = egg_info['arch'] is None
+    if root_is_purelib:
+        bw = bdist_wheel(dist.Distribution())
+    else:
+        bw = _bdist_wheel_tag(dist.Distribution())
+
+    bw.root_is_pure = root_is_purelib
+    bw.python_tag = pyver
+    bw.plat_name_supplied = True
+    bw.plat_name = egg_info['arch'] or 'any'
+    if not root_is_purelib:
+        bw.full_tag_supplied = True
+        bw.full_tag = (pyver, abi, arch)
+
+    dist_info_dir = os.path.join(dir, '{name}-{ver}.dist-info'.format(**egg_info))
+    bw.egg2dist(os.path.join(dir, 'EGG-INFO'), dist_info_dir)
+    bw.write_wheelfile(dist_info_dir, generator='egg2wheel')
+    wheel_name = '{name}-{ver}-{pyver}-{}-{}.whl'.format(abi, arch, **egg_info)
+    with WheelFile(os.path.join(dest_dir, wheel_name), 'w') as wf:
+        wf.write_files(dir)
+
+    shutil.rmtree(dir)
+
+
+def parse_wininst_info(wininfo_name, egginfo_name):
+    """Extract metadata from filenames.
+
+    Extracts the 4 metadataitems needed (name, version, pyversion, arch) from
+    the installer filename and the name of the egg-info directory embedded in
+    the zipfile (if any).
+
+    The egginfo filename has the format::
+
+        name-ver(-pyver)(-arch).egg-info
+
+    The installer filename has the format::
+
+        name-ver.arch(-pyver).exe
+
+    Some things to note:
+
+    1. The installer filename is not definitive. An installer can be renamed
+       and work perfectly well as an installer. So more reliable data should
+       be used whenever possible.
+    2. The egg-info data should be preferred for the name and version, because
+       these come straight from the distutils metadata, and are mandatory.
+    3. The pyver from the egg-info data should be ignored, as it is
+       constructed from the version of Python used to build the installer,
+       which is irrelevant - the installer filename is correct here (even to
+       the point that when it's not there, any version is implied).
+    4. The architecture must be taken from the installer filename, as it is
+       not included in the egg-info data.
+    5. Architecture-neutral installers still have an architecture because the
+       installer format itself (being executable) is architecture-specific. We
+       should therefore ignore the architecture if the content is pure-python.
+    """
+
+    egginfo = None
+    if egginfo_name:
+        egginfo = egg_info_re.search(egginfo_name)
+        if not egginfo:
+            raise ValueError("Egg info filename %s is not valid" % (egginfo_name,))
+
+    # Parse the wininst filename
+    # 1. Distribution name (up to the first '-')
+    w_name, sep, rest = wininfo_name.partition('-')
+    if not sep:
+        raise ValueError("Installer filename %s is not valid" % (wininfo_name,))
+
+    # Strip '.exe'
+    rest = rest[:-4]
+    # 2. Python version (from the last '-', must start with 'py')
+    rest2, sep, w_pyver = rest.rpartition('-')
+    if sep and w_pyver.startswith('py'):
+        rest = rest2
+        w_pyver = w_pyver.replace('.', '')
+    else:
+        # Not version specific - use py2.py3. While it is possible that
+        # pure-Python code is not compatible with both Python 2 and 3, there
+        # is no way of knowing from the wininst format, so we assume the best
+        # here (the user can always manually rename the wheel to be more
+        # restrictive if needed).
+        w_pyver = 'py2.py3'
+    # 3. Version and architecture
+    w_ver, sep, w_arch = rest.rpartition('.')
+    if not sep:
+        raise ValueError("Installer filename %s is not valid" % (wininfo_name,))
+
+    if egginfo:
+        w_name = egginfo.group('name')
+        w_ver = egginfo.group('ver')
+
+    return {'name': w_name, 'ver': w_ver, 'arch': w_arch, 'pyver': w_pyver}
+
+
+def wininst2wheel(path, dest_dir):
+    with zipfile.ZipFile(path) as bdw:
+        # Search for egg-info in the archive
+        egginfo_name = None
+        for filename in bdw.namelist():
+            if '.egg-info' in filename:
+                egginfo_name = filename
+                break
+
+        info = parse_wininst_info(os.path.basename(path), egginfo_name)
+
+        root_is_purelib = True
+        for zipinfo in bdw.infolist():
+            if zipinfo.filename.startswith('PLATLIB'):
+                root_is_purelib = False
+                break
+        if root_is_purelib:
+            paths = {'purelib': ''}
+        else:
+            paths = {'platlib': ''}
+
+        dist_info = "%(name)s-%(ver)s" % info
+        datadir = "%s.data/" % dist_info
+
+        # rewrite paths to trick ZipFile into extracting an egg
+        # XXX grab wininst .ini - between .exe, padding, and first zip file.
+        members = []
+        egginfo_name = ''
+        for zipinfo in bdw.infolist():
+            key, basename = zipinfo.filename.split('/', 1)
+            key = key.lower()
+            basepath = paths.get(key, None)
+            if basepath is None:
+                basepath = datadir + key.lower() + '/'
+            oldname = zipinfo.filename
+            newname = basepath + basename
+            zipinfo.filename = newname
+            del bdw.NameToInfo[oldname]
+            bdw.NameToInfo[newname] = zipinfo
+            # Collect member names, but omit '' (from an entry like "PLATLIB/"
+            if newname:
+                members.append(newname)
+            # Remember egg-info name for the egg2dist call below
+            if not egginfo_name:
+                if newname.endswith('.egg-info'):
+                    egginfo_name = newname
+                elif '.egg-info/' in newname:
+                    egginfo_name, sep, _ = newname.rpartition('/')
+        dir = tempfile.mkdtemp(suffix="_b2w")
+        bdw.extractall(dir, members)
+
+    # egg2wheel
+    abi = 'none'
+    pyver = info['pyver']
+    arch = (info['arch'] or 'any').replace('.', '_').replace('-', '_')
+    # Wininst installers always have arch even if they are not
+    # architecture-specific (because the format itself is).
+    # So, assume the content is architecture-neutral if root is purelib.
+    if root_is_purelib:
+        arch = 'any'
+    # If the installer is architecture-specific, it's almost certainly also
+    # CPython-specific.
+    if arch != 'any':
+        pyver = pyver.replace('py', 'cp')
+    wheel_name = '-'.join((dist_info, pyver, abi, arch))
+    if root_is_purelib:
+        bw = bdist_wheel(dist.Distribution())
+    else:
+        bw = _bdist_wheel_tag(dist.Distribution())
+
+    bw.root_is_pure = root_is_purelib
+    bw.python_tag = pyver
+    bw.plat_name_supplied = True
+    bw.plat_name = info['arch'] or 'any'
+
+    if not root_is_purelib:
+        bw.full_tag_supplied = True
+        bw.full_tag = (pyver, abi, arch)
+
+    dist_info_dir = os.path.join(dir, '%s.dist-info' % dist_info)
+    bw.egg2dist(os.path.join(dir, egginfo_name), dist_info_dir)
+    bw.write_wheelfile(dist_info_dir, generator='wininst2wheel')
+
+    wheel_path = os.path.join(dest_dir, wheel_name)
+    with WheelFile(wheel_path, 'w') as wf:
+        wf.write_files(dir)
+
+    shutil.rmtree(dir)
+
+
+def convert(files, dest_dir, verbose):
+    # Only support wheel convert if pkg_resources is present
+    require_pkgresources('wheel convert')
+
+    for pat in files:
+        for installer in iglob(pat):
+            if os.path.splitext(installer)[1] == '.egg':
+                conv = egg2wheel
+            else:
+                conv = wininst2wheel
+
+            if verbose:
+                print("{}... ".format(installer))
+                sys.stdout.flush()
+
+            conv(installer, dest_dir)
+            if verbose:
+                print("OK")
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/wheel/cli/convert.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/wheel/cli/convert.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..60f4613d7adc9cb7643a145e032bce2dfda80037
GIT binary patch
literal 7962
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
B7tH_w

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/wheel/cli/pack.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/wheel/cli/pack.py
new file mode 100644
index 0000000..af6e81c
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/wheel/cli/pack.py
@@ -0,0 +1,58 @@
+from __future__ import print_function
+
+import os.path
+import re
+import sys
+
+from wheel.cli import WheelError
+from wheel.wheelfile import WheelFile
+
+DIST_INFO_RE = re.compile(r"^(?P<namever>(?P<name>.+?)-(?P<ver>\d.*?))\.dist-info$")
+
+
+def pack(directory, dest_dir, build_number):
+    """Repack a previously unpacked wheel directory into a new wheel file.
+
+    The .dist-info/WHEEL file must contain one or more tags so that the target
+    wheel file name can be determined.
+
+    :param directory: The unpacked wheel directory
+    :param dest_dir: Destination directory (defaults to the current directory)
+    """
+    # Find the .dist-info directory
+    dist_info_dirs = [fn for fn in os.listdir(directory)
+                      if os.path.isdir(os.path.join(directory, fn)) and DIST_INFO_RE.match(fn)]
+    if len(dist_info_dirs) > 1:
+        raise WheelError('Multiple .dist-info directories found in {}'.format(directory))
+    elif not dist_info_dirs:
+        raise WheelError('No .dist-info directories found in {}'.format(directory))
+
+    # Determine the target wheel filename
+    dist_info_dir = dist_info_dirs[0]
+    name_version = DIST_INFO_RE.match(dist_info_dir).group('namever')
+
+    # Add the build number if specific
+    if build_number:
+        name_version += '-' + build_number
+
+    # Read the tags from .dist-info/WHEEL
+    with open(os.path.join(directory, dist_info_dir, 'WHEEL')) as f:
+        tags = [line.split(' ')[1].rstrip() for line in f if line.startswith('Tag: ')]
+        if not tags:
+            raise WheelError('No tags present in {}/WHEEL; cannot determine target wheel filename'
+                             .format(dist_info_dir))
+
+    # Reassemble the tags for the wheel file
+    impls = sorted({tag.split('-')[0] for tag in tags})
+    abivers = sorted({tag.split('-')[1] for tag in tags})
+    platforms = sorted({tag.split('-')[2] for tag in tags})
+    tagline = '-'.join(['.'.join(impls), '.'.join(abivers), '.'.join(platforms)])
+
+    # Repack the wheel
+    wheel_path = os.path.join(dest_dir, '{}-{}.whl'.format(name_version, tagline))
+    with WheelFile(wheel_path, 'w') as wf:
+        print("Repacking wheel as {}...".format(wheel_path), end='')
+        sys.stdout.flush()
+        wf.write_files(directory)
+
+    print('OK')
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/wheel/cli/pack.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/wheel/cli/pack.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..768e6bcdd055ca2d8425ce6c954e7b71e19298c7
GIT binary patch
literal 3102
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

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/wheel/cli/unpack.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/wheel/cli/unpack.py
new file mode 100644
index 0000000..2e9857a
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/wheel/cli/unpack.py
@@ -0,0 +1,25 @@
+from __future__ import print_function
+
+import os.path
+import sys
+
+from ..wheelfile import WheelFile
+
+
+def unpack(path, dest='.'):
+    """Unpack a wheel.
+
+    Wheel content will be unpacked to {dest}/{name}-{ver}, where {name}
+    is the package name and {ver} its version.
+
+    :param path: The path to the wheel.
+    :param dest: Destination directory (default to current directory).
+    """
+    with WheelFile(path) as wf:
+        namever = wf.parsed_filename.group('namever')
+        destination = os.path.join(dest, namever)
+        print("Unpacking to: {}...".format(destination), end='')
+        sys.stdout.flush()
+        wf.extractall(destination)
+
+    print('OK')
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/wheel/cli/unpack.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/wheel/cli/unpack.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..cfbb1a8e5927978e942561206a2a087b5b9bfebe
GIT binary patch
literal 1182
zcmZSn%**AGdLky70ScHH7#JKF7#WH^7#J8*7#LC*8FCmHav2$-7#SErd?tn*CWa_x
zupARZ4husR3quMsLkbH+4l6@08$%Qu17iv+Lkb&13nN1mJ3|T+L$C%r0|P_m|NsC0
zYcMh}FqH5yFfbGpW#*N{r<LX<mt^MW`DKDEhRAX<FffE?q^9P$W#*)ofHdeOgJfA5
z7#KJh7#N&E&Z`BP!@y9(z|hRd(4WXq%fwK_#E`|vki`UYb2B4DEi*$2GeZ^&Ll!GT
z4I@JhGea{ILoEwK2^+{wS?mloEFirQw>L8~GL~>KWN|WNaWOPAFff7)<Ay3>3{PQY
z2#f$}WCLjd`48f!;y(-w454`iiOJati3;T)N9%EMDJUo?fIXm)oS#>cnpdJwo|%)Q
zkd&%W3Raq$qEM2rP@R%mTvDrFotK!KTB}=KmReM+12Up0RRJOfHYc-Kp(G<!0c1mB
zda43Qu|i^AiUL@@LS{*^LRo52ab|uV)LyHC#G=Gpg@VMA3@e2Yu+EYUkaZwapbiAN
z52_C21}g=Z)Z&uNyhKn$D5PW-r6!l;7gZ`~q@<=LmgbazbSIY<6@fegm(|n*JFf&3
zvmi%-Tp<h(jLf`rg_3+Lh3Z;8J-rfU1_p-Iyp$4967wqoMWw&D1`h)RLl7u(OZY*l
zA+e}9H6=bRGba^fS_vqw(~I&;3&6_ri%VF*ib^uTjI8|3Jg^dQA}V2HU|>kgFUn0U
z0b5mESqv5`E=kEREdi@b%PB3+DB%LRqoSlJF}Wl$Cr1NhM-WI1Y$hlqz?PM#1%Vt~
z!VSs*h=9=mxgJaur!p`w=ob`amL-;?>X#)J>8IuAq@)%V>nEk?mnS9V<(lRe8yO~<
zr&pz0m|B$QWL23NfIxbleu#cSW`S;IUNOi8x^872p2h+C;Anx8$vK(&kW`{qPzm-1
zga^tL#h`q{z{$@j#3;%r$;itn%%lOz5MYnR$ETH+loqAN#|MF23XYikVm(ko2m)yi
z0%<M*vB1`WLK+<WL81%{3}AmD2s-)@<bIpn{FKt1R69^=C<X}#F!3<*FbOaN07up&
A2mk;8

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/wheel/metadata.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/wheel/metadata.py
new file mode 100644
index 0000000..ab0c07e
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/wheel/metadata.py
@@ -0,0 +1,141 @@
+"""
+Tools for converting old- to new-style metadata.
+"""
+
+import os.path
+import re
+import textwrap
+
+import pkg_resources
+
+from .pkginfo import read_pkg_info
+
+# Wheel itself is probably the only program that uses non-extras markers
+# in METADATA/PKG-INFO. Support its syntax with the extra at the end only.
+EXTRA_RE = re.compile(
+    r"""^(?P<package>.*?)(;\s*(?P<condition>.*?)(extra == '(?P<extra>.*?)')?)$""")
+
+
+def requires_to_requires_dist(requirement):
+    """Return the version specifier for a requirement in PEP 345/566 fashion."""
+    if getattr(requirement, 'url', None):
+        return " @ " + requirement.url
+
+    requires_dist = []
+    for op, ver in requirement.specs:
+        requires_dist.append(op + ver)
+    if not requires_dist:
+        return ''
+    return " (%s)" % ','.join(sorted(requires_dist))
+
+
+def convert_requirements(requirements):
+    """Yield Requires-Dist: strings for parsed requirements strings."""
+    for req in requirements:
+        parsed_requirement = pkg_resources.Requirement.parse(req)
+        spec = requires_to_requires_dist(parsed_requirement)
+        extras = ",".join(sorted(parsed_requirement.extras))
+        if extras:
+            extras = "[%s]" % extras
+        yield (parsed_requirement.project_name + extras + spec)
+
+
+def generate_requirements(extras_require):
+    """
+    Convert requirements from a setup()-style dictionary to ('Requires-Dist', 'requirement')
+    and ('Provides-Extra', 'extra') tuples.
+
+    extras_require is a dictionary of {extra: [requirements]} as passed to setup(),
+    using the empty extra {'': [requirements]} to hold install_requires.
+    """
+    for extra, depends in extras_require.items():
+        condition = ''
+        extra = extra or ''
+        if ':' in extra:  # setuptools extra:condition syntax
+            extra, condition = extra.split(':', 1)
+
+        extra = pkg_resources.safe_extra(extra)
+        if extra:
+            yield 'Provides-Extra', extra
+            if condition:
+                condition = "(" + condition + ") and "
+            condition += "extra == '%s'" % extra
+
+        if condition:
+            condition = ' ; ' + condition
+
+        for new_req in convert_requirements(depends):
+            yield 'Requires-Dist', new_req + condition
+
+
+def pkginfo_to_metadata(egg_info_path, pkginfo_path):
+    """
+    Convert .egg-info directory with PKG-INFO to the Metadata 2.1 format
+    """
+    pkg_info = read_pkg_info(pkginfo_path)
+    pkg_info.replace_header('Metadata-Version', '2.1')
+    # Those will be regenerated from `requires.txt`.
+    del pkg_info['Provides-Extra']
+    del pkg_info['Requires-Dist']
+    requires_path = os.path.join(egg_info_path, 'requires.txt')
+    if os.path.exists(requires_path):
+        with open(requires_path) as requires_file:
+            requires = requires_file.read()
+
+        parsed_requirements = sorted(pkg_resources.split_sections(requires),
+                                     key=lambda x: x[0] or '')
+        for extra, reqs in parsed_requirements:
+            for key, value in generate_requirements({extra: reqs}):
+                if (key, value) not in pkg_info.items():
+                    pkg_info[key] = value
+
+    description = pkg_info['Description']
+    if description:
+        pkg_info.set_payload(dedent_description(pkg_info))
+        del pkg_info['Description']
+
+    return pkg_info
+
+
+def pkginfo_unicode(pkg_info, field):
+    """Hack to coax Unicode out of an email Message() - Python 3.3+"""
+    text = pkg_info[field]
+    field = field.lower()
+    if not isinstance(text, str):
+        if not hasattr(pkg_info, 'raw_items'):  # Python 3.2
+            return str(text)
+        for item in pkg_info.raw_items():
+            if item[0].lower() == field:
+                text = item[1].encode('ascii', 'surrogateescape') \
+                    .decode('utf-8')
+                break
+
+    return text
+
+
+def dedent_description(pkg_info):
+    """
+    Dedent and convert pkg_info['Description'] to Unicode.
+    """
+    description = pkg_info['Description']
+
+    # Python 3 Unicode handling, sorta.
+    surrogates = False
+    if not isinstance(description, str):
+        surrogates = True
+        description = pkginfo_unicode(pkg_info, 'Description')
+
+    description_lines = description.splitlines()
+    description_dedent = '\n'.join(
+        # if the first line of long_description is blank,
+        # the first line here will be indented.
+        (description_lines[0].lstrip(),
+         textwrap.dedent('\n'.join(description_lines[1:])),
+         '\n'))
+
+    if surrogates:
+        description_dedent = description_dedent \
+            .encode("utf8") \
+            .decode("ascii", "surrogateescape")
+
+    return description_dedent
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/wheel/metadata.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/wheel/metadata.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..c947b37a40da71b178c7b7e1284bd92b2048fb77
GIT binary patch
literal 5114
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

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/wheel/pep425tags.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/wheel/pep425tags.py
new file mode 100644
index 0000000..13b5073
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/wheel/pep425tags.py
@@ -0,0 +1,185 @@
+"""Generate and work with PEP 425 Compatibility Tags."""
+
+import distutils.util
+import platform
+import sys
+import sysconfig
+import warnings
+
+try:
+    from importlib.machinery import get_all_suffixes
+except ImportError:
+    from imp import get_suffixes as get_all_suffixes
+
+
+def get_config_var(var):
+    try:
+        return sysconfig.get_config_var(var)
+    except IOError as e:  # pip Issue #1074
+        warnings.warn("{0}".format(e), RuntimeWarning)
+        return None
+
+
+def get_abbr_impl():
+    """Return abbreviated implementation name."""
+    impl = platform.python_implementation()
+    if impl == 'PyPy':
+        return 'pp'
+    elif impl == 'Jython':
+        return 'jy'
+    elif impl == 'IronPython':
+        return 'ip'
+    elif impl == 'CPython':
+        return 'cp'
+
+    raise LookupError('Unknown Python implementation: ' + impl)
+
+
+def get_impl_ver():
+    """Return implementation version."""
+    impl_ver = get_config_var("py_version_nodot")
+    if not impl_ver or get_abbr_impl() == 'pp':
+        impl_ver = ''.join(map(str, get_impl_version_info()))
+    return impl_ver
+
+
+def get_impl_version_info():
+    """Return sys.version_info-like tuple for use in decrementing the minor
+    version."""
+    if get_abbr_impl() == 'pp':
+        # as per https://github.com/pypa/pip/issues/2882
+        return (sys.version_info[0], sys.pypy_version_info.major,
+                sys.pypy_version_info.minor)
+    else:
+        return sys.version_info[0], sys.version_info[1]
+
+
+def get_flag(var, fallback, expected=True, warn=True):
+    """Use a fallback method for determining SOABI flags if the needed config
+    var is unset or unavailable."""
+    val = get_config_var(var)
+    if val is None:
+        if warn:
+            warnings.warn("Config variable '{0}' is unset, Python ABI tag may "
+                          "be incorrect".format(var), RuntimeWarning, 2)
+        return fallback()
+    return val == expected
+
+
+def get_abi_tag():
+    """Return the ABI tag based on SOABI (if available) or emulate SOABI
+    (CPython 2, PyPy)."""
+    soabi = get_config_var('SOABI')
+    impl = get_abbr_impl()
+    if not soabi and impl in ('cp', 'pp') and hasattr(sys, 'maxunicode'):
+        d = ''
+        m = ''
+        u = ''
+        if get_flag('Py_DEBUG',
+                    lambda: hasattr(sys, 'gettotalrefcount'),
+                    warn=(impl == 'cp')):
+            d = 'd'
+        if get_flag('WITH_PYMALLOC',
+                    lambda: impl == 'cp',
+                    warn=(impl == 'cp')):
+            m = 'm'
+        if get_flag('Py_UNICODE_SIZE',
+                    lambda: sys.maxunicode == 0x10ffff,
+                    expected=4,
+                    warn=(impl == 'cp' and
+                          sys.version_info < (3, 3))) \
+                and sys.version_info < (3, 3):
+            u = 'u'
+        abi = '%s%s%s%s%s' % (impl, get_impl_ver(), d, m, u)
+    elif soabi and soabi.startswith('cpython-'):
+        abi = 'cp' + soabi.split('-')[1]
+    elif soabi:
+        abi = soabi.replace('.', '_').replace('-', '_')
+    else:
+        abi = None
+    return abi
+
+
+def get_platform():
+    """Return our platform name 'win32', 'linux_x86_64'"""
+    # XXX remove distutils dependency
+    result = distutils.util.get_platform().replace('.', '_').replace('-', '_')
+    if result == "linux_x86_64" and sys.maxsize == 2147483647:
+        # pip pull request #3497
+        result = "linux_i686"
+    return result
+
+
+def get_supported(versions=None, supplied_platform=None):
+    """Return a list of supported tags for each version specified in
+    `versions`.
+
+    :param versions: a list of string versions, of the form ["33", "32"],
+        or None. The first version will be assumed to support our ABI.
+    """
+    supported = []
+
+    # Versions must be given with respect to the preference
+    if versions is None:
+        versions = []
+        version_info = get_impl_version_info()
+        major = version_info[:-1]
+        # Support all previous minor Python versions.
+        for minor in range(version_info[-1], -1, -1):
+            versions.append(''.join(map(str, major + (minor,))))
+
+    impl = get_abbr_impl()
+
+    abis = []
+
+    abi = get_abi_tag()
+    if abi:
+        abis[0:0] = [abi]
+
+    abi3s = set()
+    for suffix in get_all_suffixes():
+        if suffix[0].startswith('.abi'):
+            abi3s.add(suffix[0].split('.', 2)[1])
+
+    abis.extend(sorted(list(abi3s)))
+
+    abis.append('none')
+
+    platforms = []
+    if supplied_platform:
+        platforms.append(supplied_platform)
+    platforms.append(get_platform())
+
+    # Current version, current API (built specifically for our Python):
+    for abi in abis:
+        for arch in platforms:
+            supported.append(('%s%s' % (impl, versions[0]), abi, arch))
+
+    # abi3 modules compatible with older version of Python
+    for version in versions[1:]:
+        # abi3 was introduced in Python 3.2
+        if version in ('31', '30'):
+            break
+        for abi in abi3s:   # empty set if not Python 3
+            for arch in platforms:
+                supported.append(("%s%s" % (impl, version), abi, arch))
+
+    # No abi / arch, but requires our implementation:
+    for i, version in enumerate(versions):
+        supported.append(('%s%s' % (impl, version), 'none', 'any'))
+        if i == 0:
+            # Tagged specifically as being cross-version compatible
+            # (with just the major version specified)
+            supported.append(('%s%s' % (impl, versions[0][0]), 'none', 'any'))
+
+    # Major Python version + platform; e.g. binaries not using the Python API
+    for arch in platforms:
+        supported.append(('py%s' % (versions[0][0]), 'none', arch))
+
+    # No abi / arch, generic Python
+    for i, version in enumerate(versions):
+        supported.append(('py%s' % (version,), 'none', 'any'))
+        if i == 0:
+            supported.append(('py%s' % (version[0]), 'none', 'any'))
+
+    return supported
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/wheel/pep425tags.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/wheel/pep425tags.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..0c26463a18540d7364b5c0c8b4683100dbe63138
GIT binary patch
literal 6677
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
D)V{#O

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/wheel/pkginfo.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/wheel/pkginfo.py
new file mode 100644
index 0000000..115be45
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/wheel/pkginfo.py
@@ -0,0 +1,43 @@
+"""Tools for reading and writing PKG-INFO / METADATA without caring
+about the encoding."""
+
+from email.parser import Parser
+
+try:
+    unicode
+    _PY3 = False
+except NameError:
+    _PY3 = True
+
+if not _PY3:
+    from email.generator import Generator
+
+    def read_pkg_info_bytes(bytestr):
+        return Parser().parsestr(bytestr)
+
+    def read_pkg_info(path):
+        with open(path, "r") as headers:
+            message = Parser().parse(headers)
+        return message
+
+    def write_pkg_info(path, message):
+        with open(path, 'w') as metadata:
+            Generator(metadata, mangle_from_=False, maxheaderlen=0).flatten(message)
+else:
+    from email.generator import BytesGenerator
+
+    def read_pkg_info_bytes(bytestr):
+        headers = bytestr.decode(encoding="ascii", errors="surrogateescape")
+        message = Parser().parsestr(headers)
+        return message
+
+    def read_pkg_info(path):
+        with open(path, "r",
+                  encoding="ascii",
+                  errors="surrogateescape") as headers:
+            message = Parser().parse(headers)
+        return message
+
+    def write_pkg_info(path, message):
+        with open(path, "wb") as out:
+            BytesGenerator(out, mangle_from_=False, maxheaderlen=0).flatten(message)
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/wheel/pkginfo.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/wheel/pkginfo.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..43da7379d74f171bc904528c8b984ed260d54327
GIT binary patch
literal 2403
zcmZSn%**AGdLky70SZ_d7#JKF7#NBdGB7ZtFfc?hFr+Xtq%bk$Ff!yaF+?#jFjn$0
zq%t!wrm`?Zu`-0`i8HXIvN2?HF%;P{FfuZxvV(;47#Si`Ss99pz`B_kayS@rIT@lj
z85mPo7+M$@qPQ4RSiuZ#h7>k1gNGqc8?2fgteTf0ikE>gg##?d#gM`YW^gm4aDf>-
z3@O|U!5Taur-m>vFofji=M*cX<rgUwr6#6i=A|nn=A|f<7iE@!*a6<|x}JV+{tEgE
zzOEsTE{-9N3gww48Tq9p3dxB@nR)44iAf+%Nk*zdYF=_a$OOI2|NsC0*I;B|U?^c@
zU|<MHEGkYdg77&R7#Q4B^HPfvOY)17K}tZFiGhK^8RQ}XkRAqxW(I~VMur*&hGs^F
zV6a9%4Un23P+*sEFfcF_fXpl|ftt$Bz`&4HS&|A804dP`5yeRi3=H}OMVV!ZC8_#l
ziADNp`8g@6MaB9_Df;C}NqM=Zxy43?N#^NQ=@zCI<vCeZW(FXTo~Iw8Uyxa#o0(T!
zl9-dD>sIFBX&j(mo{^fG10@Tx(=+qZ^7RTTON1F17(ihcUyz+14-$+AJB1(QACRLN
z7{UHzW?*0dg$CH4dJuosfD=hG6GOiwLoFji2_x9&Obj)QAfMMVF@&cuFa$=_Ffjy!
z{qI)-3augykXa=x3=9nU1*v(EKmnycaG)S03ld8*N<cxAk(vndH<+E9T3no%o(c{j
zFhQ?i;zbW8Ay5E;LWF@)h*5$u85C9^k8!~ggEe{}sWH?tfdZ+936!x)m>5!+8B$mn
zni-k0n4w|D2nn$i28Lh_P>?`Eth@x2-g6W4(sNSd(~9zQ<Dmi-kf6y)&C3KO84XaF
z27%lZ1PbU9kO^*yImM~qpi9e1EGbFN0|#&rC=mvMoC;2kxv3?IDTyVC;1C59^a@r!
z1_lODZcT+JKXFjFf;<8WS8(Pj0V#3<<qy=X2MTSF7vV{=hJhgqoFr4=VavdTHDQ92
zBuK9x*#EGs4-T=!;^fRsaL!LHD#|Y^E&*qS(xRgL^u&_X)Z*mCf>dxIg4Lv?Cg-Q5
zf)jBNC<%aNf<R6S;$&c80EaO+M8O1|f;9*fezKr|1SJLrMhQkCL@owpDR7WkAtz9H
zkfpFPG&3;~k)uII`vrjlF-QdDQ&A8h1|mRF2nh#}8c5iHY=ww{limP^4L1V=gAyog
zK*^thk%y6uk%xvE7?dc=lY&6yM-V6>qvupm`5OdEVnLwV11X3=&MN^Wr2NtnaN+?I
z^h!aX;!P72N}!|!%8Gs(AlHLSlKA+P{N#8@A(Wb%n3<yoF1m}rF%4ExnwJUA79f9t
zOZxbLNaGSvr28f2rn-Xi6<9c=s5BLvzaYk>!>U$r`2|kJL7?ag0=Xs#6jI<YKoE2a
z4R9f0lbfGXnv-e=iqK*?P<6;8z{JeR!pOzQ%gDvV#wftV$;`>h!y>@M$;!zN00bHe
A+yDRo

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/wheel/util.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/wheel/util.py
new file mode 100644
index 0000000..0afb54a
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/wheel/util.py
@@ -0,0 +1,46 @@
+import base64
+import io
+import sys
+
+
+if sys.version_info[0] < 3:
+    text_type = unicode  # noqa: F821
+
+    StringIO = io.BytesIO
+
+    def native(s, encoding='utf-8'):
+        if isinstance(s, unicode):
+            return s.encode(encoding)
+        return s
+else:
+    text_type = str
+
+    StringIO = io.StringIO
+
+    def native(s, encoding='utf-8'):
+        if isinstance(s, bytes):
+            return s.decode(encoding)
+        return s
+
+
+def urlsafe_b64encode(data):
+    """urlsafe_b64encode without padding"""
+    return base64.urlsafe_b64encode(data).rstrip(b'=')
+
+
+def urlsafe_b64decode(data):
+    """urlsafe_b64decode without padding"""
+    pad = b'=' * (4 - (len(data) & 3))
+    return base64.urlsafe_b64decode(data + pad)
+
+
+def as_unicode(s):
+    if isinstance(s, bytes):
+        return s.decode('utf-8')
+    return s
+
+
+def as_bytes(s):
+    if isinstance(s, text_type):
+        return s.encode('utf-8')
+    return s
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/wheel/util.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/wheel/util.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..de3011076bb2a4a10332381c279cfc9d0556f5a2
GIT binary patch
literal 2061
zcmZSn%**AGdLky70ScHH7#JKF7#NCYFfcHrFfgPrGUPBYM8VmN3{i|QaVCZ+CWcfd
zhAd`=6eb4A6lR8O28N<ghEx`YC{~74MusdlhA4K16c&aQR)!WvhA0k(JZXkhPM9n^
zOqLBQo5Ie}!oU#4#gM`QW^gm4aDo{;3@Kb-1~14#!5Z8Q3=En7|NsB*mkDxrCNs#z
ztPBhcr6p;)7Rew_fG|kd86>5^z`#(#z)-`$P{PR2%*0S617c?}G1M?JG&3>;*Dx>y
zYcMh}F!*VJ^ptRc%rDN&D=taQOHM6e2br9gnVg@JTEfP_z>t~;Vrqb_C;{mzF5!TQ
zX6B`9fSd#-isKm=81xH@GRqQ6QuWIci}cg-b5c@^iuIFH^vjcy@^Vdci;WDE%+ssV
zEle%SbF!+;3_u_~Pd`MzAhSRh?1Y>gUAHn1PvZdn@{H8f94J{@l9{7dPziQWUSdgR
zSt=-0ib3vUVB}}yWu!P5f<PWA0R?MPWl3r=*rt?JxYvU~K^4Tpz`y|ZESR8&kApxi
z5&=akl3zj50K%X+0Y|wQB+9cGK{4IT$dJVZN;;s(2FF{mA}CIaa*7kvQsa}%OdwIJ
zP@Y+mkzZP(P>`6Cl9`tdj$K<wngCgrlvtc<W>O-EO)ofjii%5$G7G>-sRR@<DTyVC
z;D7-WbO{|$+LZ!@4k#!Xn37?k0&)&GWHdoJn-P>{Az7lCks*bd!9hZ#mJyUaK)Hee
zlrhA?fd$fr9$1h>fF4*upiGbnQV-6LkWd4qk(|`LAWl$ppoJU67;tn1@qpw(iVG4`
zz+nX@=n`Oj3=9nNpa26ooq<V$5gcToU<0`a9Ar4lj})Zx0~FqV#h}CqE``AU2WO!m
zP|^tk6(Zn-0nRsI?|}(=_z_&7B^Jk*LJBcekZ(bbf)*4Yzk)E8{96K!?9_^q_>#(k
z)F4o}44B73X)>`m9$bKFqk3Bd6!DOR336g)ehJ9`#g)Y+pu|{~T2!2wpBJB*mzEy{
z3Y;KN>IGK?PN34z(;r;u2bUCO=B0c3g9{~y0VPF2pgb4^HeP^%fgwl;rHrIstb;sn
plbfGXnv-e=@<K7FT;O5kVdP;JW@KaHWa4K9kvwditek9|Yyh*1z;FNn

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/wheel/wheelfile.py b/tests/python/assert_test01/venv/lib/python2.7/site-packages/wheel/wheelfile.py
new file mode 100644
index 0000000..9a1c8d2
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site-packages/wheel/wheelfile.py
@@ -0,0 +1,168 @@
+from __future__ import print_function
+
+import csv
+import hashlib
+import os.path
+import re
+import time
+from collections import OrderedDict
+from distutils import log as logger
+from zipfile import ZIP_DEFLATED, ZipInfo, ZipFile
+
+from wheel.cli import WheelError
+from wheel.util import urlsafe_b64decode, as_unicode, native, urlsafe_b64encode, as_bytes, StringIO
+
+# Non-greedy matching of an optional build number may be too clever (more
+# invalid wheel filenames will match). Separate regex for .dist-info?
+WHEEL_INFO_RE = re.compile(
+    r"""^(?P<namever>(?P<name>.+?)-(?P<ver>.+?))(-(?P<build>\d[^-]*))?
+     -(?P<pyver>.+?)-(?P<abi>.+?)-(?P<plat>.+?)\.whl$""",
+    re.VERBOSE)
+
+
+def get_zipinfo_datetime(timestamp=None):
+    # Some applications need reproducible .whl files, but they can't do this without forcing
+    # the timestamp of the individual ZipInfo objects. See issue #143.
+    timestamp = int(os.environ.get('SOURCE_DATE_EPOCH', timestamp or time.time()))
+    return time.gmtime(timestamp)[0:6]
+
+
+class WheelFile(ZipFile):
+    """A ZipFile derivative class that also reads SHA-256 hashes from
+    .dist-info/RECORD and checks any read files against those.
+    """
+
+    _default_algorithm = hashlib.sha256
+
+    def __init__(self, file, mode='r'):
+        basename = os.path.basename(file)
+        self.parsed_filename = WHEEL_INFO_RE.match(basename)
+        if not basename.endswith('.whl') or self.parsed_filename is None:
+            raise WheelError("Bad wheel filename {!r}".format(basename))
+
+        ZipFile.__init__(self, file, mode, compression=ZIP_DEFLATED, allowZip64=True)
+
+        self.dist_info_path = '{}.dist-info'.format(self.parsed_filename.group('namever'))
+        self.record_path = self.dist_info_path + '/RECORD'
+        self._file_hashes = OrderedDict()
+        self._file_sizes = {}
+        if mode == 'r':
+            # Ignore RECORD and any embedded wheel signatures
+            self._file_hashes[self.record_path] = None, None
+            self._file_hashes[self.record_path + '.jws'] = None, None
+            self._file_hashes[self.record_path + '.p7s'] = None, None
+
+            # Fill in the expected hashes by reading them from RECORD
+            try:
+                record = self.open(self.record_path)
+            except KeyError:
+                raise WheelError('Missing {} file'.format(self.record_path))
+
+            with record:
+                for line in record:
+                    line = line.decode('utf-8')
+                    path, hash_sum, size = line.rsplit(u',', 2)
+                    if hash_sum:
+                        algorithm, hash_sum = hash_sum.split(u'=')
+                        try:
+                            hashlib.new(algorithm)
+                        except ValueError:
+                            raise WheelError('Unsupported hash algorithm: {}'.format(algorithm))
+
+                        if algorithm.lower() in {'md5', 'sha1'}:
+                            raise WheelError(
+                                'Weak hash algorithm ({}) is not permitted by PEP 427'
+                                .format(algorithm))
+
+                        self._file_hashes[path] = (
+                            algorithm, urlsafe_b64decode(hash_sum.encode('ascii')))
+
+    def open(self, name_or_info, mode="r", pwd=None):
+        def _update_crc(newdata, eof=None):
+            if eof is None:
+                eof = ef._eof
+                update_crc_orig(newdata)
+            else:  # Python 2
+                update_crc_orig(newdata, eof)
+
+            running_hash.update(newdata)
+            if eof and running_hash.digest() != expected_hash:
+                raise WheelError("Hash mismatch for file '{}'".format(native(ef_name)))
+
+        ef = ZipFile.open(self, name_or_info, mode, pwd)
+        ef_name = as_unicode(name_or_info.filename if isinstance(name_or_info, ZipInfo)
+                             else name_or_info)
+        if mode == 'r' and not ef_name.endswith('/'):
+            if ef_name not in self._file_hashes:
+                raise WheelError("No hash found for file '{}'".format(native(ef_name)))
+
+            algorithm, expected_hash = self._file_hashes[ef_name]
+            if expected_hash is not None:
+                # Monkey patch the _update_crc method to also check for the hash from RECORD
+                running_hash = hashlib.new(algorithm)
+                update_crc_orig, ef._update_crc = ef._update_crc, _update_crc
+
+        return ef
+
+    def write_files(self, base_dir):
+        logger.info("creating '%s' and adding '%s' to it", self.filename, base_dir)
+        deferred = []
+        for root, dirnames, filenames in os.walk(base_dir):
+            # Sort the directory names so that `os.walk` will walk them in a
+            # defined order on the next iteration.
+            dirnames.sort()
+            for name in sorted(filenames):
+                path = os.path.normpath(os.path.join(root, name))
+                if os.path.isfile(path):
+                    arcname = os.path.relpath(path, base_dir)
+                    if arcname == self.record_path:
+                        pass
+                    elif root.endswith('.dist-info'):
+                        deferred.append((path, arcname))
+                    else:
+                        self.write(path, arcname)
+
+        deferred.sort()
+        for path, arcname in deferred:
+            self.write(path, arcname)
+
+    def write(self, filename, arcname=None, compress_type=None):
+        with open(filename, 'rb') as f:
+            st = os.fstat(f.fileno())
+            data = f.read()
+
+        zinfo = ZipInfo(arcname or filename, date_time=get_zipinfo_datetime(st.st_mtime))
+        zinfo.external_attr = st.st_mode << 16
+        zinfo.compress_type = ZIP_DEFLATED
+        self.writestr(zinfo, data, compress_type)
+
+    def writestr(self, zinfo_or_arcname, bytes, compress_type=None):
+        ZipFile.writestr(self, zinfo_or_arcname, bytes, compress_type)
+        fname = (zinfo_or_arcname.filename if isinstance(zinfo_or_arcname, ZipInfo)
+                 else zinfo_or_arcname)
+        logger.info("adding '%s'", fname)
+        if fname != self.record_path:
+            hash_ = self._default_algorithm(bytes)
+            self._file_hashes[fname] = hash_.name, native(urlsafe_b64encode(hash_.digest()))
+            self._file_sizes[fname] = len(bytes)
+
+    def close(self):
+        # Write RECORD
+        if self.fp is not None and self.mode == 'w' and self._file_hashes:
+            data = StringIO()
+            writer = csv.writer(data, delimiter=',', quotechar='"', lineterminator='\n')
+            writer.writerows((
+                (
+                    fname,
+                    algorithm + "=" + hash_,
+                    self._file_sizes[fname]
+                )
+                for fname, (algorithm, hash_) in self._file_hashes.items()
+            ))
+            writer.writerow((format(self.record_path), "", ""))
+            zinfo = ZipInfo(native(self.record_path), date_time=get_zipinfo_datetime())
+            zinfo.compress_type = ZIP_DEFLATED
+            zinfo.external_attr = 0o664 << 16
+            self.writestr(zinfo, as_bytes(data.getvalue()))
+
+        ZipFile.close(self)
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site-packages/wheel/wheelfile.pyc b/tests/python/assert_test01/venv/lib/python2.7/site-packages/wheel/wheelfile.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..07888741b805d03160a4d6c8f85ea72511b08dfc
GIT binary patch
literal 7456
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
UfKi4?fKiWyjft6&hna^R05!`o9RL6T

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/site.py b/tests/python/assert_test01/venv/lib/python2.7/site.py
new file mode 100644
index 0000000..ede3ca3
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/site.py
@@ -0,0 +1,851 @@
+"""Append module search paths for third-party packages to sys.path.
+
+****************************************************************
+* This module is automatically imported during initialization. *
+****************************************************************
+
+In earlier versions of Python (up to 1.5a3), scripts or modules that
+needed to use site-specific modules would place ``import site''
+somewhere near the top of their code.  Because of the automatic
+import, this is no longer necessary (but code that does it still
+works).
+
+This will append site-specific paths to the module search path.  On
+Unix, it starts with sys.prefix and sys.exec_prefix (if different) and
+appends lib/python<version>/site-packages as well as lib/site-python.
+It also supports the Debian convention of
+lib/python<version>/dist-packages.  On other platforms (mainly Mac and
+Windows), it uses just sys.prefix (and sys.exec_prefix, if different,
+but this is unlikely).  The resulting directories, if they exist, are
+appended to sys.path, and also inspected for path configuration files.
+
+FOR DEBIAN, this sys.path is augmented with directories in /usr/local.
+Local addons go into /usr/local/lib/python<version>/site-packages
+(resp. /usr/local/lib/site-python), Debian addons install into
+/usr/{lib,share}/python<version>/dist-packages.
+
+A path configuration file is a file whose name has the form
+<package>.pth; its contents are additional directories (one per line)
+to be added to sys.path.  Non-existing directories (or
+non-directories) are never added to sys.path; no directory is added to
+sys.path more than once.  Blank lines and lines beginning with
+'#' are skipped. Lines starting with 'import' are executed.
+
+For example, suppose sys.prefix and sys.exec_prefix are set to
+/usr/local and there is a directory /usr/local/lib/python2.X/site-packages
+with three subdirectories, foo, bar and spam, and two path
+configuration files, foo.pth and bar.pth.  Assume foo.pth contains the
+following:
+
+  # foo package configuration
+  foo
+  bar
+  bletch
+
+and bar.pth contains:
+
+  # bar package configuration
+  bar
+
+Then the following directories are added to sys.path, in this order:
+
+  /usr/local/lib/python2.X/site-packages/bar
+  /usr/local/lib/python2.X/site-packages/foo
+
+Note that bletch is omitted because it doesn't exist; bar precedes foo
+because bar.pth comes alphabetically before foo.pth; and spam is
+omitted because it is not mentioned in either path configuration file.
+
+After these path manipulations, an attempt is made to import a module
+named sitecustomize, which can perform arbitrary additional
+site-specific customizations.  If this import fails with an
+ImportError exception, it is silently ignored.
+
+"""
+
+import os
+import sys
+
+try:
+    import __builtin__ as builtins
+except ImportError:
+    import builtins
+try:
+    set
+except NameError:
+    from sets import Set as set
+
+# Prefixes for site-packages; add additional prefixes like /usr/local here
+PREFIXES = [sys.prefix, sys.exec_prefix]
+# Enable per user site-packages directory
+# set it to False to disable the feature or True to force the feature
+ENABLE_USER_SITE = None
+# for distutils.commands.install
+USER_SITE = None
+USER_BASE = None
+
+_is_64bit = (getattr(sys, "maxsize", None) or getattr(sys, "maxint")) > 2 ** 32
+_is_pypy = hasattr(sys, "pypy_version_info")
+_is_jython = sys.platform[:4] == "java"
+if _is_jython:
+    ModuleType = type(os)
+
+
+def makepath(*paths):
+    dir = os.path.join(*paths)
+    if _is_jython and (dir == "__classpath__" or dir.startswith("__pyclasspath__")):
+        return dir, dir
+    dir = os.path.abspath(dir)
+    return dir, os.path.normcase(dir)
+
+
+def abs__file__():
+    """Set all module' __file__ attribute to an absolute path"""
+    for m in sys.modules.values():
+        if (_is_jython and not isinstance(m, ModuleType)) or hasattr(m, "__loader__"):
+            # only modules need the abspath in Jython. and don't mess
+            # with a PEP 302-supplied __file__
+            continue
+        f = getattr(m, "__file__", None)
+        if f is None:
+            continue
+        m.__file__ = os.path.abspath(f)
+
+
+def removeduppaths():
+    """ Remove duplicate entries from sys.path along with making them
+    absolute"""
+    # This ensures that the initial path provided by the interpreter contains
+    # only absolute pathnames, even if we're running from the build directory.
+    L = []
+    known_paths = set()
+    for dir in sys.path:
+        # Filter out duplicate paths (on case-insensitive file systems also
+        # if they only differ in case); turn relative paths into absolute
+        # paths.
+        dir, dircase = makepath(dir)
+        if not dircase in known_paths:
+            L.append(dir)
+            known_paths.add(dircase)
+    sys.path[:] = L
+    return known_paths
+
+
+# XXX This should not be part of site.py, since it is needed even when
+# using the -S option for Python.  See http://www.python.org/sf/586680
+def addbuilddir():
+    """Append ./build/lib.<platform> in case we're running in the build dir
+    (especially for Guido :-)"""
+    from distutils.util import get_platform
+
+    s = "build/lib.{}-{:.3}".format(get_platform(), sys.version)
+    if hasattr(sys, "gettotalrefcount"):
+        s += "-pydebug"
+    s = os.path.join(os.path.dirname(sys.path[-1]), s)
+    sys.path.append(s)
+
+
+def _init_pathinfo():
+    """Return a set containing all existing directory entries from sys.path"""
+    d = set()
+    for dir in sys.path:
+        try:
+            if os.path.isdir(dir):
+                dir, dircase = makepath(dir)
+                d.add(dircase)
+        except TypeError:
+            continue
+    return d
+
+
+def addpackage(sitedir, name, known_paths):
+    """Add a new path to known_paths by combining sitedir and 'name' or execute
+    sitedir if it starts with 'import'"""
+    if known_paths is None:
+        _init_pathinfo()
+        reset = 1
+    else:
+        reset = 0
+    fullname = os.path.join(sitedir, name)
+    try:
+        f = open(fullname, "r")
+    except IOError:
+        return
+    try:
+        for line in f:
+            if line.startswith("#"):
+                continue
+            if line.startswith("import"):
+                exec(line)
+                continue
+            line = line.rstrip()
+            dir, dircase = makepath(sitedir, line)
+            if not dircase in known_paths and os.path.exists(dir):
+                sys.path.append(dir)
+                known_paths.add(dircase)
+    finally:
+        f.close()
+    if reset:
+        known_paths = None
+    return known_paths
+
+
+def addsitedir(sitedir, known_paths=None):
+    """Add 'sitedir' argument to sys.path if missing and handle .pth files in
+    'sitedir'"""
+    if known_paths is None:
+        known_paths = _init_pathinfo()
+        reset = 1
+    else:
+        reset = 0
+    sitedir, sitedircase = makepath(sitedir)
+    if not sitedircase in known_paths:
+        sys.path.append(sitedir)  # Add path component
+    try:
+        names = os.listdir(sitedir)
+    except os.error:
+        return
+    names.sort()
+    for name in names:
+        if name.endswith(os.extsep + "pth"):
+            addpackage(sitedir, name, known_paths)
+    if reset:
+        known_paths = None
+    return known_paths
+
+
+def addsitepackages(known_paths, sys_prefix=sys.prefix, exec_prefix=sys.exec_prefix):
+    """Add site-packages (and possibly site-python) to sys.path"""
+    prefixes = [os.path.join(sys_prefix, "local"), sys_prefix]
+    if exec_prefix != sys_prefix:
+        prefixes.append(os.path.join(exec_prefix, "local"))
+
+    for prefix in prefixes:
+        if prefix:
+            if sys.platform in ("os2emx", "riscos") or _is_jython:
+                sitedirs = [os.path.join(prefix, "Lib", "site-packages")]
+            elif _is_pypy:
+                sitedirs = [os.path.join(prefix, "site-packages")]
+            elif sys.platform == "darwin" and prefix == sys_prefix:
+
+                if prefix.startswith("/System/Library/Frameworks/"):  # Apple's Python
+
+                    sitedirs = [
+                        os.path.join("/Library/Python", sys.version[:3], "site-packages"),
+                        os.path.join(prefix, "Extras", "lib", "python"),
+                    ]
+
+                else:  # any other Python distros on OSX work this way
+                    sitedirs = [os.path.join(prefix, "lib", "python" + sys.version[:3], "site-packages")]
+
+            elif os.sep == "/":
+                sitedirs = [
+                    os.path.join(prefix, "lib", "python" + sys.version[:3], "site-packages"),
+                    os.path.join(prefix, "lib", "site-python"),
+                    os.path.join(prefix, "python" + sys.version[:3], "lib-dynload"),
+                ]
+                lib64_dir = os.path.join(prefix, "lib64", "python" + sys.version[:3], "site-packages")
+                if os.path.exists(lib64_dir) and os.path.realpath(lib64_dir) not in [
+                    os.path.realpath(p) for p in sitedirs
+                ]:
+                    if _is_64bit:
+                        sitedirs.insert(0, lib64_dir)
+                    else:
+                        sitedirs.append(lib64_dir)
+                try:
+                    # sys.getobjects only available in --with-pydebug build
+                    sys.getobjects
+                    sitedirs.insert(0, os.path.join(sitedirs[0], "debug"))
+                except AttributeError:
+                    pass
+                # Debian-specific dist-packages directories:
+                sitedirs.append(os.path.join(prefix, "local/lib", "python" + sys.version[:3], "dist-packages"))
+                if sys.version[0] == "2":
+                    sitedirs.append(os.path.join(prefix, "lib", "python" + sys.version[:3], "dist-packages"))
+                else:
+                    sitedirs.append(os.path.join(prefix, "lib", "python" + sys.version[0], "dist-packages"))
+                sitedirs.append(os.path.join(prefix, "lib", "dist-python"))
+            else:
+                sitedirs = [prefix, os.path.join(prefix, "lib", "site-packages")]
+            if sys.platform == "darwin":
+                # for framework builds *only* we add the standard Apple
+                # locations. Currently only per-user, but /Library and
+                # /Network/Library could be added too
+                if "Python.framework" in prefix:
+                    home = os.environ.get("HOME")
+                    if home:
+                        sitedirs.append(os.path.join(home, "Library", "Python", sys.version[:3], "site-packages"))
+            for sitedir in sitedirs:
+                if os.path.isdir(sitedir):
+                    addsitedir(sitedir, known_paths)
+    return None
+
+
+def check_enableusersite():
+    """Check if user site directory is safe for inclusion
+
+    The function tests for the command line flag (including environment var),
+    process uid/gid equal to effective uid/gid.
+
+    None: Disabled for security reasons
+    False: Disabled by user (command line option)
+    True: Safe and enabled
+    """
+    if hasattr(sys, "flags") and getattr(sys.flags, "no_user_site", False):
+        return False
+
+    if hasattr(os, "getuid") and hasattr(os, "geteuid"):
+        # check process uid == effective uid
+        if os.geteuid() != os.getuid():
+            return None
+    if hasattr(os, "getgid") and hasattr(os, "getegid"):
+        # check process gid == effective gid
+        if os.getegid() != os.getgid():
+            return None
+
+    return True
+
+
+def addusersitepackages(known_paths):
+    """Add a per user site-package to sys.path
+
+    Each user has its own python directory with site-packages in the
+    home directory.
+
+    USER_BASE is the root directory for all Python versions
+
+    USER_SITE is the user specific site-packages directory
+
+    USER_SITE/.. can be used for data.
+    """
+    global USER_BASE, USER_SITE, ENABLE_USER_SITE
+    env_base = os.environ.get("PYTHONUSERBASE", None)
+
+    def joinuser(*args):
+        return os.path.expanduser(os.path.join(*args))
+
+    # if sys.platform in ('os2emx', 'riscos'):
+    #    # Don't know what to put here
+    #    USER_BASE = ''
+    #    USER_SITE = ''
+    if os.name == "nt":
+        base = os.environ.get("APPDATA") or "~"
+        if env_base:
+            USER_BASE = env_base
+        else:
+            USER_BASE = joinuser(base, "Python")
+        USER_SITE = os.path.join(USER_BASE, "Python" + sys.version[0] + sys.version[2], "site-packages")
+    else:
+        if env_base:
+            USER_BASE = env_base
+        else:
+            USER_BASE = joinuser("~", ".local")
+        USER_SITE = os.path.join(USER_BASE, "lib", "python" + sys.version[:3], "site-packages")
+
+    if ENABLE_USER_SITE and os.path.isdir(USER_SITE):
+        addsitedir(USER_SITE, known_paths)
+    if ENABLE_USER_SITE:
+        for dist_libdir in ("lib", "local/lib"):
+            user_site = os.path.join(USER_BASE, dist_libdir, "python" + sys.version[:3], "dist-packages")
+            if os.path.isdir(user_site):
+                addsitedir(user_site, known_paths)
+    return known_paths
+
+
+def setBEGINLIBPATH():
+    """The OS/2 EMX port has optional extension modules that do double duty
+    as DLLs (and must use the .DLL file extension) for other extensions.
+    The library search path needs to be amended so these will be found
+    during module import.  Use BEGINLIBPATH so that these are at the start
+    of the library search path.
+
+    """
+    dllpath = os.path.join(sys.prefix, "Lib", "lib-dynload")
+    libpath = os.environ["BEGINLIBPATH"].split(";")
+    if libpath[-1]:
+        libpath.append(dllpath)
+    else:
+        libpath[-1] = dllpath
+    os.environ["BEGINLIBPATH"] = ";".join(libpath)
+
+
+def setquit():
+    """Define new built-ins 'quit' and 'exit'.
+    These are simply strings that display a hint on how to exit.
+
+    """
+    if os.sep == ":":
+        eof = "Cmd-Q"
+    elif os.sep == "\\":
+        eof = "Ctrl-Z plus Return"
+    else:
+        eof = "Ctrl-D (i.e. EOF)"
+
+    class Quitter(object):
+        def __init__(self, name):
+            self.name = name
+
+        def __repr__(self):
+            return "Use {}() or {} to exit".format(self.name, eof)
+
+        def __call__(self, code=None):
+            # Shells like IDLE catch the SystemExit, but listen when their
+            # stdin wrapper is closed.
+            try:
+                sys.stdin.close()
+            except:
+                pass
+            raise SystemExit(code)
+
+    builtins.quit = Quitter("quit")
+    builtins.exit = Quitter("exit")
+
+
+class _Printer(object):
+    """interactive prompt objects for printing the license text, a list of
+    contributors and the copyright notice."""
+
+    MAXLINES = 23
+
+    def __init__(self, name, data, files=(), dirs=()):
+        self.__name = name
+        self.__data = data
+        self.__files = files
+        self.__dirs = dirs
+        self.__lines = None
+
+    def __setup(self):
+        if self.__lines:
+            return
+        data = None
+        for dir in self.__dirs:
+            for filename in self.__files:
+                filename = os.path.join(dir, filename)
+                try:
+                    fp = open(filename, "r")
+                    data = fp.read()
+                    fp.close()
+                    break
+                except IOError:
+                    pass
+            if data:
+                break
+        if not data:
+            data = self.__data
+        self.__lines = data.split("\n")
+        self.__linecnt = len(self.__lines)
+
+    def __repr__(self):
+        self.__setup()
+        if len(self.__lines) <= self.MAXLINES:
+            return "\n".join(self.__lines)
+        else:
+            return "Type %s() to see the full %s text" % ((self.__name,) * 2)
+
+    def __call__(self):
+        self.__setup()
+        prompt = "Hit Return for more, or q (and Return) to quit: "
+        lineno = 0
+        while 1:
+            try:
+                for i in range(lineno, lineno + self.MAXLINES):
+                    print(self.__lines[i])
+            except IndexError:
+                break
+            else:
+                lineno += self.MAXLINES
+                key = None
+                while key is None:
+                    try:
+                        key = raw_input(prompt)
+                    except NameError:
+                        key = input(prompt)
+                    if key not in ("", "q"):
+                        key = None
+                if key == "q":
+                    break
+
+
+def setcopyright():
+    """Set 'copyright' and 'credits' in __builtin__"""
+    builtins.copyright = _Printer("copyright", sys.copyright)
+    if _is_jython:
+        builtins.credits = _Printer("credits", "Jython is maintained by the Jython developers (www.jython.org).")
+    elif _is_pypy:
+        builtins.credits = _Printer("credits", "PyPy is maintained by the PyPy developers: http://pypy.org/")
+    else:
+        builtins.credits = _Printer(
+            "credits",
+            """\
+    Thanks to CWI, CNRI, BeOpen.com, Zope Corporation and a cast of thousands
+    for supporting Python development.  See www.python.org for more information.""",
+        )
+    here = os.path.dirname(os.__file__)
+    builtins.license = _Printer(
+        "license",
+        "See https://www.python.org/psf/license/",
+        ["LICENSE.txt", "LICENSE"],
+        [sys.prefix, os.path.join(here, os.pardir), here, os.curdir],
+    )
+
+
+class _Helper(object):
+    """Define the built-in 'help'.
+    This is a wrapper around pydoc.help (with a twist).
+
+    """
+
+    def __repr__(self):
+        return "Type help() for interactive help, " "or help(object) for help about object."
+
+    def __call__(self, *args, **kwds):
+        import pydoc
+
+        return pydoc.help(*args, **kwds)
+
+
+def sethelper():
+    builtins.help = _Helper()
+
+
+def aliasmbcs():
+    """On Windows, some default encodings are not provided by Python,
+    while they are always available as "mbcs" in each locale. Make
+    them usable by aliasing to "mbcs" in such a case."""
+    if sys.platform == "win32":
+        import locale, codecs
+
+        enc = locale.getdefaultlocale()[1]
+        if enc.startswith("cp"):  # "cp***" ?
+            try:
+                codecs.lookup(enc)
+            except LookupError:
+                import encodings
+
+                encodings._cache[enc] = encodings._unknown
+                encodings.aliases.aliases[enc] = "mbcs"
+
+
+def setencoding():
+    """Set the string encoding used by the Unicode implementation.  The
+    default is 'ascii', but if you're willing to experiment, you can
+    change this."""
+    encoding = "ascii"  # Default value set by _PyUnicode_Init()
+    if 0:
+        # Enable to support locale aware default string encodings.
+        import locale
+
+        loc = locale.getdefaultlocale()
+        if loc[1]:
+            encoding = loc[1]
+    if 0:
+        # Enable to switch off string to Unicode coercion and implicit
+        # Unicode to string conversion.
+        encoding = "undefined"
+    if encoding != "ascii":
+        # On Non-Unicode builds this will raise an AttributeError...
+        sys.setdefaultencoding(encoding)  # Needs Python Unicode build !
+
+
+def execsitecustomize():
+    """Run custom site specific code, if available."""
+    try:
+        import sitecustomize
+    except ImportError:
+        pass
+
+
+def virtual_install_main_packages():
+    f = open(os.path.join(os.path.dirname(__file__), "orig-prefix.txt"))
+    sys.real_prefix = f.read().strip()
+    f.close()
+    pos = 2
+    hardcoded_relative_dirs = []
+    if sys.path[0] == "":
+        pos += 1
+    if _is_jython:
+        paths = [os.path.join(sys.real_prefix, "Lib")]
+    elif _is_pypy:
+        if sys.version_info > (3, 2):
+            cpyver = "%d" % sys.version_info[0]
+        elif sys.pypy_version_info >= (1, 5):
+            cpyver = "%d.%d" % sys.version_info[:2]
+        else:
+            cpyver = "%d.%d.%d" % sys.version_info[:3]
+        paths = [os.path.join(sys.real_prefix, "lib_pypy"), os.path.join(sys.real_prefix, "lib-python", cpyver)]
+        if sys.pypy_version_info < (1, 9):
+            paths.insert(1, os.path.join(sys.real_prefix, "lib-python", "modified-%s" % cpyver))
+        hardcoded_relative_dirs = paths[:]  # for the special 'darwin' case below
+        #
+        # This is hardcoded in the Python executable, but relative to sys.prefix:
+        for path in paths[:]:
+            plat_path = os.path.join(path, "plat-%s" % sys.platform)
+            if os.path.exists(plat_path):
+                paths.append(plat_path)
+    elif sys.platform == "win32":
+        paths = [os.path.join(sys.real_prefix, "Lib"), os.path.join(sys.real_prefix, "DLLs")]
+    else:
+        paths = [os.path.join(sys.real_prefix, "lib", "python" + sys.version[:3])]
+        hardcoded_relative_dirs = paths[:]  # for the special 'darwin' case below
+        lib64_path = os.path.join(sys.real_prefix, "lib64", "python" + sys.version[:3])
+        if os.path.exists(lib64_path):
+            if _is_64bit:
+                paths.insert(0, lib64_path)
+            else:
+                paths.append(lib64_path)
+        # This is hardcoded in the Python executable, but relative to
+        # sys.prefix.  Debian change: we need to add the multiarch triplet
+        # here, which is where the real stuff lives.  As per PEP 421, in
+        # Python 3.3+, this lives in sys.implementation, while in Python 2.7
+        # it lives in sys.
+        try:
+            arch = getattr(sys, "implementation", sys)._multiarch
+        except AttributeError:
+            # This is a non-multiarch aware Python.  Fallback to the old way.
+            arch = sys.platform
+        plat_path = os.path.join(sys.real_prefix, "lib", "python" + sys.version[:3], "plat-%s" % arch)
+        if os.path.exists(plat_path):
+            paths.append(plat_path)
+    # This is hardcoded in the Python executable, but
+    # relative to sys.prefix, so we have to fix up:
+    for path in list(paths):
+        tk_dir = os.path.join(path, "lib-tk")
+        if os.path.exists(tk_dir):
+            paths.append(tk_dir)
+
+    # These are hardcoded in the Apple's Python executable,
+    # but relative to sys.prefix, so we have to fix them up:
+    if sys.platform == "darwin":
+        hardcoded_paths = [
+            os.path.join(relative_dir, module)
+            for relative_dir in hardcoded_relative_dirs
+            for module in ("plat-darwin", "plat-mac", "plat-mac/lib-scriptpackages")
+        ]
+
+        for path in hardcoded_paths:
+            if os.path.exists(path):
+                paths.append(path)
+
+    sys.path.extend(paths)
+
+
+def force_global_eggs_after_local_site_packages():
+    """
+    Force easy_installed eggs in the global environment to get placed
+    in sys.path after all packages inside the virtualenv.  This
+    maintains the "least surprise" result that packages in the
+    virtualenv always mask global packages, never the other way
+    around.
+
+    """
+    egginsert = getattr(sys, "__egginsert", 0)
+    for i, path in enumerate(sys.path):
+        if i > egginsert and path.startswith(sys.prefix):
+            egginsert = i
+    sys.__egginsert = egginsert + 1
+
+
+def virtual_addsitepackages(known_paths):
+    force_global_eggs_after_local_site_packages()
+    return addsitepackages(known_paths, sys_prefix=sys.real_prefix)
+
+
+def fixclasspath():
+    """Adjust the special classpath sys.path entries for Jython. These
+    entries should follow the base virtualenv lib directories.
+    """
+    paths = []
+    classpaths = []
+    for path in sys.path:
+        if path == "__classpath__" or path.startswith("__pyclasspath__"):
+            classpaths.append(path)
+        else:
+            paths.append(path)
+    sys.path = paths
+    sys.path.extend(classpaths)
+
+
+def execusercustomize():
+    """Run custom user specific code, if available."""
+    try:
+        import usercustomize
+    except ImportError:
+        pass
+
+
+def enablerlcompleter():
+    """Enable default readline configuration on interactive prompts, by
+    registering a sys.__interactivehook__.
+    If the readline module can be imported, the hook will set the Tab key
+    as completion key and register ~/.python_history as history file.
+    This can be overridden in the sitecustomize or usercustomize module,
+    or in a PYTHONSTARTUP file.
+    """
+
+    def register_readline():
+        import atexit
+
+        try:
+            import readline
+            import rlcompleter
+        except ImportError:
+            return
+
+        # Reading the initialization (config) file may not be enough to set a
+        # completion key, so we set one first and then read the file.
+        readline_doc = getattr(readline, "__doc__", "")
+        if readline_doc is not None and "libedit" in readline_doc:
+            readline.parse_and_bind("bind ^I rl_complete")
+        else:
+            readline.parse_and_bind("tab: complete")
+
+        try:
+            readline.read_init_file()
+        except OSError:
+            # An OSError here could have many causes, but the most likely one
+            # is that there's no .inputrc file (or .editrc file in the case of
+            # Mac OS X + libedit) in the expected location.  In that case, we
+            # want to ignore the exception.
+            pass
+
+        if readline.get_current_history_length() == 0:
+            # If no history was loaded, default to .python_history.
+            # The guard is necessary to avoid doubling history size at
+            # each interpreter exit when readline was already configured
+            # through a PYTHONSTARTUP hook, see:
+            # http://bugs.python.org/issue5845#msg198636
+            history = os.path.join(os.path.expanduser("~"), ".python_history")
+            try:
+                readline.read_history_file(history)
+            except OSError:
+                pass
+
+            def write_history():
+                try:
+                    readline.write_history_file(history)
+                except (FileNotFoundError, PermissionError):
+                    # home directory does not exist or is not writable
+                    # https://bugs.python.org/issue19891
+                    pass
+
+            atexit.register(write_history)
+
+    sys.__interactivehook__ = register_readline
+
+
+if _is_pypy:
+
+    def import_builtin_stuff():
+        """PyPy specific: some built-in modules should be pre-imported because
+        some programs expect them to be in sys.modules on startup. This is ported
+        from PyPy's site.py.
+        """
+        import encodings
+
+        if "exceptions" in sys.builtin_module_names:
+            import exceptions
+
+        if "zipimport" in sys.builtin_module_names:
+            import zipimport
+
+
+def main():
+    global ENABLE_USER_SITE
+    virtual_install_main_packages()
+    if _is_pypy:
+        import_builtin_stuff()
+    abs__file__()
+    paths_in_sys = removeduppaths()
+    if os.name == "posix" and sys.path and os.path.basename(sys.path[-1]) == "Modules":
+        addbuilddir()
+    if _is_jython:
+        fixclasspath()
+    GLOBAL_SITE_PACKAGES = not os.path.exists(os.path.join(os.path.dirname(__file__), "no-global-site-packages.txt"))
+    if not GLOBAL_SITE_PACKAGES:
+        ENABLE_USER_SITE = False
+    if ENABLE_USER_SITE is None:
+        ENABLE_USER_SITE = check_enableusersite()
+    paths_in_sys = addsitepackages(paths_in_sys)
+    paths_in_sys = addusersitepackages(paths_in_sys)
+    if GLOBAL_SITE_PACKAGES:
+        paths_in_sys = virtual_addsitepackages(paths_in_sys)
+    if sys.platform == "os2emx":
+        setBEGINLIBPATH()
+    setquit()
+    setcopyright()
+    sethelper()
+    if sys.version_info[0] == 3:
+        enablerlcompleter()
+    aliasmbcs()
+    setencoding()
+    execsitecustomize()
+    if ENABLE_USER_SITE:
+        execusercustomize()
+    # Remove sys.setdefaultencoding() so that users cannot change the
+    # encoding after initialization.  The test for presence is needed when
+    # this module is run as a script, because this code is executed twice.
+    if hasattr(sys, "setdefaultencoding"):
+        del sys.setdefaultencoding
+
+
+main()
+
+
+def _script():
+    help = """\
+    %s [--user-base] [--user-site]
+
+    Without arguments print some useful information
+    With arguments print the value of USER_BASE and/or USER_SITE separated
+    by '%s'.
+
+    Exit codes with --user-base or --user-site:
+      0 - user site directory is enabled
+      1 - user site directory is disabled by user
+      2 - uses site directory is disabled by super user
+          or for security reasons
+     >2 - unknown error
+    """
+    args = sys.argv[1:]
+    if not args:
+        print("sys.path = [")
+        for dir in sys.path:
+            print("    {!r},".format(dir))
+        print("]")
+
+        def exists(path):
+            if os.path.isdir(path):
+                return "exists"
+            else:
+                return "doesn't exist"
+
+        print("USER_BASE: {!r} ({})".format(USER_BASE, exists(USER_BASE)))
+        print("USER_SITE: {!r} ({})".format(USER_SITE, exists(USER_SITE)))
+        print("ENABLE_USER_SITE: %r" % ENABLE_USER_SITE)
+        sys.exit(0)
+
+    buffer = []
+    if "--user-base" in args:
+        buffer.append(USER_BASE)
+    if "--user-site" in args:
+        buffer.append(USER_SITE)
+
+    if buffer:
+        print(os.pathsep.join(buffer))
+        if ENABLE_USER_SITE:
+            sys.exit(0)
+        elif ENABLE_USER_SITE is False:
+            sys.exit(1)
+        elif ENABLE_USER_SITE is None:
+            sys.exit(2)
+        else:
+            sys.exit(3)
+    else:
+        import textwrap
+
+        print(textwrap.dedent(help % (sys.argv[0], os.pathsep)))
+        sys.exit(10)
+
+
+if __name__ == "__main__":
+    _script()
diff --git a/tests/python/assert_test01/venv/lib/python2.7/site.pyc b/tests/python/assert_test01/venv/lib/python2.7/site.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..a9156a24418aa5bf7a39ecad585c0a32ec2e95a3
GIT binary patch
literal 28489
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
V{G1$|Hf&5he4Og+%$ycHi~xo(xETNd

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/sre.py b/tests/python/assert_test01/venv/lib/python2.7/sre.py
new file mode 120000
index 0000000..282157f
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/sre.py
@@ -0,0 +1 @@
+/System/Library/Frameworks/Python.framework/Versions/2.7/lib/python2.7/sre.py
\ No newline at end of file
diff --git a/tests/python/assert_test01/venv/lib/python2.7/sre_compile.py b/tests/python/assert_test01/venv/lib/python2.7/sre_compile.py
new file mode 120000
index 0000000..aae5060
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/sre_compile.py
@@ -0,0 +1 @@
+/System/Library/Frameworks/Python.framework/Versions/2.7/lib/python2.7/sre_compile.py
\ No newline at end of file
diff --git a/tests/python/assert_test01/venv/lib/python2.7/sre_compile.pyc b/tests/python/assert_test01/venv/lib/python2.7/sre_compile.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..dcabd43ee4636932c3726a077f50e7c8007c40ca
GIT binary patch
literal 13414
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
E01NpYDgXcg

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/sre_constants.py b/tests/python/assert_test01/venv/lib/python2.7/sre_constants.py
new file mode 120000
index 0000000..ec54ee3
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/sre_constants.py
@@ -0,0 +1 @@
+/System/Library/Frameworks/Python.framework/Versions/2.7/lib/python2.7/sre_constants.py
\ No newline at end of file
diff --git a/tests/python/assert_test01/venv/lib/python2.7/sre_constants.pyc b/tests/python/assert_test01/venv/lib/python2.7/sre_constants.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..88e6f8eafcebc6db25b2bafe031adc60790ab363
GIT binary patch
literal 6480
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
IcuZW30NhXtKL7v#

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/sre_parse.py b/tests/python/assert_test01/venv/lib/python2.7/sre_parse.py
new file mode 120000
index 0000000..ee2f0c3
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/sre_parse.py
@@ -0,0 +1 @@
+/System/Library/Frameworks/Python.framework/Versions/2.7/lib/python2.7/sre_parse.py
\ No newline at end of file
diff --git a/tests/python/assert_test01/venv/lib/python2.7/sre_parse.pyc b/tests/python/assert_test01/venv/lib/python2.7/sre_parse.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..c4b732aaa9bf0253fa525c393b0fde6a388cd674
GIT binary patch
literal 22069
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

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/stat.py b/tests/python/assert_test01/venv/lib/python2.7/stat.py
new file mode 120000
index 0000000..f406b15
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/stat.py
@@ -0,0 +1 @@
+/System/Library/Frameworks/Python.framework/Versions/2.7/lib/python2.7/stat.py
\ No newline at end of file
diff --git a/tests/python/assert_test01/venv/lib/python2.7/stat.pyc b/tests/python/assert_test01/venv/lib/python2.7/stat.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..a61ddd6a7f17615a7ddeb0e6ec9bc5896477f387
GIT binary patch
literal 3321
zcmZSn%*(a?MnOz60~9baFfceUFfbHXGcquwFfc?hFr+XtL@_d?Ffl|iF{CgvL@_g@
zurNfiFr=_DM6oiYurWljF{H3FM6olZa4<x1Fr;uYL~$~ta4|%2F{E%av@kG4aWkaw
zfEhdtDZC6(ybLLP3{iXxDf|pk{0u1q3{e6MDS`}9f($7_3{gT1DZ&g<!VD=QU@amH
zDWYJ8C_{=Em?6fHA`WJVGo(m>84?UBl3<1;Ly8obA;pj)%@8HckRrnnCBu*^!w@CQ
zkRr<vCC88=#}FmYkRs0zrNEG)z!0U#kfO*Cr34mN28*kJ#Z?(nlo+Da7*doOqSP5u
zR2ZT(z+Te?ds7SSeQj`n=zs%97fkAbMfAb424MAuV7*3QbBw{BHDO3mWr#9mNKs>m
zGGj<lXNWRqNYP-3vS3KjWQek4NYP>l*3bq;LOufngL8gfaY<rcNwI!fX<l+kW`16=
zLRx;2LS|k`YEeN^YDs2Zx<XNEacNFTu|j^DLVmGcaY<r{hNePdUJ8hp1L5j%aRryA
zr>7Q|q^2m87AK~sS}CLz<>xAZq!luA3-XIf6tuW9K?xxflngSN7#J8bnLz{#h+qW~
zY#@RiL~wuzP6h^sWRPMI2B~)jIU6KZ15P*&!5Sb@zs&#q3=A3|qcuP(OF#zZ=BK1W
zgh1lOp$rTR`k}?CMaBAQMX8C|`Yx%(*(Lb}`YHKY`MMdY1(}KZC8@<F#rg%6B^mj7
z`iaHGsYNC6ATa|&{j$`&GX0#)B&e*Bp1D5AV|oRZB_QVp$9wwvySR#ioCk6d10zw+
zX83^Y>>!Xs>EdKiFbBtby7`7kAY7aY%9)uA3JeUH3<)5j0YnIZhy@_x0JgXgU|?V<
zVPL3XU}$D!C}CvCW?~2i$AKR>W`aP00Sh5F7tbKD9Q`~BjhkSQ%?O`j#tli{aP}A|
zZ#a7dfio^BRIw#7lDy&M<2^vJ;pF43N43}pa&;ddZv?rz8&b_1o^Jkh_6DdJ4UYE=
zcJp-eH=&w8eEbF~Rr&aNn^Wu!XrQ<S`#aOyA5g1<K~`HKJd(-40V;i2Km-$rU}Rv(
zYyj1cpoUcD0T9;$#8m(hpb{XHfq{`BlYxN=M6iGe0T7|U;HLpH7hD|2$EV~c$H#-&
z!6EUW%BuuiD}=;*`uW3{F0NrEU}uHI`}uhKdBem*JzZc-cTX3XA;F$et}x|}A)dZ)
zjxRFD8N>+!Rny?gAqdn02m)39L7>7q2vp?<aWgP51o46heh>kw&VxX%3j#SNhzlgf
z10wi91jx$}C&YUOgIoqO2b8ekPK$T-bMp;>s|gE<fU$#I9bF(!j`s`?@(gi>Nw`M1
zI>XpO;Sr&5c4%-Aj2(`|jzD4ug-5u<)C9Q)1;E(hNbCqCc2IbPKTJ)Ke~1T+9gf6~
z0I@+~6Y3W4=kF5g8&CoYfl#-2Pha2A5Jx8;*Al3-V?cnbp9_rVAK(}m>RJK{QLxrf
zNJN4HH`FcO+21!H$Tc|F6|UaH)5XQr53D}eE#5K6*~2r;)dg%>FuG+R1rW<X#s`C3
z1~nea5B75m2=?#~K{RT>EE+b(KncVqH$SB`C)Ey=Y>JB*7#P@C*cdS&3nw!t8;U4M
VgqaftSyALL^+QCknas$>2mmG=uo?gW

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/types.py b/tests/python/assert_test01/venv/lib/python2.7/types.py
new file mode 120000
index 0000000..4769ef6
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/types.py
@@ -0,0 +1 @@
+/System/Library/Frameworks/Python.framework/Versions/2.7/lib/python2.7/types.py
\ No newline at end of file
diff --git a/tests/python/assert_test01/venv/lib/python2.7/types.pyc b/tests/python/assert_test01/venv/lib/python2.7/types.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..56f5454cc15ef7e85cb8b85840559fe6146cce57
GIT binary patch
literal 3124
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
ZVhTjJ09YM66B{EB6F(ylGe{3V69Dv|<|F_B

literal 0
HcmV?d00001

diff --git a/tests/python/assert_test01/venv/lib/python2.7/warnings.py b/tests/python/assert_test01/venv/lib/python2.7/warnings.py
new file mode 120000
index 0000000..68ff8e6
--- /dev/null
+++ b/tests/python/assert_test01/venv/lib/python2.7/warnings.py
@@ -0,0 +1 @@
+/System/Library/Frameworks/Python.framework/Versions/2.7/lib/python2.7/warnings.py
\ No newline at end of file
diff --git a/tests/python/assert_test01/venv/lib/python2.7/warnings.pyc b/tests/python/assert_test01/venv/lib/python2.7/warnings.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..746433c35b609fc713d17ac10de0774782212fe7
GIT binary patch
literal 14489
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

literal 0
HcmV?d00001

diff --git a/tests/serveur_compilation/front-end-compilation/src/app/app.component.css b/tests/serveur_compilation/front-end-compilation/src/app/app.component.css
index e69de29..5dc97c4 100644
--- a/tests/serveur_compilation/front-end-compilation/src/app/app.component.css
+++ b/tests/serveur_compilation/front-end-compilation/src/app/app.component.css
@@ -0,0 +1,5 @@
+h1{
+  color:white;
+  font-family: Arial;
+  margin-left:20px;
+}
diff --git a/tests/serveur_compilation/front-end-compilation/src/app/app.component.html b/tests/serveur_compilation/front-end-compilation/src/app/app.component.html
index 8b60453..f75c4ae 100644
--- a/tests/serveur_compilation/front-end-compilation/src/app/app.component.html
+++ b/tests/serveur_compilation/front-end-compilation/src/app/app.component.html
@@ -1,5 +1,2 @@
 <h1>TEST CODE COMPILATION</h1>
 <app-compilateur></app-compilateur>
-
-
-//voir le voc du kata
diff --git a/tests/serveur_compilation/front-end-compilation/src/app/compilateur/compilateur.component.css b/tests/serveur_compilation/front-end-compilation/src/app/compilateur/compilateur.component.css
index e69de29..2a6ac6c 100644
--- a/tests/serveur_compilation/front-end-compilation/src/app/compilateur/compilateur.component.css
+++ b/tests/serveur_compilation/front-end-compilation/src/app/compilateur/compilateur.component.css
@@ -0,0 +1,43 @@
+textarea {
+  background-color: rgba(43, 47, 57, 1);
+  border: 0;
+  color: white;
+  margin: 20px;
+  border-radius: 12px;
+  padding: 10px;
+  resize: none;
+}
+
+button {
+  background-color: rgba(43, 47, 57, 1);
+  border: 0;
+  color: white;
+  margin: 20px;
+  border-radius: 12px;
+  padding: 10px;
+  outline: none;
+}
+
+button:hover {
+  background-color: rgba(52, 73, 94, 1.0);
+}
+
+.error {
+  border: 3px rgba(192, 57, 43, 0.8) solid;
+  background-color: rgba(192, 57, 43, 0.2);
+}
+
+.success {
+  border: 3px rgba(39, 174, 96,1.0) solid;
+  background-color: rgba(39, 174, 96,0.2);
+}
+
+select {
+  padding-left: 10px;
+  background-color: rgba(43, 47, 57, 1);
+  border: 0;
+  color: white;
+  margin: 20px;
+  border-radius: 12px;
+
+}
diff --git a/tests/serveur_compilation/front-end-compilation/src/app/compilateur/compilateur.component.html b/tests/serveur_compilation/front-end-compilation/src/app/compilateur/compilateur.component.html
index 65d59a9..62c147c 100644
--- a/tests/serveur_compilation/front-end-compilation/src/app/compilateur/compilateur.component.html
+++ b/tests/serveur_compilation/front-end-compilation/src/app/compilateur/compilateur.component.html
@@ -4,10 +4,19 @@
   <option value="java">Java</option>
 </select>
 <br/>
-<br/>
 
-<textarea  rows="20" cols="100" [(ngModel)]="placeholer" >
+<br/>
+<textarea disabled rows="20" cols="100" [(ngModel)]="help">
+</textarea>
+<textarea rows="20" cols="100" [(ngModel)]="placeholer">
 </textarea>
 <br/>
-<button *ngIf="display_button" (click)="compile(placeholer)" class="code">compile</button>
-<p style="white-space: pre-wrap">{{result}}</p>
+<textarea disabled rows="20" cols="100" [(ngModel)]="assert">
+</textarea>
+<textarea [ngClass]="{'success':status === 0,'error':status === 1,'':status === 2}" style="white-space: pre-wrap" disabled rows="20" cols="100"
+          [(ngModel)]="result">
+</textarea>
+<br/>
+<button *ngIf="display_button" (click)="compile(placeholer,assert)" class="code">compile</button>
+<!--<p style="white-space: pre-wrap">{{result}}</p>-->
+
diff --git a/tests/serveur_compilation/front-end-compilation/src/app/compilateur/compilateur.component.ts b/tests/serveur_compilation/front-end-compilation/src/app/compilateur/compilateur.component.ts
index 65992e6..ae57708 100644
--- a/tests/serveur_compilation/front-end-compilation/src/app/compilateur/compilateur.component.ts
+++ b/tests/serveur_compilation/front-end-compilation/src/app/compilateur/compilateur.component.ts
@@ -18,19 +18,31 @@ export class CompilateurComponent implements OnInit {
 
   type = 'help';
 
+  assert = 'Assert that will be tested with the chosen language';
+
   display_button = false;
 
+  help = '';
+
+  status = 2;
+  error = {
+    'background-color': 'blue',
+  }
+
+
   update(event: any): void {
     this.type = event.target.value;
     this.display_button = true;
     if (this.type === 'python') {
 
-      this.placeholer = 'def avg(marks):\n' +
-        '  assert len(marks) != 0\n' +
-        '  return sum(marks)/len(marks)\n' +
+      this.placeholer = 'def easyline(n):';
+      this.help = 'Le but ici est de jouer avec les tableaux en python. dans cet exercice, il faut multiplier tous les éléments d\'un tableau par 2.\neasyline([2,4]) donnera par exemple [4,8]';
+      this.assert = 'from assertpy import assert_that\n' +
+        'import sample as m\n' +
         '\n' +
-        'mark1 = []\n' +
-        'print("Average of mark1:",avg(mark1))';
+        'assert_that(m.easyline([1,2])).is_equal_to([2,4])\n' +
+        'assert_that(m.easyline([45,53,12])).is_equal_to([90,106,24])\n' +
+        'assert_that(m.easyline([3])).is_equal_to([6])';
     } else if (this.type === 'java') {
       this.placeholer = 'public class HelloWorld {\n' +
         '\n' +
@@ -46,15 +58,19 @@ export class CompilateurComponent implements OnInit {
     }
   }
 
-  compile(stream: string): void {
+  compile(stream: string, assert: string): void {
+
+    const response = $.parseJSON(this.compilation.compile(this.type, stream, assert));
 
-    const response = $.parseJSON(this.compilation.compile(this.type, stream));
-    console.log(response);
     if (response.exit === 0) {
-      this.result = response.output + '\nExecuted in : ' + response.time + 'ms';
+      this.status = 0;
+      this.result = response.output + '\nExercise passed';
     } else {
+      this.status = 1;
       this.result = response.error;
     }
+
+    this.result += '\nExecuted in : ' + response.time + 'ms';
   }
 
   ngOnInit() {
diff --git a/tests/serveur_compilation/front-end-compilation/src/app/compilation.service.ts b/tests/serveur_compilation/front-end-compilation/src/app/compilation.service.ts
index a65b1bc..aa141a6 100644
--- a/tests/serveur_compilation/front-end-compilation/src/app/compilation.service.ts
+++ b/tests/serveur_compilation/front-end-compilation/src/app/compilation.service.ts
@@ -5,7 +5,7 @@ import * as $ from 'jquery';
   providedIn: 'root'
 })
 export class CompilationService {
-  compile(type: string, stream: string): string {
+  compile(type: string, stream: string, assert: string): string {
     let response = '';
 
     $.ajax({
@@ -14,7 +14,8 @@ export class CompilationService {
       async: false,
       data: {
         language: type,
-        code: stream
+        code: stream,
+        test: assert
       },
       success(data) {
         response = data;
diff --git a/tests/serveur_compilation/front-end-compilation/src/styles.css b/tests/serveur_compilation/front-end-compilation/src/styles.css
index 90d4ee0..5fd72c4 100644
--- a/tests/serveur_compilation/front-end-compilation/src/styles.css
+++ b/tests/serveur_compilation/front-end-compilation/src/styles.css
@@ -1 +1,4 @@
 /* You can add global styles to this file, and also import other style files */
+body{
+  background-color:rgba(47,54,64,1);
+}
diff --git a/tests/serveur_compilation/server_rest/.idea/compiler.xml b/tests/serveur_compilation/server_rest/.idea/compiler.xml
index 9e98988..14146fd 100644
--- a/tests/serveur_compilation/server_rest/.idea/compiler.xml
+++ b/tests/serveur_compilation/server_rest/.idea/compiler.xml
@@ -7,6 +7,7 @@
         <sourceTestOutputDir name="target/generated-test-sources/test-annotations" />
         <outputRelativeToContentRoot value="true" />
         <module name="server_rest_new" />
+        <module name="09" />
       </profile>
     </annotationProcessing>
   </component>
diff --git a/tests/serveur_compilation/server_rest/.idea/workspace.xml b/tests/serveur_compilation/server_rest/.idea/workspace.xml
index c66b679..cdcbdca 100644
--- a/tests/serveur_compilation/server_rest/.idea/workspace.xml
+++ b/tests/serveur_compilation/server_rest/.idea/workspace.xml
@@ -2,9 +2,23 @@
 <project version="4">
   <component name="ChangeListManager">
     <list default="true" id="e6a1f2e5-4f60-4227-82bb-83eb10fa94a5" name="Default Changelist" comment="">
-      <change beforePath="$PROJECT_DIR$/../../javalin/javalin_heroes_provider/.idea/workspace.xml" beforeDir="false" afterPath="$PROJECT_DIR$/../../javalin/javalin_heroes_provider/.idea/workspace.xml" afterDir="false" />
-      <change beforePath="$PROJECT_DIR$/../server_compilation/.idea/workspace.xml" beforeDir="false" afterPath="$PROJECT_DIR$/../server_compilation/.idea/workspace.xml" afterDir="false" />
-      <change beforePath="$PROJECT_DIR$/../server_rest/.idea/workspace.xml" beforeDir="false" afterPath="$PROJECT_DIR$/../server_rest/.idea/workspace.xml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/../../python/assert_test01/.idea/assert_test01.iml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/../../python/assert_test01/.idea/misc.xml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/../../python/assert_test01/.idea/modules.xml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/../../python/assert_test01/.idea/vcs.xml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/../../python/assert_test01/main.py" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/../../python/assert_test01/test.py" afterDir="false" />
+      <change beforePath="$PROJECT_DIR$/../front-end-compilation/src/app/app.component.html" beforeDir="false" afterPath="$PROJECT_DIR$/../front-end-compilation/src/app/app.component.html" afterDir="false" />
+      <change beforePath="$PROJECT_DIR$/../front-end-compilation/src/app/compilateur/compilateur.component.html" beforeDir="false" afterPath="$PROJECT_DIR$/../front-end-compilation/src/app/compilateur/compilateur.component.html" afterDir="false" />
+      <change beforePath="$PROJECT_DIR$/../front-end-compilation/src/app/compilateur/compilateur.component.ts" beforeDir="false" afterPath="$PROJECT_DIR$/../front-end-compilation/src/app/compilateur/compilateur.component.ts" afterDir="false" />
+      <change beforePath="$PROJECT_DIR$/../front-end-compilation/src/app/compilation.service.ts" beforeDir="false" afterPath="$PROJECT_DIR$/../front-end-compilation/src/app/compilation.service.ts" afterDir="false" />
+      <change beforePath="$PROJECT_DIR$/.idea/compiler.xml" beforeDir="false" afterPath="$PROJECT_DIR$/.idea/compiler.xml" afterDir="false" />
+      <change beforePath="$PROJECT_DIR$/.idea/workspace.xml" beforeDir="false" afterPath="$PROJECT_DIR$/.idea/workspace.xml" afterDir="false" />
+      <change beforePath="$PROJECT_DIR$/src/main/java/app.java" beforeDir="false" afterPath="$PROJECT_DIR$/src/main/java/app.java" afterDir="false" />
+      <change beforePath="$PROJECT_DIR$/../serveur_compilation/.idea/compiler.xml" beforeDir="false" afterPath="$PROJECT_DIR$/../serveur_compilation/.idea/compiler.xml" afterDir="false" />
+      <change beforePath="$PROJECT_DIR$/../serveur_compilation/.idea/workspace.xml" beforeDir="false" afterPath="$PROJECT_DIR$/../serveur_compilation/.idea/workspace.xml" afterDir="false" />
+      <change beforePath="$PROJECT_DIR$/../serveur_compilation/src/main/java/compilation.java" beforeDir="false" afterPath="$PROJECT_DIR$/../serveur_compilation/src/main/java/compilation.java" afterDir="false" />
+      <change beforePath="$PROJECT_DIR$/../serveur_compilation/target/classes/compilation.class" beforeDir="false" afterPath="$PROJECT_DIR$/../serveur_compilation/target/classes/compilation.class" afterDir="false" />
     </list>
     <ignored path="$PROJECT_DIR$/out/" />
     <ignored path="$PROJECT_DIR$/target/" />
@@ -15,15 +29,14 @@
     <option name="LAST_RESOLUTION" value="IGNORE" />
   </component>
   <component name="DefaultGradleProjectSettings">
-    <option name="testRunner" value="GRADLE" />
-    <option name="delegatedBuild" value="true" />
+    <option name="isMigrated" value="true" />
   </component>
   <component name="FileEditorManager">
-    <leaf>
+    <leaf SIDE_TABS_SIZE_LIMIT_KEY="300">
       <file pinned="false" current-in-tab="false">
         <entry file="file://$PROJECT_DIR$/pom.xml">
           <provider selected="true" editor-type-id="text-editor">
-            <state relative-caret-position="495">
+            <state relative-caret-position="675">
               <caret line="45" column="10" selection-start-line="45" selection-start-column="10" selection-end-line="45" selection-end-column="10" />
             </state>
           </provider>
@@ -32,8 +45,8 @@
       <file pinned="false" current-in-tab="true">
         <entry file="file://$PROJECT_DIR$/src/main/java/app.java">
           <provider selected="true" editor-type-id="text-editor">
-            <state relative-caret-position="60">
-              <caret line="9" column="45" lean-forward="true" selection-start-line="9" selection-start-column="45" selection-end-line="9" selection-end-column="45" />
+            <state relative-caret-position="45">
+              <caret line="8" column="18" lean-forward="true" selection-start-line="8" selection-start-column="18" selection-end-line="8" selection-end-column="18" />
             </state>
           </provider>
         </entry>
@@ -47,6 +60,7 @@
     <option name="CHANGED_PATHS">
       <list>
         <option value="$PROJECT_DIR$/pom.xml" />
+        <option value="$PROJECT_DIR$/src/main/java/app.java" />
       </list>
     </option>
   </component>
@@ -65,7 +79,6 @@
     </option>
   </component>
   <component name="ProjectFrameBounds">
-    <option name="x" value="149" />
     <option name="y" value="23" />
     <option name="width" value="1920" />
     <option name="height" value="1121" />
@@ -78,37 +91,20 @@
       <foldersAlwaysOnTop value="true" />
     </navigator>
     <panes>
-      <pane id="ProjectPane">
-        <subPane>
-          <expand>
-            <path>
-              <item name="server_rest_new" type="b2602c69:ProjectViewProjectNode" />
-              <item name="server_rest_new" type="462c0819:PsiDirectoryNode" />
-            </path>
-            <path>
-              <item name="server_rest_new" type="b2602c69:ProjectViewProjectNode" />
-              <item name="server_rest_new" type="462c0819:PsiDirectoryNode" />
-              <item name="src" type="462c0819:PsiDirectoryNode" />
-            </path>
-            <path>
-              <item name="server_rest_new" type="b2602c69:ProjectViewProjectNode" />
-              <item name="server_rest_new" type="462c0819:PsiDirectoryNode" />
-              <item name="src" type="462c0819:PsiDirectoryNode" />
-              <item name="main" type="462c0819:PsiDirectoryNode" />
-            </path>
-          </expand>
-          <select />
-        </subPane>
-      </pane>
-      <pane id="Scope" />
       <pane id="PackagesPane" />
+      <pane id="ProjectPane" />
+      <pane id="Scope" />
     </panes>
   </component>
   <component name="PropertiesComponent">
     <property name="ASKED_SHARE_PROJECT_CONFIGURATION_FILES" value="true" />
+    <property name="SHARE_PROJECT_CONFIGURATION_FILES" value="true" />
     <property name="WebServerToolWindowFactoryState" value="false" />
     <property name="aspect.path.notification.shown" value="true" />
-    <property name="last_opened_file_path" value="$PROJECT_DIR$/src/main/java" />
+    <property name="last_opened_file_path" value="$PROJECT_DIR$" />
+    <property name="node.js.detected.package.eslint" value="true" />
+    <property name="node.js.path.for.package.eslint" value="project" />
+    <property name="node.js.selected.package.eslint" value="(autodetect)" />
     <property name="nodejs_interpreter_path.stuck_in_default_project" value="undefined stuck path" />
     <property name="nodejs_npm_path_reset_for_default_project" value="true" />
   </component>
@@ -129,6 +125,20 @@
       </list>
     </option>
   </component>
+  <component name="RunManager">
+    <configuration name="app" type="Application" factoryName="Application" temporary="true" nameIsGenerated="true">
+      <option name="MAIN_CLASS_NAME" value="app" />
+      <module name="09" />
+      <method v="2">
+        <option name="Make" enabled="true" />
+      </method>
+    </configuration>
+    <recent_temporary>
+      <list>
+        <item itemvalue="Application.app" />
+      </list>
+    </recent_temporary>
+  </component>
   <component name="SbtLocalSettings">
     <option name="projectSyncType">
       <map>
@@ -148,43 +158,46 @@
       <option name="presentableId" value="Default" />
       <updated>1556636097236</updated>
       <workItem from="1556636100835" duration="126000" />
+      <workItem from="1556699423305" duration="678000" />
+      <workItem from="1556700805455" duration="927000" />
     </task>
     <servers />
   </component>
   <component name="TimeTrackingManager">
-    <option name="totallyTimeSpent" value="126000" />
+    <option name="totallyTimeSpent" value="1731000" />
   </component>
   <component name="ToolWindowManager">
-    <frame x="149" y="23" width="1920" height="1121" extended-state="6" />
+    <frame x="0" y="23" width="1920" height="1121" extended-state="0" />
     <layout>
-      <window_info id="Image Layers" />
-      <window_info id="Designer" />
-      <window_info id="UI Designer" />
-      <window_info id="Capture Tool" />
-      <window_info id="Favorites" side_tool="true" />
-      <window_info active="true" content_ui="combo" id="Project" order="0" visible="true" weight="0.24973376" />
+      <window_info content_ui="combo" id="Project" order="0" visible="true" weight="0.2550586" />
       <window_info id="Structure" order="1" side_tool="true" weight="0.25" />
-      <window_info anchor="bottom" id="Docker" show_stripe_button="false" />
-      <window_info anchor="bottom" id="Database Changes" />
-      <window_info anchor="bottom" id="Version Control" />
-      <window_info anchor="bottom" id="Terminal" />
-      <window_info anchor="bottom" id="Event Log" side_tool="true" />
+      <window_info id="Image Layers" order="2" />
+      <window_info id="Designer" order="3" />
+      <window_info id="UI Designer" order="4" />
+      <window_info id="Capture Tool" order="5" />
+      <window_info id="Favorites" order="6" side_tool="true" />
       <window_info anchor="bottom" id="Message" order="0" />
       <window_info anchor="bottom" id="Find" order="1" />
-      <window_info anchor="bottom" id="Run" order="2" />
+      <window_info anchor="bottom" id="Run" order="2" weight="0.32944608" />
       <window_info anchor="bottom" id="Debug" order="3" weight="0.4" />
       <window_info anchor="bottom" id="Cvs" order="4" weight="0.25" />
       <window_info anchor="bottom" id="Inspection" order="5" weight="0.4" />
       <window_info anchor="bottom" id="TODO" order="6" />
-      <window_info anchor="right" id="Palette" />
-      <window_info anchor="right" id="Theme Preview" />
-      <window_info anchor="right" id="Maven" />
-      <window_info anchor="right" id="Capture Analysis" />
-      <window_info anchor="right" id="Palette&#9;" />
-      <window_info anchor="right" id="Database" />
+      <window_info anchor="bottom" id="Docker" order="7" show_stripe_button="false" />
+      <window_info anchor="bottom" id="Version Control" order="8" />
+      <window_info anchor="bottom" id="Database Changes" order="9" />
+      <window_info anchor="bottom" id="Terminal" order="10" />
+      <window_info anchor="bottom" id="Event Log" order="11" side_tool="true" />
+      <window_info anchor="bottom" id="Messages" order="12" />
       <window_info anchor="right" id="Commander" internal_type="SLIDING" order="0" type="SLIDING" weight="0.4" />
       <window_info anchor="right" id="Ant Build" order="1" weight="0.25" />
       <window_info anchor="right" content_ui="combo" id="Hierarchy" order="2" weight="0.25" />
+      <window_info anchor="right" id="Palette" order="3" />
+      <window_info anchor="right" id="Theme Preview" order="4" />
+      <window_info anchor="right" id="Maven" order="5" />
+      <window_info anchor="right" id="Capture Analysis" order="6" />
+      <window_info anchor="right" id="Palette&#9;" order="7" />
+      <window_info anchor="right" id="Database" order="8" />
     </layout>
   </component>
   <component name="TypeScriptGeneratedFilesManager">
@@ -193,15 +206,15 @@
   <component name="editorHistoryManager">
     <entry file="file://$PROJECT_DIR$/pom.xml">
       <provider selected="true" editor-type-id="text-editor">
-        <state relative-caret-position="495">
+        <state relative-caret-position="675">
           <caret line="45" column="10" selection-start-line="45" selection-start-column="10" selection-end-line="45" selection-end-column="10" />
         </state>
       </provider>
     </entry>
     <entry file="file://$PROJECT_DIR$/src/main/java/app.java">
       <provider selected="true" editor-type-id="text-editor">
-        <state relative-caret-position="60">
-          <caret line="9" column="45" lean-forward="true" selection-start-line="9" selection-start-column="45" selection-end-line="9" selection-end-column="45" />
+        <state relative-caret-position="45">
+          <caret line="8" column="18" lean-forward="true" selection-start-line="8" selection-start-column="18" selection-end-line="8" selection-end-column="18" />
         </state>
       </provider>
     </entry>
diff --git a/tests/serveur_compilation/server_rest/src/main/java/app.java b/tests/serveur_compilation/server_rest/src/main/java/app.java
index 14dee56..27b9c4e 100644
--- a/tests/serveur_compilation/server_rest/src/main/java/app.java
+++ b/tests/serveur_compilation/server_rest/src/main/java/app.java
@@ -24,8 +24,9 @@ public class app {
             DataOutputStream wr = new DataOutputStream (connection.getOutputStream());
             String type = StringEscapeUtils.escapeJava(ctx.queryParams("language").get(0));
             String code = StringEscapeUtils.escapeJava(ctx.queryParams("code").get(0));
+            String vassert = StringEscapeUtils.escapeJava(ctx.queryParams("test").get(0));
 
-            wr.writeBytes("{\"language\":\""+type+"\",\"stream\":\""+code+"\"}");
+            wr.writeBytes("{\"language\":\""+type+"\",\"stream\":\""+code+"\",\"assert\":\""+vassert+"\"}");
 
             wr.close();
 
diff --git a/tests/serveur_compilation/server_rest/target/classes/app.class b/tests/serveur_compilation/server_rest/target/classes/app.class
new file mode 100644
index 0000000000000000000000000000000000000000..776ea7c957bad8508fffbceb8541fe9774c7aa7e
GIT binary patch
literal 3028
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
S298fghHwUEh6sj8h6n&i`6(X&

literal 0
HcmV?d00001

diff --git a/tests/serveur_compilation/serveur_compilation/.idea/compiler.xml b/tests/serveur_compilation/serveur_compilation/.idea/compiler.xml
index ffc0939..9e7b9fd 100644
--- a/tests/serveur_compilation/serveur_compilation/.idea/compiler.xml
+++ b/tests/serveur_compilation/serveur_compilation/.idea/compiler.xml
@@ -6,6 +6,7 @@
         <sourceOutputDir name="target/generated-sources/annotations" />
         <sourceTestOutputDir name="target/generated-test-sources/test-annotations" />
         <outputRelativeToContentRoot value="true" />
+        <module name="05" />
         <module name="serveur_compilation_new" />
       </profile>
     </annotationProcessing>
diff --git a/tests/serveur_compilation/serveur_compilation/.idea/workspace.xml b/tests/serveur_compilation/serveur_compilation/.idea/workspace.xml
index e523fc4..743efce 100644
--- a/tests/serveur_compilation/serveur_compilation/.idea/workspace.xml
+++ b/tests/serveur_compilation/serveur_compilation/.idea/workspace.xml
@@ -2,9 +2,22 @@
 <project version="4">
   <component name="ChangeListManager">
     <list default="true" id="8d8fb2c1-8426-4933-8193-ee68625cf8de" name="Default Changelist" comment="">
-      <change beforePath="$PROJECT_DIR$/../../javalin/javalin_heroes_provider/.idea/workspace.xml" beforeDir="false" afterPath="$PROJECT_DIR$/../../javalin/javalin_heroes_provider/.idea/workspace.xml" afterDir="false" />
-      <change beforePath="$PROJECT_DIR$/../server_compilation/.idea/workspace.xml" beforeDir="false" afterPath="$PROJECT_DIR$/../server_compilation/.idea/workspace.xml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/../../python/assert_test01/.idea/assert_test01.iml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/../../python/assert_test01/.idea/misc.xml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/../../python/assert_test01/.idea/modules.xml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/../../python/assert_test01/.idea/vcs.xml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/../../python/assert_test01/main.py" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/../../python/assert_test01/test.py" afterDir="false" />
+      <change beforePath="$PROJECT_DIR$/../front-end-compilation/src/app/app.component.html" beforeDir="false" afterPath="$PROJECT_DIR$/../front-end-compilation/src/app/app.component.html" afterDir="false" />
+      <change beforePath="$PROJECT_DIR$/../front-end-compilation/src/app/compilateur/compilateur.component.html" beforeDir="false" afterPath="$PROJECT_DIR$/../front-end-compilation/src/app/compilateur/compilateur.component.html" afterDir="false" />
+      <change beforePath="$PROJECT_DIR$/../front-end-compilation/src/app/compilateur/compilateur.component.ts" beforeDir="false" afterPath="$PROJECT_DIR$/../front-end-compilation/src/app/compilateur/compilateur.component.ts" afterDir="false" />
+      <change beforePath="$PROJECT_DIR$/../front-end-compilation/src/app/compilation.service.ts" beforeDir="false" afterPath="$PROJECT_DIR$/../front-end-compilation/src/app/compilation.service.ts" afterDir="false" />
+      <change beforePath="$PROJECT_DIR$/../server_rest/.idea/compiler.xml" beforeDir="false" afterPath="$PROJECT_DIR$/../server_rest/.idea/compiler.xml" afterDir="false" />
       <change beforePath="$PROJECT_DIR$/../server_rest/.idea/workspace.xml" beforeDir="false" afterPath="$PROJECT_DIR$/../server_rest/.idea/workspace.xml" afterDir="false" />
+      <change beforePath="$PROJECT_DIR$/../server_rest/src/main/java/app.java" beforeDir="false" afterPath="$PROJECT_DIR$/../server_rest/src/main/java/app.java" afterDir="false" />
+      <change beforePath="$PROJECT_DIR$/.idea/compiler.xml" beforeDir="false" afterPath="$PROJECT_DIR$/.idea/compiler.xml" afterDir="false" />
+      <change beforePath="$PROJECT_DIR$/.idea/workspace.xml" beforeDir="false" afterPath="$PROJECT_DIR$/.idea/workspace.xml" afterDir="false" />
+      <change beforePath="$PROJECT_DIR$/src/main/java/compilation.java" beforeDir="false" afterPath="$PROJECT_DIR$/src/main/java/compilation.java" afterDir="false" />
     </list>
     <ignored path="$PROJECT_DIR$/out/" />
     <ignored path="$PROJECT_DIR$/target/" />
@@ -15,15 +28,14 @@
     <option name="LAST_RESOLUTION" value="IGNORE" />
   </component>
   <component name="DefaultGradleProjectSettings">
-    <option name="testRunner" value="GRADLE" />
-    <option name="delegatedBuild" value="true" />
+    <option name="isMigrated" value="true" />
   </component>
   <component name="FileEditorManager">
-    <leaf>
+    <leaf SIDE_TABS_SIZE_LIMIT_KEY="300">
       <file pinned="false" current-in-tab="false">
         <entry file="file://$PROJECT_DIR$/pom.xml">
           <provider selected="true" editor-type-id="text-editor">
-            <state relative-caret-position="525">
+            <state relative-caret-position="591">
               <caret line="47" column="19" selection-start-line="47" selection-start-column="19" selection-end-line="47" selection-end-column="19" />
             </state>
           </provider>
@@ -32,8 +44,8 @@
       <file pinned="false" current-in-tab="true">
         <entry file="file://$PROJECT_DIR$/src/main/java/compilation.java">
           <provider selected="true" editor-type-id="text-editor">
-            <state relative-caret-position="165">
-              <caret line="11" column="40" selection-start-line="11" selection-start-column="40" selection-end-line="11" selection-end-column="40" />
+            <state relative-caret-position="135">
+              <caret line="9" column="82" lean-forward="true" selection-start-line="9" selection-start-column="82" selection-end-line="9" selection-end-column="82" />
               <folding>
                 <element signature="imports" expanded="true" />
               </folding>
@@ -59,6 +71,7 @@
     <option name="CHANGED_PATHS">
       <list>
         <option value="$PROJECT_DIR$/pom.xml" />
+        <option value="$PROJECT_DIR$/src/main/java/compilation.java" />
       </list>
     </option>
   </component>
@@ -69,11 +82,10 @@
       </MavenImportingSettings>
     </option>
   </component>
-  <component name="ProjectFrameBounds" extendedState="6">
-    <option name="x" value="149" />
-    <option name="y" value="23" />
+  <component name="ProjectFrameBounds" fullScreen="true">
+    <option name="x" value="1920" />
     <option name="width" value="1920" />
-    <option name="height" value="1121" />
+    <option name="height" value="1200" />
   </component>
   <component name="ProjectLevelVcsManager" settingsEditedManually="true" />
   <component name="ProjectView">
@@ -86,32 +98,8 @@
         <subPane>
           <expand>
             <path>
-              <item name="serveur_compilation_new" type="b2602c69:ProjectViewProjectNode" />
-              <item name="serveur_compilation_new" type="462c0819:PsiDirectoryNode" />
-            </path>
-            <path>
-              <item name="serveur_compilation_new" type="b2602c69:ProjectViewProjectNode" />
-              <item name="serveur_compilation_new" type="462c0819:PsiDirectoryNode" />
-              <item name="src" type="462c0819:PsiDirectoryNode" />
-            </path>
-            <path>
-              <item name="serveur_compilation_new" type="b2602c69:ProjectViewProjectNode" />
-              <item name="serveur_compilation_new" type="462c0819:PsiDirectoryNode" />
-              <item name="src" type="462c0819:PsiDirectoryNode" />
-              <item name="main" type="462c0819:PsiDirectoryNode" />
-            </path>
-            <path>
-              <item name="serveur_compilation_new" type="b2602c69:ProjectViewProjectNode" />
-              <item name="serveur_compilation_new" type="462c0819:PsiDirectoryNode" />
-              <item name="src" type="462c0819:PsiDirectoryNode" />
-              <item name="main" type="462c0819:PsiDirectoryNode" />
-              <item name="java" type="462c0819:PsiDirectoryNode" />
-            </path>
-            <path>
-              <item name="serveur_compilation_new" type="b2602c69:ProjectViewProjectNode" />
-              <item name="serveur_compilation_new" type="462c0819:PsiDirectoryNode" />
-              <item name="src" type="462c0819:PsiDirectoryNode" />
-              <item name="test" type="462c0819:PsiDirectoryNode" />
+              <item name="serveur_compilation" type="b2602c69:ProjectViewProjectNode" />
+              <item name="serveur_compilation" type="462c0819:PsiDirectoryNode" />
             </path>
           </expand>
           <select />
@@ -121,11 +109,18 @@
     </panes>
   </component>
   <component name="PropertiesComponent">
+    <property name="SHARE_PROJECT_CONFIGURATION_FILES" value="true" />
     <property name="WebServerToolWindowFactoryState" value="false" />
     <property name="aspect.path.notification.shown" value="true" />
-    <property name="last_opened_file_path" value="$PROJECT_DIR$/src/main/java" />
+    <property name="last_opened_file_path" value="$PROJECT_DIR$" />
+    <property name="node.js.detected.package.eslint" value="true" />
+    <property name="node.js.path.for.package.eslint" value="project" />
+    <property name="node.js.selected.package.eslint" value="(autodetect)" />
     <property name="nodejs_interpreter_path.stuck_in_default_project" value="undefined stuck path" />
     <property name="nodejs_npm_path_reset_for_default_project" value="true" />
+    <property name="project.structure.last.edited" value="Modules" />
+    <property name="project.structure.proportion" value="0.15" />
+    <property name="project.structure.side.proportion" value="0.2" />
   </component>
   <component name="RecentsManager">
     <key name="CopyFile.RECENT_KEYS">
@@ -147,7 +142,7 @@
   <component name="RunManager">
     <configuration name="app" type="Application" factoryName="Application" temporary="true" nameIsGenerated="true">
       <option name="MAIN_CLASS_NAME" value="app" />
-      <module name="serveur_compilation_new" />
+      <module name="05" />
       <method v="2">
         <option name="Make" enabled="true" />
       </method>
@@ -177,44 +172,46 @@
       <option name="presentableId" value="Default" />
       <updated>1556635807220</updated>
       <workItem from="1556635811007" duration="263000" />
+      <workItem from="1556699075828" duration="2375000" />
     </task>
     <servers />
   </component>
   <component name="TimeTrackingManager">
-    <option name="totallyTimeSpent" value="263000" />
+    <option name="totallyTimeSpent" value="2638000" />
   </component>
   <component name="ToolWindowManager">
-    <frame x="0" y="23" width="1920" height="1121" extended-state="6" />
+    <frame x="1920" y="0" width="1920" height="1200" extended-state="0" />
+    <editor active="true" />
     <layout>
-      <window_info id="Image Layers" />
-      <window_info id="Designer" />
-      <window_info id="UI Designer" />
-      <window_info id="Capture Tool" />
-      <window_info id="Favorites" side_tool="true" />
-      <window_info content_ui="combo" id="Project" order="0" visible="true" weight="0.24973376" />
+      <window_info content_ui="combo" id="Project" order="0" visible="true" weight="0.25239617" />
       <window_info id="Structure" order="1" side_tool="true" weight="0.25" />
-      <window_info anchor="bottom" id="Messages" />
-      <window_info anchor="bottom" id="Docker" show_stripe_button="false" />
-      <window_info anchor="bottom" id="Database Changes" />
-      <window_info anchor="bottom" id="Version Control" />
-      <window_info anchor="bottom" id="Terminal" />
-      <window_info anchor="bottom" id="Event Log" side_tool="true" />
+      <window_info id="Image Layers" order="2" />
+      <window_info id="Designer" order="3" />
+      <window_info id="UI Designer" order="4" />
+      <window_info id="Capture Tool" order="5" />
+      <window_info id="Favorites" order="6" side_tool="true" />
       <window_info anchor="bottom" id="Message" order="0" />
       <window_info anchor="bottom" id="Find" order="1" />
-      <window_info anchor="bottom" id="Run" order="2" weight="0.32944608" />
+      <window_info anchor="bottom" id="Run" order="2" weight="0.32920355" />
       <window_info anchor="bottom" id="Debug" order="3" weight="0.4" />
       <window_info anchor="bottom" id="Cvs" order="4" weight="0.25" />
       <window_info anchor="bottom" id="Inspection" order="5" weight="0.4" />
       <window_info anchor="bottom" id="TODO" order="6" />
-      <window_info anchor="right" id="Palette" />
-      <window_info anchor="right" id="Theme Preview" />
-      <window_info anchor="right" id="Maven" />
-      <window_info anchor="right" id="Capture Analysis" />
-      <window_info anchor="right" id="Palette&#9;" />
-      <window_info anchor="right" id="Database" />
+      <window_info anchor="bottom" id="Docker" order="7" show_stripe_button="false" />
+      <window_info anchor="bottom" id="Version Control" order="8" />
+      <window_info anchor="bottom" id="Database Changes" order="9" />
+      <window_info anchor="bottom" id="Terminal" order="10" weight="0.32920355" />
+      <window_info anchor="bottom" id="Event Log" order="11" side_tool="true" />
+      <window_info anchor="bottom" id="Messages" order="12" />
       <window_info anchor="right" id="Commander" internal_type="SLIDING" order="0" type="SLIDING" weight="0.4" />
       <window_info anchor="right" id="Ant Build" order="1" weight="0.25" />
       <window_info anchor="right" content_ui="combo" id="Hierarchy" order="2" weight="0.25" />
+      <window_info anchor="right" id="Palette" order="3" />
+      <window_info anchor="right" id="Database" order="4" />
+      <window_info anchor="right" id="Theme Preview" order="5" />
+      <window_info anchor="right" id="Maven" order="6" />
+      <window_info anchor="right" id="Capture Analysis" order="7" />
+      <window_info anchor="right" id="Palette&#9;" order="8" />
     </layout>
   </component>
   <component name="TypeScriptGeneratedFilesManager">
@@ -223,7 +220,7 @@
   <component name="editorHistoryManager">
     <entry file="file://$PROJECT_DIR$/pom.xml">
       <provider selected="true" editor-type-id="text-editor">
-        <state relative-caret-position="525">
+        <state relative-caret-position="591">
           <caret line="47" column="19" selection-start-line="47" selection-start-column="19" selection-end-line="47" selection-end-column="19" />
         </state>
       </provider>
@@ -237,8 +234,8 @@
     </entry>
     <entry file="file://$PROJECT_DIR$/src/main/java/compilation.java">
       <provider selected="true" editor-type-id="text-editor">
-        <state relative-caret-position="165">
-          <caret line="11" column="40" selection-start-line="11" selection-start-column="40" selection-end-line="11" selection-end-column="40" />
+        <state relative-caret-position="135">
+          <caret line="9" column="82" lean-forward="true" selection-start-line="9" selection-start-column="82" selection-end-line="9" selection-end-column="82" />
           <folding>
             <element signature="imports" expanded="true" />
           </folding>
@@ -246,4 +243,78 @@
       </provider>
     </entry>
   </component>
+  <component name="masterDetails">
+    <states>
+      <state key="ArtifactsStructureConfigurable.UI">
+        <settings>
+          <artifact-editor />
+          <splitter-proportions>
+            <option name="proportions">
+              <list>
+                <option value="0.2" />
+              </list>
+            </option>
+          </splitter-proportions>
+        </settings>
+      </state>
+      <state key="FacetStructureConfigurable.UI">
+        <settings>
+          <splitter-proportions>
+            <option name="proportions">
+              <list>
+                <option value="0.2" />
+              </list>
+            </option>
+          </splitter-proportions>
+        </settings>
+      </state>
+      <state key="GlobalLibrariesConfigurable.UI">
+        <settings>
+          <splitter-proportions>
+            <option name="proportions">
+              <list>
+                <option value="0.2" />
+              </list>
+            </option>
+          </splitter-proportions>
+        </settings>
+      </state>
+      <state key="JdkListConfigurable.UI">
+        <settings>
+          <last-edited>12</last-edited>
+          <splitter-proportions>
+            <option name="proportions">
+              <list>
+                <option value="0.2" />
+              </list>
+            </option>
+          </splitter-proportions>
+        </settings>
+      </state>
+      <state key="ModuleStructureConfigurable.UI">
+        <settings>
+          <last-edited>05</last-edited>
+          <splitter-proportions>
+            <option name="proportions">
+              <list>
+                <option value="0.2" />
+                <option value="0.6" />
+              </list>
+            </option>
+          </splitter-proportions>
+        </settings>
+      </state>
+      <state key="ProjectLibrariesConfigurable.UI">
+        <settings>
+          <splitter-proportions>
+            <option name="proportions">
+              <list>
+                <option value="0.2" />
+              </list>
+            </option>
+          </splitter-proportions>
+        </settings>
+      </state>
+    </states>
+  </component>
 </project>
\ No newline at end of file
diff --git a/tests/serveur_compilation/serveur_compilation/__pycache__/sample.cpython-37.pyc b/tests/serveur_compilation/serveur_compilation/__pycache__/sample.cpython-37.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..4fc1f24fa24d2a8f9d515f49a3f31248170c1847
GIT binary patch
literal 268
zcmZ?b<>g{vU|^WG=wyr{0|Ucj5C?{t7#J8F7#J9ec^DWNQW#PgTNt7kQka4nG?|kb
zp^88>2s?w+u`n<&)G!1yXfpb(WYA>1#h6zFk^>XJ!u3OoQ;UlA(~43Pv-Mq4i?d7e
z3-nX+v+{K_QVTK@^-EHVON#Z2Q;W({ON-)@^K%O_a}rB3^YgHaCFU07r0Nw^-r`72
xEUwJS%u5B?RSa@815**mDSn!aU>a;c62Z*Cz;KJhCO1E&G$+*#r0X-tHvrW*Jh%V=

literal 0
HcmV?d00001

diff --git a/tests/serveur_compilation/serveur_compilation/src/main/java/compilation.java b/tests/serveur_compilation/serveur_compilation/src/main/java/compilation.java
index c16e7ca..2f16589 100644
--- a/tests/serveur_compilation/serveur_compilation/src/main/java/compilation.java
+++ b/tests/serveur_compilation/serveur_compilation/src/main/java/compilation.java
@@ -7,12 +7,13 @@ public class compilation {
     public HashMap<String, Object> execute_kata(JSONObject input) {
 
 
-        String filename = "", cmd = "", line, output = "", error = "";
+        String filename = "", filename_test="", cmd = "", line, output = "", error = "";
 
         switch (input.get("language").toString()) {
             case "python":
                 filename = "sample.py";
-                cmd = "python " + filename;
+                filename_test = "assert.py";
+                cmd = "python3 " + filename_test;
                 break;
             case "java":
                 filename = "app.java";
@@ -28,8 +29,16 @@ public class compilation {
             e.printStackTrace();
         }
 
+        try(PrintWriter writer = new PrintWriter(filename_test,"UTF-8")){
+            writer.println(input.get("assert"));
+        } catch (FileNotFoundException e) {
+            e.printStackTrace();
+        } catch (UnsupportedEncodingException e) {
+            e.printStackTrace();
+        }
+
 
-        long start,elapsed = 0;
+        long start, elapsed = 0;
         Process cmdProc = null;
 
         try {
@@ -76,6 +85,9 @@ public class compilation {
         File file = new File(filename);
         file.delete();
 
+        file = new File(filename_test);
+        file.delete();
+
         return json;
     }
 }
diff --git a/tests/serveur_compilation/serveur_compilation/target/classes/compilation.class b/tests/serveur_compilation/serveur_compilation/target/classes/compilation.class
index c940bcb0b792f79f564b9a8b0ccb5b52e4b1c5a0..34eb1119e3bed9e1fc9c99959481b5e220f8e396 100644
GIT binary patch
delta 2794
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

delta 2394
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
b2U^I{4+%AJM6fYrfGd|w21bS~Fe@7X%_FM<

-- 
GitLab